diff --git a/stage0/src/Init/Control/Except.lean b/stage0/src/Init/Control/Except.lean index 117492c987..9f39bc2597 100644 --- a/stage0/src/Init/Control/Except.lean +++ b/stage0/src/Init/Control/Except.lean @@ -181,7 +181,8 @@ instance (ε m out) [MonadRun out m] : MonadRun (fun α => out (Except ε α)) ( ⟨fun α => run⟩ /-- Execute `x` and then execute `finalizer` even if `x` threw an exception -/ -@[inline] def finally {ε α : Type u} {m : Type u → Type v} [Monad m] [MonadExcept ε m] (x : m α) (finalizer : m PUnit) : m α := -catch - (do a ← x; finalizer; pure a) - (fun e => do finalizer; throw e) +@[inline] def finally {ε α : Type u} {m : Type u → Type v} [Monad m] [MonadExcept ε m] (x : m α) (finalizer : m PUnit) : m α := do +r ← catch (Except.ok <$> x) (fun ex => @pure m _ _ $ Except.error ex); +match r with +| Except.ok a => finalizer *> pure a +| Except.error e => finalizer *> throw e diff --git a/stage0/src/Lean/Elab/CollectFVars.lean b/stage0/src/Lean/Elab/CollectFVars.lean new file mode 100644 index 0000000000..2f725631ad --- /dev/null +++ b/stage0/src/Lean/Elab/CollectFVars.lean @@ -0,0 +1,41 @@ +/- +Copyright (c) 2020 Microsoft Corporation. All rights reserved. +Released under Apache 2.0 license as described in the file LICENSE. +Authors: Leonardo de Moura, Sebastian Ullrich +-/ +import Lean.Util.CollectFVars +import Lean.Elab.Term + +namespace Lean +namespace Elab +namespace Term + +def collectUsedFVars (ref : Syntax) (used : CollectFVars.State) (e : Expr) : TermElabM CollectFVars.State := do +e ← Term.instantiateMVars ref e; +pure $ collectFVars used e + +def collectUsedFVarsAtFVars (ref : Syntax) (used : CollectFVars.State) (fvars : Array Expr) : TermElabM CollectFVars.State := +fvars.foldlM + (fun used fvar => do + fvarType ← Term.inferType ref fvar; + collectUsedFVars ref used fvarType) + used + +def removeUnused (ref : Syntax) (vars : Array Expr) (used : CollectFVars.State) : TermElabM (LocalContext × LocalInstances × Array Expr) := do +localInsts ← Term.getLocalInsts; +lctx ← Term.getLCtx; +(lctx, localInsts, newVars, _) ← vars.foldrM + (fun var (result : LocalContext × LocalInstances × Array Expr × CollectFVars.State) => + let (lctx, localInsts, newVars, used) := result; + if used.fvarSet.contains var.fvarId! then do + varType ← Term.inferType ref var; + used ← Term.collectUsedFVars ref used varType; + pure (lctx, localInsts, newVars.push var, used) + else + pure (lctx.erase var.fvarId!, localInsts.erase var.fvarId!, newVars, used)) + (lctx, localInsts, #[], used); +pure (lctx, localInsts, newVars.reverse) + +end Term +end Elab +end Lean diff --git a/stage0/src/Lean/Elab/Command.lean b/stage0/src/Lean/Elab/Command.lean index b19fa5f452..e8422eae35 100644 --- a/stage0/src/Lean/Elab/Command.lean +++ b/stage0/src/Lean/Elab/Command.lean @@ -249,6 +249,9 @@ _root_.dbgTrace (toString a) $ fun _ => pure () def setEnv (newEnv : Environment) : CommandElabM Unit := modify $ fun s => { s with env := newEnv } +@[inline] def modifyEnv (f : Environment → Environment) : CommandElabM Unit := +modify $ fun s => { s with env := f s.env } + def getCurrNamespace : CommandElabM Name := do scope ← getScope; pure scope.currNamespace @@ -636,7 +639,7 @@ else let optUnivDeclStx := declId.getArg 1; (id, optUnivDeclStx) -@[inline] def withDeclId (declId : Syntax) (f : Name → CommandElabM Unit) : CommandElabM Unit := do +def withDeclId {α} (declId : Syntax) (f : Name → CommandElabM α) : CommandElabM α := do -- ident >> optional (".{" >> sepBy1 ident ", " >> "}") let (id, optUnivDeclStx) := expandDeclId declId; savedLevelNames ← getLevelNames; @@ -669,15 +672,23 @@ match scpView.name with /-- Sort the given list of `usedParams` using the following order: - - If it is an explicit level `explicitParams`, then use user given order. + - If it is an explicit level `allUserParams`, then use user given order. - Otherwise, use lexicographical. + Remark: `scopeParams` are the universe params introduced using the `universe` command. `allUserParams` contains + the universe params introduced using the `universe` command *and* the `.{...}` notation. + + Remark: this function return an exception if there is an `u` not in `usedParams`, that is in `allUserParams` but not in `scopeParams`. + Remark: `explicitParams` are in reverse declaration order. That is, the head is the last declared parameter. -/ -def sortDeclLevelParams (explicitParams : List Name) (usedParams : Array Name) : List Name := -let result := explicitParams.foldl (fun result levelName => if usedParams.elem levelName then levelName :: result else result) []; -let remaining := usedParams.filter (fun levelParam => !explicitParams.elem levelParam); -let remaining := remaining.qsort Name.lt; -result ++ remaining.toList +def sortDeclLevelParams (scopeParams : List Name) (allUserParams : List Name) (usedParams : Array Name) : Except String (List Name) := +match allUserParams.find? $ fun u => !usedParams.contains u && !scopeParams.elem u with +| some u => throw ("unused universe parameter '" ++ toString u ++ "'") +| none => + let result := allUserParams.foldl (fun result levelName => if usedParams.elem levelName then levelName :: result else result) []; + let remaining := usedParams.filter (fun levelParam => !allUserParams.elem levelParam); + let remaining := remaining.qsort Name.lt; + pure $ result ++ remaining.toList end Command end Elab diff --git a/stage0/src/Lean/Elab/DeclModifiers.lean b/stage0/src/Lean/Elab/DeclModifiers.lean index fa28669349..f0f6fd08f2 100644 --- a/stage0/src/Lean/Elab/DeclModifiers.lean +++ b/stage0/src/Lean/Elab/DeclModifiers.lean @@ -15,6 +15,8 @@ structure Attribute := instance Attribute.hasFormat : HasFormat Attribute := ⟨fun attr => Format.bracket "@[" (toString attr.name ++ (if attr.args.isMissing then "" else toString attr.args)) "]"⟩ +instance Attribute.inhabited : Inhabited Attribute := ⟨{ name := arbitrary _ }⟩ + inductive Visibility | regular | «protected» | «private» @@ -32,6 +34,14 @@ structure Modifiers := (isUnsafe : Bool := false) (attrs : Array Attribute := #[]) +def Modifiers.isPrivate : Modifiers → Bool +| { visibility := Visibility.private, .. } => true +| _ => false + +def Modifiers.isProtected : Modifiers → Bool +| { visibility := Visibility.protected, .. } => true +| _ => false + def Modifiers.addAttribute (modifiers : Modifiers) (attr : Attribute) : Modifiers := { modifiers with attrs := modifiers.attrs.push attr } @@ -105,15 +115,6 @@ pure { attrs := attrs } -def mkDeclName (modifiers : Modifiers) (atomicName : Name) : CommandElabM Name := do -currNamespace ← getCurrNamespace; -let declName := currNamespace ++ atomicName; -match modifiers.visibility with -| Visibility.private => do - env ← getEnv; - pure $ mkPrivateName env declName -| _ => pure declName - def checkNotAlreadyDeclared (ref : Syntax) (declName : Name) : CommandElabM Unit := do env ← getEnv; when (env.contains declName) $ @@ -128,6 +129,28 @@ match privateToUserName? declName with when (env.contains declName) $ throwError ref ("a non-private declaration '" ++ declName ++ "' has already been declared") +def applyVisibility (ref : Syntax) (visibility : Visibility) (declName : Name) : CommandElabM Name := +match visibility with +| Visibility.private => do + env ← getEnv; + let declName := mkPrivateName env declName; + checkNotAlreadyDeclared ref declName; + pure declName +| Visibility.protected => do + checkNotAlreadyDeclared ref declName; + env ← getEnv; + let env := addProtected env declName; + setEnv env; + pure declName +| _ => do + checkNotAlreadyDeclared ref declName; + pure declName + +def mkDeclName (ref : Syntax) (modifiers : Modifiers) (atomicName : Name) : CommandElabM Name := do +currNamespace ← getCurrNamespace; +let declName := currNamespace ++ atomicName; +applyVisibility ref modifiers.visibility declName + def applyAttributes (ref : Syntax) (declName : Name) (attrs : Array Attribute) (applicationTime : AttributeApplicationTime) : CommandElabM Unit := attrs.forM $ fun attr => do env ← getEnv; diff --git a/stage0/src/Lean/Elab/Declaration.lean b/stage0/src/Lean/Elab/Declaration.lean index e8a175c335..414b510948 100644 --- a/stage0/src/Lean/Elab/Declaration.lean +++ b/stage0/src/Lean/Elab/Declaration.lean @@ -89,57 +89,107 @@ elabDefLike { declId := declId, binders := binders, type? := some type, val := stx.getArg 2 } -def elabAxiom (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := +def elabAxiom (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := do -- parser! "axiom " >> declId >> declSig let declId := stx.getArg 1; let (binders, typeStx) := expandDeclSig (stx.getArg 2); +scopeLevelNames ← getLevelNames; withDeclId declId $ fun name => do - declName ← mkDeclName modifiers name; + declName ← mkDeclName declId modifiers name; applyAttributes stx declName modifiers.attrs AttributeApplicationTime.beforeElaboration; - explictLevelNames ← getLevelNames; + allUserLevelNames ← getLevelNames; decl ← runTermElabM declName $ fun vars => Term.elabBinders binders.getArgs $ fun xs => do { type ← Term.elabType typeStx; Term.synthesizeSyntheticMVars false; type ← Term.instantiateMVars typeStx type; type ← Term.mkForall typeStx xs type; (type, _) ← Term.mkForallUsedOnly typeStx vars type; - type ← Term.levelMVarToParam type; + (type, _) ← Term.levelMVarToParam type; let usedParams := (collectLevelParams {} type).params; - let levelParams := sortDeclLevelParams explictLevelNames usedParams; - pure $ Declaration.axiomDecl { - name := declName, - lparams := levelParams, - type := type, - isUnsafe := modifiers.isUnsafe - } - }; + match sortDeclLevelParams scopeLevelNames allUserLevelNames usedParams with + | Except.error msg => Term.throwError stx msg + | Except.ok levelParams => + pure $ Declaration.axiomDecl { + name := declName, + lparams := levelParams, + type := type, + isUnsafe := modifiers.isUnsafe + } + }; addDecl stx decl; applyAttributes stx declName modifiers.attrs AttributeApplicationTime.afterTypeChecking; applyAttributes stx declName modifiers.attrs AttributeApplicationTime.afterCompilation +private def checkValidInductiveModifier (ref : Syntax) (modifiers : Modifiers) : CommandElabM Unit := do +when modifiers.isNoncomputable $ + throwError ref "invalid use of 'noncomputable' in inductive declaration"; +when modifiers.isPartial $ + throwError ref "invalid use of 'partial' in inductive declaration"; +unless (modifiers.attrs.size == 0 || (modifiers.attrs.size == 1 && (modifiers.attrs.get! 0).name == `class)) $ + throwError ref "invalid use of attributes in inductive declaration"; +pure () + +private def checkValidCtorModifier (ref : Syntax) (modifiers : Modifiers) : CommandElabM Unit := do +when modifiers.isNoncomputable $ + throwError ref "invalid use of 'noncomputable' in constructor declaration"; +when modifiers.isPartial $ + throwError ref "invalid use of 'partial' in constructor declaration"; +when modifiers.isUnsafe $ + throwError ref "invalid use of 'unsafe' in constructor declaration"; +when (modifiers.attrs.size != 0) $ + throwError ref "invalid use of attributes in constructor declaration"; +pure () + /- -parser! "inductive " >> declId >> optDeclSig >> many introRule -parser! try ("class " >> "inductive ") >> declId >> optDeclSig >> many introRule +parser! "inductive " >> declId >> optDeclSig >> many ctor +parser! try ("class " >> "inductive ") >> declId >> optDeclSig >> many ctor Remark: numTokens == 1 for regular `inductive` and 2 for `class inductive`. -/ -private def inductiveSyntaxToView (modifiers : Modifiers) (decl : Syntax) (numTokens := 1) : InductiveView := +private def inductiveSyntaxToView (modifiers : Modifiers) (decl : Syntax) (numTokens := 1) : CommandElabM InductiveView := do +checkValidInductiveModifier decl modifiers; let (binders, type?) := expandOptDeclSig (decl.getArg (numTokens + 1)); -{ ref := decl, - modifiers := modifiers, - declId := decl.getArg numTokens, - binders := binders, - type? := type?, - introRules := (decl.getArg (numTokens + 2)).getArgs } +let declId := decl.getArg numTokens; +withDeclId declId fun name => do + levelNames ← getLevelNames; + declName ← mkDeclName declId modifiers name; + ctors ← (decl.getArg (numTokens + 2)).getArgs.mapM fun ctor => do { + -- def ctor := parser! " | " >> declModifiers >> ident >> optional inferMod >> optDeclSig + ctorModifiers ← elabModifiers (ctor.getArg 1); + when (ctorModifiers.isPrivate && modifiers.isPrivate) $ + throwError ctor "invalid 'private' constructor in a 'private' inductive datatype"; + when (ctorModifiers.isProtected && modifiers.isPrivate) $ + throwError ctor "invalid 'protected' constructor in a 'private' inductive datatype"; + checkValidCtorModifier ctor ctorModifiers; + let ctorName := ctor.getIdAt 2; + let ctorName := declName ++ ctorName; + ctorName ← applyVisibility (ctor.getArg 2) ctorModifiers.visibility ctorName; + let inferMod := !(ctor.getArg 3).isNone; + let (binders, type?) := expandOptDeclSig (ctor.getArg 4); + pure { ref := ctor, modifiers := ctorModifiers, declName := ctorName, inferMod := inferMod, binders := binders, type? := type? : CtorView } + }; + pure { + ref := decl, + modifiers := modifiers, + shortDeclName := name, + declName := declName, + levelNames := levelNames, + binders := binders, + type? := type?, + ctors := ctors + } -private def classInductiveSyntaxToView (modifiers : Modifiers) (decl : Syntax) : InductiveView := +private def classInductiveSyntaxToView (modifiers : Modifiers) (decl : Syntax) : CommandElabM InductiveView := inductiveSyntaxToView modifiers decl 2 -def elabInductive (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := -elabInductiveCore #[inductiveSyntaxToView modifiers stx] +def elabInductive (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := do +v ← inductiveSyntaxToView modifiers stx; +elabInductiveCore #[v] -def elabClassInductive (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := -elabInductiveCore #[classInductiveSyntaxToView modifiers stx] +def elabClassInductive (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := do +let modifiers := modifiers.addAttribute { name := `class }; +v ← classInductiveSyntaxToView modifiers stx; +elabInductiveCore #[v] def elabStructure (modifiers : Modifiers) (stx : Syntax) : CommandElabM Unit := pure () -- TODO @@ -183,7 +233,7 @@ private def isMutualInductive (stx : Syntax) : Bool := private def elabMutualInductive (elems : Array Syntax) : CommandElabM Unit := do views ← elems.mapM $ fun stx => do { modifiers ← elabModifiers (stx.getArg 0); - pure $ inductiveSyntaxToView modifiers (stx.getArg 1) + inductiveSyntaxToView modifiers (stx.getArg 1) }; elabInductiveCore views diff --git a/stage0/src/Lean/Elab/Definition.lean b/stage0/src/Lean/Elab/Definition.lean index 33b96724dc..c17d4f96d5 100644 --- a/stage0/src/Lean/Elab/Definition.lean +++ b/stage0/src/Lean/Elab/Definition.lean @@ -6,7 +6,7 @@ Authors: Leonardo de Moura, Sebastian Ullrich import Std.ShareCommon import Lean.Util.CollectLevelParams import Lean.Util.FoldConsts -import Lean.Util.CollectFVars +import Lean.Elab.CollectFVars import Lean.Elab.DeclModifiers import Lean.Elab.Binders @@ -40,49 +40,26 @@ structure DefView := (type? : Option Syntax) (val : Syntax) -def collectUsedFVars (ref : Syntax) (used : CollectFVars.State) (e : Expr) : TermElabM CollectFVars.State := do -e ← Term.instantiateMVars ref e; -pure $ collectFVars used e - -def collectUsedFVarsAtFVars (ref : Syntax) (used : CollectFVars.State) (fvars : Array Expr) : TermElabM CollectFVars.State := -fvars.foldlM - (fun used fvar => do - fvarType ← Term.inferType ref fvar; - collectUsedFVars ref used fvarType) - used - -def removeUnused (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (eType : Expr) +private def removeUnused (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (eType : Expr) : TermElabM (LocalContext × LocalInstances × Array Expr) := do let used : CollectFVars.State := {}; -used ← collectUsedFVars ref used eType; -used ← collectUsedFVars ref used e; -used ← collectUsedFVarsAtFVars ref used xs; -localInsts ← Term.getLocalInsts; -lctx ← Term.getLCtx; -(lctx, localInsts, newVars, _) ← vars.foldrM - (fun var (result : LocalContext × LocalInstances × Array Expr × CollectFVars.State) => - let (lctx, localInsts, newVars, used) := result; - if used.fvarSet.contains var.fvarId! then do - varType ← Term.inferType ref var; - used ← collectUsedFVars ref used varType; - pure (lctx, localInsts, newVars.push var, used) - else - pure (lctx.erase var.fvarId!, localInsts.erase var.fvarId!, newVars, used)) - (lctx, localInsts, #[], used); -pure (lctx, localInsts, newVars.reverse) +used ← Term.collectUsedFVars ref used eType; +used ← Term.collectUsedFVars ref used e; +used ← Term.collectUsedFVarsAtFVars ref used xs; +Term.removeUnused ref vars used -def withUsedWhen {α} (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (eType : Expr) (cond : Bool) (k : Array Expr → TermElabM α) : TermElabM α := +private def withUsedWhen {α} (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (eType : Expr) (cond : Bool) (k : Array Expr → TermElabM α) : TermElabM α := if cond then do (lctx, localInsts, vars) ← removeUnused ref vars xs e eType; Term.withLCtx lctx localInsts $ k vars else k vars -def withUsedWhen' {α} (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (cond : Bool) (k : Array Expr → TermElabM α) : TermElabM α := +private def withUsedWhen' {α} (ref : Syntax) (vars : Array Expr) (xs : Array Expr) (e : Expr) (cond : Bool) (k : Array Expr → TermElabM α) : TermElabM α := let dummyExpr := mkSort levelOne; withUsedWhen ref vars xs e dummyExpr cond k -def mkDef (view : DefView) (declName : Name) (explictLevelNames : List Name) (vars : Array Expr) (xs : Array Expr) (type : Expr) (val : Expr) +def mkDef (view : DefView) (declName : Name) (scopeLevelNames allUserLevelNames : List Name) (vars : Array Expr) (xs : Array Expr) (type : Expr) (val : Expr) : TermElabM (Option Declaration) := do let ref := view.ref; Term.synthesizeSyntheticMVars; @@ -96,8 +73,8 @@ else withUsedWhen ref vars xs val type view.kind.isDefOrAbbrevOrOpaque $ fun var type ← Term.mkForall ref vars type; val ← Term.mkLambda ref xs val; val ← Term.mkLambda ref vars val; - type ← Term.levelMVarToParam type; - val ← Term.levelMVarToParam val; + (type, nextParamIdx) ← Term.levelMVarToParam type; + (val, _) ← Term.levelMVarToParam val nextParamIdx; type ← Term.instantiateMVars ref type; val ← Term.instantiateMVars view.val val; let shareCommonTypeVal : Std.ShareCommonM (Expr × Expr) := do { @@ -110,25 +87,27 @@ else withUsedWhen ref vars xs val type view.kind.isDefOrAbbrevOrOpaque $ fun var let usedParams : CollectLevelParams.State := {}; let usedParams := collectLevelParams usedParams type; let usedParams := collectLevelParams usedParams val; - let levelParams := sortDeclLevelParams explictLevelNames usedParams.params; - match view.kind with - | DefKind.theorem => - -- TODO theorem elaboration in parallel - pure $ some $ Declaration.thmDecl { name := declName, lparams := levelParams, type := type, value := Task.pure val } - | DefKind.opaque => - pure $ some $ Declaration.opaqueDecl { name := declName, lparams := levelParams, type := type, value := val, isUnsafe := view.modifiers.isUnsafe } - | DefKind.abbrev => - pure $ some $ Declaration.defnDecl { - name := declName, lparams := levelParams, type := type, value := val, - hints := ReducibilityHints.abbrev, - isUnsafe := view.modifiers.isUnsafe } - | DefKind.def => do - env ← Term.getEnv; - pure $ some $ Declaration.defnDecl { - name := declName, lparams := levelParams, type := type, value := val, - hints := ReducibilityHints.regular (getMaxHeight env val + 1), - isUnsafe := view.modifiers.isUnsafe } - | _ => unreachable! + match sortDeclLevelParams scopeLevelNames allUserLevelNames usedParams.params with + | Except.error msg => Term.throwError ref msg + | Except.ok levelParams => + match view.kind with + | DefKind.theorem => + -- TODO theorem elaboration in parallel + pure $ some $ Declaration.thmDecl { name := declName, lparams := levelParams, type := type, value := Task.pure val } + | DefKind.opaque => + pure $ some $ Declaration.opaqueDecl { name := declName, lparams := levelParams, type := type, value := val, isUnsafe := view.modifiers.isUnsafe } + | DefKind.abbrev => + pure $ some $ Declaration.defnDecl { + name := declName, lparams := levelParams, type := type, value := val, + hints := ReducibilityHints.abbrev, + isUnsafe := view.modifiers.isUnsafe } + | DefKind.def => do + env ← Term.getEnv; + pure $ some $ Declaration.defnDecl { + name := declName, lparams := levelParams, type := type, value := val, + hints := ReducibilityHints.regular (getMaxHeight env val + 1), + isUnsafe := view.modifiers.isUnsafe } + | _ => unreachable! def elabDefVal (defVal : Syntax) (expectedType : Expr) : TermElabM Expr := do let kind := defVal.getKind; @@ -140,13 +119,13 @@ else if kind == `Lean.Parser.Command.declValEqns then else Term.throwUnsupportedSyntax -def elabDefLike (view : DefView) : CommandElabM Unit := +def elabDefLike (view : DefView) : CommandElabM Unit := do let ref := view.ref; +scopeLevelNames ← getLevelNames; withDeclId view.declId $ fun name => do - declName ← mkDeclName view.modifiers name; - checkNotAlreadyDeclared ref declName; + declName ← mkDeclName view.declId view.modifiers name; applyAttributes ref declName view.modifiers.attrs AttributeApplicationTime.beforeElaboration; - explictLevelNames ← getLevelNames; + allUserLevelNames ← getLevelNames; decl? ← runTermElabM declName $ fun vars => Term.elabBinders view.binders.getArgs $ fun xs => match view.type? with | some typeStx => do @@ -155,11 +134,11 @@ withDeclId view.declId $ fun name => do type ← Term.instantiateMVars typeStx type; withUsedWhen' ref vars xs type view.kind.isTheorem $ fun vars => do val ← elabDefVal view.val type; - mkDef view declName explictLevelNames vars xs type val + mkDef view declName scopeLevelNames allUserLevelNames vars xs type val | none => do { type ← Term.mkFreshTypeMVar view.binders; val ← elabDefVal view.val type; - mkDef view declName explictLevelNames vars xs type val + mkDef view declName scopeLevelNames allUserLevelNames vars xs type val }; match decl? with | none => pure () diff --git a/stage0/src/Lean/Elab/Inductive.lean b/stage0/src/Lean/Elab/Inductive.lean index e11c62a7bf..4961909d12 100644 --- a/stage0/src/Lean/Elab/Inductive.lean +++ b/stage0/src/Lean/Elab/Inductive.lean @@ -3,45 +3,476 @@ Copyright (c) 2020 Microsoft Corporation. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Authors: Leonardo de Moura -/ +import Lean.Util.ReplaceLevel +import Lean.Util.ReplaceExpr +import Lean.Util.CollectLevelParams +import Lean.Util.Constructions import Lean.Elab.Command +import Lean.Elab.CollectFVars import Lean.Elab.Definition namespace Lean namespace Elab namespace Command +structure CtorView := +(ref : Syntax) +(modifiers : Modifiers) +(inferMod : Bool) -- true if `{}` is used in the constructor declaration +(declName : Name) +(binders : Syntax) +(type? : Option Syntax) + +instance CtorView.inhabited : Inhabited CtorView := +⟨{ ref := arbitrary _, modifiers := {}, inferMod := false, declName := arbitrary _, binders := arbitrary _, type? := none }⟩ + structure InductiveView := (ref : Syntax) (modifiers : Modifiers) -(declId : Syntax) +(shortDeclName : Name) +(declName : Name) +(levelNames : List Name) (binders : Syntax) (type? : Option Syntax) -(introRules : Array Syntax) +(ctors : Array CtorView) instance InductiveView.inhabited : Inhabited InductiveView := -⟨{ ref := arbitrary _, modifiers := {}, declId := arbitrary _, binders := arbitrary _, type? := none, introRules := #[] }⟩ +⟨{ ref := arbitrary _, modifiers := {}, shortDeclName := arbitrary _, declName := arbitrary _, + levelNames := [], binders := arbitrary _, type? := none, ctors := #[] }⟩ -def mkInductive (ref : Syntax) (declName : Name) (explictLevelNames : List Name) (vars : Array Expr) (xs : Array Expr) (type : Expr) (intros : Array Syntax) - : TermElabM Declaration := do -Term.throwError ref ref +structure ElabHeaderResult := +(view : InductiveView) +(lctx : LocalContext) +(localInsts : LocalInstances) +(params : Array Expr) +(type : Expr) + +instance ElabHeaderResult.inhabited : Inhabited ElabHeaderResult := +⟨{ view := arbitrary _, lctx := arbitrary _, localInsts := arbitrary _, params := #[], type := arbitrary _ }⟩ + +private partial def elabHeaderAux (views : Array InductiveView) + : Nat → Array ElabHeaderResult → TermElabM (Array ElabHeaderResult) +| i, acc => + if h : i < views.size then + let view := views.get ⟨i, h⟩; + Term.elabBinders view.binders.getArgs fun params => do + lctx ← Term.getLCtx; + localInsts ← Term.getLocalInsts; + match view.type? with + | none => do + u ← Term.mkFreshLevelMVar view.ref; + let type := mkSort (mkLevelSucc u); + elabHeaderAux (i+1) (acc.push { lctx := lctx, localInsts := localInsts, params := params, type := type, view := view }) + | some typeStx => do + type ← Term.elabTerm typeStx none; + unlessM (Term.isTypeFormerType view.ref type) $ + Term.throwError typeStx "invalid inductive type, resultant type is not a sort"; + elabHeaderAux (i+1) (acc.push { lctx := lctx, localInsts := localInsts, params := params, type := type, view := view }) + else + pure acc + +private def checkNumParams (rs : Array ElabHeaderResult) : TermElabM Nat := do +let numParams := (rs.get! 0).params.size; +rs.forM fun r => unless (r.params.size == numParams) $ + Term.throwError r.view.ref "invalid inductive type, number of parameters mismatch in mutually inductive datatypes"; +pure numParams + +private def checkUnsafe (rs : Array ElabHeaderResult) : TermElabM Unit := +let isUnsafe := (rs.get! 0).view.modifiers.isUnsafe; +rs.forM fun r => unless (r.view.modifiers.isUnsafe == isUnsafe) $ + Term.throwError r.view.ref "invalid inductive type, cannot mix unsafe and safe declarations in a mutually inductive datatypes" + +private def checkLevelNames (views : Array InductiveView) : TermElabM Unit := +when (views.size > 1) do + let levelNames := (views.get! 0).levelNames; + views.forM fun view => unless (view.levelNames == levelNames) $ + Term.throwError view.ref "invalid inductive type, universe parameters mismatch in mutually inductive datatypes" + +private def mkTypeFor (r : ElabHeaderResult) : TermElabM Expr := do +Term.withLocalContext r.lctx r.localInsts do + Term.mkForall r.view.ref r.params r.type + +private def throwUnexpectedInductiveType {α} (ref : Syntax) : TermElabM α := +Term.throwError ref "unexpected inductive resulting type" + +-- Given `e` of the form `forall As, B`, return `B`. +private def getResultingType (ref : Syntax) (e : Expr) : TermElabM Expr := +Term.liftMetaM ref $ Meta.forallTelescopeReducing e fun _ r => pure r + +private def eqvFirstTypeResult (firstType type : Expr) : MetaM Bool := +Meta.forallTelescopeReducing firstType fun _ firstTypeResult => Meta.isDefEq firstTypeResult type + +-- Auxiliary function for checking whether the types in mutually inductive declaration are compatible. +private partial def checkParamsAndResultType (ref : Syntax) (numParams : Nat) : Nat → Expr → Expr → TermElabM Unit +| i, type, firstType => do + type ← Term.whnf ref type; + if i < numParams then do + firstType ← Term.whnf ref firstType; + match type, firstType with + | Expr.forallE n₁ d₁ b₁ c₁, Expr.forallE n₂ d₂ b₂ c₂ => do + unless (n₁ == n₂) $ + let msg : MessageData := + "invalid mutually inductive types, parameter name mismatch '" ++ n₁ ++ "', expected '" ++ n₂ ++ "'"; + Term.throwError ref msg; + unlessM (Term.isDefEq ref d₁ d₂) $ + let msg : MessageData := + "invalid mutually inductive types, type mismatch at parameter '" ++ n₁ ++ "'" ++ indentExpr d₁ + ++ Format.line ++ "expected type" ++ indentExpr d₂; + Term.throwError ref msg; + unless (c₁.binderInfo == c₂.binderInfo) $ + -- TODO: improve this error message? + Term.throwError ref ("invalid mutually inductive types, binder annotation mismatch at parameter '" ++ n₁ ++ "'"); + Term.withLocalDecl ref n₁ c₁.binderInfo d₁ fun x => + let type := b₁.instantiate1 x; + let firstType := b₂.instantiate1 x; + checkParamsAndResultType (i+1) type firstType + | _, _ => throwUnexpectedInductiveType ref + else + match type with + | Expr.forallE n d b c => + Term.withLocalDecl ref n c.binderInfo d fun x => + let type := b.instantiate1 x; + checkParamsAndResultType (i+1) type firstType + | Expr.sort _ _ => + unlessM (Term.liftMetaM ref $ eqvFirstTypeResult firstType type) $ + let msg : MessageData := + "invalid mutually inductive types, resulting universe mismatch, given " ++ indentExpr type ++ Format.line ++ "expected type" ++ indentExpr firstType; + Term.throwError ref msg + | _ => throwUnexpectedInductiveType ref + +-- Auxiliary function for checking whether the types in mutually inductive declaration are compatible. +private def checkHeader (r : ElabHeaderResult) (numParams : Nat) (firstType? : Option Expr) : TermElabM Expr := do +type ← mkTypeFor r; +match firstType? with +| none => pure type +| some firstType => do + checkParamsAndResultType r.view.ref numParams 0 type firstType; + pure firstType + +-- Auxiliary function for checking whether the types in mutually inductive declaration are compatible. +private partial def checkHeaders (rs : Array ElabHeaderResult) (numParams : Nat) : Nat → Option Expr → TermElabM Unit +| i, firstType? => when (i < rs.size) do + type ← checkHeader (rs.get! i) numParams firstType?; + checkHeaders (i+1) type + +private def elabHeader (views : Array InductiveView) : TermElabM (Array ElabHeaderResult) := do +rs ← elabHeaderAux views 0 #[]; +when (rs.size > 1) do { + checkUnsafe rs; + numParams ← checkNumParams rs; + checkHeaders rs numParams 0 none +}; +pure rs + +private partial def withInductiveLocalDeclsAux {α} (ref : Syntax) (namesAndTypes : Array (Name × Expr)) (params : Array Expr) + (x : Array Expr → Array Expr → TermElabM α) : Nat → Array Expr → TermElabM α +| i, indFVars => + if h : i < namesAndTypes.size then do + let (id, type) := namesAndTypes.get ⟨i, h⟩; + type ← Term.liftMetaM ref (Meta.instantiateForall type params); + Term.withLocalDecl ref id BinderInfo.default type fun indFVar => withInductiveLocalDeclsAux (i+1) (indFVars.push indFVar) + else + x params indFVars + +/- Create a local declaration for each inductive type in `rs`, and execute `x params indFVars`, where `params` are the inductive type parameters and + `indFVars` are the new local declarations. + We use the the local context/instances and parameters of rs[0]. + Note that this method is executed after we executed `checkHeaders` and established all + parameters are compatible. -/ +private def withInductiveLocalDecls {α} (rs : Array ElabHeaderResult) (x : Array Expr → Array Expr → TermElabM α) : TermElabM α := do +namesAndTypes ← rs.mapM fun r => do { + type ← mkTypeFor r; + pure (r.view.shortDeclName, type) +}; +let r0 := rs.get! 0; +let params := r0.params; +Term.withLocalContext r0.lctx r0.localInsts $ + withInductiveLocalDeclsAux r0.view.ref namesAndTypes params x 0 #[] + +private def isInductiveFamily (ref : Syntax) (indFVar : Expr) : TermElabM Bool := do +indFVarType ← Term.inferType ref indFVar; +indFVarType ← Term.whnf ref indFVarType; +pure !indFVarType.isSort + +/- + Elaborate constructor types. + + Remark: we check whether the resulting type is correct, but + we do not check for: + - Positivity (it is a rare failure, and the kernel already checks for it). + - Universe constraints (the kernel checks for it). -/ +private def elabCtors (indFVar : Expr) (params : Array Expr) (r : ElabHeaderResult) : TermElabM (List Constructor) := do +let ref := r.view.ref; +indFamily ← isInductiveFamily ref indFVar; +r.view.ctors.toList.mapM fun ctorView => Term.elabBinders ctorView.binders.getArgs fun ctorParams => do + let ref := ctorView.ref; + type ← match ctorView.type? with + | none => do + when indFamily $ + Term.throwError ref "constructor resulting type must be specified in inductive family declaration"; + pure indFVar + | some ctorType => do { + type ← Term.elabTerm ctorType none; + resultingType ← getResultingType ref type; + unless (resultingType.getAppFn == indFVar) $ + Term.throwError ref ("unexpected constructor resulting type" ++ indentExpr resultingType); + unlessM (Term.isType ref resultingType) $ + Term.throwError ref ("unexpected constructor resulting type, type expected" ++ indentExpr resultingType); + pure type + }; + type ← Term.mkForall ref ctorParams type; + type ← Term.mkForall ref params type; + pure { name := ctorView.declName, type := type } + +/- Convert universe metavariables occurring in the `indTypes` into new parameters. + Remark: if the resulting inductive datatype has universe metavariables, we will fix it later using + `inferResultingUniverse`. -/ +private def levelMVarToParamAux (ref : Syntax) (indTypes : List InductiveType) : StateT Nat TermElabM (List InductiveType) := +indTypes.mapM fun indType => do + type ← liftM $ Term.instantiateMVars ref indType.type; + type ← Term.levelMVarToParam' type; + ctors ← indType.ctors.mapM fun ctor => do { + ctorType ← liftM $ Term.instantiateMVars ref ctor.type; + ctorType ← Term.levelMVarToParam' ctorType; + pure { ctor with type := ctorType } + }; + pure { indType with ctors := ctors, type := type } + +private def levelMVarToParam (ref : Syntax) (indTypes : List InductiveType) : TermElabM (List InductiveType) := +(levelMVarToParamAux ref indTypes).run' 1 + +private def getResultingUniverse (ref : Syntax) : List InductiveType → TermElabM Level +| [] => Term.throwError ref "unexpected empty inductive declaration" +| indType :: _ => do + r ← getResultingType ref indType.type; + match r with + | Expr.sort u _ => pure u + | _ => Term.throwError ref "unexpected inductive type resulting type" + +private def tmpIndParam := mkLevelParam `_tmp_ind_univ_param + +/-- + Return true if the resulting universe level is of the form `?m + k`. + Return false if the resulting universe level does not contain universe metavariables. + Throw exeception otherwise. -/ +private def shouldInferResultUniverse (ref : Syntax) (indTypes : List InductiveType) : TermElabM Bool := do +u ← getResultingUniverse ref indTypes; +u ← Term.instantiateLevelMVars ref u; +if u.hasMVar then + match u.getLevelOffset with + | Level.mvar mvarId _ => do + Term.assignLevelMVar mvarId tmpIndParam; + pure true + | _ => + Term.throwError ref $ + "cannot infer resulting universe level of inductive datatype, given level contains metavariables " ++ mkSort u ++ ", provide universe explicitly" +else + pure false + +/- + Auxiliary function for `updateResultingUniverse` + `addLevel u r rOffset us` add `u` components to `us` if they are not already there and it is different from the resulting universe level `r+rOffset`. + If `u` is a `max`, then its components are recursively processed. + If `u` is a `succ` and `rOffset > 0`, we process the `u`s child using `rOffset-1`. + + This method is used to infer the resulting universe level of an inductive datatype. -/ +private def addLevel : Level → Level → Nat → Array Level → Except String (Array Level) +| Level.max u v _, r, rOffset, us => do us ← addLevel u r rOffset us; addLevel v r rOffset us +| Level.zero _, _, _, us => pure us +| Level.succ u _, r, rOffset+1, us => addLevel u r rOffset us +| u, r, rOffset, us => + if rOffset == 0 && u == r then pure us + else if r.occurs u then throw "failed to compute resulting universe level of inductive datatype, provide universe explicitly" + else if us.contains u then pure us + else pure (us.push u) + +/- Auxiliary function for `updateResultingUniverse` -/ +private partial def collectUniversesFromCtorTypeAux (ref : Syntax) (r : Level) (rOffset : Nat) : Nat → Expr → Array Level → TermElabM (Array Level) +| 0, Expr.forallE n d b c, us => do + u ← Term.getLevel ref d; + u ← Term.instantiateLevelMVars ref u; + match addLevel u r rOffset us with + | Except.error msg => Term.throwError ref msg + | Except.ok us => Term.withLocalDecl ref n c.binderInfo d $ fun x => + let e := b.instantiate1 x; + collectUniversesFromCtorTypeAux 0 e us +| i+1, Expr.forallE n d b c, us => do + Term.withLocalDecl ref n c.binderInfo d $ fun x => + let e := b.instantiate1 x; + collectUniversesFromCtorTypeAux i e us +| _, _, us => pure us + +/- Auxiliary function for `updateResultingUniverse` -/ +private partial def collectUniversesFromCtorType + (ref : Syntax) (r : Level) (rOffset : Nat) (ctorType : Expr) (numParams : Nat) (us : Array Level) : TermElabM (Array Level) := +collectUniversesFromCtorTypeAux ref r rOffset numParams ctorType us + +/- Auxiliary function for `updateResultingUniverse` -/ +private partial def collectUniverses (ref : Syntax) (r : Level) (rOffset : Nat) (numParams : Nat) (indTypes : List InductiveType) : TermElabM (Array Level) := +indTypes.foldlM + (fun us indType => indType.ctors.foldlM + (fun us ctor => collectUniversesFromCtorType ref r rOffset ctor.type numParams us) + us) + #[] + +private def updateResultingUniverse (ref : Syntax) (numParams : Nat) (indTypes : List InductiveType) : TermElabM (List InductiveType) := do +r ← getResultingUniverse ref indTypes; +let rOffset : Nat := r.getOffset; +let r : Level := r.getLevelOffset; +unless (r.isParam) $ + Term.throwError ref "failed to compute resulting universe level of inductive datatype, provide universe explicitly"; +us ← collectUniverses ref r rOffset numParams indTypes; +let rNew := Level.mkNaryMax us.toList; +pure $ indTypes.map fun indType => + let type := indType.type.replaceLevel fun u => if u == tmpIndParam then some rNew else none; + { indType with type := type } + +private def traceIndTypes (indTypes : List InductiveType) : TermElabM Unit := +indTypes.forM fun indType => + indType.ctors.forM fun ctor => _root_.dbgTrace (" >> " ++ toString ctor.name ++ " : " ++ toString ctor.type) fun _ => pure () + +private def removeUnused (ref : Syntax) (vars : Array Expr) (indTypes : List InductiveType) : TermElabM (LocalContext × LocalInstances × Array Expr) := do +used ← indTypes.foldlM + (fun (used : CollectFVars.State) indType => do + used ← Term.collectUsedFVars ref used indType.type; + indType.ctors.foldlM (fun (used : CollectFVars.State) ctor => Term.collectUsedFVars ref used ctor.type) used) + {}; +Term.removeUnused ref vars used + +private def withUsed {α} (ref : Syntax) (vars : Array Expr) (indTypes : List InductiveType) (k : Array Expr → TermElabM α) : TermElabM α := do +(lctx, localInsts, vars) ← removeUnused ref vars indTypes; +Term.withLCtx lctx localInsts $ k vars + +private def updateParams (ref : Syntax) (vars : Array Expr) (indTypes : List InductiveType) : TermElabM (List InductiveType) := +indTypes.mapM fun indType => do + type ← Term.mkForall ref vars indType.type; + ctors ← indType.ctors.mapM fun ctor => do { + ctorType ← Term.mkForall ref vars ctor.type; + pure { ctor with type := ctorType } + }; + pure { indType with type := type, ctors := ctors } + +private def collectLevelParamsInInductive (indTypes : List InductiveType) : Array Name := +let usedParams := indTypes.foldl + (fun (usedParams : CollectLevelParams.State) indType => + let usedParams := collectLevelParams usedParams indType.type; + indType.ctors.foldl + (fun (usedParams : CollectLevelParams.State) ctor => collectLevelParams usedParams ctor.type) + usedParams) + {}; +usedParams.params + +private def mkIndFVar2Const (views : Array InductiveView) (indFVars : Array Expr) (levelNames : List Name) : ExprMap Expr := +let levelParams := levelNames.map mkLevelParam; +views.size.fold + (fun i (m : ExprMap Expr) => + let view := views.get! i; + let indFVar := indFVars.get! i; + m.insert indFVar (mkConst view.declName levelParams)) + {} + +private def replaceIndFVarsWithConsts (views : Array InductiveView) (indFVars : Array Expr) (levelNames : List Name) (numParams : Nat) (indTypes : List InductiveType) + : TermElabM (List InductiveType) := +let ref := (views.get! 0).ref; +let indFVar2Const := mkIndFVar2Const views indFVars levelNames; +indTypes.mapM fun indType => do + ctors ← indType.ctors.mapM fun ctor => do { + type ← Term.liftMetaM ref $ Meta.forallBoundedTelescope ctor.type numParams fun params type => do { + let type := type.replace fun e => if !e.isFVar then none else + match indFVar2Const.find? e with + | some c => some $ mkAppN c params + | none => none; + Meta.mkForall params type + }; + pure { ctor with type := type } + }; + pure { indType with ctors := ctors } + +abbrev Ctor2InferMod := Std.HashMap Name Bool + +private def mkCtor2InferMod (views : Array InductiveView) : Ctor2InferMod := +views.foldl + (fun (m : Ctor2InferMod) view => view.ctors.foldl + (fun (m : Ctor2InferMod) ctorView => m.insert ctorView.declName ctorView.inferMod) + m) + {} + +private def applyInferMod (views : Array InductiveView) (numParams : Nat) (indTypes : List InductiveType) : List InductiveType := +let ctor2InferMod := mkCtor2InferMod views; +indTypes.map fun indType => + let ctors := indType.ctors.map fun ctor => + let inferMod := ctor2InferMod.find! ctor.name; -- true if `{}` was used + let ctorType := ctor.type.inferImplicit numParams !inferMod; + { ctor with type := ctorType }; + { indType with ctors := ctors } + +private def mkInductiveDecl (vars : Array Expr) (views : Array InductiveView) : TermElabM Declaration := do +let view0 := views.get! 0; +scopeLevelNames ← Term.getLevelNames; +checkLevelNames views; +let allUserLevelNames := view0.levelNames; +let isUnsafe := view0.modifiers.isUnsafe; +let ref := view0.ref; +adaptReader (fun (ctx : Term.Context) => { ctx with levelNames := allUserLevelNames }) do + rs ← elabHeader views; + withInductiveLocalDecls rs fun params indFVars => do + let numExplicitParams := params.size; + indTypes ← views.size.foldM + (fun i (indTypes : List InductiveType) => do + let indFVar := indFVars.get! i; + let r := rs.get! i; + type ← Term.mkForall ref params r.type; + ctors ← elabCtors indFVar params r; + let indType := { name := r.view.declName, type := type, ctors := ctors : InductiveType }; + pure (indType :: indTypes)) + []; + let indTypes := indTypes.reverse; + Term.synthesizeSyntheticMVars false; -- resolve pending + inferLevel ← shouldInferResultUniverse ref indTypes; + withUsed ref vars indTypes $ fun vars => do + let numParams := vars.size + numExplicitParams; + indTypes ← updateParams ref vars indTypes; + indTypes ← levelMVarToParam ref indTypes; + indTypes ← if inferLevel then updateResultingUniverse ref numParams indTypes else pure indTypes; + let usedLevelNames := collectLevelParamsInInductive indTypes; + match sortDeclLevelParams scopeLevelNames allUserLevelNames usedLevelNames with + | Except.error msg => Term.throwError ref msg + | Except.ok levelParams => do + indTypes ← replaceIndFVarsWithConsts views indFVars levelParams numParams indTypes; + let indTypes := applyInferMod views numParams indTypes; + pure $ Declaration.inductDecl levelParams numParams indTypes isUnsafe + +private def mkAuxConstructions (views : Array InductiveView) : CommandElabM Unit := do +env ← getEnv; +let hasEq := env.contains `Eq; +let hasHEq := env.contains `HEq; +let hasUnit := env.contains `PUnit; +let hasProd := env.contains `Prod; +views.forM fun view => do { + let n := view.declName; + modifyEnv fun env => mkRecOn env n; + when hasUnit $ modifyEnv fun env => mkCasesOn env n; + when (hasUnit && hasEq && hasHEq) $ modifyEnv fun env => mkNoConfusion env n; + when (hasUnit && hasProd) $ modifyEnv fun env => mkBelow env n; + when (hasUnit && hasProd) $ modifyEnv fun env => mkIBelow env n; + pure () +}; +views.forM fun view => do { + let n := view.declName; + when (hasUnit && hasProd) $ modifyEnv fun env => mkBRecOn env n; + when (hasUnit && hasProd) $ modifyEnv fun env => mkBInductionOn env n; + pure () +} def elabInductiveCore (views : Array InductiveView) : CommandElabM Unit := do -let ref := (views.get! 0).ref; -throwError ref ("WIP\n" ++ toString (views.map (fun (v : InductiveView) => v.ref))) --- pure () -/- -withDeclId declId $ fun name => do - declName ← mkDeclName modifiers name; - checkNotAlreadyDeclared ref declName; - applyAttributes ref declName modifiers.attrs AttributeApplicationTime.beforeElaboration; - explictLevelNames ← getLevelNames; - decl ← runTermElabM declName $ fun vars => Term.elabBinders binders.getArgs $ fun xs => do { - -- TODO - pure () - }; - - throwError ref (ref ++ "\n" ++ toString explictLevelNames) --/ +let view0 := views.get! 0; +let ref := view0.ref; +decl ← runTermElabM view0.declName $ fun vars => mkInductiveDecl vars views; +addDecl ref decl; +mkAuxConstructions views; +-- We need to invoke `applyAttributes` because `class` is implemented as an attribute. +views.forM fun view => applyAttributes ref view.declName view.modifiers.attrs AttributeApplicationTime.afterTypeChecking; +pure () end Command end Elab diff --git a/stage0/src/Lean/Elab/Term.lean b/stage0/src/Lean/Elab/Term.lean index 25f2bc4282..a36b68d677 100644 --- a/stage0/src/Lean/Elab/Term.lean +++ b/stage0/src/Lean/Elab/Term.lean @@ -123,6 +123,7 @@ def getMCtx : TermElabM MetavarContext := do s ← get; pure s.mctx def getLCtx : TermElabM LocalContext := do ctx ← read; pure ctx.lctx def getLocalInsts : TermElabM LocalInstances := do ctx ← read; pure ctx.localInstances def getOptions : TermElabM Options := do ctx ← read; pure ctx.config.opts +def getLevelNames : TermElabM (List Name) := do ctx ← read; pure ctx.levelNames def setEnv (env : Environment) : TermElabM Unit := modify $ fun s => { s with env := env } def setMCtx (mctx : MetavarContext) : TermElabM Unit := modify $ fun s => { s with mctx := mctx } @@ -194,6 +195,7 @@ def setTraceState (traceState : TraceState) : TermElabM Unit := modify $ fun s = def isExprMVarAssigned (mvarId : MVarId) : TermElabM Bool := do mctx ← getMCtx; pure $ mctx.isExprAssigned mvarId def getMVarDecl (mvarId : MVarId) : TermElabM MetavarDecl := do mctx ← getMCtx; pure $ mctx.getDecl mvarId def assignExprMVar (mvarId : MVarId) (val : Expr) : TermElabM Unit := modify $ fun s => { s with mctx := s.mctx.assignExpr mvarId val } +def assignLevelMVar (mvarId : MVarId) (val : Level) : TermElabM Unit := modify $ fun s => { s with mctx := s.mctx.assignLevel mvarId val } def logTrace (cls : Name) (ref : Syntax) (msg : MessageData) : TermElabM Unit := do ctx ← read; @@ -247,14 +249,17 @@ fun ctx s => def ppGoal (ref : Syntax) (mvarId : MVarId) : TermElabM Format := liftMetaM ref $ Meta.ppGoal mvarId def isType (ref : Syntax) (e : Expr) : TermElabM Bool := liftMetaM ref $ Meta.isType e def isTypeFormer (ref : Syntax) (e : Expr) : TermElabM Bool := liftMetaM ref $ Meta.isTypeFormer e +def isTypeFormerType (ref : Syntax) (e : Expr) : TermElabM Bool := liftMetaM ref $ Meta.isTypeFormerType e def isDefEqNoConstantApprox (ref : Syntax) (t s : Expr) : TermElabM Bool := liftMetaM ref $ Meta.approxDefEq $ Meta.isDefEq t s def isDefEq (ref : Syntax) (t s : Expr) : TermElabM Bool := liftMetaM ref $ Meta.fullApproxDefEq $ Meta.isDefEq t s +def isLevelDefEq (ref : Syntax) (u v : Level) : TermElabM Bool := liftMetaM ref $ Meta.isLevelDefEq u v def inferType (ref : Syntax) (e : Expr) : TermElabM Expr := liftMetaM ref $ Meta.inferType e def whnf (ref : Syntax) (e : Expr) : TermElabM Expr := liftMetaM ref $ Meta.whnf e def whnfForall (ref : Syntax) (e : Expr) : TermElabM Expr := liftMetaM ref $ Meta.whnfForall e def whnfCore (ref : Syntax) (e : Expr) : TermElabM Expr := liftMetaM ref $ Meta.whnfCore e def unfoldDefinition? (ref : Syntax) (e : Expr) : TermElabM (Option Expr) := liftMetaM ref $ Meta.unfoldDefinition? e def instantiateMVars (ref : Syntax) (e : Expr) : TermElabM Expr := liftMetaM ref $ Meta.instantiateMVars e +def instantiateLevelMVars (ref : Syntax) (u : Level) : TermElabM Level := liftMetaM ref $ Meta.instantiateLevelMVars u def isClass (ref : Syntax) (t : Expr) : TermElabM (Option Name) := liftMetaM ref $ Meta.isClass t def mkFreshLevelMVar (ref : Syntax) : TermElabM Level := liftMetaM ref $ Meta.mkFreshLevelMVar def mkFreshExprMVar (ref : Syntax) (type? : Option Expr := none) (kind : MetavarKind := MetavarKind.natural) (userName? : Name := Name.anonymous) : TermElabM Expr := @@ -329,13 +334,25 @@ adaptReader (fun (ctx : Context) => { ctx with mayPostpone := false }) x def mkExplicitBinder (ident : Syntax) (type : Syntax) : Syntax := mkNode `Lean.Parser.Term.explicitBinder #[mkAtom "(", mkNullNode #[ident], mkNullNode #[mkAtom ":", type], mkNullNode, mkAtom ")"] -/-- Convert unassigned universe level metavariables into parameters. -/ -def levelMVarToParam (e : Expr) : TermElabM Expr := do +/-- + Convert unassigned universe level metavariables into parameters. + The new parameter names are of the form `u_i` where `i >= nextParamIdx`. + The method returns the updated expression and new `nextParamIdx`. + + Remark: we make sure the generated parameter names do not clash with the universes at `ctx.levelNames`. -/ +def levelMVarToParam (e : Expr) (nextParamIdx : Nat := 1) : TermElabM (Expr × Nat) := do ctx ← read; mctx ← getMCtx; -let r := mctx.levelMVarToParam (fun n => ctx.levelNames.elem n) e; +let r := mctx.levelMVarToParam (fun n => ctx.levelNames.elem n) e `u nextParamIdx; modify $ fun s => { s with mctx := r.mctx }; -pure r.expr +pure (r.expr, r.nextParamIdx) + +/-- Variant of `levelMVarToParam` where `nextParamIdx` is stored in a state monad. -/ +def levelMVarToParam' (e : Expr) : StateT Nat TermElabM Expr := do +nextParamIdx ← get; +(e, nextParamIdx) ← liftM $ levelMVarToParam e nextParamIdx; +set nextParamIdx; +pure e /-- Auxiliary method for creating fresh binder names. @@ -887,6 +904,14 @@ finally x (modify $ fun s => { s with cache := { s.cache with synthInstance := s @[inline] def resettingSynthInstanceCacheWhen {α} (b : Bool) (x : TermElabM α) : TermElabM α := if b then resettingSynthInstanceCache x else x +def withLocalContext {α} (lctx : LocalContext) (localInsts : LocalInstances) (x : TermElabM α) : TermElabM α := do +localInstsCurr ← getLocalInsts; +adaptReader (fun (ctx : Context) => { ctx with lctx := lctx, localInstances := localInsts }) $ + if localInsts == localInstsCurr then + x + else + resettingSynthInstanceCache x + /-- Execute `x` using the given metavariable's `LocalContext` and `LocalInstances`. The type class resolution cache is flushed when executing `x` if its `LocalInstances` are diff --git a/stage0/src/Lean/Environment.lean b/stage0/src/Lean/Environment.lean index cfcb8251d0..c3613e4899 100644 --- a/stage0/src/Lean/Environment.lean +++ b/stage0/src/Lean/Environment.lean @@ -29,13 +29,24 @@ structure Import := instance : HasToString Import := ⟨fun imp => toString imp.module ++ if imp.runtimeOnly then " (runtime)" else ""⟩ +/-- + A compacted region holds multiple Lean objects in a contiguous memory region, which can be read/written to/from disk. + Objects inside the region do not have reference counters and cannot be freed individually. The contents of .olean + files are compacted regions. -/ +def CompactedRegion := USize + +/-- Free a compacted region and its contents. No live references to the contents may exist at the time of invocation. -/ +@[extern 2 "lean_compacted_region_free"] +unsafe constant CompactedRegion.free : CompactedRegion → IO Unit := arbitrary _ + /- Environment fields that are not used often. -/ structure EnvironmentHeader := (trustLevel : UInt32 := 0) (quotInit : Bool := false) (mainModule : Name := arbitrary _) (imports : Array Import := #[]) -- direct imports -(moduleNames : NameSet := {}) -- all imported .lean modules +(regions : Array CompactedRegion := #[]) -- compacted regions of all imported modules +(moduleNames : NameSet := {}) -- names of all imported modules open Std (HashMap) @@ -447,7 +458,29 @@ instance ModuleData.inhabited : Inhabited ModuleData := @[extern 3 "lean_save_module_data"] constant saveModuleData (fname : @& String) (m : ModuleData) : IO Unit := arbitrary _ @[extern 2 "lean_read_module_data"] -constant readModuleData (fname : @& String) : IO ModuleData := arbitrary _ +constant readModuleData (fname : @& String) : IO (ModuleData × CompactedRegion) := arbitrary _ + +/-- + Free compacted regions of imports. No live references to imported objects may exist at the time of invocation; in + particular, `env` should be the last reference to any `Environment` derived from these imports. -/ +@[noinline, export lean_environment_free_regions] +unsafe def Environment.freeRegions (env : Environment) : IO Unit := +/- + NOTE: This assumes `env` is not inferred as a borrowed parameter, and is freed after extracting the `header` field. + Otherwise, we would encounter undefined behavior when the constant map in `env`, which may reference objects in + compacted regions, is freed after the regions. + + In the currently produced IR, we indeed see: + ``` + def Lean.Environment.freeRegions (x_1 : obj) (x_2 : obj) : obj := + let x_3 : obj := proj[3] x_1; + inc x_3; + dec x_1; + ... + ``` + + TODO: statically check for this. -/ +env.header.regions.forM CompactedRegion.free def mkModuleData (env : Environment) : IO ModuleData := do pExts ← persistentEnvExtensionsRef.get; @@ -470,20 +503,21 @@ pure { def writeModule (env : Environment) (fname : String) : IO Unit := do modData ← mkModuleData env; saveModuleData fname modData -partial def importModulesAux : List Import → (NameSet × Array ModuleData) → IO (NameSet × Array ModuleData) +partial def importModulesAux : List Import → (NameSet × Array ModuleData × Array CompactedRegion) → IO (NameSet × Array ModuleData × Array CompactedRegion) | [], r => pure r -| i::is, (s, mods) => +| i::is, (s, mods, regions) => if i.runtimeOnly || s.contains i.module then - importModulesAux is (s, mods) + importModulesAux is (s, mods, regions) else do let s := s.insert i.module; mFile ← findOLean i.module; unlessM (IO.fileExists mFile) $ throw $ IO.userError $ "object file '" ++ mFile ++ "' of module " ++ toString i.module ++ " does not exist"; - mod ← readModuleData mFile; - (s, mods) ← importModulesAux mod.imports.toList (s, mods); + (mod, region) ← readModuleData mFile; + (s, mods, regions) ← importModulesAux mod.imports.toList (s, mods, regions); let mods := mods.push mod; - importModulesAux is (s, mods) + let regions := regions.push region; + importModulesAux is (s, mods, regions) private partial def getEntriesFor (mod : ModuleData) (extId : Name) : Nat → Array EnvExtensionState | i => @@ -510,7 +544,7 @@ pExtDescrs.iterateM env $ fun _ extDescr env => do @[export lean_import_modules] def importModules (imports : List Import) (trustLevel : UInt32 := 0) : IO Environment := do -(moduleNames, mods) ← importModulesAux imports ({}, #[]); +(moduleNames, mods, regions) ← importModulesAux imports ({}, #[], #[]); let const2ModIdx := mods.iterate {} $ fun (modIdx) (mod : ModuleData) (m : HashMap Name ModuleIdx) => mod.constants.iterate m $ fun _ cinfo m => m.insert cinfo.name modIdx.val; @@ -529,6 +563,7 @@ let env : Environment := { quotInit := !imports.isEmpty, -- We assume `core.lean` initializes quotient module trustLevel := trustLevel, imports := imports.toArray, + regions := regions, moduleNames := moduleNames } }; @@ -537,6 +572,13 @@ env ← finalizePersistentExtensions env; env ← mods.iterateM env $ fun _ mod env => performModifications env mod.serialized; pure env +/-- + Create environment object from imports and free compacted regions after calling `act`. No live references to the + environment object or imported objects may exist after `act` finishes. -/ +unsafe def withImportModules {α : Type} (imports : List Import) (trustLevel : UInt32 := 0) (x : Environment → IO α) : IO α := do +env ← importModules imports trustLevel; +finally (x env) env.freeRegions + def regNamespacesExtension : IO (SimplePersistentEnvExtension Name NameSet) := registerSimplePersistentEnvExtension { name := `namespaces, diff --git a/stage0/src/Lean/Expr.lean b/stage0/src/Lean/Expr.lean index 9a010c7f43..d8420da3d9 100644 --- a/stage0/src/Lean/Expr.lean +++ b/stage0/src/Lean/Expr.lean @@ -551,6 +551,11 @@ def bindingBody! : Expr → Expr | lam _ _ b _ => b | _ => panic! "binding expected" +def bindingInfo! : Expr → BinderInfo +| forallE _ _ _ c => c.binderInfo +| lam _ _ _ c => c.binderInfo +| _ => panic! "binding expected" + def letName! : Expr → Name | letE n _ _ _ _ => n | _ => panic! "let expression expected" @@ -565,6 +570,11 @@ e.looseBVarRange > 0 @[extern "lean_expr_has_loose_bvar"] constant hasLooseBVar (e : @& Expr) (bvarIdx : @& Nat) : Bool := arbitrary _ +/-- Return true if `e` contains the loose bound variable `bvarIdx` in an explicit parameter, or in the range if `tryRange == true`. -/ +def hasLooseBVarInExplicitDomain : Expr → Nat → Bool → Bool +| Expr.forallE _ d b c, bvarIdx, tryRange => (c.binderInfo.isExplicit && hasLooseBVar d bvarIdx) || hasLooseBVarInExplicitDomain b (bvarIdx+1) tryRange +| e, bvarIdx, tryRange => tryRange && hasLooseBVar e bvarIdx + /-- Lower the loose bound variables `>= s` in `e` by `d`. That is, a loose bound variable `bvar i`. @@ -579,6 +589,22 @@ constant lowerLooseBVars (e : @& Expr) (s d : @& Nat) : Expr := arbitrary _ @[extern "lean_expr_lift_loose_bvars"] constant liftLooseBVars (e : @& Expr) (s d : @& Nat) : Expr := arbitrary _ +/-- + `inferImplicit e numParams considerRange` updates the first `numParams` parameter binder annotations of the `e` forall type. + It marks any parameter with an explicit binder annotation if there is another explicit arguments that depends on it or + the resulting type if `considerRange == true`. + + Remark: we use this function to infer the bind annotations of inductive datatype constructors, and structure projections. + When the `{}` annotation is used in these commands, we set `considerRange == false`. +-/ +def inferImplicit : Expr → Nat → Bool → Expr +| Expr.forallE n d b c, i+1, considerRange => + let b := inferImplicit b i considerRange; + let newInfo := if c.binderInfo.isExplicit && hasLooseBVarInExplicitDomain b 0 considerRange then BinderInfo.implicit else c.binderInfo; + mkForall n newInfo d b +| e, 0, _ => e +| e, _, _ => e + /-- Instantiate the loose bound variables in `e` using `subst`. That is, a loose `Expr.bvar i` is replaced with `subst[i]`. -/ @[extern "lean_expr_instantiate"] diff --git a/stage0/src/Lean/Level.lean b/stage0/src/Lean/Level.lean index 0b9b169348..3589a3c6b8 100644 --- a/stage0/src/Lean/Level.lean +++ b/stage0/src/Lean/Level.lean @@ -360,6 +360,7 @@ def dec : Level → Option Level If `dec l₂` succeeds, then `imax l₁ l₂` is equivalent to `max l₁ l₂`. -/ | imax l₁ l₂ _ => mkLevelMax <$> dec l₁ <*> dec l₂ + /- Level to Format -/ namespace LevelToFormat inductive Result @@ -452,6 +453,13 @@ match lvl with | imax lhs rhs d => updateIMax (imax lhs rhs d) newLhs newRhs rfl | _ => panic! "imax level expected" +def mkNaryMax : List Level → Level +| [] => levelZero +| [u] => u +| u::us => mkLevelMax u (mkNaryMax us) + +/- Level to Format -/ + @[specialize] def instantiateParams (s : Name → Option Level) : Level → Level | u@(zero _) => u | u@(succ v _) => if u.hasParam then u.updateSucc (instantiateParams v) rfl else u diff --git a/stage0/src/Lean/Meta/Basic.lean b/stage0/src/Lean/Meta/Basic.lean index e429e077f0..f365f5fcf0 100644 --- a/stage0/src/Lean/Meta/Basic.lean +++ b/stage0/src/Lean/Meta/Basic.lean @@ -834,6 +834,21 @@ type ← inferType value; let type := type.headBeta; mkAuxDefinition name type value +private partial def instantiateForallAux (ps : Array Expr) : Nat → Expr → MetaM Expr +| i, e => + if h : i < ps.size then do + let p := ps.get ⟨i, h⟩; + e ← whnf e; + match e with + | Expr.forallE _ _ b _ => instantiateForallAux (i+1) (b.instantiate1 p) + | _ => throw (Exception.other "invalid instantiateForall, too many parameters") + else + pure e + +/- Given `e` of the form `forall (a_1 : A_1) ... (a_n : A_n), B[a_1, ..., a_n]` and `p_1 : A_1, ... p_n : A_n`, return `B[p_1, ..., p_n]`. -/ +def instantiateForall (e : Expr) (ps : Array Expr) : MetaM Expr := +instantiateForallAux ps 0 e + @[init] private def regTraceClasses : IO Unit := do registerTraceClass `Meta; registerTraceClass `Meta.debug diff --git a/stage0/src/Lean/Meta/InferType.lean b/stage0/src/Lean/Meta/InferType.lean index 528596fe95..5addbe5218 100644 --- a/stage0/src/Lean/Meta/InferType.lean +++ b/stage0/src/Lean/Meta/InferType.lean @@ -326,14 +326,14 @@ match r with | Expr.sort _ _ => pure true | _ => pure false -partial def isTypeFormerAux : Expr → MetaM Bool +partial def isTypeFormerType : Expr → MetaM Bool | type => do type ← whnfD type; match type with | Expr.sort _ _ => pure true | Expr.forallE n d b c => withLocalDecl n d c.binderInfo $ fun fvar => - isTypeFormerAux (b.instantiate1 fvar) + isTypeFormerType (b.instantiate1 fvar) | _ => pure false /-- @@ -341,7 +341,7 @@ partial def isTypeFormerAux : Expr → MetaM Bool Remark: it subsumes `isType` -/ def isTypeFormer (e : Expr) : MetaM Bool := do type ← inferType e; -isTypeFormerAux type +isTypeFormerType type end Meta end Lean diff --git a/stage0/src/Lean/MetavarContext.lean b/stage0/src/Lean/MetavarContext.lean index 1f0e953978..6a83da7f5b 100644 --- a/stage0/src/Lean/MetavarContext.lean +++ b/stage0/src/Lean/MetavarContext.lean @@ -1035,7 +1035,7 @@ structure UnivMVarParamResult := def levelMVarToParam (mctx : MetavarContext) (alreadyUsedPred : Name → Bool) (e : Expr) (paramNamePrefix : Name := `u) (nextParamIdx : Nat := 1) : UnivMVarParamResult := let (e, s) := LevelMVarToParam.main e { paramNamePrefix := paramNamePrefix, alreadyUsedPred := alreadyUsedPred } { mctx := mctx, nextParamIdx := nextParamIdx }; -{ mctx := mctx, +{ mctx := s.mctx, newParamNames := s.paramNames, nextParamIdx := s.nextParamIdx, expr := e } diff --git a/stage0/src/Lean/Parser/Command.lean b/stage0/src/Lean/Parser/Command.lean index 77bcb9409b..e53fab611e 100644 --- a/stage0/src/Lean/Parser/Command.lean +++ b/stage0/src/Lean/Parser/Command.lean @@ -54,9 +54,9 @@ def «instance» := parser! "instance " >> optional declId >> declSig >> d def «axiom» := parser! "axiom " >> declId >> declSig def «example» := parser! "example " >> declSig >> declVal def inferMod := parser! try ("{" >> "}") -def introRule := parser! " | " >> ident >> optional inferMod >> optDeclSig -def «inductive» := parser! "inductive " >> declId >> optDeclSig >> many introRule -def classInductive := parser! try ("class " >> "inductive ") >> declId >> optDeclSig >> many introRule +def ctor := parser! " | " >> declModifiers >> ident >> optional inferMod >> optDeclSig +def «inductive» := parser! "inductive " >> declId >> optDeclSig >> many ctor +def classInductive := parser! try ("class " >> "inductive ") >> declId >> optDeclSig >> many ctor def structExplicitBinder := parser! "(" >> many ident >> optional inferMod >> optDeclSig >> optional Term.binderDefault >> ")" def structImplicitBinder := parser! "{" >> many ident >> optional inferMod >> optDeclSig >> "}" def structInstBinder := parser! "[" >> many ident >> optional inferMod >> optDeclSig >> "]" diff --git a/stage0/src/Lean/Util.lean b/stage0/src/Lean/Util.lean index 880c63b7aa..23d9567e55 100644 --- a/stage0/src/Lean/Util.lean +++ b/stage0/src/Lean/Util.lean @@ -18,4 +18,6 @@ import Lean.Util.Trace import Lean.Util.WHNF import Lean.Util.FindExpr import Lean.Util.ReplaceExpr +import Lean.Util.ReplaceLevel import Lean.Util.FoldConsts +import Lean.Util.Constructions diff --git a/stage0/src/Lean/Util/Constructions.lean b/stage0/src/Lean/Util/Constructions.lean new file mode 100644 index 0000000000..0d7abe401d --- /dev/null +++ b/stage0/src/Lean/Util/Constructions.lean @@ -0,0 +1,18 @@ +/- +Copyright (c) 2020 Microsoft Corporation. All rights reserved. +Released under Apache 2.0 license as described in the file LICENSE. +Authors: Leonardo de Moura +-/ +import Lean.Environment + +namespace Lean + +@[extern "lean_mk_cases_on"] constant mkCasesOn (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_rec_on"] constant mkRecOn (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_no_confusion"] constant mkNoConfusion (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_below"] constant mkBelow (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_ibelow"] constant mkIBelow (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_brec_on"] constant mkBRecOn (env : Environment) (name : @& Name) : Environment := env +@[extern "lean_mk_binduction_on"] constant mkBInductionOn (env : Environment) (name : @& Name) : Environment := env + +end Lean diff --git a/stage0/src/Lean/Util/ReplaceLevel.lean b/stage0/src/Lean/Util/ReplaceLevel.lean new file mode 100644 index 0000000000..8767e73211 --- /dev/null +++ b/stage0/src/Lean/Util/ReplaceLevel.lean @@ -0,0 +1,80 @@ +/- +Copyright (c) 2020 Microsoft Corporation. All rights reserved. +Released under Apache 2.0 license as described in the file LICENSE. +Authors: Leonardo de Moura +-/ +import Lean.Expr + +namespace Lean +namespace Level + +partial def replace (f? : Level → Option Level) : Level → Level +| u => + match f? u with + | some v => v + | none => match u with + | max v₁ v₂ _ => mkLevelMax (replace v₁) (replace v₂) + | imax v₁ v₂ _ => mkLevelIMax (replace v₁) (replace v₂) + | succ v _ => mkLevelSucc (replace v) + | _ => u + +end Level + +namespace Expr + +namespace ReplaceLevelImpl + +abbrev cacheSize : USize := 8192 + +structure State := +(keys : Array Expr) -- Remark: our "unsafe" implementation relies on the fact that `()` is not a valid Expr +(results : Array Expr) + +abbrev ReplaceM := StateM State + +@[inline] unsafe def cache (i : USize) (key : Expr) (result : Expr) : ReplaceM Expr := do +modify $ fun s => { keys := s.keys.uset i key lcProof, results := s.results.uset i result lcProof }; +pure result + +@[specialize] unsafe def replaceUnsafeM (f? : Level → Option Level) (size : USize) : Expr → ReplaceM Expr +| e => do + c ← get; + let h := ptrAddrUnsafe e; + let i := h % size; + if ptrAddrUnsafe (c.keys.uget i lcProof) == h then + pure $ c.results.uget i lcProof + else match e with + | Expr.forallE _ d b _ => do d ← replaceUnsafeM d; b ← replaceUnsafeM b; cache i e $ e.updateForallE! d b + | Expr.lam _ d b _ => do d ← replaceUnsafeM d; b ← replaceUnsafeM b; cache i e $ e.updateLambdaE! d b + | Expr.mdata _ b _ => do b ← replaceUnsafeM b; cache i e $ e.updateMData! b + | Expr.letE _ t v b _ => do t ← replaceUnsafeM t; v ← replaceUnsafeM v; b ← replaceUnsafeM b; cache i e $ e.updateLet! t v b + | Expr.app f a _ => do f ← replaceUnsafeM f; a ← replaceUnsafeM a; cache i e $ e.updateApp! f a + | Expr.proj _ _ b _ => do b ← replaceUnsafeM b; cache i e $ e.updateProj! b + | Expr.sort u _ => cache i e $ e.updateSort! (u.replace f?) + | Expr.const n us _ => cache i e $ e.updateConst! (us.map (Level.replace f?)) + | Expr.localE _ _ _ _ => unreachable! + | e => pure e + +unsafe def initCache : State := +{ keys := mkArray cacheSize.toNat (cast lcProof ()), -- `()` is not a valid `Expr` + results := mkArray cacheSize.toNat (arbitrary _) } + +@[inline] unsafe def replaceUnsafe (f? : Level → Option Level) (e : Expr) : Expr := +(replaceUnsafeM f? cacheSize e).run' initCache + +end ReplaceLevelImpl + +@[implementedBy ReplaceLevelImpl.replaceUnsafe] +partial def replaceLevel (f? : Level → Option Level) : Expr → Expr +| e@(Expr.forallE _ d b _) => let d := replaceLevel d; let b := replaceLevel b; e.updateForallE! d b +| e@(Expr.lam _ d b _) => let d := replaceLevel d; let b := replaceLevel b; e.updateLambdaE! d b +| e@(Expr.mdata _ b _) => let b := replaceLevel b; e.updateMData! b +| e@(Expr.letE _ t v b _) => let t := replaceLevel t; let v := replaceLevel v; let b := replaceLevel b; e.updateLet! t v b +| e@(Expr.app f a _) => let f := replaceLevel f; let a := replaceLevel a; e.updateApp! f a +| e@(Expr.proj _ _ b _) => let b := replaceLevel b; e.updateProj! b +| e@(Expr.sort u _) => e.updateSort! (u.replace f?) +| e@(Expr.const n us _) => e.updateConst! (us.map (Level.replace f?)) +| e => e + +end Expr +end Lean diff --git a/stage0/src/lean.mk.in b/stage0/src/lean.mk.in index b4bb49dc2c..e8052f2cee 100644 --- a/stage0/src/lean.mk.in +++ b/stage0/src/lean.mk.in @@ -19,6 +19,7 @@ BIN_NAME = $(PKG) STATIC_LIB_NAME = lib$(PKG).a LEAN_OPTS = @LEAN_EXTRA_MAKE_OPTS@ LEANC_OPTS = -O3 -DNDEBUG +LINK_OPTS = SRCS = $(shell find $(PKG) -name '*.lean' 2> /dev/null || true; find $(PKG).lean 2> /dev/null) DEPS = $(addprefix $(TEMP_OUT)/,$(SRCS:.lean=.depend)) @@ -73,7 +74,7 @@ $(BIN_OUT)/$(BIN_NAME): $(addprefix $(TEMP_OUT)/,$(SRCS:.lean=.o)) | $(BIN_OUT) ifdef CMAKE_LIKE_OUTPUT @echo "[ ] Linking $@" endif - leanc -o "$@" -x none $^ + leanc -o "$@" -x none $^ $(LINK_OPTS) $(LIB_OUT)/$(STATIC_LIB_NAME): $(addprefix $(TEMP_OUT)/,$(SRCS:.lean=.o)) | $(LIB_OUT) @rm -f $@ diff --git a/stage0/src/library/constructions/brec_on.cpp b/stage0/src/library/constructions/brec_on.cpp index 7f1b81398d..ce5e5a9e10 100644 --- a/stage0/src/library/constructions/brec_on.cpp +++ b/stage0/src/library/constructions/brec_on.cpp @@ -354,4 +354,38 @@ environment mk_brec_on(environment const & env, name const & n) { environment mk_binduction_on(environment const & env, name const & n) { return mk_brec_on(env, n, true); -}} +} + +extern "C" object * lean_mk_below(object * env, object * n) { + try { + return mk_below(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} + +extern "C" object * lean_mk_ibelow(object * env, object * n) { + try { + return mk_ibelow(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} + +extern "C" object * lean_mk_brec_on(object * env, object * n) { + try { + return mk_brec_on(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} + +extern "C" object * lean_mk_binduction_on(object * env, object * n) { + try { + return mk_binduction_on(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} + +} diff --git a/stage0/src/library/constructions/cases_on.cpp b/stage0/src/library/constructions/cases_on.cpp index c025bc9c9e..3a407b1abe 100644 --- a/stage0/src/library/constructions/cases_on.cpp +++ b/stage0/src/library/constructions/cases_on.cpp @@ -186,4 +186,12 @@ environment mk_cases_on(environment const & env, name const & n) { new_env = add_aux_recursor(new_env, cases_on_name); return add_protected(new_env, cases_on_name); } + +extern "C" object * lean_mk_cases_on(object * env, object * n) { + try { + return mk_cases_on(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} } diff --git a/stage0/src/library/constructions/no_confusion.cpp b/stage0/src/library/constructions/no_confusion.cpp index 5d3b64d468..2bfb963e7f 100644 --- a/stage0/src/library/constructions/no_confusion.cpp +++ b/stage0/src/library/constructions/no_confusion.cpp @@ -235,4 +235,12 @@ environment mk_no_confusion(environment const & env, name const & n) { new_env = add_no_confusion(new_env, no_confusion_name); return add_protected(new_env, no_confusion_name); } + +extern "C" object * lean_mk_no_confusion(object * env, object * n) { + try { + return mk_no_confusion(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} } diff --git a/stage0/src/library/constructions/rec_on.cpp b/stage0/src/library/constructions/rec_on.cpp index a17430a40d..f39f28beec 100644 --- a/stage0/src/library/constructions/rec_on.cpp +++ b/stage0/src/library/constructions/rec_on.cpp @@ -60,4 +60,12 @@ environment mk_rec_on(environment const & env, name const & n) { new_env = add_aux_recursor(new_env, rec_on_name); return add_protected(new_env, rec_on_name); } + +extern "C" object * lean_mk_rec_on(object * env, object * n) { + try { + return mk_rec_on(environment(env), name(n, true)).steal(); + } catch (exception &) { + return env; + } +} } diff --git a/stage0/src/library/module.cpp b/stage0/src/library/module.cpp index 3fbba6344f..093c51d07f 100644 --- a/stage0/src/library/module.cpp +++ b/stage0/src/library/module.cpp @@ -79,22 +79,19 @@ extern "C" object * lean_read_module_data(object * fname, object *) { return set_io_error((sstream() << "failed to read file '" << olean_fn << "', invalid header").str()); } delete[] header; - char * buffer = new char[size - header_size]; + // use `malloc` here as expected by `compacted_region` + char * buffer = static_cast(malloc(size - header_size)); in.read(buffer, size - header_size); if (!in) { return set_io_error((sstream() << "failed to read file '" << olean_fn << "'").str()); } in.close(); - /* We don't free compacted_region objects */ compacted_region * region = new compacted_region(size - header_size, buffer); -#if defined(__has_feature) -#if __has_feature(address_sanitizer) - // do not report as leak - __lsan_ignore_object(region); -#endif -#endif object * mod = region->read(); - return set_io_result(mod); + object * mod_region = alloc_cnstr(0, 2, 0); + cnstr_set(mod_region, 0, mod); + cnstr_set(mod_region, 1, box_size_t(reinterpret_cast(region))); + return set_io_result(mod_region); } catch (exception & ex) { return set_io_error((sstream() << "failed to read '" << olean_fn << "': " << ex.what()).str()); } diff --git a/stage0/src/library/print.cpp b/stage0/src/library/print.cpp index e7df3735ce..48282f6693 100644 --- a/stage0/src/library/print.cpp +++ b/stage0/src/library/print.cpp @@ -147,6 +147,10 @@ struct print_expr_fn { print_child(app_arg(e)); } + static bool is_arrow(expr const & t) { + return lean::is_arrow(t) && binding_info(t) == binder_info::Default; + } + void print_arrow_body(expr const & a) { if (is_atomic(a) || is_arrow(a)) return print(a); diff --git a/stage0/src/runtime/compact.cpp b/stage0/src/runtime/compact.cpp index f5e2b9a059..1469a69bd4 100644 --- a/stage0/src/runtime/compact.cpp +++ b/stage0/src/runtime/compact.cpp @@ -482,4 +482,9 @@ object * compacted_region::read() { } } } + +extern "C" obj_res lean_compacted_region_free(usize region, object *) { + delete reinterpret_cast(region); + return lean_mk_io_result(lean_box(0)); +} } diff --git a/stage0/src/shell/lean.cpp b/stage0/src/shell/lean.cpp index b179a68144..c70bd07c3c 100644 --- a/stage0/src/shell/lean.cpp +++ b/stage0/src/shell/lean.cpp @@ -373,6 +373,11 @@ extern "C" object* lean_print_deps(object* deps, object* w); void print_deps(object_ref const & deps) { consume_io_result(lean_print_deps(deps.to_obj_arg(), io_mk_world())); } + +extern "C" object* lean_environment_free_regions(object * env, object * w); +void environment_free_regions(environment && env) { + consume_io_result(lean_environment_free_regions(env.steal(), io_mk_world())); +} } void check_optarg(char const * option_name) { @@ -656,7 +661,9 @@ int main(int argc, char ** argv) { } if (run && ok) { - return ir::run_main(env, argc - optind, argv + optind); + uint32 ret = ir::run_main(env, argc - optind, argv + optind); + environment_free_regions(std::move(env)); + return ret; } if (olean_fn && ok) { time_task t(".olean serialization", @@ -681,6 +688,7 @@ int main(int argc, char ** argv) { if (!json_output) display_cumulative_profiling_times(std::cerr); + environment_free_regions(std::move(env)); return ok ? 0 : 1; } catch (lean::throwable & ex) { std::cerr << lean::message_builder(env, ios, mod_fn, lean::pos_info(1, 1), lean::ERROR).set_exception( diff --git a/stage0/stdlib/CMakeLists.txt b/stage0/stdlib/CMakeLists.txt index a9376ca1da..321a744e76 100644 --- a/stage0/stdlib/CMakeLists.txt +++ b/stage0/stdlib/CMakeLists.txt @@ -1 +1 @@ -add_library (stage0 OBJECT ./Init.c ./Init/Coe.c ./Init/Control.c ./Init/Control/Alternative.c ./Init/Control/Applicative.c ./Init/Control/Conditional.c ./Init/Control/EState.c ./Init/Control/Except.c ./Init/Control/Functor.c ./Init/Control/Id.c ./Init/Control/Lift.c ./Init/Control/Monad.c ./Init/Control/Option.c ./Init/Control/Reader.c ./Init/Control/State.c ./Init/Core.c ./Init/Data.c ./Init/Data/Array.c ./Init/Data/Array/Basic.c ./Init/Data/Array/BinSearch.c ./Init/Data/Array/QSort.c ./Init/Data/Basic.c ./Init/Data/ByteArray.c ./Init/Data/ByteArray/Basic.c ./Init/Data/Char.c ./Init/Data/Char/Basic.c ./Init/Data/Fin.c ./Init/Data/Fin/Basic.c ./Init/Data/Float.c ./Init/Data/FloatArray.c ./Init/Data/FloatArray/Basic.c ./Init/Data/Hashable.c ./Init/Data/Int.c ./Init/Data/Int/Basic.c ./Init/Data/List.c ./Init/Data/List/Basic.c ./Init/Data/List/BasicAux.c ./Init/Data/List/Control.c ./Init/Data/List/Instances.c ./Init/Data/Nat.c ./Init/Data/Nat/Basic.c ./Init/Data/Nat/Bitwise.c ./Init/Data/Nat/Control.c ./Init/Data/Nat/Div.c ./Init/Data/Option.c ./Init/Data/Option/Basic.c ./Init/Data/Option/BasicAux.c ./Init/Data/Option/Instances.c ./Init/Data/Random.c ./Init/Data/Repr.c ./Init/Data/String.c ./Init/Data/String/Basic.c ./Init/Data/String/Extra.c ./Init/Data/ToString.c ./Init/Data/UInt.c ./Init/Fix.c ./Init/HasCoe.c ./Init/LeanInit.c ./Init/System.c ./Init/System/FilePath.c ./Init/System/IO.c ./Init/System/IOError.c ./Init/System/Platform.c ./Init/Util.c ./Init/WF.c ./Lean.c ./Lean/Attributes.c ./Lean/AuxRecursor.c ./Lean/Class.c ./Lean/Compiler.c ./Lean/Compiler/ClosedTermCache.c ./Lean/Compiler/ConstFolding.c ./Lean/Compiler/ExportAttr.c ./Lean/Compiler/ExternAttr.c ./Lean/Compiler/IR.c ./Lean/Compiler/IR/Basic.c ./Lean/Compiler/IR/Borrow.c ./Lean/Compiler/IR/Boxing.c ./Lean/Compiler/IR/Checker.c ./Lean/Compiler/IR/CompilerM.c ./Lean/Compiler/IR/CtorLayout.c ./Lean/Compiler/IR/ElimDeadBranches.c ./Lean/Compiler/IR/ElimDeadVars.c ./Lean/Compiler/IR/EmitC.c ./Lean/Compiler/IR/EmitUtil.c ./Lean/Compiler/IR/ExpandResetReuse.c ./Lean/Compiler/IR/Format.c ./Lean/Compiler/IR/FreeVars.c ./Lean/Compiler/IR/LiveVars.c ./Lean/Compiler/IR/NormIds.c ./Lean/Compiler/IR/PushProj.c ./Lean/Compiler/IR/RC.c ./Lean/Compiler/IR/ResetReuse.c ./Lean/Compiler/IR/SimpCase.c ./Lean/Compiler/IR/UnboxResult.c ./Lean/Compiler/ImplementedByAttr.c ./Lean/Compiler/InitAttr.c ./Lean/Compiler/InlineAttrs.c ./Lean/Compiler/NameMangling.c ./Lean/Compiler/NeverExtractAttr.c ./Lean/Compiler/Specialize.c ./Lean/Compiler/Util.c ./Lean/Data/Format.c ./Lean/Data/Json.c ./Lean/Data/Json/Basic.c ./Lean/Data/Json/FromToJson.c ./Lean/Data/Json/Parser.c ./Lean/Data/Json/Printer.c ./Lean/Data/KVMap.c ./Lean/Data/LBool.c ./Lean/Data/LOption.c ./Lean/Data/Name.c ./Lean/Data/Occurrences.c ./Lean/Data/Options.c ./Lean/Data/Position.c ./Lean/Data/SMap.c ./Lean/Data/Trie.c ./Lean/Declaration.c ./Lean/Delaborator.c ./Lean/Elab.c ./Lean/Elab/Alias.c ./Lean/Elab/App.c ./Lean/Elab/Binders.c ./Lean/Elab/BuiltinNotation.c ./Lean/Elab/Command.c ./Lean/Elab/DeclModifiers.c ./Lean/Elab/Declaration.c ./Lean/Elab/Definition.c ./Lean/Elab/DoNotation.c ./Lean/Elab/Exception.c ./Lean/Elab/Frontend.c ./Lean/Elab/Import.c ./Lean/Elab/Inductive.c ./Lean/Elab/Level.c ./Lean/Elab/Log.c ./Lean/Elab/Match.c ./Lean/Elab/Quotation.c ./Lean/Elab/ResolveName.c ./Lean/Elab/StrategyAttrs.c ./Lean/Elab/StructInst.c ./Lean/Elab/Syntax.c ./Lean/Elab/SyntheticMVars.c ./Lean/Elab/Tactic.c ./Lean/Elab/Tactic/Basic.c ./Lean/Elab/Tactic/ElabTerm.c ./Lean/Elab/Tactic/Generalize.c ./Lean/Elab/Tactic/Induction.c ./Lean/Elab/Tactic/Injection.c ./Lean/Elab/Term.c ./Lean/Elab/Util.c ./Lean/Environment.c ./Lean/EqnCompiler.c ./Lean/EqnCompiler/MatchPattern.c ./Lean/Eval.c ./Lean/Expr.c ./Lean/HeadIndex.c ./Lean/Hygiene.c ./Lean/KeyedDeclsAttribute.c ./Lean/Level.c ./Lean/Linter.c ./Lean/LocalContext.c ./Lean/Message.c ./Lean/Meta.c ./Lean/Meta/AbstractMVars.c ./Lean/Meta/AppBuilder.c ./Lean/Meta/Basic.c ./Lean/Meta/Check.c ./Lean/Meta/DiscrTree.c ./Lean/Meta/DiscrTreeTypes.c ./Lean/Meta/Exception.c ./Lean/Meta/ExprDefEq.c ./Lean/Meta/FunInfo.c ./Lean/Meta/GeneralizeTelescope.c ./Lean/Meta/InferType.c ./Lean/Meta/Instances.c ./Lean/Meta/KAbstract.c ./Lean/Meta/LevelDefEq.c ./Lean/Meta/Message.c ./Lean/Meta/Offset.c ./Lean/Meta/RecursorInfo.c ./Lean/Meta/Reduce.c ./Lean/Meta/SynthInstance.c ./Lean/Meta/Tactic.c ./Lean/Meta/Tactic/Apply.c ./Lean/Meta/Tactic/Assert.c ./Lean/Meta/Tactic/Assumption.c ./Lean/Meta/Tactic/Cases.c ./Lean/Meta/Tactic/Clear.c ./Lean/Meta/Tactic/FVarSubst.c ./Lean/Meta/Tactic/Generalize.c ./Lean/Meta/Tactic/Induction.c ./Lean/Meta/Tactic/Injection.c ./Lean/Meta/Tactic/Intro.c ./Lean/Meta/Tactic/LocalDecl.c ./Lean/Meta/Tactic/Revert.c ./Lean/Meta/Tactic/Rewrite.c ./Lean/Meta/Tactic/Subst.c ./Lean/Meta/Tactic/Target.c ./Lean/Meta/Tactic/Util.c ./Lean/Meta/WHNF.c ./Lean/MetavarContext.c ./Lean/Modifiers.c ./Lean/Parser.c ./Lean/Parser/Command.c ./Lean/Parser/Level.c ./Lean/Parser/Module.c ./Lean/Parser/Parser.c ./Lean/Parser/Syntax.c ./Lean/Parser/Tactic.c ./Lean/Parser/Term.c ./Lean/Parser/Transform.c ./Lean/PrettyPrinter.c ./Lean/PrettyPrinter/Parenthesizer.c ./Lean/ProjFns.c ./Lean/ReducibilityAttrs.c ./Lean/Runtime.c ./Lean/Scopes.c ./Lean/Structure.c ./Lean/Syntax.c ./Lean/ToExpr.c ./Lean/Util.c ./Lean/Util/Closure.c ./Lean/Util/CollectFVars.c ./Lean/Util/CollectLevelParams.c ./Lean/Util/CollectMVars.c ./Lean/Util/FindExpr.c ./Lean/Util/FindMVar.c ./Lean/Util/FoldConsts.c ./Lean/Util/MonadCache.c ./Lean/Util/PPExt.c ./Lean/Util/PPGoal.c ./Lean/Util/Path.c ./Lean/Util/Profile.c ./Lean/Util/RecDepth.c ./Lean/Util/Recognizers.c ./Lean/Util/ReplaceExpr.c ./Lean/Util/Sorry.c ./Lean/Util/Trace.c ./Lean/Util/WHNF.c ./Std.c ./Std/Data.c ./Std/Data/AssocList.c ./Std/Data/BinomialHeap.c ./Std/Data/DList.c ./Std/Data/HashMap.c ./Std/Data/HashSet.c ./Std/Data/PersistentArray.c ./Std/Data/PersistentHashMap.c ./Std/Data/PersistentHashSet.c ./Std/Data/Queue.c ./Std/Data/RBMap.c ./Std/Data/RBTree.c ./Std/Data/Stack.c ./Std/ShareCommon.c ) +add_library (stage0 OBJECT ./Init.c ./Init/Coe.c ./Init/Control.c ./Init/Control/Alternative.c ./Init/Control/Applicative.c ./Init/Control/Conditional.c ./Init/Control/EState.c ./Init/Control/Except.c ./Init/Control/Functor.c ./Init/Control/Id.c ./Init/Control/Lift.c ./Init/Control/Monad.c ./Init/Control/Option.c ./Init/Control/Reader.c ./Init/Control/State.c ./Init/Core.c ./Init/Data.c ./Init/Data/Array.c ./Init/Data/Array/Basic.c ./Init/Data/Array/BinSearch.c ./Init/Data/Array/QSort.c ./Init/Data/Basic.c ./Init/Data/ByteArray.c ./Init/Data/ByteArray/Basic.c ./Init/Data/Char.c ./Init/Data/Char/Basic.c ./Init/Data/Fin.c ./Init/Data/Fin/Basic.c ./Init/Data/Float.c ./Init/Data/FloatArray.c ./Init/Data/FloatArray/Basic.c ./Init/Data/Hashable.c ./Init/Data/Int.c ./Init/Data/Int/Basic.c ./Init/Data/List.c ./Init/Data/List/Basic.c ./Init/Data/List/BasicAux.c ./Init/Data/List/Control.c ./Init/Data/List/Instances.c ./Init/Data/Nat.c ./Init/Data/Nat/Basic.c ./Init/Data/Nat/Bitwise.c ./Init/Data/Nat/Control.c ./Init/Data/Nat/Div.c ./Init/Data/Option.c ./Init/Data/Option/Basic.c ./Init/Data/Option/BasicAux.c ./Init/Data/Option/Instances.c ./Init/Data/Random.c ./Init/Data/Repr.c ./Init/Data/String.c ./Init/Data/String/Basic.c ./Init/Data/String/Extra.c ./Init/Data/ToString.c ./Init/Data/UInt.c ./Init/Fix.c ./Init/HasCoe.c ./Init/LeanInit.c ./Init/System.c ./Init/System/FilePath.c ./Init/System/IO.c ./Init/System/IOError.c ./Init/System/Platform.c ./Init/Util.c ./Init/WF.c ./Lean.c ./Lean/Attributes.c ./Lean/AuxRecursor.c ./Lean/Class.c ./Lean/Compiler.c ./Lean/Compiler/ClosedTermCache.c ./Lean/Compiler/ConstFolding.c ./Lean/Compiler/ExportAttr.c ./Lean/Compiler/ExternAttr.c ./Lean/Compiler/IR.c ./Lean/Compiler/IR/Basic.c ./Lean/Compiler/IR/Borrow.c ./Lean/Compiler/IR/Boxing.c ./Lean/Compiler/IR/Checker.c ./Lean/Compiler/IR/CompilerM.c ./Lean/Compiler/IR/CtorLayout.c ./Lean/Compiler/IR/ElimDeadBranches.c ./Lean/Compiler/IR/ElimDeadVars.c ./Lean/Compiler/IR/EmitC.c ./Lean/Compiler/IR/EmitUtil.c ./Lean/Compiler/IR/ExpandResetReuse.c ./Lean/Compiler/IR/Format.c ./Lean/Compiler/IR/FreeVars.c ./Lean/Compiler/IR/LiveVars.c ./Lean/Compiler/IR/NormIds.c ./Lean/Compiler/IR/PushProj.c ./Lean/Compiler/IR/RC.c ./Lean/Compiler/IR/ResetReuse.c ./Lean/Compiler/IR/SimpCase.c ./Lean/Compiler/IR/UnboxResult.c ./Lean/Compiler/ImplementedByAttr.c ./Lean/Compiler/InitAttr.c ./Lean/Compiler/InlineAttrs.c ./Lean/Compiler/NameMangling.c ./Lean/Compiler/NeverExtractAttr.c ./Lean/Compiler/Specialize.c ./Lean/Compiler/Util.c ./Lean/Data/Format.c ./Lean/Data/Json.c ./Lean/Data/Json/Basic.c ./Lean/Data/Json/FromToJson.c ./Lean/Data/Json/Parser.c ./Lean/Data/Json/Printer.c ./Lean/Data/KVMap.c ./Lean/Data/LBool.c ./Lean/Data/LOption.c ./Lean/Data/Name.c ./Lean/Data/Occurrences.c ./Lean/Data/Options.c ./Lean/Data/Position.c ./Lean/Data/SMap.c ./Lean/Data/Trie.c ./Lean/Declaration.c ./Lean/Delaborator.c ./Lean/Elab.c ./Lean/Elab/Alias.c ./Lean/Elab/App.c ./Lean/Elab/Binders.c ./Lean/Elab/BuiltinNotation.c ./Lean/Elab/CollectFVars.c ./Lean/Elab/Command.c ./Lean/Elab/DeclModifiers.c ./Lean/Elab/Declaration.c ./Lean/Elab/Definition.c ./Lean/Elab/DoNotation.c ./Lean/Elab/Exception.c ./Lean/Elab/Frontend.c ./Lean/Elab/Import.c ./Lean/Elab/Inductive.c ./Lean/Elab/Level.c ./Lean/Elab/Log.c ./Lean/Elab/Match.c ./Lean/Elab/Quotation.c ./Lean/Elab/ResolveName.c ./Lean/Elab/StrategyAttrs.c ./Lean/Elab/StructInst.c ./Lean/Elab/Syntax.c ./Lean/Elab/SyntheticMVars.c ./Lean/Elab/Tactic.c ./Lean/Elab/Tactic/Basic.c ./Lean/Elab/Tactic/ElabTerm.c ./Lean/Elab/Tactic/Generalize.c ./Lean/Elab/Tactic/Induction.c ./Lean/Elab/Tactic/Injection.c ./Lean/Elab/Term.c ./Lean/Elab/Util.c ./Lean/Environment.c ./Lean/EqnCompiler.c ./Lean/EqnCompiler/MatchPattern.c ./Lean/Eval.c ./Lean/Expr.c ./Lean/HeadIndex.c ./Lean/Hygiene.c ./Lean/KeyedDeclsAttribute.c ./Lean/Level.c ./Lean/Linter.c ./Lean/LocalContext.c ./Lean/Message.c ./Lean/Meta.c ./Lean/Meta/AbstractMVars.c ./Lean/Meta/AppBuilder.c ./Lean/Meta/Basic.c ./Lean/Meta/Check.c ./Lean/Meta/DiscrTree.c ./Lean/Meta/DiscrTreeTypes.c ./Lean/Meta/Exception.c ./Lean/Meta/ExprDefEq.c ./Lean/Meta/FunInfo.c ./Lean/Meta/GeneralizeTelescope.c ./Lean/Meta/InferType.c ./Lean/Meta/Instances.c ./Lean/Meta/KAbstract.c ./Lean/Meta/LevelDefEq.c ./Lean/Meta/Message.c ./Lean/Meta/Offset.c ./Lean/Meta/RecursorInfo.c ./Lean/Meta/Reduce.c ./Lean/Meta/SynthInstance.c ./Lean/Meta/Tactic.c ./Lean/Meta/Tactic/Apply.c ./Lean/Meta/Tactic/Assert.c ./Lean/Meta/Tactic/Assumption.c ./Lean/Meta/Tactic/Cases.c ./Lean/Meta/Tactic/Clear.c ./Lean/Meta/Tactic/FVarSubst.c ./Lean/Meta/Tactic/Generalize.c ./Lean/Meta/Tactic/Induction.c ./Lean/Meta/Tactic/Injection.c ./Lean/Meta/Tactic/Intro.c ./Lean/Meta/Tactic/LocalDecl.c ./Lean/Meta/Tactic/Revert.c ./Lean/Meta/Tactic/Rewrite.c ./Lean/Meta/Tactic/Subst.c ./Lean/Meta/Tactic/Target.c ./Lean/Meta/Tactic/Util.c ./Lean/Meta/WHNF.c ./Lean/MetavarContext.c ./Lean/Modifiers.c ./Lean/Parser.c ./Lean/Parser/Command.c ./Lean/Parser/Level.c ./Lean/Parser/Module.c ./Lean/Parser/Parser.c ./Lean/Parser/Syntax.c ./Lean/Parser/Tactic.c ./Lean/Parser/Term.c ./Lean/Parser/Transform.c ./Lean/PrettyPrinter.c ./Lean/PrettyPrinter/Parenthesizer.c ./Lean/ProjFns.c ./Lean/ReducibilityAttrs.c ./Lean/Runtime.c ./Lean/Scopes.c ./Lean/Structure.c ./Lean/Syntax.c ./Lean/ToExpr.c ./Lean/Util.c ./Lean/Util/Closure.c ./Lean/Util/CollectFVars.c ./Lean/Util/CollectLevelParams.c ./Lean/Util/CollectMVars.c ./Lean/Util/Constructions.c ./Lean/Util/FindExpr.c ./Lean/Util/FindMVar.c ./Lean/Util/FoldConsts.c ./Lean/Util/MonadCache.c ./Lean/Util/PPExt.c ./Lean/Util/PPGoal.c ./Lean/Util/Path.c ./Lean/Util/Profile.c ./Lean/Util/RecDepth.c ./Lean/Util/Recognizers.c ./Lean/Util/ReplaceExpr.c ./Lean/Util/ReplaceLevel.c ./Lean/Util/Sorry.c ./Lean/Util/Trace.c ./Lean/Util/WHNF.c ./Std.c ./Std/Data.c ./Std/Data/AssocList.c ./Std/Data/BinomialHeap.c ./Std/Data/DList.c ./Std/Data/HashMap.c ./Std/Data/HashSet.c ./Std/Data/PersistentArray.c ./Std/Data/PersistentHashMap.c ./Std/Data/PersistentHashSet.c ./Std/Data/Queue.c ./Std/Data/RBMap.c ./Std/Data/RBTree.c ./Std/Data/Stack.c ./Std/ShareCommon.c ) diff --git a/stage0/stdlib/Init/Control/Except.c b/stage0/stdlib/Init/Control/Except.c index dbcaa8cf80..300377b655 100644 --- a/stage0/stdlib/Init/Control/Except.c +++ b/stage0/stdlib/Init/Control/Except.c @@ -75,7 +75,7 @@ lean_object* l_ExceptT_Monad___rarg___lambda__7(lean_object*, lean_object*, lean lean_object* l_monadExceptAdapterTrans___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Except_Monad___closed__7; lean_object* l_ExceptT_lift(lean_object*, lean_object*); -lean_object* l_finally___rarg___lambda__1(lean_object*, lean_object*, lean_object*); +lean_object* l_finally___rarg___lambda__1(lean_object*, lean_object*); lean_object* l_ExceptT_pure___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Except_MonadExcept___lambda__1(lean_object*, lean_object*); lean_object* l_ExceptT_Monad___rarg___lambda__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -2123,61 +2123,84 @@ x_4 = lean_alloc_closure((void*)(l_ExceptT_MonadRun___rarg), 3, 0); return x_4; } } -lean_object* l_finally___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_finally___rarg___lambda__1(lean_object* x_1, lean_object* x_2) { _start: { -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_4 = lean_ctor_get(x_1, 0); -lean_inc(x_4); +lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_3 = lean_ctor_get(x_1, 1); +lean_inc(x_3); lean_dec(x_1); -x_5 = lean_ctor_get(x_4, 4); -lean_inc(x_5); -x_6 = lean_ctor_get(x_4, 1); -lean_inc(x_6); -lean_dec(x_4); -x_7 = lean_apply_2(x_6, lean_box(0), x_3); -x_8 = lean_apply_3(x_5, lean_box(0), x_2, x_7); -return x_8; +x_4 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_4, 0, x_2); +x_5 = lean_apply_2(x_3, lean_box(0), x_4); +return x_5; } } lean_object* l_finally___rarg___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { +if (lean_obj_tag(x_4) == 0) +{ lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_5 = lean_ctor_get(x_1, 0); +x_5 = lean_ctor_get(x_4, 0); lean_inc(x_5); -lean_dec(x_1); -x_6 = lean_ctor_get(x_5, 4); +lean_dec(x_4); +x_6 = lean_ctor_get(x_1, 4); lean_inc(x_6); -lean_dec(x_5); +lean_dec(x_1); x_7 = lean_ctor_get(x_2, 0); lean_inc(x_7); lean_dec(x_2); -x_8 = lean_apply_2(x_7, lean_box(0), x_4); +x_8 = lean_apply_2(x_7, lean_box(0), x_5); x_9 = lean_apply_3(x_6, lean_box(0), x_3, x_8); 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_dec(x_2); +x_10 = lean_ctor_get(x_4, 0); +lean_inc(x_10); +lean_dec(x_4); +x_11 = lean_ctor_get(x_1, 4); +lean_inc(x_11); +x_12 = lean_ctor_get(x_1, 1); +lean_inc(x_12); +lean_dec(x_1); +x_13 = lean_apply_2(x_12, lean_box(0), x_10); +x_14 = lean_apply_3(x_11, lean_box(0), x_3, x_13); +return x_14; +} +} } lean_object* l_finally___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_5 = lean_ctor_get(x_2, 1); +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_1, 1); lean_inc(x_5); -x_6 = lean_ctor_get(x_1, 1); +x_6 = lean_ctor_get(x_2, 1); lean_inc(x_6); -lean_inc(x_4); -lean_inc(x_1); -x_7 = lean_alloc_closure((void*)(l_finally___rarg___lambda__1), 3, 2); -lean_closure_set(x_7, 0, x_1); -lean_closure_set(x_7, 1, x_4); -x_8 = lean_apply_4(x_6, lean_box(0), lean_box(0), x_3, x_7); -x_9 = lean_alloc_closure((void*)(l_finally___rarg___lambda__2), 4, 3); -lean_closure_set(x_9, 0, x_1); -lean_closure_set(x_9, 1, x_2); -lean_closure_set(x_9, 2, x_4); -x_10 = lean_apply_3(x_5, lean_box(0), x_8, x_9); -return x_10; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +lean_dec(x_8); +x_10 = l_ExceptT_lift___rarg___closed__1; +x_11 = lean_apply_4(x_9, lean_box(0), lean_box(0), x_10, x_3); +lean_inc(x_7); +x_12 = lean_alloc_closure((void*)(l_finally___rarg___lambda__1), 2, 1); +lean_closure_set(x_12, 0, x_7); +x_13 = lean_apply_3(x_6, lean_box(0), x_11, x_12); +x_14 = lean_alloc_closure((void*)(l_finally___rarg___lambda__2), 4, 3); +lean_closure_set(x_14, 0, x_7); +lean_closure_set(x_14, 1, x_2); +lean_closure_set(x_14, 2, x_4); +x_15 = lean_apply_4(x_5, lean_box(0), lean_box(0), x_13, x_14); +return x_15; } } lean_object* l_finally(lean_object* x_1, lean_object* x_2, lean_object* x_3) { diff --git a/stage0/stdlib/Lean/Compiler/IR/Boxing.c b/stage0/stdlib/Lean/Compiler/IR/Boxing.c index 465cbafa7d..56e22ee3d7 100644 --- a/stage0/stdlib/Lean/Compiler/IR/Boxing.c +++ b/stage0/stdlib/Lean/Compiler/IR/Boxing.c @@ -94,6 +94,7 @@ lean_object* l_Lean_IR_explicitBoxing(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_IR_ExplicitBoxing_getJPParams___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_IR_ExplicitBoxing_withParams___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_IR_ExplicitBoxing_getScrutineeType___boxed(lean_object*); +extern lean_object* l_Lean_importModules___closed__1; lean_object* l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_visitVDeclExpr___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_addBoxedVersions___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -136,7 +137,6 @@ lean_object* l_Lean_IR_ExplicitBoxing_getDecl(lean_object*, lean_object*, lean_o lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_IR_Decl_Inhabited___closed__1; lean_object* l_Lean_IR_ExplicitBoxing_castVarIfNeeded(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; lean_object* l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_addBoxedVersions___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_IR_ExplicitBoxing_mkCast___closed__3; lean_object* l_Lean_IR_Decl_params(lean_object*); @@ -613,17 +613,6 @@ return x_73; } } } -lean_object* _init_l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Array_empty___closed__1; -x_2 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_2, 0, x_1); -lean_ctor_set(x_2, 1, x_1); -return x_2; -} -} lean_object* l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux(lean_object* x_1, lean_object* x_2) { _start: { @@ -643,7 +632,7 @@ x_10 = lean_ctor_get(x_8, 1); lean_inc(x_10); lean_dec(x_8); x_11 = lean_array_get_size(x_9); -x_12 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_12 = l_Lean_importModules___closed__1; lean_inc(x_11); x_13 = l_Nat_foldMAux___main___at_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___spec__2(x_3, x_9, x_11, x_11, x_12, x_10); lean_dec(x_11); @@ -2993,7 +2982,7 @@ x_5 = lean_alloc_closure((void*)(l_Lean_IR_ExplicitBoxing_castArgsIfNeededAux___ lean_closure_set(x_5, 0, x_2); x_6 = l_Lean_IR_ExplicitBoxing_castArgsIfNeededAux___closed__2; x_7 = lean_unsigned_to_nat(0u); -x_8 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_8 = l_Lean_importModules___closed__1; x_9 = l_Array_iterateMAux___main___rarg(x_6, lean_box(0), x_1, x_5, x_7, x_8); x_10 = lean_apply_2(x_9, x_3, x_4); return x_10; @@ -3307,7 +3296,7 @@ _start: { lean_object* x_5; lean_object* x_6; lean_object* x_7; x_5 = lean_unsigned_to_nat(0u); -x_6 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_6 = l_Lean_importModules___closed__1; x_7 = l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_castArgsIfNeeded___spec__2(x_1, x_2, x_2, x_5, x_6, x_3, x_4); return x_7; } @@ -3676,7 +3665,7 @@ _start: { lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = lean_unsigned_to_nat(0u); -x_5 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_5 = l_Lean_importModules___closed__1; x_6 = l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_boxArgsIfNeeded___spec__2(x_1, x_1, x_4, x_5, x_2, x_3); return x_6; } @@ -4219,7 +4208,7 @@ _start: { lean_object* x_5; lean_object* x_6; lean_object* x_7; x_5 = lean_unsigned_to_nat(0u); -x_6 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_6 = l_Lean_importModules___closed__1; x_7 = l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_visitVDeclExpr___spec__2(x_1, x_2, x_2, x_5, x_6, x_3, x_4); return x_7; } @@ -5500,7 +5489,7 @@ _start: { lean_object* x_5; lean_object* x_6; lean_object* x_7; x_5 = lean_unsigned_to_nat(0u); -x_6 = l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1; +x_6 = l_Lean_importModules___closed__1; x_7 = l_Array_iterateMAux___main___at_Lean_IR_ExplicitBoxing_visitFnBody___main___spec__3(x_1, x_2, x_2, x_5, x_6, x_3, x_4); return x_7; } @@ -7419,8 +7408,6 @@ if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l_Lean_IR_ExplicitBoxing_mkBoxedName___closed__1 = _init_l_Lean_IR_ExplicitBoxing_mkBoxedName___closed__1(); lean_mark_persistent(l_Lean_IR_ExplicitBoxing_mkBoxedName___closed__1); -l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1 = _init_l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1(); -lean_mark_persistent(l_Lean_IR_ExplicitBoxing_mkBoxedVersionAux___closed__1); l_Lean_IR_ExplicitBoxing_mkCast___closed__1 = _init_l_Lean_IR_ExplicitBoxing_mkCast___closed__1(); lean_mark_persistent(l_Lean_IR_ExplicitBoxing_mkCast___closed__1); l_Lean_IR_ExplicitBoxing_mkCast___closed__2 = _init_l_Lean_IR_ExplicitBoxing_mkCast___closed__2(); diff --git a/stage0/stdlib/Lean/Elab/App.c b/stage0/stdlib/Lean/Elab/App.c index 70c9947d50..301b9f12ad 100644 --- a/stage0/stdlib/Lean/Elab/App.c +++ b/stage0/stdlib/Lean/Elab/App.c @@ -96,7 +96,6 @@ lean_object* l_Lean_Expr_getOptParamDefault_x3f(lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); lean_object* l___private_Lean_Elab_App_23__toMessageData___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_App_13__resolveLValAux___closed__27; -lean_object* l___private_Lean_Elab_App_26__expandApp___closed__1; lean_object* l___private_Lean_Elab_App_26__expandApp___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_App_3__mkArrow___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isTypeFormer(lean_object*, lean_object*, lean_object*, lean_object*); @@ -244,6 +243,7 @@ lean_object* l_Lean_Elab_Term_elabChoice(lean_object*, lean_object*, lean_object lean_object* l___private_Lean_Elab_App_2__elabArg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_App_4__tryCoeFun___closed__1; extern lean_object* l___private_Lean_Elab_Util_4__regTraceClasses___closed__1; +extern lean_object* l_Lean_importModules___closed__1; extern lean_object* l_Lean_formatEntry___closed__1; lean_object* l___private_Lean_Elab_App_15__resolveLVal(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*); @@ -17556,17 +17556,6 @@ return x_61; } } } -lean_object* _init_l___private_Lean_Elab_App_26__expandApp___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Array_empty___closed__1; -x_2 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_2, 0, x_1); -lean_ctor_set(x_2, 1, x_1); -return x_2; -} -} lean_object* l___private_Lean_Elab_App_26__expandApp(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -17577,7 +17566,7 @@ x_6 = lean_unsigned_to_nat(1u); x_7 = l_Lean_Syntax_getArg(x_1, x_6); x_8 = l_Lean_Syntax_getArgs(x_7); lean_dec(x_7); -x_9 = l___private_Lean_Elab_App_26__expandApp___closed__1; +x_9 = l_Lean_importModules___closed__1; x_10 = l_Array_iterateMAux___main___at___private_Lean_Elab_App_26__expandApp___spec__1(x_1, x_8, x_4, x_9, x_2, x_3); lean_dec(x_8); if (lean_obj_tag(x_10) == 0) @@ -18349,8 +18338,6 @@ l___private_Lean_Elab_App_25__elabAppAux___closed__2 = _init_l___private_Lean_El lean_mark_persistent(l___private_Lean_Elab_App_25__elabAppAux___closed__2); l___private_Lean_Elab_App_25__elabAppAux___closed__3 = _init_l___private_Lean_Elab_App_25__elabAppAux___closed__3(); lean_mark_persistent(l___private_Lean_Elab_App_25__elabAppAux___closed__3); -l___private_Lean_Elab_App_26__expandApp___closed__1 = _init_l___private_Lean_Elab_App_26__expandApp___closed__1(); -lean_mark_persistent(l___private_Lean_Elab_App_26__expandApp___closed__1); l___regBuiltin_Lean_Elab_Term_elabApp___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabApp___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabApp___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabApp(lean_io_mk_world()); diff --git a/stage0/stdlib/Lean/Elab/Binders.c b/stage0/stdlib/Lean/Elab/Binders.c index 6017ec8153..7fab4e48d6 100644 --- a/stage0/stdlib/Lean/Elab/Binders.c +++ b/stage0/stdlib/Lean/Elab/Binders.c @@ -4374,86 +4374,95 @@ lean_inc(x_10); x_14 = l___private_Lean_Elab_Binders_8__elabBindersAux___main(x_1, x_12, x_13, x_7, x_10, x_3, x_11); if (lean_obj_tag(x_14) == 0) { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; +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; uint8_t x_24; x_15 = lean_ctor_get(x_14, 0); lean_inc(x_15); x_16 = lean_ctor_get(x_15, 1); lean_inc(x_16); x_17 = lean_ctor_get(x_14, 1); lean_inc(x_17); -lean_dec(x_14); -x_18 = lean_ctor_get(x_15, 0); -lean_inc(x_18); -lean_dec(x_15); -x_19 = lean_ctor_get(x_16, 0); +if (lean_is_exclusive(x_14)) { + lean_ctor_release(x_14, 0); + lean_ctor_release(x_14, 1); + x_18 = x_14; +} else { + lean_dec_ref(x_14); + x_18 = lean_box(0); +} +x_19 = lean_ctor_get(x_15, 0); lean_inc(x_19); -x_20 = lean_ctor_get(x_16, 1); +lean_dec(x_15); +x_20 = lean_ctor_get(x_16, 0); lean_inc(x_20); +x_21 = lean_ctor_get(x_16, 1); +lean_inc(x_21); lean_dec(x_16); -x_21 = lean_array_get_size(x_10); +x_22 = lean_array_get_size(x_10); lean_dec(x_10); -x_22 = lean_array_get_size(x_20); -x_23 = lean_nat_dec_lt(x_21, x_22); +x_23 = lean_array_get_size(x_21); +x_24 = lean_nat_dec_lt(x_22, x_23); +lean_dec(x_23); lean_dec(x_22); -lean_dec(x_21); -if (x_23 == 0) -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_3); if (x_24 == 0) { -lean_object* x_25; uint8_t x_26; -x_25 = lean_ctor_get(x_3, 0); -x_26 = !lean_is_exclusive(x_25); -if (x_26 == 0) +uint8_t x_25; +lean_dec(x_18); +x_25 = !lean_is_exclusive(x_3); +if (x_25 == 0) { -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_25, 2); -lean_dec(x_27); -x_28 = lean_ctor_get(x_25, 1); +lean_object* x_26; uint8_t x_27; +x_26 = lean_ctor_get(x_3, 0); +x_27 = !lean_is_exclusive(x_26); +if (x_27 == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_26, 2); lean_dec(x_28); -lean_ctor_set(x_25, 2, x_20); -lean_ctor_set(x_25, 1, x_19); -x_29 = lean_apply_3(x_2, x_18, x_3, x_17); -return x_29; +x_29 = lean_ctor_get(x_26, 1); +lean_dec(x_29); +lean_ctor_set(x_26, 2, x_21); +lean_ctor_set(x_26, 1, x_20); +x_30 = lean_apply_3(x_2, x_19, x_3, x_17); +return x_30; } else { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_30 = lean_ctor_get(x_25, 0); -x_31 = lean_ctor_get(x_25, 3); -x_32 = lean_ctor_get(x_25, 4); +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_31 = lean_ctor_get(x_26, 0); +x_32 = lean_ctor_get(x_26, 3); +x_33 = lean_ctor_get(x_26, 4); +lean_inc(x_33); lean_inc(x_32); lean_inc(x_31); -lean_inc(x_30); -lean_dec(x_25); -x_33 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_33, 0, x_30); -lean_ctor_set(x_33, 1, x_19); -lean_ctor_set(x_33, 2, x_20); -lean_ctor_set(x_33, 3, x_31); -lean_ctor_set(x_33, 4, x_32); -lean_ctor_set(x_3, 0, x_33); -x_34 = lean_apply_3(x_2, x_18, x_3, x_17); -return x_34; +lean_dec(x_26); +x_34 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_34, 0, x_31); +lean_ctor_set(x_34, 1, x_20); +lean_ctor_set(x_34, 2, x_21); +lean_ctor_set(x_34, 3, x_32); +lean_ctor_set(x_34, 4, x_33); +lean_ctor_set(x_3, 0, x_34); +x_35 = lean_apply_3(x_2, x_19, x_3, x_17); +return x_35; } } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; uint8_t x_45; uint8_t x_46; uint8_t 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_35 = lean_ctor_get(x_3, 0); -x_36 = lean_ctor_get(x_3, 1); -x_37 = lean_ctor_get(x_3, 2); -x_38 = lean_ctor_get(x_3, 3); -x_39 = lean_ctor_get(x_3, 4); -x_40 = lean_ctor_get(x_3, 5); -x_41 = lean_ctor_get(x_3, 6); -x_42 = lean_ctor_get(x_3, 7); -x_43 = lean_ctor_get(x_3, 8); -x_44 = lean_ctor_get(x_3, 9); -x_45 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_46 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_47 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; uint8_t 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_36 = lean_ctor_get(x_3, 0); +x_37 = lean_ctor_get(x_3, 1); +x_38 = lean_ctor_get(x_3, 2); +x_39 = lean_ctor_get(x_3, 3); +x_40 = lean_ctor_get(x_3, 4); +x_41 = lean_ctor_get(x_3, 5); +x_42 = lean_ctor_get(x_3, 6); +x_43 = lean_ctor_get(x_3, 7); +x_44 = lean_ctor_get(x_3, 8); +x_45 = lean_ctor_get(x_3, 9); +x_46 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); +x_47 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); +x_48 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); @@ -4463,1268 +4472,720 @@ lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); -lean_inc(x_35); lean_dec(x_3); -x_48 = lean_ctor_get(x_35, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_35, 3); +x_49 = lean_ctor_get(x_36, 0); lean_inc(x_49); -x_50 = lean_ctor_get(x_35, 4); +x_50 = lean_ctor_get(x_36, 3); lean_inc(x_50); -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); - lean_ctor_release(x_35, 4); - x_51 = x_35; +x_51 = lean_ctor_get(x_36, 4); +lean_inc(x_51); +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_52 = x_36; } else { - lean_dec_ref(x_35); - x_51 = lean_box(0); + lean_dec_ref(x_36); + x_52 = lean_box(0); } -if (lean_is_scalar(x_51)) { - x_52 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(0, 5, 0); } else { - x_52 = x_51; + x_53 = x_52; } -lean_ctor_set(x_52, 0, x_48); -lean_ctor_set(x_52, 1, x_19); -lean_ctor_set(x_52, 2, x_20); -lean_ctor_set(x_52, 3, x_49); -lean_ctor_set(x_52, 4, x_50); -x_53 = lean_alloc_ctor(0, 10, 3); -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); -lean_ctor_set(x_53, 6, x_41); -lean_ctor_set(x_53, 7, x_42); -lean_ctor_set(x_53, 8, x_43); -lean_ctor_set(x_53, 9, x_44); -lean_ctor_set_uint8(x_53, sizeof(void*)*10, x_45); -lean_ctor_set_uint8(x_53, sizeof(void*)*10 + 1, x_46); -lean_ctor_set_uint8(x_53, sizeof(void*)*10 + 2, x_47); -x_54 = lean_apply_3(x_2, x_18, x_53, x_17); -return x_54; +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_20); +lean_ctor_set(x_53, 2, x_21); +lean_ctor_set(x_53, 3, x_50); +lean_ctor_set(x_53, 4, x_51); +x_54 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_37); +lean_ctor_set(x_54, 2, x_38); +lean_ctor_set(x_54, 3, x_39); +lean_ctor_set(x_54, 4, x_40); +lean_ctor_set(x_54, 5, x_41); +lean_ctor_set(x_54, 6, x_42); +lean_ctor_set(x_54, 7, x_43); +lean_ctor_set(x_54, 8, x_44); +lean_ctor_set(x_54, 9, x_45); +lean_ctor_set_uint8(x_54, sizeof(void*)*10, x_46); +lean_ctor_set_uint8(x_54, sizeof(void*)*10 + 1, x_47); +lean_ctor_set_uint8(x_54, sizeof(void*)*10 + 2, x_48); +x_55 = lean_apply_3(x_2, x_19, x_54, x_17); +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; uint8_t x_61; -x_55 = lean_ctor_get(x_17, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_55, 2); +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; +x_56 = lean_ctor_get(x_17, 0); lean_inc(x_56); -lean_dec(x_55); x_57 = lean_ctor_get(x_56, 2); lean_inc(x_57); lean_dec(x_56); -x_58 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_17); -x_59 = lean_ctor_get(x_3, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_58, 1); -lean_inc(x_60); -lean_dec(x_58); -x_61 = !lean_is_exclusive(x_3); -if (x_61 == 0) +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_62; uint8_t x_63; -x_62 = lean_ctor_get(x_3, 0); -lean_dec(x_62); -x_63 = !lean_is_exclusive(x_59); -if (x_63 == 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_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_59, 2); -lean_dec(x_64); -x_65 = lean_ctor_get(x_59, 1); -lean_dec(x_65); -lean_ctor_set(x_59, 2, x_20); -lean_ctor_set(x_59, 1, x_19); -x_66 = lean_apply_3(x_2, x_18, x_3, x_60); -if (lean_obj_tag(x_66) == 0) +lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_160 = lean_ctor_get(x_155, 2); +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) { -lean_object* x_67; lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_67 = lean_ctor_get(x_66, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_67, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_68, 2); -lean_inc(x_69); -x_70 = !lean_is_exclusive(x_66); -if (x_70 == 0) -{ -lean_object* x_71; uint8_t x_72; -x_71 = lean_ctor_get(x_66, 1); -lean_dec(x_71); -x_72 = !lean_is_exclusive(x_67); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_67, 0); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_68); -if (x_74 == 0) -{ -lean_object* x_75; uint8_t x_76; -x_75 = lean_ctor_get(x_68, 2); -lean_dec(x_75); -x_76 = !lean_is_exclusive(x_69); -if (x_76 == 0) -{ -lean_object* x_77; -x_77 = lean_ctor_get(x_69, 2); -lean_dec(x_77); -lean_ctor_set(x_69, 2, x_57); -return x_66; +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_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_78 = lean_ctor_get(x_69, 0); -x_79 = lean_ctor_get(x_69, 1); -x_80 = lean_ctor_get(x_69, 3); +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 +{ +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_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; +} +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_59 = x_179; +x_60 = x_178; +goto block_153; +} +} +} +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_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); +lean_inc(x_199); +x_200 = lean_ctor_get(x_198, 1); +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; +} +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; +} +} +block_153: +{ +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_61 = lean_ctor_get(x_60, 0); +lean_inc(x_61); +x_62 = lean_ctor_get(x_61, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_59, 0); +lean_inc(x_63); +lean_dec(x_59); +x_64 = !lean_is_exclusive(x_60); +if (x_64 == 0) +{ +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_60, 0); +lean_dec(x_65); +x_66 = !lean_is_exclusive(x_61); +if (x_66 == 0) +{ +lean_object* x_67; uint8_t x_68; +x_67 = lean_ctor_get(x_61, 2); +lean_dec(x_67); +x_68 = !lean_is_exclusive(x_62); +if (x_68 == 0) +{ +lean_object* x_69; lean_object* x_70; +x_69 = lean_ctor_get(x_62, 2); +lean_dec(x_69); +lean_ctor_set(x_62, 2, x_58); +if (lean_is_scalar(x_18)) { + x_70 = lean_alloc_ctor(1, 2, 0); +} else { + x_70 = x_18; + lean_ctor_set_tag(x_70, 1); +} +lean_ctor_set(x_70, 0, x_63); +lean_ctor_set(x_70, 1, x_60); +return x_70; +} +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_62, 0); +x_72 = lean_ctor_get(x_62, 1); +x_73 = lean_ctor_get(x_62, 3); +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); +if (lean_is_scalar(x_18)) { + x_75 = lean_alloc_ctor(1, 2, 0); +} else { + x_75 = x_18; + lean_ctor_set_tag(x_75, 1); +} +lean_ctor_set(x_75, 0, x_63); +lean_ctor_set(x_75, 1, x_60); +return x_75; +} +} +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_inc(x_80); lean_inc(x_79); lean_inc(x_78); -lean_dec(x_69); -x_81 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_81, 0, x_78); -lean_ctor_set(x_81, 1, x_79); -lean_ctor_set(x_81, 2, x_57); -lean_ctor_set(x_81, 3, x_80); -lean_ctor_set(x_68, 2, x_81); -return x_66; -} -} -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; -x_82 = lean_ctor_get(x_68, 0); -x_83 = lean_ctor_get(x_68, 1); -x_84 = lean_ctor_get(x_68, 3); -x_85 = lean_ctor_get(x_68, 4); -x_86 = lean_ctor_get(x_68, 5); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); +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); lean_inc(x_82); -lean_dec(x_68); -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); +x_83 = lean_ctor_get(x_62, 3); +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); + x_84 = x_62; +} else { + lean_dec_ref(x_62); + 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_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); +if (lean_is_scalar(x_18)) { + x_87 = lean_alloc_ctor(1, 2, 0); +} else { + x_87 = x_18; + lean_ctor_set_tag(x_87, 1); +} +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_60); +return x_87; +} +} +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_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); lean_inc(x_89); -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); - x_90 = x_69; -} else { - lean_dec_ref(x_69); - x_90 = lean_box(0); -} -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); -} else { - x_91 = x_90; -} -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_57); -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_67, 0, x_92); -return x_66; -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_93 = lean_ctor_get(x_67, 1); -x_94 = lean_ctor_get(x_67, 2); -x_95 = lean_ctor_get(x_67, 3); -x_96 = lean_ctor_get(x_67, 4); -x_97 = lean_ctor_get(x_67, 5); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); +lean_inc(x_88); +lean_dec(x_60); +x_93 = lean_ctor_get(x_61, 0); lean_inc(x_93); -lean_dec(x_67); -x_98 = lean_ctor_get(x_68, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_68, 1); +x_94 = lean_ctor_get(x_61, 1); +lean_inc(x_94); +x_95 = lean_ctor_get(x_61, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_61, 4); +lean_inc(x_96); +x_97 = lean_ctor_get(x_61, 5); +lean_inc(x_97); +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); + lean_ctor_release(x_61, 5); + x_98 = x_61; +} else { + lean_dec_ref(x_61); + x_98 = lean_box(0); +} +x_99 = lean_ctor_get(x_62, 0); lean_inc(x_99); -x_100 = lean_ctor_get(x_68, 3); +x_100 = lean_ctor_get(x_62, 1); lean_inc(x_100); -x_101 = lean_ctor_get(x_68, 4); +x_101 = lean_ctor_get(x_62, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_68, 5); -lean_inc(x_102); -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); - lean_ctor_release(x_68, 5); - x_103 = x_68; +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; } else { - lean_dec_ref(x_68); - x_103 = lean_box(0); + lean_dec_ref(x_62); + x_102 = lean_box(0); } -x_104 = lean_ctor_get(x_69, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_69, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_69, 3); -lean_inc(x_106); -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); - x_107 = x_69; +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_69); - x_107 = lean_box(0); + x_103 = x_102; } -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 4, 0); +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); } else { - x_108 = x_107; + x_104 = x_98; } -lean_ctor_set(x_108, 0, x_104); -lean_ctor_set(x_108, 1, x_105); -lean_ctor_set(x_108, 2, x_57); -lean_ctor_set(x_108, 3, x_106); -if (lean_is_scalar(x_103)) { - x_109 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_18)) { + x_106 = lean_alloc_ctor(1, 2, 0); } else { - x_109 = x_103; + x_106 = x_18; + lean_ctor_set_tag(x_106, 1); } -lean_ctor_set(x_109, 0, x_98); -lean_ctor_set(x_109, 1, x_99); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_100); -lean_ctor_set(x_109, 4, x_101); -lean_ctor_set(x_109, 5, x_102); -x_110 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_110, 0, x_109); -lean_ctor_set(x_110, 1, x_93); -lean_ctor_set(x_110, 2, x_94); -lean_ctor_set(x_110, 3, x_95); -lean_ctor_set(x_110, 4, x_96); -lean_ctor_set(x_110, 5, x_97); -lean_ctor_set(x_66, 1, x_110); -return x_66; +lean_ctor_set(x_106, 0, x_63); +lean_ctor_set(x_106, 1, x_105); +return x_106; } } else { -lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_111 = lean_ctor_get(x_66, 0); -lean_inc(x_111); -lean_dec(x_66); -x_112 = lean_ctor_get(x_67, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_67, 2); -lean_inc(x_113); -x_114 = lean_ctor_get(x_67, 3); -lean_inc(x_114); -x_115 = lean_ctor_get(x_67, 4); -lean_inc(x_115); -x_116 = lean_ctor_get(x_67, 5); -lean_inc(x_116); -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); - lean_ctor_release(x_67, 5); - x_117 = x_67; -} else { - lean_dec_ref(x_67); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_68, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_68, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_68, 3); -lean_inc(x_120); -x_121 = lean_ctor_get(x_68, 4); -lean_inc(x_121); -x_122 = lean_ctor_get(x_68, 5); -lean_inc(x_122); -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); - lean_ctor_release(x_68, 5); - x_123 = x_68; -} else { - lean_dec_ref(x_68); - x_123 = lean_box(0); -} -x_124 = lean_ctor_get(x_69, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_69, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_69, 3); -lean_inc(x_126); -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); - x_127 = x_69; -} else { - lean_dec_ref(x_69); - x_127 = lean_box(0); -} -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_57); -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); -if (lean_is_scalar(x_117)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_117; -} -lean_ctor_set(x_130, 0, x_129); -lean_ctor_set(x_130, 1, x_112); -lean_ctor_set(x_130, 2, x_113); -lean_ctor_set(x_130, 3, x_114); -lean_ctor_set(x_130, 4, x_115); -lean_ctor_set(x_130, 5, x_116); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_111); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; uint8_t x_135; -x_132 = lean_ctor_get(x_66, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_133, 2); -lean_inc(x_134); -x_135 = !lean_is_exclusive(x_66); -if (x_135 == 0) -{ -lean_object* x_136; uint8_t x_137; -x_136 = lean_ctor_get(x_66, 1); -lean_dec(x_136); -x_137 = !lean_is_exclusive(x_132); -if (x_137 == 0) -{ -lean_object* x_138; uint8_t x_139; -x_138 = lean_ctor_get(x_132, 0); -lean_dec(x_138); -x_139 = !lean_is_exclusive(x_133); -if (x_139 == 0) -{ -lean_object* x_140; uint8_t x_141; -x_140 = lean_ctor_get(x_133, 2); -lean_dec(x_140); -x_141 = !lean_is_exclusive(x_134); -if (x_141 == 0) -{ -lean_object* x_142; -x_142 = lean_ctor_get(x_134, 2); -lean_dec(x_142); -lean_ctor_set(x_134, 2, x_57); -return x_66; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_143 = lean_ctor_get(x_134, 0); -x_144 = lean_ctor_get(x_134, 1); -x_145 = lean_ctor_get(x_134, 3); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); -lean_dec(x_134); -x_146 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_146, 0, x_143); -lean_ctor_set(x_146, 1, x_144); -lean_ctor_set(x_146, 2, x_57); -lean_ctor_set(x_146, 3, x_145); -lean_ctor_set(x_133, 2, x_146); -return x_66; -} -} -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; -x_147 = lean_ctor_get(x_133, 0); -x_148 = lean_ctor_get(x_133, 1); -x_149 = lean_ctor_get(x_133, 3); -x_150 = lean_ctor_get(x_133, 4); -x_151 = lean_ctor_get(x_133, 5); -lean_inc(x_151); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_dec(x_133); -x_152 = lean_ctor_get(x_134, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_134, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_134, 3); -lean_inc(x_154); -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_155 = x_134; -} else { - lean_dec_ref(x_134); - x_155 = lean_box(0); -} -if (lean_is_scalar(x_155)) { - x_156 = lean_alloc_ctor(0, 4, 0); -} else { - x_156 = x_155; -} -lean_ctor_set(x_156, 0, x_152); -lean_ctor_set(x_156, 1, x_153); -lean_ctor_set(x_156, 2, x_57); -lean_ctor_set(x_156, 3, x_154); -x_157 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_157, 0, x_147); -lean_ctor_set(x_157, 1, x_148); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_149); -lean_ctor_set(x_157, 4, x_150); -lean_ctor_set(x_157, 5, x_151); -lean_ctor_set(x_132, 0, x_157); -return x_66; -} -} -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; lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_158 = lean_ctor_get(x_132, 1); -x_159 = lean_ctor_get(x_132, 2); -x_160 = lean_ctor_get(x_132, 3); -x_161 = lean_ctor_get(x_132, 4); -x_162 = lean_ctor_get(x_132, 5); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_132); -x_163 = lean_ctor_get(x_133, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_133, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_133, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_133, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_133, 5); -lean_inc(x_167); -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_168 = x_133; -} else { - lean_dec_ref(x_133); - x_168 = lean_box(0); -} -x_169 = lean_ctor_get(x_134, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_134, 1); -lean_inc(x_170); -x_171 = lean_ctor_get(x_134, 3); -lean_inc(x_171); -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_172 = x_134; -} else { - lean_dec_ref(x_134); - x_172 = lean_box(0); -} -if (lean_is_scalar(x_172)) { - x_173 = lean_alloc_ctor(0, 4, 0); -} else { - x_173 = x_172; -} -lean_ctor_set(x_173, 0, x_169); -lean_ctor_set(x_173, 1, x_170); -lean_ctor_set(x_173, 2, x_57); -lean_ctor_set(x_173, 3, x_171); -if (lean_is_scalar(x_168)) { - x_174 = lean_alloc_ctor(0, 6, 0); -} else { - x_174 = x_168; -} -lean_ctor_set(x_174, 0, x_163); -lean_ctor_set(x_174, 1, x_164); -lean_ctor_set(x_174, 2, x_173); -lean_ctor_set(x_174, 3, x_165); -lean_ctor_set(x_174, 4, x_166); -lean_ctor_set(x_174, 5, x_167); -x_175 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_175, 0, x_174); -lean_ctor_set(x_175, 1, x_158); -lean_ctor_set(x_175, 2, x_159); -lean_ctor_set(x_175, 3, x_160); -lean_ctor_set(x_175, 4, x_161); -lean_ctor_set(x_175, 5, x_162); -lean_ctor_set(x_66, 1, x_175); -return x_66; -} -} -else -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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; -x_176 = lean_ctor_get(x_66, 0); -lean_inc(x_176); -lean_dec(x_66); -x_177 = lean_ctor_get(x_132, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_132, 2); -lean_inc(x_178); -x_179 = lean_ctor_get(x_132, 3); -lean_inc(x_179); -x_180 = lean_ctor_get(x_132, 4); -lean_inc(x_180); -x_181 = lean_ctor_get(x_132, 5); -lean_inc(x_181); -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_182 = x_132; -} else { - lean_dec_ref(x_132); - x_182 = lean_box(0); -} -x_183 = lean_ctor_get(x_133, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_133, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_133, 3); -lean_inc(x_185); -x_186 = lean_ctor_get(x_133, 4); -lean_inc(x_186); -x_187 = lean_ctor_get(x_133, 5); -lean_inc(x_187); -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_188 = x_133; -} else { - lean_dec_ref(x_133); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_134, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_134, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_134, 3); -lean_inc(x_191); -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_192 = x_134; -} else { - lean_dec_ref(x_134); - 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_57); -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_182)) { - x_195 = lean_alloc_ctor(0, 6, 0); -} else { - x_195 = x_182; -} -lean_ctor_set(x_195, 0, x_194); -lean_ctor_set(x_195, 1, x_177); -lean_ctor_set(x_195, 2, x_178); -lean_ctor_set(x_195, 3, x_179); -lean_ctor_set(x_195, 4, x_180); -lean_ctor_set(x_195, 5, x_181); -x_196 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_196, 0, x_176); -lean_ctor_set(x_196, 1, x_195); -return x_196; -} -} -} -else -{ -lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -x_197 = lean_ctor_get(x_59, 0); -x_198 = lean_ctor_get(x_59, 3); -x_199 = lean_ctor_get(x_59, 4); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); +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_dec(x_59); -x_200 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_200, 0, x_197); -lean_ctor_set(x_200, 1, x_19); -lean_ctor_set(x_200, 2, x_20); -lean_ctor_set(x_200, 3, x_198); -lean_ctor_set(x_200, 4, x_199); -lean_ctor_set(x_3, 0, x_200); -x_201 = lean_apply_3(x_2, x_18, x_3, x_60); -if (lean_obj_tag(x_201) == 0) +x_110 = !lean_is_exclusive(x_60); +if (x_110 == 0) { -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; 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_202 = lean_ctor_get(x_201, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_202, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_203, 2); -lean_inc(x_204); -x_205 = lean_ctor_get(x_201, 0); -lean_inc(x_205); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - x_206 = x_201; +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_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_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); +if (lean_is_scalar(x_18)) { + x_116 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_201); - x_206 = lean_box(0); + x_116 = x_18; } -x_207 = lean_ctor_get(x_202, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_202, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_202, 3); -lean_inc(x_209); -x_210 = lean_ctor_get(x_202, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_202, 5); -lean_inc(x_211); -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); - lean_ctor_release(x_202, 4); - lean_ctor_release(x_202, 5); - x_212 = x_202; -} else { - lean_dec_ref(x_202); - x_212 = lean_box(0); -} -x_213 = lean_ctor_get(x_203, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_203, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_203, 3); -lean_inc(x_215); -x_216 = lean_ctor_get(x_203, 4); -lean_inc(x_216); -x_217 = lean_ctor_get(x_203, 5); -lean_inc(x_217); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - lean_ctor_release(x_203, 3); - lean_ctor_release(x_203, 4); - lean_ctor_release(x_203, 5); - x_218 = x_203; -} else { - lean_dec_ref(x_203); - x_218 = lean_box(0); -} -x_219 = lean_ctor_get(x_204, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_204, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_204, 3); -lean_inc(x_221); -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_222 = x_204; -} else { - lean_dec_ref(x_204); - x_222 = lean_box(0); -} -if (lean_is_scalar(x_222)) { - x_223 = lean_alloc_ctor(0, 4, 0); -} else { - x_223 = x_222; -} -lean_ctor_set(x_223, 0, x_219); -lean_ctor_set(x_223, 1, x_220); -lean_ctor_set(x_223, 2, x_57); -lean_ctor_set(x_223, 3, x_221); -if (lean_is_scalar(x_218)) { - x_224 = lean_alloc_ctor(0, 6, 0); -} else { - x_224 = x_218; -} -lean_ctor_set(x_224, 0, x_213); -lean_ctor_set(x_224, 1, x_214); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_215); -lean_ctor_set(x_224, 4, x_216); -lean_ctor_set(x_224, 5, x_217); -if (lean_is_scalar(x_212)) { - x_225 = lean_alloc_ctor(0, 6, 0); -} else { - x_225 = x_212; -} -lean_ctor_set(x_225, 0, x_224); -lean_ctor_set(x_225, 1, x_207); -lean_ctor_set(x_225, 2, x_208); -lean_ctor_set(x_225, 3, x_209); -lean_ctor_set(x_225, 4, x_210); -lean_ctor_set(x_225, 5, x_211); -if (lean_is_scalar(x_206)) { - x_226 = lean_alloc_ctor(0, 2, 0); -} else { - x_226 = x_206; -} -lean_ctor_set(x_226, 0, x_205); -lean_ctor_set(x_226, 1, x_225); -return x_226; +lean_ctor_set(x_116, 0, x_109); +lean_ctor_set(x_116, 1, x_60); +return x_116; } else { -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; lean_object* x_250; lean_object* x_251; -x_227 = lean_ctor_get(x_201, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_227, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_201, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - x_231 = x_201; +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 { - lean_dec_ref(x_201); - x_231 = lean_box(0); -} -x_232 = lean_ctor_get(x_227, 1); -lean_inc(x_232); -x_233 = lean_ctor_get(x_227, 2); -lean_inc(x_233); -x_234 = lean_ctor_get(x_227, 3); -lean_inc(x_234); -x_235 = lean_ctor_get(x_227, 4); -lean_inc(x_235); -x_236 = lean_ctor_get(x_227, 5); -lean_inc(x_236); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - lean_ctor_release(x_227, 2); - lean_ctor_release(x_227, 3); - lean_ctor_release(x_227, 4); - lean_ctor_release(x_227, 5); - x_237 = x_227; -} else { - lean_dec_ref(x_227); - x_237 = lean_box(0); -} -x_238 = lean_ctor_get(x_228, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_228, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_228, 3); -lean_inc(x_240); -x_241 = lean_ctor_get(x_228, 4); -lean_inc(x_241); -x_242 = lean_ctor_get(x_228, 5); -lean_inc(x_242); -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_243 = x_228; -} else { - lean_dec_ref(x_228); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_229, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_229, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_229, 3); -lean_inc(x_246); -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); - x_247 = x_229; -} else { - lean_dec_ref(x_229); - x_247 = lean_box(0); -} -if (lean_is_scalar(x_247)) { - x_248 = lean_alloc_ctor(0, 4, 0); -} else { - x_248 = x_247; -} -lean_ctor_set(x_248, 0, x_244); -lean_ctor_set(x_248, 1, x_245); -lean_ctor_set(x_248, 2, x_57); -lean_ctor_set(x_248, 3, x_246); -if (lean_is_scalar(x_243)) { - x_249 = lean_alloc_ctor(0, 6, 0); -} else { - x_249 = x_243; -} -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); -} else { - x_250 = x_237; -} -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); -if (lean_is_scalar(x_231)) { - x_251 = lean_alloc_ctor(1, 2, 0); -} else { - x_251 = x_231; -} -lean_ctor_set(x_251, 0, x_230); -lean_ctor_set(x_251, 1, x_250); -return x_251; + 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_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; uint8_t x_261; uint8_t x_262; uint8_t 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_252 = lean_ctor_get(x_3, 1); -x_253 = lean_ctor_get(x_3, 2); -x_254 = lean_ctor_get(x_3, 3); -x_255 = lean_ctor_get(x_3, 4); -x_256 = lean_ctor_get(x_3, 5); -x_257 = lean_ctor_get(x_3, 6); -x_258 = lean_ctor_get(x_3, 7); -x_259 = lean_ctor_get(x_3, 8); -x_260 = lean_ctor_get(x_3, 9); -x_261 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_262 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_263 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -lean_inc(x_260); -lean_inc(x_259); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_inc(x_254); -lean_inc(x_253); -lean_inc(x_252); -lean_dec(x_3); -x_264 = lean_ctor_get(x_59, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_59, 3); -lean_inc(x_265); -x_266 = lean_ctor_get(x_59, 4); -lean_inc(x_266); -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_267 = x_59; +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_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_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_59); - x_267 = lean_box(0); + lean_dec_ref(x_108); + x_130 = lean_box(0); } -if (lean_is_scalar(x_267)) { - x_268 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_130)) { + x_131 = lean_alloc_ctor(0, 4, 0); } else { - x_268 = x_267; + x_131 = x_130; } -lean_ctor_set(x_268, 0, x_264); -lean_ctor_set(x_268, 1, x_19); -lean_ctor_set(x_268, 2, x_20); -lean_ctor_set(x_268, 3, x_265); -lean_ctor_set(x_268, 4, x_266); -x_269 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_269, 0, x_268); -lean_ctor_set(x_269, 1, x_252); -lean_ctor_set(x_269, 2, x_253); -lean_ctor_set(x_269, 3, x_254); -lean_ctor_set(x_269, 4, x_255); -lean_ctor_set(x_269, 5, x_256); -lean_ctor_set(x_269, 6, x_257); -lean_ctor_set(x_269, 7, x_258); -lean_ctor_set(x_269, 8, x_259); -lean_ctor_set(x_269, 9, x_260); -lean_ctor_set_uint8(x_269, sizeof(void*)*10, x_261); -lean_ctor_set_uint8(x_269, sizeof(void*)*10 + 1, x_262); -lean_ctor_set_uint8(x_269, sizeof(void*)*10 + 2, x_263); -x_270 = lean_apply_3(x_2, x_18, x_269, x_60); -if (lean_obj_tag(x_270) == 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; 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_271 = lean_ctor_get(x_270, 1); -lean_inc(x_271); -x_272 = lean_ctor_get(x_271, 0); -lean_inc(x_272); -x_273 = lean_ctor_get(x_272, 2); -lean_inc(x_273); -x_274 = lean_ctor_get(x_270, 0); -lean_inc(x_274); -if (lean_is_exclusive(x_270)) { - lean_ctor_release(x_270, 0); - lean_ctor_release(x_270, 1); - x_275 = x_270; +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 { - lean_dec_ref(x_270); - x_275 = lean_box(0); + x_133 = x_18; } -x_276 = lean_ctor_get(x_271, 1); -lean_inc(x_276); -x_277 = lean_ctor_get(x_271, 2); -lean_inc(x_277); -x_278 = lean_ctor_get(x_271, 3); -lean_inc(x_278); -x_279 = lean_ctor_get(x_271, 4); -lean_inc(x_279); -x_280 = lean_ctor_get(x_271, 5); -lean_inc(x_280); -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); - lean_ctor_release(x_271, 5); - x_281 = x_271; -} else { - lean_dec_ref(x_271); - x_281 = lean_box(0); +lean_ctor_set(x_133, 0, x_109); +lean_ctor_set(x_133, 1, x_60); +return x_133; } -x_282 = lean_ctor_get(x_272, 0); -lean_inc(x_282); -x_283 = lean_ctor_get(x_272, 1); -lean_inc(x_283); -x_284 = lean_ctor_get(x_272, 3); -lean_inc(x_284); -x_285 = lean_ctor_get(x_272, 4); -lean_inc(x_285); -x_286 = lean_ctor_get(x_272, 5); -lean_inc(x_286); -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); - lean_ctor_release(x_272, 4); - lean_ctor_release(x_272, 5); - x_287 = x_272; -} else { - lean_dec_ref(x_272); - x_287 = lean_box(0); -} -x_288 = lean_ctor_get(x_273, 0); -lean_inc(x_288); -x_289 = lean_ctor_get(x_273, 1); -lean_inc(x_289); -x_290 = lean_ctor_get(x_273, 3); -lean_inc(x_290); -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_291 = x_273; -} else { - lean_dec_ref(x_273); - x_291 = lean_box(0); -} -if (lean_is_scalar(x_291)) { - x_292 = lean_alloc_ctor(0, 4, 0); -} else { - x_292 = x_291; -} -lean_ctor_set(x_292, 0, x_288); -lean_ctor_set(x_292, 1, x_289); -lean_ctor_set(x_292, 2, x_57); -lean_ctor_set(x_292, 3, x_290); -if (lean_is_scalar(x_287)) { - x_293 = lean_alloc_ctor(0, 6, 0); -} else { - x_293 = x_287; -} -lean_ctor_set(x_293, 0, x_282); -lean_ctor_set(x_293, 1, x_283); -lean_ctor_set(x_293, 2, x_292); -lean_ctor_set(x_293, 3, x_284); -lean_ctor_set(x_293, 4, x_285); -lean_ctor_set(x_293, 5, x_286); -if (lean_is_scalar(x_281)) { - x_294 = lean_alloc_ctor(0, 6, 0); -} else { - x_294 = x_281; -} -lean_ctor_set(x_294, 0, x_293); -lean_ctor_set(x_294, 1, x_276); -lean_ctor_set(x_294, 2, x_277); -lean_ctor_set(x_294, 3, x_278); -lean_ctor_set(x_294, 4, x_279); -lean_ctor_set(x_294, 5, x_280); -if (lean_is_scalar(x_275)) { - x_295 = lean_alloc_ctor(0, 2, 0); -} else { - x_295 = x_275; -} -lean_ctor_set(x_295, 0, x_274); -lean_ctor_set(x_295, 1, x_294); -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; 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; lean_object* x_320; -x_296 = lean_ctor_get(x_270, 1); -lean_inc(x_296); -x_297 = lean_ctor_get(x_296, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_297, 2); -lean_inc(x_298); -x_299 = lean_ctor_get(x_270, 0); -lean_inc(x_299); -if (lean_is_exclusive(x_270)) { - lean_ctor_release(x_270, 0); - lean_ctor_release(x_270, 1); - x_300 = x_270; +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_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; } else { - lean_dec_ref(x_270); - x_300 = lean_box(0); + lean_dec_ref(x_107); + x_144 = lean_box(0); } -x_301 = lean_ctor_get(x_296, 1); -lean_inc(x_301); -x_302 = lean_ctor_get(x_296, 2); -lean_inc(x_302); -x_303 = lean_ctor_get(x_296, 3); -lean_inc(x_303); -x_304 = lean_ctor_get(x_296, 4); -lean_inc(x_304); -x_305 = lean_ctor_get(x_296, 5); -lean_inc(x_305); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - lean_ctor_release(x_296, 4); - lean_ctor_release(x_296, 5); - x_306 = x_296; +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; } else { - lean_dec_ref(x_296); - x_306 = lean_box(0); + lean_dec_ref(x_108); + x_148 = lean_box(0); } -x_307 = lean_ctor_get(x_297, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_297, 1); -lean_inc(x_308); -x_309 = lean_ctor_get(x_297, 3); -lean_inc(x_309); -x_310 = lean_ctor_get(x_297, 4); -lean_inc(x_310); -x_311 = lean_ctor_get(x_297, 5); -lean_inc(x_311); -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); - lean_ctor_release(x_297, 5); - x_312 = x_297; +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_297); - x_312 = lean_box(0); + x_149 = x_148; } -x_313 = lean_ctor_get(x_298, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_298, 1); -lean_inc(x_314); -x_315 = lean_ctor_get(x_298, 3); -lean_inc(x_315); -if (lean_is_exclusive(x_298)) { - lean_ctor_release(x_298, 0); - lean_ctor_release(x_298, 1); - lean_ctor_release(x_298, 2); - lean_ctor_release(x_298, 3); - x_316 = x_298; +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 { - lean_dec_ref(x_298); - x_316 = lean_box(0); + x_150 = x_144; } -if (lean_is_scalar(x_316)) { - x_317 = lean_alloc_ctor(0, 4, 0); +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); +if (lean_is_scalar(x_18)) { + x_152 = lean_alloc_ctor(0, 2, 0); } else { - x_317 = x_316; + x_152 = x_18; } -lean_ctor_set(x_317, 0, x_313); -lean_ctor_set(x_317, 1, x_314); -lean_ctor_set(x_317, 2, x_57); -lean_ctor_set(x_317, 3, x_315); -if (lean_is_scalar(x_312)) { - x_318 = lean_alloc_ctor(0, 6, 0); -} else { - x_318 = x_312; +lean_ctor_set(x_152, 0, x_109); +lean_ctor_set(x_152, 1, x_151); +return x_152; } -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_306)) { - x_319 = lean_alloc_ctor(0, 6, 0); -} else { - x_319 = x_306; -} -lean_ctor_set(x_319, 0, x_318); -lean_ctor_set(x_319, 1, x_301); -lean_ctor_set(x_319, 2, x_302); -lean_ctor_set(x_319, 3, x_303); -lean_ctor_set(x_319, 4, x_304); -lean_ctor_set(x_319, 5, x_305); -if (lean_is_scalar(x_300)) { - x_320 = lean_alloc_ctor(1, 2, 0); -} else { - x_320 = x_300; -} -lean_ctor_set(x_320, 0, x_299); -lean_ctor_set(x_320, 1, x_319); -return x_320; } } } } else { -uint8_t x_321; +uint8_t x_205; lean_dec(x_10); lean_dec(x_3); lean_dec(x_2); -x_321 = !lean_is_exclusive(x_14); -if (x_321 == 0) +x_205 = !lean_is_exclusive(x_14); +if (x_205 == 0) { return x_14; } else { -lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_322 = lean_ctor_get(x_14, 0); -x_323 = lean_ctor_get(x_14, 1); -lean_inc(x_323); -lean_inc(x_322); +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_dec(x_14); -x_324 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_324, 0, x_322); -lean_ctor_set(x_324, 1, x_323); -return x_324; +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; } } } else { -lean_object* x_325; lean_object* x_326; -x_325 = l_Array_empty___closed__1; -x_326 = lean_apply_3(x_2, x_325, x_3, x_4); -return x_326; +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; } } } @@ -21575,85 +21036,94 @@ lean_inc(x_4); x_16 = l_Lean_Elab_Term_FunBinders_elabFunBindersAux___main(x_1, x_15, x_14, x_4, x_12); if (lean_obj_tag(x_16) == 0) { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; uint8_t x_25; +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; uint8_t x_26; x_17 = lean_ctor_get(x_16, 0); lean_inc(x_17); x_18 = lean_ctor_get(x_16, 1); lean_inc(x_18); -lean_dec(x_16); -x_19 = lean_array_get_size(x_11); +if (lean_is_exclusive(x_16)) { + lean_ctor_release(x_16, 0); + lean_ctor_release(x_16, 1); + x_19 = x_16; +} else { + lean_dec_ref(x_16); + x_19 = lean_box(0); +} +x_20 = lean_array_get_size(x_11); lean_dec(x_11); -x_20 = lean_ctor_get(x_17, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_17, 1); +x_21 = lean_ctor_get(x_17, 0); lean_inc(x_21); -x_22 = lean_ctor_get(x_17, 2); +x_22 = lean_ctor_get(x_17, 1); lean_inc(x_22); -x_23 = lean_ctor_get(x_17, 3); +x_23 = lean_ctor_get(x_17, 2); lean_inc(x_23); +x_24 = lean_ctor_get(x_17, 3); +lean_inc(x_24); lean_dec(x_17); -x_24 = lean_array_get_size(x_22); -x_25 = lean_nat_dec_lt(x_19, x_24); -lean_dec(x_24); -lean_dec(x_19); -if (x_25 == 0) -{ -uint8_t x_26; -x_26 = !lean_is_exclusive(x_4); +x_25 = lean_array_get_size(x_23); +x_26 = lean_nat_dec_lt(x_20, x_25); +lean_dec(x_25); +lean_dec(x_20); if (x_26 == 0) { -lean_object* x_27; uint8_t x_28; -x_27 = lean_ctor_get(x_4, 0); -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) +uint8_t x_27; +lean_dec(x_19); +x_27 = !lean_is_exclusive(x_4); +if (x_27 == 0) { -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_27, 2); -lean_dec(x_29); -x_30 = lean_ctor_get(x_27, 1); +lean_object* x_28; uint8_t x_29; +x_28 = lean_ctor_get(x_4, 0); +x_29 = !lean_is_exclusive(x_28); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_28, 2); lean_dec(x_30); -lean_ctor_set(x_27, 2, x_22); -lean_ctor_set(x_27, 1, x_21); -x_31 = lean_apply_4(x_3, x_20, x_23, x_4, x_18); -return x_31; +x_31 = lean_ctor_get(x_28, 1); +lean_dec(x_31); +lean_ctor_set(x_28, 2, x_23); +lean_ctor_set(x_28, 1, x_22); +x_32 = lean_apply_4(x_3, x_21, x_24, x_4, x_18); +return x_32; } else { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_32 = lean_ctor_get(x_27, 0); -x_33 = lean_ctor_get(x_27, 3); -x_34 = lean_ctor_get(x_27, 4); +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_33 = lean_ctor_get(x_28, 0); +x_34 = lean_ctor_get(x_28, 3); +x_35 = lean_ctor_get(x_28, 4); +lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); -lean_inc(x_32); -lean_dec(x_27); -x_35 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_35, 0, x_32); -lean_ctor_set(x_35, 1, x_21); -lean_ctor_set(x_35, 2, x_22); -lean_ctor_set(x_35, 3, x_33); -lean_ctor_set(x_35, 4, x_34); -lean_ctor_set(x_4, 0, x_35); -x_36 = lean_apply_4(x_3, x_20, x_23, x_4, x_18); -return x_36; +lean_dec(x_28); +x_36 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_36, 0, x_33); +lean_ctor_set(x_36, 1, x_22); +lean_ctor_set(x_36, 2, x_23); +lean_ctor_set(x_36, 3, x_34); +lean_ctor_set(x_36, 4, x_35); +lean_ctor_set(x_4, 0, x_36); +x_37 = lean_apply_4(x_3, x_21, x_24, x_4, x_18); +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; uint8_t x_47; uint8_t x_48; uint8_t 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_37 = lean_ctor_get(x_4, 0); -x_38 = lean_ctor_get(x_4, 1); -x_39 = lean_ctor_get(x_4, 2); -x_40 = lean_ctor_get(x_4, 3); -x_41 = lean_ctor_get(x_4, 4); -x_42 = lean_ctor_get(x_4, 5); -x_43 = lean_ctor_get(x_4, 6); -x_44 = lean_ctor_get(x_4, 7); -x_45 = lean_ctor_get(x_4, 8); -x_46 = lean_ctor_get(x_4, 9); -x_47 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); -x_48 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); -x_49 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +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; uint8_t x_48; uint8_t x_49; uint8_t 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_4, 0); +x_39 = lean_ctor_get(x_4, 1); +x_40 = lean_ctor_get(x_4, 2); +x_41 = lean_ctor_get(x_4, 3); +x_42 = lean_ctor_get(x_4, 4); +x_43 = lean_ctor_get(x_4, 5); +x_44 = lean_ctor_get(x_4, 6); +x_45 = lean_ctor_get(x_4, 7); +x_46 = lean_ctor_get(x_4, 8); +x_47 = lean_ctor_get(x_4, 9); +x_48 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); +x_49 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); +x_50 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); @@ -21663,1268 +21133,720 @@ lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_inc(x_37); lean_dec(x_4); -x_50 = lean_ctor_get(x_37, 0); -lean_inc(x_50); -x_51 = lean_ctor_get(x_37, 3); +x_51 = lean_ctor_get(x_38, 0); lean_inc(x_51); -x_52 = lean_ctor_get(x_37, 4); +x_52 = lean_ctor_get(x_38, 3); lean_inc(x_52); -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); - lean_ctor_release(x_37, 4); - x_53 = x_37; +x_53 = lean_ctor_get(x_38, 4); +lean_inc(x_53); +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_54 = x_38; } else { - lean_dec_ref(x_37); - x_53 = lean_box(0); + lean_dec_ref(x_38); + x_54 = lean_box(0); } -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 5, 0); } else { - x_54 = x_53; + x_55 = x_54; } -lean_ctor_set(x_54, 0, x_50); -lean_ctor_set(x_54, 1, x_21); -lean_ctor_set(x_54, 2, x_22); -lean_ctor_set(x_54, 3, x_51); -lean_ctor_set(x_54, 4, x_52); -x_55 = lean_alloc_ctor(0, 10, 3); -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); -lean_ctor_set(x_55, 6, x_43); -lean_ctor_set(x_55, 7, x_44); -lean_ctor_set(x_55, 8, x_45); -lean_ctor_set(x_55, 9, x_46); -lean_ctor_set_uint8(x_55, sizeof(void*)*10, x_47); -lean_ctor_set_uint8(x_55, sizeof(void*)*10 + 1, x_48); -lean_ctor_set_uint8(x_55, sizeof(void*)*10 + 2, x_49); -x_56 = lean_apply_4(x_3, x_20, x_23, x_55, x_18); -return x_56; +lean_ctor_set(x_55, 0, x_51); +lean_ctor_set(x_55, 1, x_22); +lean_ctor_set(x_55, 2, x_23); +lean_ctor_set(x_55, 3, x_52); +lean_ctor_set(x_55, 4, x_53); +x_56 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_56, 0, x_55); +lean_ctor_set(x_56, 1, x_39); +lean_ctor_set(x_56, 2, x_40); +lean_ctor_set(x_56, 3, x_41); +lean_ctor_set(x_56, 4, x_42); +lean_ctor_set(x_56, 5, x_43); +lean_ctor_set(x_56, 6, x_44); +lean_ctor_set(x_56, 7, x_45); +lean_ctor_set(x_56, 8, x_46); +lean_ctor_set(x_56, 9, x_47); +lean_ctor_set_uint8(x_56, sizeof(void*)*10, x_48); +lean_ctor_set_uint8(x_56, sizeof(void*)*10 + 1, x_49); +lean_ctor_set_uint8(x_56, sizeof(void*)*10 + 2, x_50); +x_57 = lean_apply_4(x_3, x_21, x_24, x_56, x_18); +return x_57; } } 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; uint8_t x_63; -x_57 = lean_ctor_get(x_18, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_57, 2); +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; +x_58 = lean_ctor_get(x_18, 0); lean_inc(x_58); -lean_dec(x_57); x_59 = lean_ctor_get(x_58, 2); lean_inc(x_59); lean_dec(x_58); -x_60 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_18); -x_61 = lean_ctor_get(x_4, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_60, 1); -lean_inc(x_62); -lean_dec(x_60); -x_63 = !lean_is_exclusive(x_4); -if (x_63 == 0) +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_64; uint8_t x_65; -x_64 = lean_ctor_get(x_4, 0); -lean_dec(x_64); -x_65 = !lean_is_exclusive(x_61); -if (x_65 == 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_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_61, 2); -lean_dec(x_66); -x_67 = lean_ctor_get(x_61, 1); -lean_dec(x_67); -lean_ctor_set(x_61, 2, x_22); -lean_ctor_set(x_61, 1, x_21); -x_68 = lean_apply_4(x_3, x_20, x_23, x_4, x_62); -if (lean_obj_tag(x_68) == 0) +lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_162 = lean_ctor_get(x_157, 2); +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) { -lean_object* x_69; lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_69 = lean_ctor_get(x_68, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_69, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_70, 2); -lean_inc(x_71); -x_72 = !lean_is_exclusive(x_68); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_68, 1); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_69); -if (x_74 == 0) -{ -lean_object* x_75; uint8_t x_76; -x_75 = lean_ctor_get(x_69, 0); -lean_dec(x_75); -x_76 = !lean_is_exclusive(x_70); -if (x_76 == 0) -{ -lean_object* x_77; uint8_t x_78; -x_77 = lean_ctor_get(x_70, 2); -lean_dec(x_77); -x_78 = !lean_is_exclusive(x_71); -if (x_78 == 0) -{ -lean_object* x_79; -x_79 = lean_ctor_get(x_71, 2); -lean_dec(x_79); -lean_ctor_set(x_71, 2, x_59); -return x_68; +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_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -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_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 +{ +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_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; +} +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_61 = x_181; +x_62 = x_180; +goto block_155; +} +} +} +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_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); +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_61 = x_203; +x_62 = x_202; +goto block_155; +} +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; +} +} +block_155: +{ +if (lean_obj_tag(x_61) == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; uint8_t x_66; +x_63 = lean_ctor_get(x_62, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_63, 2); +lean_inc(x_64); +x_65 = lean_ctor_get(x_61, 0); +lean_inc(x_65); +lean_dec(x_61); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; uint8_t x_68; +x_67 = lean_ctor_get(x_62, 0); +lean_dec(x_67); +x_68 = !lean_is_exclusive(x_63); +if (x_68 == 0) +{ +lean_object* x_69; uint8_t x_70; +x_69 = lean_ctor_get(x_63, 2); +lean_dec(x_69); +x_70 = !lean_is_exclusive(x_64); +if (x_70 == 0) +{ +lean_object* x_71; lean_object* x_72; +x_71 = lean_ctor_get(x_64, 2); +lean_dec(x_71); +lean_ctor_set(x_64, 2, x_60); +if (lean_is_scalar(x_19)) { + x_72 = lean_alloc_ctor(1, 2, 0); +} else { + x_72 = x_19; + lean_ctor_set_tag(x_72, 1); +} +lean_ctor_set(x_72, 0, x_65); +lean_ctor_set(x_72, 1, x_62); +return x_72; +} +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_64, 0); +x_74 = lean_ctor_get(x_64, 1); +x_75 = lean_ctor_get(x_64, 3); +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); +if (lean_is_scalar(x_19)) { + x_77 = lean_alloc_ctor(1, 2, 0); +} else { + x_77 = x_19; + lean_ctor_set_tag(x_77, 1); +} +lean_ctor_set(x_77, 0, x_65); +lean_ctor_set(x_77, 1, x_62); +return x_77; +} +} +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_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_59); -lean_ctor_set(x_83, 3, x_82); -lean_ctor_set(x_70, 2, x_83); -return x_68; -} -} -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; -x_84 = lean_ctor_get(x_70, 0); -x_85 = lean_ctor_get(x_70, 1); -x_86 = lean_ctor_get(x_70, 3); -x_87 = lean_ctor_get(x_70, 4); -x_88 = lean_ctor_get(x_70, 5); -lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); +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); lean_inc(x_84); -lean_dec(x_70); -x_89 = lean_ctor_get(x_71, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_71, 1); -lean_inc(x_90); -x_91 = lean_ctor_get(x_71, 3); +x_85 = lean_ctor_get(x_64, 3); +lean_inc(x_85); +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; +} else { + lean_dec_ref(x_64); + x_86 = lean_box(0); +} +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); +} else { + x_87 = x_86; +} +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); +if (lean_is_scalar(x_19)) { + x_89 = lean_alloc_ctor(1, 2, 0); +} else { + x_89 = x_19; + lean_ctor_set_tag(x_89, 1); +} +lean_ctor_set(x_89, 0, x_65); +lean_ctor_set(x_89, 1, x_62); +return x_89; +} +} +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_inc(x_94); +lean_inc(x_93); +lean_inc(x_92); lean_inc(x_91); -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_92 = x_71; -} else { - lean_dec_ref(x_71); - x_92 = lean_box(0); -} -if (lean_is_scalar(x_92)) { - x_93 = lean_alloc_ctor(0, 4, 0); -} else { - x_93 = x_92; -} -lean_ctor_set(x_93, 0, x_89); -lean_ctor_set(x_93, 1, x_90); -lean_ctor_set(x_93, 2, x_59); -lean_ctor_set(x_93, 3, x_91); -x_94 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_94, 0, x_84); -lean_ctor_set(x_94, 1, x_85); -lean_ctor_set(x_94, 2, x_93); -lean_ctor_set(x_94, 3, x_86); -lean_ctor_set(x_94, 4, x_87); -lean_ctor_set(x_94, 5, x_88); -lean_ctor_set(x_69, 0, x_94); -return x_68; -} -} -else -{ -lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_95 = lean_ctor_get(x_69, 1); -x_96 = lean_ctor_get(x_69, 2); -x_97 = lean_ctor_get(x_69, 3); -x_98 = lean_ctor_get(x_69, 4); -x_99 = lean_ctor_get(x_69, 5); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); +lean_inc(x_90); +lean_dec(x_62); +x_95 = lean_ctor_get(x_63, 0); lean_inc(x_95); -lean_dec(x_69); -x_100 = lean_ctor_get(x_70, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_70, 1); +x_96 = lean_ctor_get(x_63, 1); +lean_inc(x_96); +x_97 = lean_ctor_get(x_63, 3); +lean_inc(x_97); +x_98 = lean_ctor_get(x_63, 4); +lean_inc(x_98); +x_99 = lean_ctor_get(x_63, 5); +lean_inc(x_99); +if (lean_is_exclusive(x_63)) { + lean_ctor_release(x_63, 0); + lean_ctor_release(x_63, 1); + lean_ctor_release(x_63, 2); + lean_ctor_release(x_63, 3); + lean_ctor_release(x_63, 4); + lean_ctor_release(x_63, 5); + x_100 = x_63; +} else { + lean_dec_ref(x_63); + x_100 = lean_box(0); +} +x_101 = lean_ctor_get(x_64, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_70, 3); +x_102 = lean_ctor_get(x_64, 1); lean_inc(x_102); -x_103 = lean_ctor_get(x_70, 4); +x_103 = lean_ctor_get(x_64, 3); lean_inc(x_103); -x_104 = lean_ctor_get(x_70, 5); -lean_inc(x_104); -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_105 = x_70; +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; } else { - lean_dec_ref(x_70); - x_105 = lean_box(0); + lean_dec_ref(x_64); + x_104 = lean_box(0); } -x_106 = lean_ctor_get(x_71, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_71, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_71, 3); -lean_inc(x_108); -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_109 = x_71; +if (lean_is_scalar(x_104)) { + x_105 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_71); - x_109 = lean_box(0); + x_105 = x_104; } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); +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); } else { - x_110 = x_109; + x_106 = x_100; } -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_59); -lean_ctor_set(x_110, 3, x_108); -if (lean_is_scalar(x_105)) { - x_111 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_19)) { + x_108 = lean_alloc_ctor(1, 2, 0); } else { - x_111 = x_105; + x_108 = x_19; + lean_ctor_set_tag(x_108, 1); } -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); -x_112 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_95); -lean_ctor_set(x_112, 2, x_96); -lean_ctor_set(x_112, 3, x_97); -lean_ctor_set(x_112, 4, x_98); -lean_ctor_set(x_112, 5, x_99); -lean_ctor_set(x_68, 1, x_112); -return x_68; +lean_ctor_set(x_108, 0, x_65); +lean_ctor_set(x_108, 1, x_107); +return x_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; 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_113 = lean_ctor_get(x_68, 0); -lean_inc(x_113); -lean_dec(x_68); -x_114 = lean_ctor_get(x_69, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_69, 2); -lean_inc(x_115); -x_116 = lean_ctor_get(x_69, 3); -lean_inc(x_116); -x_117 = lean_ctor_get(x_69, 4); -lean_inc(x_117); -x_118 = lean_ctor_get(x_69, 5); -lean_inc(x_118); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - lean_ctor_release(x_69, 3); - lean_ctor_release(x_69, 4); - lean_ctor_release(x_69, 5); - x_119 = x_69; -} else { - lean_dec_ref(x_69); - x_119 = lean_box(0); -} -x_120 = lean_ctor_get(x_70, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_70, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_70, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_70, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_70, 5); -lean_inc(x_124); -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_125 = x_70; -} else { - lean_dec_ref(x_70); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_71, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_71, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_71, 3); -lean_inc(x_128); -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_129 = x_71; -} else { - lean_dec_ref(x_71); - 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_59); -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_119)) { - x_132 = lean_alloc_ctor(0, 6, 0); -} else { - x_132 = x_119; -} -lean_ctor_set(x_132, 0, x_131); -lean_ctor_set(x_132, 1, x_114); -lean_ctor_set(x_132, 2, x_115); -lean_ctor_set(x_132, 3, x_116); -lean_ctor_set(x_132, 4, x_117); -lean_ctor_set(x_132, 5, x_118); -x_133 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_133, 0, x_113); -lean_ctor_set(x_133, 1, x_132); -return x_133; -} -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; uint8_t x_137; -x_134 = lean_ctor_get(x_68, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_134, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_135, 2); -lean_inc(x_136); -x_137 = !lean_is_exclusive(x_68); -if (x_137 == 0) -{ -lean_object* x_138; uint8_t x_139; -x_138 = lean_ctor_get(x_68, 1); -lean_dec(x_138); -x_139 = !lean_is_exclusive(x_134); -if (x_139 == 0) -{ -lean_object* x_140; uint8_t x_141; -x_140 = lean_ctor_get(x_134, 0); -lean_dec(x_140); -x_141 = !lean_is_exclusive(x_135); -if (x_141 == 0) -{ -lean_object* x_142; uint8_t x_143; -x_142 = lean_ctor_get(x_135, 2); -lean_dec(x_142); -x_143 = !lean_is_exclusive(x_136); -if (x_143 == 0) -{ -lean_object* x_144; -x_144 = lean_ctor_get(x_136, 2); -lean_dec(x_144); -lean_ctor_set(x_136, 2, x_59); -return x_68; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_145 = lean_ctor_get(x_136, 0); -x_146 = lean_ctor_get(x_136, 1); -x_147 = lean_ctor_get(x_136, 3); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_dec(x_136); -x_148 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_148, 0, x_145); -lean_ctor_set(x_148, 1, x_146); -lean_ctor_set(x_148, 2, x_59); -lean_ctor_set(x_148, 3, x_147); -lean_ctor_set(x_135, 2, x_148); -return x_68; -} -} -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; -x_149 = lean_ctor_get(x_135, 0); -x_150 = lean_ctor_get(x_135, 1); -x_151 = lean_ctor_get(x_135, 3); -x_152 = lean_ctor_get(x_135, 4); -x_153 = lean_ctor_get(x_135, 5); -lean_inc(x_153); -lean_inc(x_152); -lean_inc(x_151); -lean_inc(x_150); -lean_inc(x_149); -lean_dec(x_135); -x_154 = lean_ctor_get(x_136, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_136, 1); -lean_inc(x_155); -x_156 = lean_ctor_get(x_136, 3); -lean_inc(x_156); -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_157 = x_136; -} else { - lean_dec_ref(x_136); - 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_59); -lean_ctor_set(x_158, 3, x_156); -x_159 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_159, 0, x_149); -lean_ctor_set(x_159, 1, x_150); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_151); -lean_ctor_set(x_159, 4, x_152); -lean_ctor_set(x_159, 5, x_153); -lean_ctor_set(x_134, 0, x_159); -return x_68; -} -} -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; 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_160 = lean_ctor_get(x_134, 1); -x_161 = lean_ctor_get(x_134, 2); -x_162 = lean_ctor_get(x_134, 3); -x_163 = lean_ctor_get(x_134, 4); -x_164 = lean_ctor_get(x_134, 5); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_dec(x_134); -x_165 = lean_ctor_get(x_135, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_135, 1); -lean_inc(x_166); -x_167 = lean_ctor_get(x_135, 3); -lean_inc(x_167); -x_168 = lean_ctor_get(x_135, 4); -lean_inc(x_168); -x_169 = lean_ctor_get(x_135, 5); -lean_inc(x_169); -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_170 = x_135; -} else { - lean_dec_ref(x_135); - x_170 = lean_box(0); -} -x_171 = lean_ctor_get(x_136, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_136, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_136, 3); -lean_inc(x_173); -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_174 = x_136; -} else { - lean_dec_ref(x_136); - x_174 = 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_59); -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); -x_177 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_177, 0, x_176); -lean_ctor_set(x_177, 1, x_160); -lean_ctor_set(x_177, 2, x_161); -lean_ctor_set(x_177, 3, x_162); -lean_ctor_set(x_177, 4, x_163); -lean_ctor_set(x_177, 5, x_164); -lean_ctor_set(x_68, 1, x_177); -return x_68; -} -} -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; 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_178 = lean_ctor_get(x_68, 0); -lean_inc(x_178); -lean_dec(x_68); -x_179 = lean_ctor_get(x_134, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_134, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_134, 3); -lean_inc(x_181); -x_182 = lean_ctor_get(x_134, 4); -lean_inc(x_182); -x_183 = lean_ctor_get(x_134, 5); -lean_inc(x_183); -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); - lean_ctor_release(x_134, 5); - x_184 = x_134; -} else { - lean_dec_ref(x_134); - x_184 = lean_box(0); -} -x_185 = lean_ctor_get(x_135, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_135, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_135, 3); -lean_inc(x_187); -x_188 = lean_ctor_get(x_135, 4); -lean_inc(x_188); -x_189 = lean_ctor_get(x_135, 5); -lean_inc(x_189); -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_190 = x_135; -} else { - lean_dec_ref(x_135); - x_190 = lean_box(0); -} -x_191 = lean_ctor_get(x_136, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_136, 1); -lean_inc(x_192); -x_193 = lean_ctor_get(x_136, 3); -lean_inc(x_193); -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_194 = x_136; -} else { - lean_dec_ref(x_136); - x_194 = lean_box(0); -} -if (lean_is_scalar(x_194)) { - x_195 = lean_alloc_ctor(0, 4, 0); -} else { - x_195 = x_194; -} -lean_ctor_set(x_195, 0, x_191); -lean_ctor_set(x_195, 1, x_192); -lean_ctor_set(x_195, 2, x_59); -lean_ctor_set(x_195, 3, x_193); -if (lean_is_scalar(x_190)) { - x_196 = lean_alloc_ctor(0, 6, 0); -} else { - x_196 = x_190; -} -lean_ctor_set(x_196, 0, x_185); -lean_ctor_set(x_196, 1, x_186); -lean_ctor_set(x_196, 2, x_195); -lean_ctor_set(x_196, 3, x_187); -lean_ctor_set(x_196, 4, x_188); -lean_ctor_set(x_196, 5, x_189); -if (lean_is_scalar(x_184)) { - x_197 = lean_alloc_ctor(0, 6, 0); -} else { - x_197 = x_184; -} -lean_ctor_set(x_197, 0, x_196); -lean_ctor_set(x_197, 1, x_179); -lean_ctor_set(x_197, 2, x_180); -lean_ctor_set(x_197, 3, x_181); -lean_ctor_set(x_197, 4, x_182); -lean_ctor_set(x_197, 5, x_183); -x_198 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_198, 0, x_178); -lean_ctor_set(x_198, 1, x_197); -return x_198; -} -} -} -else -{ -lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; -x_199 = lean_ctor_get(x_61, 0); -x_200 = lean_ctor_get(x_61, 3); -x_201 = lean_ctor_get(x_61, 4); -lean_inc(x_201); -lean_inc(x_200); -lean_inc(x_199); +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_dec(x_61); -x_202 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_21); -lean_ctor_set(x_202, 2, x_22); -lean_ctor_set(x_202, 3, x_200); -lean_ctor_set(x_202, 4, x_201); -lean_ctor_set(x_4, 0, x_202); -x_203 = lean_apply_4(x_3, x_20, x_23, x_4, x_62); -if (lean_obj_tag(x_203) == 0) +x_112 = !lean_is_exclusive(x_62); +if (x_112 == 0) { -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; 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_204 = lean_ctor_get(x_203, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_204, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_205, 2); -lean_inc(x_206); -x_207 = lean_ctor_get(x_203, 0); -lean_inc(x_207); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - x_208 = x_203; +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_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_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); +if (lean_is_scalar(x_19)) { + x_118 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_203); - x_208 = lean_box(0); + x_118 = x_19; } -x_209 = lean_ctor_get(x_204, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_204, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_204, 3); -lean_inc(x_211); -x_212 = lean_ctor_get(x_204, 4); -lean_inc(x_212); -x_213 = lean_ctor_get(x_204, 5); -lean_inc(x_213); -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); - lean_ctor_release(x_204, 5); - x_214 = x_204; -} else { - lean_dec_ref(x_204); - x_214 = lean_box(0); -} -x_215 = lean_ctor_get(x_205, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_205, 1); -lean_inc(x_216); -x_217 = lean_ctor_get(x_205, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_205, 4); -lean_inc(x_218); -x_219 = lean_ctor_get(x_205, 5); -lean_inc(x_219); -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); - lean_ctor_release(x_205, 5); - x_220 = x_205; -} else { - lean_dec_ref(x_205); - x_220 = lean_box(0); -} -x_221 = lean_ctor_get(x_206, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_206, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_206, 3); -lean_inc(x_223); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_224 = x_206; -} else { - lean_dec_ref(x_206); - x_224 = lean_box(0); -} -if (lean_is_scalar(x_224)) { - x_225 = lean_alloc_ctor(0, 4, 0); -} else { - x_225 = x_224; -} -lean_ctor_set(x_225, 0, x_221); -lean_ctor_set(x_225, 1, x_222); -lean_ctor_set(x_225, 2, x_59); -lean_ctor_set(x_225, 3, x_223); -if (lean_is_scalar(x_220)) { - x_226 = lean_alloc_ctor(0, 6, 0); -} else { - x_226 = x_220; -} -lean_ctor_set(x_226, 0, x_215); -lean_ctor_set(x_226, 1, x_216); -lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_217); -lean_ctor_set(x_226, 4, x_218); -lean_ctor_set(x_226, 5, x_219); -if (lean_is_scalar(x_214)) { - x_227 = lean_alloc_ctor(0, 6, 0); -} else { - x_227 = x_214; -} -lean_ctor_set(x_227, 0, x_226); -lean_ctor_set(x_227, 1, x_209); -lean_ctor_set(x_227, 2, x_210); -lean_ctor_set(x_227, 3, x_211); -lean_ctor_set(x_227, 4, x_212); -lean_ctor_set(x_227, 5, x_213); -if (lean_is_scalar(x_208)) { - x_228 = lean_alloc_ctor(0, 2, 0); -} else { - x_228 = x_208; -} -lean_ctor_set(x_228, 0, x_207); -lean_ctor_set(x_228, 1, x_227); -return x_228; +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_62); +return x_118; } else { -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; lean_object* x_252; lean_object* x_253; -x_229 = lean_ctor_get(x_203, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_229, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_203, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - x_233 = x_203; +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 { - lean_dec_ref(x_203); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_229, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_229, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_229, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_229, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_229, 5); -lean_inc(x_238); -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_239 = x_229; -} else { - lean_dec_ref(x_229); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_230, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_230, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_230, 3); -lean_inc(x_242); -x_243 = lean_ctor_get(x_230, 4); -lean_inc(x_243); -x_244 = lean_ctor_get(x_230, 5); -lean_inc(x_244); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_245 = x_230; -} else { - lean_dec_ref(x_230); - x_245 = lean_box(0); -} -x_246 = lean_ctor_get(x_231, 0); -lean_inc(x_246); -x_247 = lean_ctor_get(x_231, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_231, 3); -lean_inc(x_248); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_249 = x_231; -} else { - lean_dec_ref(x_231); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_246); -lean_ctor_set(x_250, 1, x_247); -lean_ctor_set(x_250, 2, x_59); -lean_ctor_set(x_250, 3, x_248); -if (lean_is_scalar(x_245)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_245; -} -lean_ctor_set(x_251, 0, x_240); -lean_ctor_set(x_251, 1, x_241); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_242); -lean_ctor_set(x_251, 4, x_243); -lean_ctor_set(x_251, 5, x_244); -if (lean_is_scalar(x_239)) { - x_252 = lean_alloc_ctor(0, 6, 0); -} else { - x_252 = x_239; -} -lean_ctor_set(x_252, 0, x_251); -lean_ctor_set(x_252, 1, x_234); -lean_ctor_set(x_252, 2, x_235); -lean_ctor_set(x_252, 3, x_236); -lean_ctor_set(x_252, 4, x_237); -lean_ctor_set(x_252, 5, x_238); -if (lean_is_scalar(x_233)) { - x_253 = lean_alloc_ctor(1, 2, 0); -} else { - x_253 = x_233; -} -lean_ctor_set(x_253, 0, x_232); -lean_ctor_set(x_253, 1, x_252); -return x_253; + 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_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; uint8_t x_263; uint8_t x_264; uint8_t 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_254 = lean_ctor_get(x_4, 1); -x_255 = lean_ctor_get(x_4, 2); -x_256 = lean_ctor_get(x_4, 3); -x_257 = lean_ctor_get(x_4, 4); -x_258 = lean_ctor_get(x_4, 5); -x_259 = lean_ctor_get(x_4, 6); -x_260 = lean_ctor_get(x_4, 7); -x_261 = lean_ctor_get(x_4, 8); -x_262 = lean_ctor_get(x_4, 9); -x_263 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); -x_264 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); -x_265 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_inc(x_259); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_inc(x_254); -lean_dec(x_4); -x_266 = lean_ctor_get(x_61, 0); -lean_inc(x_266); -x_267 = lean_ctor_get(x_61, 3); -lean_inc(x_267); -x_268 = lean_ctor_get(x_61, 4); -lean_inc(x_268); -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_269 = x_61; +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_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_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_61); - x_269 = lean_box(0); + lean_dec_ref(x_110); + x_132 = lean_box(0); } -if (lean_is_scalar(x_269)) { - x_270 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_132)) { + x_133 = lean_alloc_ctor(0, 4, 0); } else { - x_270 = x_269; + x_133 = x_132; } -lean_ctor_set(x_270, 0, x_266); -lean_ctor_set(x_270, 1, x_21); -lean_ctor_set(x_270, 2, x_22); -lean_ctor_set(x_270, 3, x_267); -lean_ctor_set(x_270, 4, x_268); -x_271 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_271, 0, x_270); -lean_ctor_set(x_271, 1, x_254); -lean_ctor_set(x_271, 2, x_255); -lean_ctor_set(x_271, 3, x_256); -lean_ctor_set(x_271, 4, x_257); -lean_ctor_set(x_271, 5, x_258); -lean_ctor_set(x_271, 6, x_259); -lean_ctor_set(x_271, 7, x_260); -lean_ctor_set(x_271, 8, x_261); -lean_ctor_set(x_271, 9, x_262); -lean_ctor_set_uint8(x_271, sizeof(void*)*10, x_263); -lean_ctor_set_uint8(x_271, sizeof(void*)*10 + 1, x_264); -lean_ctor_set_uint8(x_271, sizeof(void*)*10 + 2, x_265); -x_272 = lean_apply_4(x_3, x_20, x_23, x_271, x_62); -if (lean_obj_tag(x_272) == 0) -{ -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; 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; lean_object* x_297; -x_273 = lean_ctor_get(x_272, 1); -lean_inc(x_273); -x_274 = lean_ctor_get(x_273, 0); -lean_inc(x_274); -x_275 = lean_ctor_get(x_274, 2); -lean_inc(x_275); -x_276 = lean_ctor_get(x_272, 0); -lean_inc(x_276); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - x_277 = x_272; +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 { - lean_dec_ref(x_272); - x_277 = lean_box(0); + x_135 = x_19; } -x_278 = lean_ctor_get(x_273, 1); -lean_inc(x_278); -x_279 = lean_ctor_get(x_273, 2); -lean_inc(x_279); -x_280 = lean_ctor_get(x_273, 3); -lean_inc(x_280); -x_281 = lean_ctor_get(x_273, 4); -lean_inc(x_281); -x_282 = lean_ctor_get(x_273, 5); -lean_inc(x_282); -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); - lean_ctor_release(x_273, 4); - lean_ctor_release(x_273, 5); - x_283 = x_273; -} else { - lean_dec_ref(x_273); - x_283 = lean_box(0); +lean_ctor_set(x_135, 0, x_111); +lean_ctor_set(x_135, 1, x_62); +return x_135; } -x_284 = lean_ctor_get(x_274, 0); -lean_inc(x_284); -x_285 = lean_ctor_get(x_274, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_274, 3); -lean_inc(x_286); -x_287 = lean_ctor_get(x_274, 4); -lean_inc(x_287); -x_288 = lean_ctor_get(x_274, 5); -lean_inc(x_288); -if (lean_is_exclusive(x_274)) { - lean_ctor_release(x_274, 0); - lean_ctor_release(x_274, 1); - lean_ctor_release(x_274, 2); - lean_ctor_release(x_274, 3); - lean_ctor_release(x_274, 4); - lean_ctor_release(x_274, 5); - x_289 = x_274; -} else { - lean_dec_ref(x_274); - x_289 = lean_box(0); -} -x_290 = lean_ctor_get(x_275, 0); -lean_inc(x_290); -x_291 = lean_ctor_get(x_275, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_275, 3); -lean_inc(x_292); -if (lean_is_exclusive(x_275)) { - lean_ctor_release(x_275, 0); - lean_ctor_release(x_275, 1); - lean_ctor_release(x_275, 2); - lean_ctor_release(x_275, 3); - x_293 = x_275; -} else { - lean_dec_ref(x_275); - x_293 = lean_box(0); -} -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 4, 0); -} else { - x_294 = x_293; -} -lean_ctor_set(x_294, 0, x_290); -lean_ctor_set(x_294, 1, x_291); -lean_ctor_set(x_294, 2, x_59); -lean_ctor_set(x_294, 3, x_292); -if (lean_is_scalar(x_289)) { - x_295 = lean_alloc_ctor(0, 6, 0); -} else { - x_295 = x_289; -} -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_283)) { - x_296 = lean_alloc_ctor(0, 6, 0); -} else { - x_296 = x_283; -} -lean_ctor_set(x_296, 0, x_295); -lean_ctor_set(x_296, 1, x_278); -lean_ctor_set(x_296, 2, x_279); -lean_ctor_set(x_296, 3, x_280); -lean_ctor_set(x_296, 4, x_281); -lean_ctor_set(x_296, 5, x_282); -if (lean_is_scalar(x_277)) { - x_297 = lean_alloc_ctor(0, 2, 0); -} else { - x_297 = x_277; -} -lean_ctor_set(x_297, 0, x_276); -lean_ctor_set(x_297, 1, x_296); -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; 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_298 = lean_ctor_get(x_272, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_298, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_299, 2); -lean_inc(x_300); -x_301 = lean_ctor_get(x_272, 0); -lean_inc(x_301); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - x_302 = x_272; +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_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; } else { - lean_dec_ref(x_272); - x_302 = lean_box(0); + lean_dec_ref(x_109); + x_146 = lean_box(0); } -x_303 = lean_ctor_get(x_298, 1); -lean_inc(x_303); -x_304 = lean_ctor_get(x_298, 2); -lean_inc(x_304); -x_305 = lean_ctor_get(x_298, 3); -lean_inc(x_305); -x_306 = lean_ctor_get(x_298, 4); -lean_inc(x_306); -x_307 = lean_ctor_get(x_298, 5); -lean_inc(x_307); -if (lean_is_exclusive(x_298)) { - lean_ctor_release(x_298, 0); - lean_ctor_release(x_298, 1); - lean_ctor_release(x_298, 2); - lean_ctor_release(x_298, 3); - lean_ctor_release(x_298, 4); - lean_ctor_release(x_298, 5); - x_308 = x_298; +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; } else { - lean_dec_ref(x_298); - x_308 = lean_box(0); + lean_dec_ref(x_110); + x_150 = lean_box(0); } -x_309 = lean_ctor_get(x_299, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_299, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_299, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_299, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_299, 5); -lean_inc(x_313); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - lean_ctor_release(x_299, 1); - lean_ctor_release(x_299, 2); - lean_ctor_release(x_299, 3); - lean_ctor_release(x_299, 4); - lean_ctor_release(x_299, 5); - x_314 = x_299; +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_299); - x_314 = lean_box(0); + x_151 = x_150; } -x_315 = lean_ctor_get(x_300, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_300, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_300, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_300)) { - lean_ctor_release(x_300, 0); - lean_ctor_release(x_300, 1); - lean_ctor_release(x_300, 2); - lean_ctor_release(x_300, 3); - x_318 = x_300; +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 { - lean_dec_ref(x_300); - x_318 = lean_box(0); + x_152 = x_146; } -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); +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); +if (lean_is_scalar(x_19)) { + x_154 = lean_alloc_ctor(0, 2, 0); } else { - x_319 = x_318; + x_154 = x_19; } -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_59); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; +lean_ctor_set(x_154, 0, x_111); +lean_ctor_set(x_154, 1, x_153); +return x_154; } -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -if (lean_is_scalar(x_308)) { - x_321 = lean_alloc_ctor(0, 6, 0); -} else { - x_321 = x_308; -} -lean_ctor_set(x_321, 0, x_320); -lean_ctor_set(x_321, 1, x_303); -lean_ctor_set(x_321, 2, x_304); -lean_ctor_set(x_321, 3, x_305); -lean_ctor_set(x_321, 4, x_306); -lean_ctor_set(x_321, 5, x_307); -if (lean_is_scalar(x_302)) { - x_322 = lean_alloc_ctor(1, 2, 0); -} else { - x_322 = x_302; -} -lean_ctor_set(x_322, 0, x_301); -lean_ctor_set(x_322, 1, x_321); -return x_322; } } } } else { -uint8_t x_323; +uint8_t x_207; lean_dec(x_11); lean_dec(x_4); lean_dec(x_3); -x_323 = !lean_is_exclusive(x_16); -if (x_323 == 0) +x_207 = !lean_is_exclusive(x_16); +if (x_207 == 0) { return x_16; } else { -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_16, 0); -x_325 = lean_ctor_get(x_16, 1); -lean_inc(x_325); -lean_inc(x_324); +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_dec(x_16); -x_326 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_326, 0, x_324); -lean_ctor_set(x_326, 1, x_325); -return x_326; +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_327; lean_object* x_328; -x_327 = l_Array_empty___closed__1; -x_328 = lean_apply_4(x_3, x_327, x_2, x_4, x_5); -return x_328; +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; } } } diff --git a/stage0/stdlib/Lean/Elab/CollectFVars.c b/stage0/stdlib/Lean/Elab/CollectFVars.c new file mode 100644 index 0000000000..9bc01bf24c --- /dev/null +++ b/stage0/stdlib/Lean/Elab/CollectFVars.c @@ -0,0 +1,885 @@ +// Lean compiler output +// Module: Lean.Elab.CollectFVars +// Imports: Init Lean.Util.CollectFVars Lean.Elab.Term +#include +#if defined(__clang__) +#pragma clang diagnostic ignored "-Wunused-parameter" +#pragma clang diagnostic ignored "-Wunused-label" +#elif defined(__GNUC__) && !defined(__CLANG__) +#pragma GCC diagnostic ignored "-Wunused-parameter" +#pragma GCC diagnostic ignored "-Wunused-label" +#pragma GCC diagnostic ignored "-Wunused-but-set-variable" +#endif +#ifdef __cplusplus +extern "C" { +#endif +lean_object* l_Lean_Elab_Term_removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_inferType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVarsAtFVars___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_local_ctx_erase(lean_object*, lean_object*); +extern lean_object* l_Array_empty___closed__1; +lean_object* l_Array_reverseAux___main___rarg(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_removeUnused___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_array_push(lean_object*, lean_object*); +lean_object* lean_array_get_size(lean_object*); +lean_object* lean_nat_add(lean_object*, lean_object*); +lean_object* lean_array_fget(lean_object*, lean_object*); +uint8_t lean_nat_dec_eq(lean_object*, lean_object*); +lean_object* lean_nat_sub(lean_object*, lean_object*); +lean_object* l_Lean_Expr_fvarId_x21(lean_object*); +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVars___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_LocalInstances_erase(lean_object*, lean_object*); +lean_object* l_Lean_CollectFVars_main___main(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVarsAtFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_getLocalInsts(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_getLCtx(lean_object*, lean_object*); +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_NameSet_contains(lean_object*, lean_object*); +uint8_t lean_nat_dec_lt(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVars(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = l_Lean_Elab_Term_instantiateMVars(x_1, x_3, x_4, x_5); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +x_8 = lean_ctor_get(x_6, 0); +x_9 = l_Lean_CollectFVars_main___main(x_8, x_2); +lean_ctor_set(x_6, 0, x_9); +return x_6; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_6, 0); +x_11 = lean_ctor_get(x_6, 1); +lean_inc(x_11); +lean_inc(x_10); +lean_dec(x_6); +x_12 = l_Lean_CollectFVars_main___main(x_10, x_2); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_11); +return x_13; +} +} +} +lean_object* l_Lean_Elab_Term_collectUsedFVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_3); +x_9 = lean_nat_dec_lt(x_4, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; +lean_dec(x_6); +lean_dec(x_4); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_5); +lean_ctor_set(x_10, 1, x_7); +return x_10; +} +else +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_11 = lean_array_fget(x_3, x_4); +x_12 = lean_unsigned_to_nat(1u); +x_13 = lean_nat_add(x_4, x_12); +lean_dec(x_4); +lean_inc(x_6); +x_14 = l_Lean_Elab_Term_inferType(x_1, x_11, x_6, x_7); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +lean_inc(x_6); +x_17 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_5, x_15, x_6, x_16); +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +lean_dec(x_17); +x_4 = x_13; +x_5 = x_18; +x_7 = x_19; +goto _start; +} +else +{ +uint8_t x_21; +lean_dec(x_13); +lean_dec(x_6); +lean_dec(x_5); +x_21 = !lean_is_exclusive(x_14); +if (x_21 == 0) +{ +return x_14; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_14, 0); +x_23 = lean_ctor_get(x_14, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_14); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +} +} +lean_object* l_Lean_Elab_Term_collectUsedFVarsAtFVars(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; +x_6 = lean_unsigned_to_nat(0u); +x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(x_1, x_3, x_3, x_6, x_2, x_4, x_5); +return x_7; +} +} +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_8; +} +} +lean_object* l_Lean_Elab_Term_collectUsedFVarsAtFVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Elab_Term_collectUsedFVarsAtFVars(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_nat_dec_eq(x_4, x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_sub(x_4, x_11); +lean_dec(x_4); +x_13 = lean_array_fget(x_3, x_12); +x_14 = lean_ctor_get(x_6, 1); +lean_inc(x_14); +x_15 = lean_ctor_get(x_14, 1); +lean_inc(x_15); +x_16 = !lean_is_exclusive(x_6); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; uint8_t x_19; +x_17 = lean_ctor_get(x_6, 0); +x_18 = lean_ctor_get(x_6, 1); +lean_dec(x_18); +x_19 = !lean_is_exclusive(x_14); +if (x_19 == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; +x_20 = lean_ctor_get(x_14, 0); +x_21 = lean_ctor_get(x_14, 1); +lean_dec(x_21); +x_22 = lean_ctor_get(x_15, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_15, 1); +lean_inc(x_23); +x_24 = lean_ctor_get(x_23, 1); +lean_inc(x_24); +x_25 = l_Lean_Expr_fvarId_x21(x_13); +x_26 = l_Lean_NameSet_contains(x_24, x_25); +lean_dec(x_24); +if (x_26 == 0) +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_23); +lean_dec(x_22); +lean_dec(x_13); +lean_inc(x_25); +x_27 = lean_local_ctx_erase(x_17, x_25); +x_28 = l_Lean_LocalInstances_erase(x_20, x_25); +lean_dec(x_25); +lean_ctor_set(x_14, 0, x_28); +lean_ctor_set(x_6, 0, x_27); +x_4 = x_12; +x_5 = lean_box(0); +goto _start; +} +else +{ +uint8_t x_30; +lean_dec(x_25); +x_30 = !lean_is_exclusive(x_15); +if (x_30 == 0) +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_15, 1); +lean_dec(x_31); +x_32 = lean_ctor_get(x_15, 0); +lean_dec(x_32); +lean_inc(x_7); +lean_inc(x_13); +x_33 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); +if (lean_obj_tag(x_33) == 0) +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_ctor_get(x_33, 1); +lean_inc(x_35); +lean_dec(x_33); +lean_inc(x_7); +x_36 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_23, x_34, x_7, x_35); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_36, 1); +lean_inc(x_38); +lean_dec(x_36); +x_39 = lean_array_push(x_22, x_13); +lean_ctor_set(x_15, 1, x_37); +lean_ctor_set(x_15, 0, x_39); +x_4 = x_12; +x_5 = lean_box(0); +x_8 = x_38; +goto _start; +} +else +{ +uint8_t x_41; +lean_free_object(x_15); +lean_dec(x_23); +lean_dec(x_22); +lean_free_object(x_14); +lean_dec(x_20); +lean_free_object(x_6); +lean_dec(x_17); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_7); +x_41 = !lean_is_exclusive(x_33); +if (x_41 == 0) +{ +return x_33; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_33, 0); +x_43 = lean_ctor_get(x_33, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_33); +x_44 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_44, 0, x_42); +lean_ctor_set(x_44, 1, x_43); +return x_44; +} +} +} +else +{ +lean_object* x_45; +lean_dec(x_15); +lean_inc(x_7); +lean_inc(x_13); +x_45 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +lean_inc(x_7); +x_48 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_23, x_46, x_7, x_47); +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +x_51 = lean_array_push(x_22, x_13); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_49); +lean_ctor_set(x_14, 1, x_52); +x_4 = x_12; +x_5 = lean_box(0); +x_8 = x_50; +goto _start; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +lean_dec(x_23); +lean_dec(x_22); +lean_free_object(x_14); +lean_dec(x_20); +lean_free_object(x_6); +lean_dec(x_17); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_7); +x_54 = lean_ctor_get(x_45, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_45, 1); +lean_inc(x_55); +if (lean_is_exclusive(x_45)) { + lean_ctor_release(x_45, 0); + lean_ctor_release(x_45, 1); + x_56 = x_45; +} else { + lean_dec_ref(x_45); + x_56 = lean_box(0); +} +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_56; +} +lean_ctor_set(x_57, 0, x_54); +lean_ctor_set(x_57, 1, x_55); +return x_57; +} +} +} +} +else +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_58 = lean_ctor_get(x_14, 0); +lean_inc(x_58); +lean_dec(x_14); +x_59 = lean_ctor_get(x_15, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_15, 1); +lean_inc(x_60); +x_61 = lean_ctor_get(x_60, 1); +lean_inc(x_61); +x_62 = l_Lean_Expr_fvarId_x21(x_13); +x_63 = l_Lean_NameSet_contains(x_61, x_62); +lean_dec(x_61); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; +lean_dec(x_60); +lean_dec(x_59); +lean_dec(x_13); +lean_inc(x_62); +x_64 = lean_local_ctx_erase(x_17, x_62); +x_65 = l_Lean_LocalInstances_erase(x_58, x_62); +lean_dec(x_62); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_15); +lean_ctor_set(x_6, 1, x_66); +lean_ctor_set(x_6, 0, x_64); +x_4 = x_12; +x_5 = lean_box(0); +goto _start; +} +else +{ +lean_object* x_68; lean_object* x_69; +lean_dec(x_62); +if (lean_is_exclusive(x_15)) { + lean_ctor_release(x_15, 0); + lean_ctor_release(x_15, 1); + x_68 = x_15; +} else { + lean_dec_ref(x_15); + x_68 = lean_box(0); +} +lean_inc(x_7); +lean_inc(x_13); +x_69 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); +if (lean_obj_tag(x_69) == 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; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_69, 1); +lean_inc(x_71); +lean_dec(x_69); +lean_inc(x_7); +x_72 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_60, x_70, x_7, x_71); +x_73 = lean_ctor_get(x_72, 0); +lean_inc(x_73); +x_74 = lean_ctor_get(x_72, 1); +lean_inc(x_74); +lean_dec(x_72); +x_75 = lean_array_push(x_59, x_13); +if (lean_is_scalar(x_68)) { + x_76 = lean_alloc_ctor(0, 2, 0); +} else { + x_76 = x_68; +} +lean_ctor_set(x_76, 0, x_75); +lean_ctor_set(x_76, 1, x_73); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_58); +lean_ctor_set(x_77, 1, x_76); +lean_ctor_set(x_6, 1, x_77); +x_4 = x_12; +x_5 = lean_box(0); +x_8 = x_74; +goto _start; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +lean_dec(x_68); +lean_dec(x_60); +lean_dec(x_59); +lean_dec(x_58); +lean_free_object(x_6); +lean_dec(x_17); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_7); +x_79 = lean_ctor_get(x_69, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_69, 1); +lean_inc(x_80); +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + x_81 = x_69; +} else { + lean_dec_ref(x_69); + x_81 = lean_box(0); +} +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); +return x_82; +} +} +} +} +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; uint8_t x_90; +x_83 = lean_ctor_get(x_6, 0); +lean_inc(x_83); +lean_dec(x_6); +x_84 = lean_ctor_get(x_14, 0); +lean_inc(x_84); +if (lean_is_exclusive(x_14)) { + lean_ctor_release(x_14, 0); + lean_ctor_release(x_14, 1); + x_85 = x_14; +} else { + lean_dec_ref(x_14); + x_85 = lean_box(0); +} +x_86 = lean_ctor_get(x_15, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_15, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_87, 1); +lean_inc(x_88); +x_89 = l_Lean_Expr_fvarId_x21(x_13); +x_90 = l_Lean_NameSet_contains(x_88, x_89); +lean_dec(x_88); +if (x_90 == 0) +{ +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +lean_dec(x_87); +lean_dec(x_86); +lean_dec(x_13); +lean_inc(x_89); +x_91 = lean_local_ctx_erase(x_83, x_89); +x_92 = l_Lean_LocalInstances_erase(x_84, x_89); +lean_dec(x_89); +if (lean_is_scalar(x_85)) { + x_93 = lean_alloc_ctor(0, 2, 0); +} else { + x_93 = x_85; +} +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_15); +x_94 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_94, 0, x_91); +lean_ctor_set(x_94, 1, x_93); +x_4 = x_12; +x_5 = lean_box(0); +x_6 = x_94; +goto _start; +} +else +{ +lean_object* x_96; lean_object* x_97; +lean_dec(x_89); +if (lean_is_exclusive(x_15)) { + lean_ctor_release(x_15, 0); + lean_ctor_release(x_15, 1); + x_96 = x_15; +} else { + lean_dec_ref(x_15); + x_96 = lean_box(0); +} +lean_inc(x_7); +lean_inc(x_13); +x_97 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); +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; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; +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); +lean_inc(x_7); +x_100 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_87, x_98, x_7, x_99); +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_array_push(x_86, x_13); +if (lean_is_scalar(x_96)) { + x_104 = lean_alloc_ctor(0, 2, 0); +} else { + x_104 = x_96; +} +lean_ctor_set(x_104, 0, x_103); +lean_ctor_set(x_104, 1, x_101); +if (lean_is_scalar(x_85)) { + x_105 = lean_alloc_ctor(0, 2, 0); +} else { + x_105 = x_85; +} +lean_ctor_set(x_105, 0, x_84); +lean_ctor_set(x_105, 1, x_104); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_83); +lean_ctor_set(x_106, 1, x_105); +x_4 = x_12; +x_5 = lean_box(0); +x_6 = x_106; +x_8 = x_102; +goto _start; +} +else +{ +lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; +lean_dec(x_96); +lean_dec(x_87); +lean_dec(x_86); +lean_dec(x_85); +lean_dec(x_84); +lean_dec(x_83); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_7); +x_108 = lean_ctor_get(x_97, 0); +lean_inc(x_108); +x_109 = lean_ctor_get(x_97, 1); +lean_inc(x_109); +if (lean_is_exclusive(x_97)) { + lean_ctor_release(x_97, 0); + lean_ctor_release(x_97, 1); + x_110 = x_97; +} else { + lean_dec_ref(x_97); + x_110 = lean_box(0); +} +if (lean_is_scalar(x_110)) { + x_111 = lean_alloc_ctor(1, 2, 0); +} else { + x_111 = x_110; +} +lean_ctor_set(x_111, 0, x_108); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +} +} +} +else +{ +lean_object* x_112; +lean_dec(x_7); +lean_dec(x_4); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_6); +lean_ctor_set(x_112, 1, x_8); +return x_112; +} +} +} +lean_object* l_Lean_Elab_Term_removeUnused(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; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_6 = l_Lean_Elab_Term_getLocalInsts(x_4, x_5); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_Elab_Term_getLCtx(x_4, x_8); +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +lean_dec(x_9); +x_12 = l_Array_empty___closed__1; +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_3); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_7); +lean_ctor_set(x_14, 1, x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_10); +lean_ctor_set(x_15, 1, x_14); +x_16 = lean_array_get_size(x_2); +x_17 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1(x_1, x_2, x_2, x_16, lean_box(0), x_15, x_4, x_11); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_18, 1); +lean_inc(x_19); +x_20 = lean_ctor_get(x_19, 1); +lean_inc(x_20); +x_21 = !lean_is_exclusive(x_17); +if (x_21 == 0) +{ +lean_object* x_22; lean_object* x_23; uint8_t x_24; +x_22 = lean_ctor_get(x_17, 0); +lean_dec(x_22); +x_23 = lean_ctor_get(x_18, 0); +lean_inc(x_23); +lean_dec(x_18); +x_24 = !lean_is_exclusive(x_19); +if (x_24 == 0) +{ +lean_object* x_25; lean_object* x_26; uint8_t x_27; +x_25 = lean_ctor_get(x_19, 0); +x_26 = lean_ctor_get(x_19, 1); +lean_dec(x_26); +x_27 = !lean_is_exclusive(x_20); +if (x_27 == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_28 = lean_ctor_get(x_20, 0); +x_29 = lean_ctor_get(x_20, 1); +lean_dec(x_29); +x_30 = lean_unsigned_to_nat(0u); +x_31 = l_Array_reverseAux___main___rarg(x_28, x_30); +lean_ctor_set(x_20, 1, x_31); +lean_ctor_set(x_20, 0, x_25); +lean_ctor_set(x_19, 0, x_23); +lean_ctor_set(x_17, 0, x_19); +return x_17; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_32 = lean_ctor_get(x_20, 0); +lean_inc(x_32); +lean_dec(x_20); +x_33 = lean_unsigned_to_nat(0u); +x_34 = l_Array_reverseAux___main___rarg(x_32, x_33); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_25); +lean_ctor_set(x_35, 1, x_34); +lean_ctor_set(x_19, 1, x_35); +lean_ctor_set(x_19, 0, x_23); +lean_ctor_set(x_17, 0, x_19); +return x_17; +} +} +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; +x_36 = lean_ctor_get(x_19, 0); +lean_inc(x_36); +lean_dec(x_19); +x_37 = lean_ctor_get(x_20, 0); +lean_inc(x_37); +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + x_38 = x_20; +} else { + lean_dec_ref(x_20); + x_38 = lean_box(0); +} +x_39 = lean_unsigned_to_nat(0u); +x_40 = l_Array_reverseAux___main___rarg(x_37, x_39); +if (lean_is_scalar(x_38)) { + x_41 = lean_alloc_ctor(0, 2, 0); +} else { + x_41 = x_38; +} +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_23); +lean_ctor_set(x_42, 1, x_41); +lean_ctor_set(x_17, 0, x_42); +return x_17; +} +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_43 = lean_ctor_get(x_17, 1); +lean_inc(x_43); +lean_dec(x_17); +x_44 = lean_ctor_get(x_18, 0); +lean_inc(x_44); +lean_dec(x_18); +x_45 = lean_ctor_get(x_19, 0); +lean_inc(x_45); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_46 = x_19; +} else { + lean_dec_ref(x_19); + x_46 = lean_box(0); +} +x_47 = lean_ctor_get(x_20, 0); +lean_inc(x_47); +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + x_48 = x_20; +} else { + lean_dec_ref(x_20); + x_48 = lean_box(0); +} +x_49 = lean_unsigned_to_nat(0u); +x_50 = l_Array_reverseAux___main___rarg(x_47, x_49); +if (lean_is_scalar(x_48)) { + x_51 = lean_alloc_ctor(0, 2, 0); +} else { + x_51 = x_48; +} +lean_ctor_set(x_51, 0, x_45); +lean_ctor_set(x_51, 1, x_50); +if (lean_is_scalar(x_46)) { + x_52 = lean_alloc_ctor(0, 2, 0); +} else { + x_52 = x_46; +} +lean_ctor_set(x_52, 0, x_44); +lean_ctor_set(x_52, 1, x_51); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_43); +return x_53; +} +} +else +{ +uint8_t x_54; +x_54 = !lean_is_exclusive(x_17); +if (x_54 == 0) +{ +return x_17; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_17, 0); +x_56 = lean_ctor_get(x_17, 1); +lean_inc(x_56); +lean_inc(x_55); +lean_dec(x_17); +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; +} +} +} +} +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_removeUnused___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_9; +} +} +lean_object* l_Lean_Elab_Term_removeUnused___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Elab_Term_removeUnused(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* initialize_Init(lean_object*); +lean_object* initialize_Lean_Util_CollectFVars(lean_object*); +lean_object* initialize_Lean_Elab_Term(lean_object*); +static bool _G_initialized = false; +lean_object* initialize_Lean_Elab_CollectFVars(lean_object* w) { +lean_object * res; +if (_G_initialized) return lean_mk_io_result(lean_box(0)); +_G_initialized = true; +res = initialize_Init(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +res = initialize_Lean_Util_CollectFVars(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +res = initialize_Lean_Elab_Term(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 +} +#endif diff --git a/stage0/stdlib/Lean/Elab/Command.c b/stage0/stdlib/Lean/Elab/Command.c index 333fb48674..d2f6289353 100644 --- a/stage0/stdlib/Lean/Elab/Command.c +++ b/stage0/stdlib/Lean/Elab/Command.c @@ -20,6 +20,7 @@ lean_object* l_Lean_Elab_Term_getEnv___rarg(lean_object*); extern lean_object* l_Lean_Name_toString___closed__1; lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_elabCommand___main___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabSection(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_extractMacroScopes(lean_object*); lean_object* l___private_Lean_Elab_Command_8__updateState___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_commandElabAttribute___closed__3; @@ -29,11 +30,13 @@ extern lean_object* l_Lean_Meta_check___closed__1; lean_object* l_Lean_Syntax_isNatLitAux(lean_object*, lean_object*); extern lean_object* l___private_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__7; lean_object* l_Lean_Elab_Command_getOptions(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg___closed__2; lean_object* l___private_Lean_Elab_Command_4__modifyGetState(lean_object*); extern lean_object* l_Lean_Elab_Tactic_evalTactic___main___closed__3; lean_object* l_Lean_Elab_Command_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_div(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg___closed__1; lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabVariable___spec__2(lean_object*, lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); extern lean_object* l_Lean_nullKind; @@ -71,13 +74,13 @@ extern lean_object* l_Lean_identKind___closed__2; uint8_t l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_withNamespace___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Command_15__checkEndHeader___main___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabCheck___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_find_x3f___at_Lean_Elab_Command_elabCommand___main___spec__2___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_logUnknownDecl(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_withIncRecDepth___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(lean_object*); lean_object* l_Lean_Meta_SynthInstance_SynthM_inhabited___lambda__1___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_throwUnsupportedSyntax___boxed(lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; extern lean_object* l_Lean_verboseOption___closed__3; @@ -117,7 +120,9 @@ lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabVariable lean_object* l___regBuiltin_Lean_Elab_Command_elabExport___closed__1; lean_object* l_Lean_Elab_Command_elabCheck(lean_object*, lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); +lean_object* l_List_find_x3f___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_SMap_empty___at_Lean_Elab_Command_commandElabAttribute___spec__1___closed__1; +lean_object* lean_string_append(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabEvalUnsafe___lambda__2___closed__1; lean_object* l_Lean_Elab_Command_elabUniverse___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabSynth___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -223,7 +228,6 @@ lean_object* l_Lean_Elab_Command_CommandElabM_monadLog___closed__1; lean_object* l_Lean_Elab_Command_CommandElabM_monadLog___closed__3; lean_object* l_Lean_Elab_Command_CommandElabM_monadLog___lambda__3___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabEvalUnsafe___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withDeclId___closed__1; extern lean_object* l_Lean_EnvExtension_Inhabited___rarg___closed__1; lean_object* l_Lean_Elab_logAt___at_Lean_Elab_Command_logTrace___spec__2(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_getOptionDecl(lean_object*, lean_object*); @@ -284,10 +288,12 @@ extern lean_object* l_Lean_Parser_Command_namespace___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_mkCommandElabAttribute___closed__6; lean_object* l_Lean_Elab_Command_CommandElabCoreM_monadState; lean_object* l___regBuiltin_Lean_Elab_Command_elabSetOption(lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); size_t l_Lean_Name_hash(lean_object*); lean_object* l___private_Lean_Elab_Command_13__addNamespace(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Elab_Command_elabCommand___main___spec__5___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabTermAux___main(lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Char_HasRepr___closed__1; extern lean_object* l_Lean_Elab_Term_elabUsingElabFns___closed__6; lean_object* l___regBuiltin_Lean_Elab_Command_elabCheck___closed__2; lean_object* l_Lean_Elab_getMacros(lean_object*, lean_object*, lean_object*, lean_object*); @@ -316,6 +322,7 @@ uint8_t l_Lean_Environment_contains(lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_findAux___main___at_Lean_Elab_Command_elabCommand___main___spec__3___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabExport(lean_object*); lean_object* l_Lean_Elab_Command_getScopes(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_modifyEnv(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withLocalDecl___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elbChoice(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_docComment___elambda__1___closed__2; @@ -327,6 +334,7 @@ lean_object* l_Lean_Elab_Command_hasNoErrorMessages(lean_object*, lean_object*); extern lean_object* l_Lean_Options_empty; lean_object* l___regBuiltin_Lean_Elab_Command_elabEnd___closed__1; extern lean_object* l_Lean_Parser_Command_variable___elambda__1___closed__2; +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabUniverses___closed__1; lean_object* l_Lean_Elab_Command_elabEvalUnsafe___closed__1; lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabOpenSimple___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -371,11 +379,10 @@ lean_object* l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg___clos lean_object* l___regBuiltin_Lean_Elab_Command_elabEval___closed__1; extern lean_object* l_Lean_PersistentEnvExtension_inhabited___rarg___closed__3; lean_object* l_Lean_Elab_Command_withMacroExpansion(lean_object*); -lean_object* l_Lean_Elab_Command_withDeclId___closed__3; lean_object* l_Lean_Elab_Command_Lean_Elab_MonadMacroAdapter___closed__6; lean_object* l_ReaderT_bind___at_Lean_Elab_Command_CommandElabM_monadLog___spec__2(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_CommandElabM_MonadQuotation___closed__4; lean_object* l_Lean_Elab_Command_elabOpenHiding(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabChoiceAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -385,12 +392,14 @@ size_t l_USize_land(size_t, size_t); lean_object* l___regBuiltin_Lean_Elab_Command_elabEnd(lean_object*); lean_object* l_List_head_x21___at_Lean_Elab_Command_getScope___spec__1___boxed(lean_object*); lean_object* l_Lean_Elab_Command_throwUnsupportedSyntax(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg___closed__3; lean_object* l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg___closed__2; lean_object* l_Lean_Elab_Command_commandElabAttribute___closed__4; extern lean_object* l_Lean_nullKind___closed__2; lean_object* l___private_Lean_Elab_Command_6__mkTermContext___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabOpenHiding___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Elab_Command_elabCommand___main___spec__5(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_sortDeclLevelParams___lambda__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_CommandElabM_monadLog; lean_object* l_Lean_Elab_Command_addUnivLevel(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_CommandElabCoreM_monadState___closed__4; @@ -406,7 +415,6 @@ lean_object* l_List_drop___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_addUnivLevel___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabExport___closed__2; lean_object* l_Lean_Elab_Command_elabCommand___main___closed__1; -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__4(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_setOption___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_mkCommandElabAttribute___closed__1; lean_object* l___private_Lean_Elab_Command_15__checkEndHeader___boxed(lean_object*, lean_object*); @@ -436,12 +444,10 @@ lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l_Lean_Elab_Command_elabEval(lean_object*, lean_object*); extern lean_object* l_Bool_HasRepr___closed__2; lean_object* l_Lean_Elab_Command_State_inhabited___closed__2; -lean_object* l_Lean_Elab_Command_withDeclId___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_throwError(lean_object*); lean_object* l_Lean_Elab_Command_elabEnd___closed__5; lean_object* l_Lean_Syntax_getKind(lean_object*); lean_object* l_Lean_Elab_Command_elabEnd___closed__1; -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_CommandElabM_monadLog___closed__5; lean_object* l_Lean_MacroScopesView_review(lean_object*); lean_object* l_Lean_Elab_Command_elabEnd___boxed(lean_object*, lean_object*, lean_object*); @@ -458,7 +464,6 @@ lean_object* l_Std_PersistentHashMap_findAtAux___main___at_Lean_Elab_Command_ela lean_object* l_Lean_Elab_Command_elbChoice___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabNamespace(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabOpen(lean_object*); -lean_object* l_Lean_Elab_Command_withDeclId___closed__2; lean_object* l_Std_mkHashMap___at_Lean_Elab_Command_commandElabAttribute___spec__2(lean_object*); lean_object* l_Lean_Elab_Command_withNamespace___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_compileDecl___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -503,6 +508,7 @@ lean_object* l___private_Lean_Elab_Command_12__addScopes___boxed(lean_object*, l uint8_t l_Lean_Syntax_isOfKind(lean_object*, lean_object*); lean_object* l_Lean_PersistentEnvExtension_getState___rarg(lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabCheckFailure(lean_object*); +uint8_t l_Lean_Elab_Command_sortDeclLevelParams___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabSynth(lean_object*); lean_object* l_Lean_Elab_Command_elabVariable___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_Lean_Elab_MonadMacroAdapter___closed__7; @@ -512,7 +518,7 @@ lean_object* l_Lean_Elab_Command_elabEvalUnsafe___lambda__3___closed__9; lean_object* l_Array_qsortAux___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__3(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_setEnv(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_openSimple___elambda__1___closed__2; -lean_object* l_Lean_Elab_Command_withDeclId(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId(lean_object*); lean_object* l_Lean_Elab_Command_mkMessageAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_variables___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_failIfSucceeds___closed__3; @@ -564,6 +570,7 @@ lean_object* l_Lean_Elab_Command_elabOpenOnly___boxed(lean_object*, lean_object* extern lean_object* l_Lean_Parser_Command_synth___elambda__1___closed__2; lean_object* l___private_Lean_Elab_Term_2__fromMetaException(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabSynth___closed__3; +lean_object* l_Lean_Elab_Command_sortDeclLevelParams___closed__1; lean_object* l_Lean_Elab_Command_elabChoiceAux___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_mkMessageAux(lean_object*, lean_object*, lean_object*, uint8_t); lean_object* l_Lean_mkConst(lean_object*, lean_object*); @@ -577,6 +584,7 @@ lean_object* l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; extern lean_object* l_Lean_PersistentEnvExtension_inhabited___rarg___closed__4; lean_object* l_Lean_Elab_Command_logTrace___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_openHiding___elambda__1___closed__2; +lean_object* l_Lean_Elab_Command_failIfSucceeds___closed__6; extern lean_object* l_Lean_Parser_regBuiltinCommandParserAttr___closed__3; lean_object* l_Lean_Elab_Command_elabInitQuot___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_CommandElabM_MonadQuotation; @@ -8805,6 +8813,174 @@ return x_37; } } } +lean_object* l_Lean_Elab_Command_modifyEnv(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +lean_inc(x_2); +x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; lean_object* x_6; uint8_t x_7; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +lean_dec(x_4); +x_7 = !lean_is_exclusive(x_5); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_5, 0); +x_9 = lean_apply_1(x_1, x_8); +lean_ctor_set(x_5, 0, x_9); +x_10 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_6); +if (lean_obj_tag(x_10) == 0) +{ +uint8_t x_11; +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_10, 0); +lean_dec(x_12); +x_13 = lean_box(0); +lean_ctor_set(x_10, 0, x_13); +return x_10; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_10, 1); +lean_inc(x_14); +lean_dec(x_10); +x_15 = lean_box(0); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +return x_16; +} +} +else +{ +uint8_t x_17; +x_17 = !lean_is_exclusive(x_10); +if (x_17 == 0) +{ +return x_10; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_10, 0); +x_19 = lean_ctor_get(x_10, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_10); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_21 = lean_ctor_get(x_5, 0); +x_22 = lean_ctor_get(x_5, 1); +x_23 = lean_ctor_get(x_5, 2); +x_24 = lean_ctor_get(x_5, 3); +x_25 = lean_ctor_get(x_5, 4); +lean_inc(x_25); +lean_inc(x_24); +lean_inc(x_23); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_5); +x_26 = lean_apply_1(x_1, x_21); +x_27 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_27, 0, x_26); +lean_ctor_set(x_27, 1, x_22); +lean_ctor_set(x_27, 2, x_23); +lean_ctor_set(x_27, 3, x_24); +lean_ctor_set(x_27, 4, x_25); +x_28 = l___private_Lean_Elab_Command_3__setState(x_27, x_2, x_6); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_28, 1); +lean_inc(x_29); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + x_30 = x_28; +} else { + lean_dec_ref(x_28); + x_30 = lean_box(0); +} +x_31 = lean_box(0); +if (lean_is_scalar(x_30)) { + x_32 = lean_alloc_ctor(0, 2, 0); +} else { + x_32 = x_30; +} +lean_ctor_set(x_32, 0, x_31); +lean_ctor_set(x_32, 1, x_29); +return x_32; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_33 = lean_ctor_get(x_28, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_28, 1); +lean_inc(x_34); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + x_35 = x_28; +} else { + lean_dec_ref(x_28); + x_35 = lean_box(0); +} +if (lean_is_scalar(x_35)) { + x_36 = lean_alloc_ctor(1, 2, 0); +} else { + x_36 = x_35; +} +lean_ctor_set(x_36, 0, x_33); +lean_ctor_set(x_36, 1, x_34); +return x_36; +} +} +} +else +{ +uint8_t x_37; +lean_dec(x_2); +lean_dec(x_1); +x_37 = !lean_is_exclusive(x_4); +if (x_37 == 0) +{ +return x_4; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_4, 0); +x_39 = lean_ctor_get(x_4, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_4); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_38); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +} lean_object* l_Lean_Elab_Command_getCurrNamespace(lean_object* x_1, lean_object* x_2) { _start: { @@ -17951,14 +18127,10 @@ lean_inc(x_8); x_9 = lean_ctor_get(x_7, 1); lean_inc(x_9); lean_dec(x_7); -lean_inc(x_2); -lean_inc(x_5); x_10 = l_Lean_Elab_Command_setEnv(x_5, x_2, x_9); if (lean_obj_tag(x_10) == 0) { uint8_t x_11; -lean_dec(x_5); -lean_dec(x_2); x_11 = !lean_is_exclusive(x_10); if (x_11 == 0) { @@ -17982,145 +18154,109 @@ return x_14; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; +uint8_t x_15; lean_dec(x_8); -x_15 = lean_ctor_get(x_10, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_10, 1); +x_15 = !lean_is_exclusive(x_10); +if (x_15 == 0) +{ +return x_10; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_10, 0); +x_17 = lean_ctor_get(x_10, 1); +lean_inc(x_17); lean_inc(x_16); lean_dec(x_10); -x_17 = l_Lean_Elab_Command_setEnv(x_5, x_2, x_16); -if (lean_obj_tag(x_17) == 0) -{ -uint8_t x_18; -x_18 = !lean_is_exclusive(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -x_19 = lean_ctor_get(x_17, 0); -lean_dec(x_19); -lean_ctor_set_tag(x_17, 1); -lean_ctor_set(x_17, 0, x_15); -return x_17; +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} } else { -lean_object* x_20; lean_object* x_21; -x_20 = lean_ctor_get(x_17, 1); +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_7, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_7, 1); lean_inc(x_20); -lean_dec(x_17); -x_21 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_21, 0, x_15); -lean_ctor_set(x_21, 1, x_20); -return x_21; -} -} -else +lean_dec(x_7); +x_21 = l_Lean_Elab_Command_setEnv(x_5, x_2, x_20); +if (lean_obj_tag(x_21) == 0) { uint8_t x_22; -lean_dec(x_15); -x_22 = !lean_is_exclusive(x_17); +x_22 = !lean_is_exclusive(x_21); if (x_22 == 0) { -return x_17; +lean_object* x_23; +x_23 = lean_ctor_get(x_21, 0); +lean_dec(x_23); +lean_ctor_set_tag(x_21, 1); +lean_ctor_set(x_21, 0, x_19); +return x_21; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_17, 0); -x_24 = lean_ctor_get(x_17, 1); +lean_object* x_24; lean_object* x_25; +x_24 = lean_ctor_get(x_21, 1); lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_17); +lean_dec(x_21); x_25 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 0, x_19); lean_ctor_set(x_25, 1, x_24); return x_25; } } -} +else +{ +uint8_t x_26; +lean_dec(x_19); +x_26 = !lean_is_exclusive(x_21); +if (x_26 == 0) +{ +return x_21; } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_7, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_7, 1); +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_21, 0); +x_28 = lean_ctor_get(x_21, 1); +lean_inc(x_28); lean_inc(x_27); -lean_dec(x_7); -x_28 = l_Lean_Elab_Command_setEnv(x_5, x_2, x_27); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; -x_30 = lean_ctor_get(x_28, 0); -lean_dec(x_30); -lean_ctor_set_tag(x_28, 1); -lean_ctor_set(x_28, 0, x_26); -return x_28; -} -else -{ -lean_object* x_31; lean_object* x_32; -x_31 = lean_ctor_get(x_28, 1); -lean_inc(x_31); -lean_dec(x_28); -x_32 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_32, 0, x_26); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -else -{ -uint8_t x_33; -lean_dec(x_26); -x_33 = !lean_is_exclusive(x_28); -if (x_33 == 0) -{ -return x_28; -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_28, 0); -x_35 = lean_ctor_get(x_28, 1); -lean_inc(x_35); -lean_inc(x_34); -lean_dec(x_28); -x_36 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -return x_36; +lean_dec(x_21); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; } } } } else { -uint8_t x_37; +uint8_t x_30; lean_dec(x_2); lean_dec(x_1); -x_37 = !lean_is_exclusive(x_4); -if (x_37 == 0) +x_30 = !lean_is_exclusive(x_4); +if (x_30 == 0) { return x_4; } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -lean_inc(x_39); -lean_inc(x_38); +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_4, 0); +x_32 = lean_ctor_get(x_4, 1); +lean_inc(x_32); +lean_inc(x_31); lean_dec(x_4); -x_40 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_40, 0, x_38); -lean_ctor_set(x_40, 1, x_39); -return x_40; +x_33 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_33, 0, x_31); +lean_ctor_set(x_33, 1, x_32); +return x_33; } } } @@ -18320,360 +18456,356 @@ lean_inc(x_2); x_7 = l_Lean_Elab_Command_getEnv(x_2, x_3); if (lean_obj_tag(x_7) == 0) { -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_29; lean_object* x_30; lean_object* x_41; +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_22; lean_object* x_23; lean_object* x_34; x_8 = lean_ctor_get(x_7, 0); lean_inc(x_8); x_9 = lean_ctor_get(x_7, 1); lean_inc(x_9); lean_dec(x_7); lean_inc(x_2); -x_41 = l___private_Lean_Elab_Command_2__getState(x_2, x_9); -if (lean_obj_tag(x_41) == 0) +x_34 = l___private_Lean_Elab_Command_2__getState(x_2, x_9); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_41, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_41, 1); -lean_inc(x_43); -lean_dec(x_41); -x_44 = l___private_Lean_Elab_Command_9__getVarDecls(x_42); -lean_dec(x_42); +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); +lean_dec(x_34); +x_37 = l___private_Lean_Elab_Command_9__getVarDecls(x_35); +lean_dec(x_35); lean_inc(x_2); -x_45 = l___private_Lean_Elab_Command_2__getState(x_2, x_43); -if (lean_obj_tag(x_45) == 0) +x_38 = l___private_Lean_Elab_Command_2__getState(x_2, x_36); +if (lean_obj_tag(x_38) == 0) { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_46 = lean_ctor_get(x_45, 0); +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +lean_dec(x_38); +x_41 = l_Lean_Elab_Command_elabCheck___closed__3; +x_42 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_39, x_41); +x_43 = l___private_Lean_Elab_Command_7__mkTermState(x_39); +lean_dec(x_39); +x_44 = l_Lean_Elab_Term_elabBinders___rarg(x_37, x_6, x_42, x_43); +lean_dec(x_37); +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_44, 1); lean_inc(x_46); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -x_48 = l_Lean_Elab_Command_elabCheck___closed__3; -x_49 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_46, x_48); -x_50 = l___private_Lean_Elab_Command_7__mkTermState(x_46); -lean_dec(x_46); -x_51 = l_Lean_Elab_Term_elabBinders___rarg(x_44, x_6, x_49, x_50); lean_dec(x_44); -if (lean_obj_tag(x_51) == 0) +lean_inc(x_2); +x_47 = l___private_Lean_Elab_Command_2__getState(x_2, x_40); +if (lean_obj_tag(x_47) == 0) { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 0); +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; uint8_t x_53; +x_48 = lean_ctor_get(x_46, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_47, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_47, 1); +lean_inc(x_50); +lean_dec(x_47); +x_51 = lean_ctor_get(x_48, 0); +lean_inc(x_51); +lean_dec(x_48); +x_52 = lean_ctor_get(x_46, 2); lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -lean_inc(x_2); -x_54 = l___private_Lean_Elab_Command_2__getState(x_2, x_47); -if (lean_obj_tag(x_54) == 0) +lean_dec(x_46); +x_53 = !lean_is_exclusive(x_49); +if (x_53 == 0) { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -x_55 = lean_ctor_get(x_53, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_54, 1); -lean_inc(x_57); +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_49, 1); lean_dec(x_54); -x_58 = lean_ctor_get(x_55, 0); -lean_inc(x_58); +x_55 = lean_ctor_get(x_49, 0); lean_dec(x_55); -x_59 = lean_ctor_get(x_53, 2); -lean_inc(x_59); -lean_dec(x_53); -x_60 = !lean_is_exclusive(x_56); -if (x_60 == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_56, 1); -lean_dec(x_61); -x_62 = lean_ctor_get(x_56, 0); -lean_dec(x_62); -lean_ctor_set(x_56, 1, x_59); -lean_ctor_set(x_56, 0, x_58); +lean_ctor_set(x_49, 1, x_52); +lean_ctor_set(x_49, 0, x_51); lean_inc(x_2); -x_63 = l___private_Lean_Elab_Command_3__setState(x_56, x_2, x_57); -if (lean_obj_tag(x_63) == 0) +x_56 = l___private_Lean_Elab_Command_3__setState(x_49, x_2, x_50); +if (lean_obj_tag(x_56) == 0) { -lean_object* x_64; -x_64 = lean_ctor_get(x_63, 1); -lean_inc(x_64); -lean_dec(x_63); -x_10 = x_52; -x_11 = x_64; -goto block_28; -} -else -{ -lean_object* x_65; lean_object* x_66; -lean_dec(x_52); -x_65 = lean_ctor_get(x_63, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_63, 1); -lean_inc(x_66); -lean_dec(x_63); -x_29 = x_65; -x_30 = x_66; -goto block_40; -} -} -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_56, 2); -x_68 = lean_ctor_get(x_56, 3); -x_69 = lean_ctor_get(x_56, 4); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); +lean_object* x_57; +x_57 = lean_ctor_get(x_56, 1); +lean_inc(x_57); lean_dec(x_56); -x_70 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_70, 0, x_58); -lean_ctor_set(x_70, 1, x_59); -lean_ctor_set(x_70, 2, x_67); -lean_ctor_set(x_70, 3, x_68); -lean_ctor_set(x_70, 4, x_69); -lean_inc(x_2); -x_71 = l___private_Lean_Elab_Command_3__setState(x_70, x_2, x_57); -if (lean_obj_tag(x_71) == 0) +x_10 = x_45; +x_11 = x_57; +goto block_21; +} +else { -lean_object* x_72; -x_72 = lean_ctor_get(x_71, 1); +lean_object* x_58; lean_object* x_59; +lean_dec(x_45); +x_58 = lean_ctor_get(x_56, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +lean_dec(x_56); +x_22 = x_58; +x_23 = x_59; +goto block_33; +} +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_60 = lean_ctor_get(x_49, 2); +x_61 = lean_ctor_get(x_49, 3); +x_62 = lean_ctor_get(x_49, 4); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_49); +x_63 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_63, 0, x_51); +lean_ctor_set(x_63, 1, x_52); +lean_ctor_set(x_63, 2, x_60); +lean_ctor_set(x_63, 3, x_61); +lean_ctor_set(x_63, 4, x_62); +lean_inc(x_2); +x_64 = l___private_Lean_Elab_Command_3__setState(x_63, x_2, x_50); +if (lean_obj_tag(x_64) == 0) +{ +lean_object* x_65; +x_65 = lean_ctor_get(x_64, 1); +lean_inc(x_65); +lean_dec(x_64); +x_10 = x_45; +x_11 = x_65; +goto block_21; +} +else +{ +lean_object* x_66; lean_object* x_67; +lean_dec(x_45); +x_66 = lean_ctor_get(x_64, 0); +lean_inc(x_66); +x_67 = lean_ctor_get(x_64, 1); +lean_inc(x_67); +lean_dec(x_64); +x_22 = x_66; +x_23 = x_67; +goto block_33; +} +} +} +else +{ +lean_object* x_68; lean_object* x_69; +lean_dec(x_46); +lean_dec(x_45); +x_68 = lean_ctor_get(x_47, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_47, 1); +lean_inc(x_69); +lean_dec(x_47); +x_22 = x_68; +x_23 = x_69; +goto block_33; +} +} +else +{ +lean_object* x_70; +x_70 = lean_ctor_get(x_44, 0); +lean_inc(x_70); +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_44, 1); +lean_inc(x_71); +lean_dec(x_44); +x_72 = lean_ctor_get(x_70, 0); lean_inc(x_72); -lean_dec(x_71); -x_10 = x_52; -x_11 = x_72; -goto block_28; -} -else +lean_dec(x_70); +lean_inc(x_2); +x_73 = l___private_Lean_Elab_Command_2__getState(x_2, x_40); +if (lean_obj_tag(x_73) == 0) { -lean_object* x_73; lean_object* x_74; -lean_dec(x_52); -x_73 = lean_ctor_get(x_71, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_71, 1); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; uint8_t x_79; +x_74 = lean_ctor_get(x_71, 0); lean_inc(x_74); -lean_dec(x_71); -x_29 = x_73; -x_30 = x_74; -goto block_40; -} -} -} -else -{ -lean_object* x_75; lean_object* x_76; -lean_dec(x_53); -lean_dec(x_52); -x_75 = lean_ctor_get(x_54, 0); +x_75 = lean_ctor_get(x_73, 0); lean_inc(x_75); -x_76 = lean_ctor_get(x_54, 1); +x_76 = lean_ctor_get(x_73, 1); lean_inc(x_76); -lean_dec(x_54); -x_29 = x_75; -x_30 = x_76; -goto block_40; -} -} -else -{ -lean_object* x_77; -x_77 = lean_ctor_get(x_51, 0); +lean_dec(x_73); +x_77 = lean_ctor_get(x_74, 0); lean_inc(x_77); -if (lean_obj_tag(x_77) == 0) -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_51, 1); +lean_dec(x_74); +x_78 = lean_ctor_get(x_71, 2); lean_inc(x_78); -lean_dec(x_51); -x_79 = lean_ctor_get(x_77, 0); -lean_inc(x_79); -lean_dec(x_77); -lean_inc(x_2); -x_80 = l___private_Lean_Elab_Command_2__getState(x_2, x_47); -if (lean_obj_tag(x_80) == 0) +lean_dec(x_71); +x_79 = !lean_is_exclusive(x_75); +if (x_79 == 0) { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_81 = lean_ctor_get(x_78, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_80, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_80, 1); -lean_inc(x_83); +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_75, 1); lean_dec(x_80); -x_84 = lean_ctor_get(x_81, 0); -lean_inc(x_84); +x_81 = lean_ctor_get(x_75, 0); lean_dec(x_81); -x_85 = lean_ctor_get(x_78, 2); -lean_inc(x_85); -lean_dec(x_78); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_82, 1); -lean_dec(x_87); -x_88 = lean_ctor_get(x_82, 0); -lean_dec(x_88); -lean_ctor_set(x_82, 1, x_85); -lean_ctor_set(x_82, 0, x_84); +lean_ctor_set(x_75, 1, x_78); +lean_ctor_set(x_75, 0, x_77); lean_inc(x_2); -x_89 = l___private_Lean_Elab_Command_3__setState(x_82, x_2, x_83); -if (lean_obj_tag(x_89) == 0) +x_82 = l___private_Lean_Elab_Command_3__setState(x_75, x_2, x_76); +if (lean_obj_tag(x_82) == 0) { -lean_object* x_90; -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -lean_dec(x_89); -x_29 = x_79; -x_30 = x_90; -goto block_40; -} -else -{ -lean_object* x_91; lean_object* x_92; -lean_dec(x_79); -x_91 = lean_ctor_get(x_89, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_29 = x_91; -x_30 = x_92; -goto block_40; -} -} -else -{ -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_82, 2); -x_94 = lean_ctor_get(x_82, 3); -x_95 = lean_ctor_get(x_82, 4); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); +lean_object* x_83; +x_83 = lean_ctor_get(x_82, 1); +lean_inc(x_83); lean_dec(x_82); -x_96 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_96, 0, x_84); -lean_ctor_set(x_96, 1, x_85); -lean_ctor_set(x_96, 2, x_93); -lean_ctor_set(x_96, 3, x_94); -lean_ctor_set(x_96, 4, x_95); -lean_inc(x_2); -x_97 = l___private_Lean_Elab_Command_3__setState(x_96, x_2, x_83); -if (lean_obj_tag(x_97) == 0) -{ -lean_object* x_98; -x_98 = lean_ctor_get(x_97, 1); -lean_inc(x_98); -lean_dec(x_97); -x_29 = x_79; -x_30 = x_98; -goto block_40; +x_22 = x_72; +x_23 = x_83; +goto block_33; } else { +lean_object* x_84; lean_object* x_85; +lean_dec(x_72); +x_84 = lean_ctor_get(x_82, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_82, 1); +lean_inc(x_85); +lean_dec(x_82); +x_22 = x_84; +x_23 = x_85; +goto block_33; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_86 = lean_ctor_get(x_75, 2); +x_87 = lean_ctor_get(x_75, 3); +x_88 = lean_ctor_get(x_75, 4); +lean_inc(x_88); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_75); +x_89 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_89, 0, x_77); +lean_ctor_set(x_89, 1, x_78); +lean_ctor_set(x_89, 2, x_86); +lean_ctor_set(x_89, 3, x_87); +lean_ctor_set(x_89, 4, x_88); +lean_inc(x_2); +x_90 = l___private_Lean_Elab_Command_3__setState(x_89, x_2, x_76); +if (lean_obj_tag(x_90) == 0) +{ +lean_object* x_91; +x_91 = lean_ctor_get(x_90, 1); +lean_inc(x_91); +lean_dec(x_90); +x_22 = x_72; +x_23 = x_91; +goto block_33; +} +else +{ +lean_object* x_92; lean_object* x_93; +lean_dec(x_72); +x_92 = lean_ctor_get(x_90, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_90, 1); +lean_inc(x_93); +lean_dec(x_90); +x_22 = x_92; +x_23 = x_93; +goto block_33; +} +} +} +else +{ +lean_object* x_94; lean_object* x_95; +lean_dec(x_72); +lean_dec(x_71); +x_94 = lean_ctor_get(x_73, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_73, 1); +lean_inc(x_95); +lean_dec(x_73); +x_22 = x_94; +x_23 = x_95; +goto block_33; +} +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; +lean_dec(x_44); +x_96 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_97 = l_unreachable_x21___rarg(x_96); +lean_inc(x_2); +x_98 = lean_apply_2(x_97, x_2, x_40); +if (lean_obj_tag(x_98) == 0) +{ lean_object* x_99; lean_object* x_100; -lean_dec(x_79); -x_99 = lean_ctor_get(x_97, 0); +x_99 = lean_ctor_get(x_98, 0); lean_inc(x_99); -x_100 = lean_ctor_get(x_97, 1); +x_100 = lean_ctor_get(x_98, 1); lean_inc(x_100); -lean_dec(x_97); -x_29 = x_99; -x_30 = x_100; -goto block_40; -} -} +lean_dec(x_98); +x_10 = x_99; +x_11 = x_100; +goto block_21; } else { lean_object* x_101; lean_object* x_102; -lean_dec(x_79); -lean_dec(x_78); -x_101 = lean_ctor_get(x_80, 0); +x_101 = lean_ctor_get(x_98, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_80, 1); +x_102 = lean_ctor_get(x_98, 1); lean_inc(x_102); -lean_dec(x_80); -x_29 = x_101; -x_30 = x_102; -goto block_40; +lean_dec(x_98); +x_22 = x_101; +x_23 = x_102; +goto block_33; +} +} } } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; -lean_dec(x_51); -x_103 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_104 = l_unreachable_x21___rarg(x_103); -lean_inc(x_2); -x_105 = lean_apply_2(x_104, x_2, x_47); -if (lean_obj_tag(x_105) == 0) +lean_object* x_103; lean_object* x_104; +lean_dec(x_37); +lean_dec(x_6); +x_103 = lean_ctor_get(x_38, 0); +lean_inc(x_103); +x_104 = lean_ctor_get(x_38, 1); +lean_inc(x_104); +lean_dec(x_38); +x_22 = x_103; +x_23 = x_104; +goto block_33; +} +} +else { -lean_object* x_106; lean_object* x_107; -x_106 = lean_ctor_get(x_105, 0); +lean_object* x_105; lean_object* x_106; +lean_dec(x_6); +x_105 = lean_ctor_get(x_34, 0); +lean_inc(x_105); +x_106 = lean_ctor_get(x_34, 1); lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_10 = x_106; -x_11 = x_107; -goto block_28; +lean_dec(x_34); +x_22 = x_105; +x_23 = x_106; +goto block_33; } -else -{ -lean_object* x_108; lean_object* x_109; -x_108 = lean_ctor_get(x_105, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_105, 1); -lean_inc(x_109); -lean_dec(x_105); -x_29 = x_108; -x_30 = x_109; -goto block_40; -} -} -} -} -else -{ -lean_object* x_110; lean_object* x_111; -lean_dec(x_44); -lean_dec(x_6); -x_110 = lean_ctor_get(x_45, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_45, 1); -lean_inc(x_111); -lean_dec(x_45); -x_29 = x_110; -x_30 = x_111; -goto block_40; -} -} -else -{ -lean_object* x_112; lean_object* x_113; -lean_dec(x_6); -x_112 = lean_ctor_get(x_41, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_41, 1); -lean_inc(x_113); -lean_dec(x_41); -x_29 = x_112; -x_30 = x_113; -goto block_40; -} -block_28: +block_21: { lean_object* x_12; -lean_inc(x_2); -lean_inc(x_8); x_12 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_11); if (lean_obj_tag(x_12) == 0) { uint8_t x_13; -lean_dec(x_8); -lean_dec(x_2); x_13 = !lean_is_exclusive(x_12); if (x_13 == 0) { @@ -18697,140 +18829,104 @@ return x_16; } else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; +uint8_t x_17; lean_dec(x_10); -x_17 = lean_ctor_get(x_12, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_12, 1); +x_17 = !lean_is_exclusive(x_12); +if (x_17 == 0) +{ +return x_12; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_12, 0); +x_19 = lean_ctor_get(x_12, 1); +lean_inc(x_19); lean_inc(x_18); lean_dec(x_12); -x_19 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_18); -if (lean_obj_tag(x_19) == 0) +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +block_33: { -uint8_t x_20; -x_20 = !lean_is_exclusive(x_19); -if (x_20 == 0) +lean_object* x_24; +x_24 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_23); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_21; -x_21 = lean_ctor_get(x_19, 0); -lean_dec(x_21); -lean_ctor_set_tag(x_19, 1); -lean_ctor_set(x_19, 0, x_17); -return x_19; +uint8_t x_25; +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_24, 0); +lean_dec(x_26); +lean_ctor_set_tag(x_24, 1); +lean_ctor_set(x_24, 0, x_22); +return x_24; } else { -lean_object* x_22; lean_object* x_23; -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); -lean_dec(x_19); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_17); -lean_ctor_set(x_23, 1, x_22); -return x_23; +lean_object* x_27; lean_object* x_28; +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +lean_dec(x_24); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_22); +lean_ctor_set(x_28, 1, x_27); +return x_28; } } else { -uint8_t x_24; -lean_dec(x_17); -x_24 = !lean_is_exclusive(x_19); -if (x_24 == 0) +uint8_t x_29; +lean_dec(x_22); +x_29 = !lean_is_exclusive(x_24); +if (x_29 == 0) { -return x_19; +return x_24; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_19, 0); -x_26 = lean_ctor_get(x_19, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_19); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -} -block_40: -{ -lean_object* x_31; -x_31 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_30); -if (lean_obj_tag(x_31) == 0) -{ -uint8_t x_32; -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_tag(x_31, 1); -lean_ctor_set(x_31, 0, x_29); -return x_31; -} -else -{ -lean_object* x_34; lean_object* x_35; -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); -lean_dec(x_31); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_29); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -else -{ -uint8_t x_36; -lean_dec(x_29); -x_36 = !lean_is_exclusive(x_31); -if (x_36 == 0) -{ -return x_31; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_31, 0); -x_38 = lean_ctor_get(x_31, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_31); -x_39 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_39, 0, x_37); -lean_ctor_set(x_39, 1, x_38); -return x_39; +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_24, 0); +x_31 = lean_ctor_get(x_24, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_24); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; } } } } else { -uint8_t x_114; +uint8_t x_107; lean_dec(x_6); lean_dec(x_2); -x_114 = !lean_is_exclusive(x_7); -if (x_114 == 0) +x_107 = !lean_is_exclusive(x_7); +if (x_107 == 0) { return x_7; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_7, 0); -x_116 = lean_ctor_get(x_7, 1); -lean_inc(x_116); -lean_inc(x_115); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_7, 0); +x_109 = lean_ctor_get(x_7, 1); +lean_inc(x_109); +lean_inc(x_108); lean_dec(x_7); -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; +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; } } } @@ -18999,6 +19095,17 @@ return x_2; lean_object* _init_l_Lean_Elab_Command_failIfSucceeds___closed__4() { _start: { +uint8_t x_1; lean_object* x_2; lean_object* x_3; +x_1 = 0; +x_2 = lean_box(x_1); +x_3 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_3, 0, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Elab_Command_failIfSucceeds___closed__5() { +_start: +{ lean_object* x_1; lean_object* x_2; x_1 = l_Lean_Elab_Exception_hasToString___closed__1; x_2 = lean_alloc_ctor(2, 1, 0); @@ -19006,11 +19113,11 @@ lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l_Lean_Elab_Command_failIfSucceeds___closed__5() { +lean_object* _init_l_Lean_Elab_Command_failIfSucceeds___closed__6() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_1 = l_Lean_Elab_Command_failIfSucceeds___closed__5; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; @@ -19055,279 +19162,288 @@ lean_inc(x_3); x_15 = l___private_Lean_Elab_Command_3__setState(x_10, x_3, x_11); if (lean_obj_tag(x_15) == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_56; lean_object* x_57; lean_object* x_98; lean_object* x_99; lean_object* x_134; +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_105; lean_object* x_106; lean_object* x_145; x_16 = lean_ctor_get(x_15, 1); lean_inc(x_16); lean_dec(x_15); lean_inc(x_3); -x_134 = lean_apply_2(x_2, x_3, x_16); -if (lean_obj_tag(x_134) == 0) +x_145 = lean_apply_2(x_2, x_3, x_16); +if (lean_obj_tag(x_145) == 0) { -lean_object* x_135; lean_object* x_136; -x_135 = lean_ctor_get(x_134, 1); -lean_inc(x_135); -lean_dec(x_134); +lean_object* x_146; lean_object* x_147; +x_146 = lean_ctor_get(x_145, 1); +lean_inc(x_146); +lean_dec(x_145); lean_inc(x_3); -x_136 = l_Lean_Elab_Command_hasNoErrorMessages(x_3, x_135); -if (lean_obj_tag(x_136) == 0) +x_147 = l_Lean_Elab_Command_hasNoErrorMessages(x_3, x_146); +if (lean_obj_tag(x_147) == 0) { -lean_object* x_137; lean_object* x_138; uint8_t 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_unbox(x_137); -lean_dec(x_137); -x_56 = x_139; -x_57 = x_138; -goto block_97; +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); +x_150 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_150, 0, x_148); +x_17 = x_150; +x_18 = x_149; +goto block_104; } else { -lean_object* x_140; lean_object* x_141; -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_98 = x_140; -x_99 = x_141; -goto block_133; +lean_object* x_151; lean_object* x_152; +x_151 = lean_ctor_get(x_147, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_147, 1); +lean_inc(x_152); +lean_dec(x_147); +x_105 = x_151; +x_106 = x_152; +goto block_144; } } else { -lean_object* x_142; lean_object* x_143; -x_142 = lean_ctor_get(x_134, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_134, 1); -lean_inc(x_143); -lean_dec(x_134); -x_98 = x_142; -x_99 = x_143; -goto block_133; +lean_object* x_153; lean_object* x_154; +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +lean_dec(x_145); +x_105 = x_153; +x_106 = x_154; +goto block_144; } -block_55: +block_104: { -lean_object* x_19; -lean_inc(x_3); -x_19 = l___private_Lean_Elab_Command_2__getState(x_3, x_18); -if (lean_obj_tag(x_19) == 0) +if (lean_obj_tag(x_17) == 0) { -lean_object* x_20; lean_object* x_21; uint8_t x_22; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = !lean_is_exclusive(x_20); -if (x_22 == 0) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_23 = lean_ctor_get(x_20, 1); -x_24 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_23); -x_25 = l_Std_PersistentArray_append___rarg(x_8, x_24); -lean_dec(x_24); -lean_ctor_set(x_20, 1, x_25); -x_26 = l___private_Lean_Elab_Command_3__setState(x_20, x_3, x_21); -if (lean_obj_tag(x_26) == 0) -{ -uint8_t x_27; -x_27 = !lean_is_exclusive(x_26); -if (x_27 == 0) -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_26, 0); -lean_dec(x_28); -lean_ctor_set_tag(x_26, 1); -lean_ctor_set(x_26, 0, x_17); -return x_26; -} -else -{ -lean_object* x_29; lean_object* x_30; -x_29 = lean_ctor_get(x_26, 1); -lean_inc(x_29); -lean_dec(x_26); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_17); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -else -{ -uint8_t x_31; +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_17, 0); +lean_inc(x_19); lean_dec(x_17); -x_31 = !lean_is_exclusive(x_26); -if (x_31 == 0) +lean_inc(x_3); +x_20 = l___private_Lean_Elab_Command_2__getState(x_3, x_18); +if (lean_obj_tag(x_20) == 0) { -return x_26; +lean_object* x_21; lean_object* x_22; uint8_t x_23; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = !lean_is_exclusive(x_21); +if (x_23 == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_24 = lean_ctor_get(x_21, 1); +x_25 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_24); +x_26 = l_Std_PersistentArray_append___rarg(x_8, x_25); +lean_dec(x_25); +lean_ctor_set(x_21, 1, x_26); +x_27 = l___private_Lean_Elab_Command_3__setState(x_21, x_3, x_22); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +lean_object* x_29; +x_29 = lean_ctor_get(x_27, 0); +lean_dec(x_29); +lean_ctor_set_tag(x_27, 1); +lean_ctor_set(x_27, 0, x_19); +return x_27; } else { -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_26, 0); -x_33 = lean_ctor_get(x_26, 1); +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(1, 2, 0); +lean_ctor_set(x_31, 0, x_19); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +else +{ +uint8_t x_32; +lean_dec(x_19); +x_32 = !lean_is_exclusive(x_27); +if (x_32 == 0) +{ +return x_27; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_27, 0); +x_34 = lean_ctor_get(x_27, 1); +lean_inc(x_34); lean_inc(x_33); -lean_inc(x_32); -lean_dec(x_26); -x_34 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_34, 0, x_32); -lean_ctor_set(x_34, 1, x_33); -return x_34; +lean_dec(x_27); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_33); +lean_ctor_set(x_35, 1, x_34); +return x_35; } } } else { -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_35 = lean_ctor_get(x_20, 0); -x_36 = lean_ctor_get(x_20, 1); -x_37 = lean_ctor_get(x_20, 2); -x_38 = lean_ctor_get(x_20, 3); -x_39 = lean_ctor_get(x_20, 4); +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_36 = lean_ctor_get(x_21, 0); +x_37 = lean_ctor_get(x_21, 1); +x_38 = lean_ctor_get(x_21, 2); +x_39 = lean_ctor_get(x_21, 3); +x_40 = lean_ctor_get(x_21, 4); +lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_20); -x_40 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_36); -x_41 = l_Std_PersistentArray_append___rarg(x_8, x_40); -lean_dec(x_40); -x_42 = lean_alloc_ctor(0, 5, 0); -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 = l___private_Lean_Elab_Command_3__setState(x_42, x_3, x_21); -if (lean_obj_tag(x_43) == 0) +lean_dec(x_21); +x_41 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_37); +x_42 = l_Std_PersistentArray_append___rarg(x_8, x_41); +lean_dec(x_41); +x_43 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_43, 0, x_36); +lean_ctor_set(x_43, 1, x_42); +lean_ctor_set(x_43, 2, x_38); +lean_ctor_set(x_43, 3, x_39); +lean_ctor_set(x_43, 4, x_40); +x_44 = l___private_Lean_Elab_Command_3__setState(x_43, x_3, x_22); +if (lean_obj_tag(x_44) == 0) { -lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_43, 1); -lean_inc(x_44); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - x_45 = x_43; +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_44, 1); +lean_inc(x_45); +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + x_46 = x_44; } else { - lean_dec_ref(x_43); - x_45 = lean_box(0); + lean_dec_ref(x_44); + x_46 = lean_box(0); } -if (lean_is_scalar(x_45)) { - x_46 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_46)) { + x_47 = lean_alloc_ctor(1, 2, 0); } else { - x_46 = x_45; - lean_ctor_set_tag(x_46, 1); + x_47 = x_46; + lean_ctor_set_tag(x_47, 1); } -lean_ctor_set(x_46, 0, x_17); -lean_ctor_set(x_46, 1, x_44); -return x_46; +lean_ctor_set(x_47, 0, x_19); +lean_ctor_set(x_47, 1, x_45); +return x_47; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_17); -x_47 = lean_ctor_get(x_43, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_43, 1); +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_19); +x_48 = lean_ctor_get(x_44, 0); lean_inc(x_48); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - x_49 = x_43; +x_49 = lean_ctor_get(x_44, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + x_50 = x_44; } else { - lean_dec_ref(x_43); - x_49 = lean_box(0); + lean_dec_ref(x_44); + x_50 = lean_box(0); } -if (lean_is_scalar(x_49)) { - x_50 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(1, 2, 0); } else { - x_50 = x_49; + x_51 = x_50; } -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -return x_50; +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_49); +return x_51; } } } else { -uint8_t x_51; -lean_dec(x_17); +uint8_t x_52; +lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); -x_51 = !lean_is_exclusive(x_19); -if (x_51 == 0) +x_52 = !lean_is_exclusive(x_20); +if (x_52 == 0) { -return x_19; +return x_20; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_19, 0); -x_53 = lean_ctor_get(x_19, 1); +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_20, 0); +x_54 = lean_ctor_get(x_20, 1); +lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_19); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_dec(x_20); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; } } } -block_97: +else { -lean_object* x_58; +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_17, 0); +lean_inc(x_56); +lean_dec(x_17); lean_inc(x_3); -x_58 = l___private_Lean_Elab_Command_2__getState(x_3, x_57); -if (lean_obj_tag(x_58) == 0) +x_57 = l___private_Lean_Elab_Command_2__getState(x_3, x_18); +if (lean_obj_tag(x_57) == 0) { -lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_59 = lean_ctor_get(x_58, 0); +lean_object* x_58; lean_object* x_59; uint8_t x_60; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_58, 1); -lean_inc(x_60); -lean_dec(x_58); -x_61 = !lean_is_exclusive(x_59); -if (x_61 == 0) +lean_dec(x_57); +x_60 = !lean_is_exclusive(x_58); +if (x_60 == 0) { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_62 = lean_ctor_get(x_59, 1); -x_63 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_62); -lean_inc(x_8); -x_64 = l_Std_PersistentArray_append___rarg(x_8, x_63); -lean_dec(x_63); -lean_ctor_set(x_59, 1, x_64); +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_61 = lean_ctor_get(x_58, 1); +x_62 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_61); +x_63 = l_Std_PersistentArray_append___rarg(x_8, x_62); +lean_dec(x_62); +lean_ctor_set(x_58, 1, x_63); lean_inc(x_3); -x_65 = l___private_Lean_Elab_Command_3__setState(x_59, x_3, x_60); -if (lean_obj_tag(x_65) == 0) +x_64 = l___private_Lean_Elab_Command_3__setState(x_58, x_3, x_59); +if (lean_obj_tag(x_64) == 0) { -lean_dec(x_8); -if (x_56 == 0) +uint8_t x_65; +x_65 = lean_unbox(x_56); +lean_dec(x_56); +if (x_65 == 0) { uint8_t x_66; lean_dec(x_3); -x_66 = !lean_is_exclusive(x_65); +x_66 = !lean_is_exclusive(x_64); if (x_66 == 0) { lean_object* x_67; lean_object* x_68; -x_67 = lean_ctor_get(x_65, 0); +x_67 = lean_ctor_get(x_64, 0); lean_dec(x_67); x_68 = lean_box(0); -lean_ctor_set(x_65, 0, x_68); -return x_65; +lean_ctor_set(x_64, 0, x_68); +return x_64; } else { lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_65, 1); +x_69 = lean_ctor_get(x_64, 1); lean_inc(x_69); -lean_dec(x_65); +lean_dec(x_64); x_70 = lean_box(0); x_71 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_71, 0, x_70); @@ -19338,9 +19454,9 @@ return x_71; else { lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_65, 1); +x_72 = lean_ctor_get(x_64, 1); lean_inc(x_72); -lean_dec(x_65); +lean_dec(x_64); x_73 = l_Lean_Elab_Command_failIfSucceeds___closed__3; x_74 = l_Lean_Elab_Command_throwError___rarg(x_1, x_73, x_3, x_72); return x_74; @@ -19348,795 +19464,889 @@ return x_74; } else { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_65, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_65, 1); +uint8_t x_75; +lean_dec(x_56); +lean_dec(x_3); +x_75 = !lean_is_exclusive(x_64); +if (x_75 == 0) +{ +return x_64; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_64, 0); +x_77 = lean_ctor_get(x_64, 1); +lean_inc(x_77); lean_inc(x_76); -lean_dec(x_65); -x_17 = x_75; -x_18 = x_76; -goto block_55; +lean_dec(x_64); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} } } else { -lean_object* x_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_59, 0); -x_78 = lean_ctor_get(x_59, 1); -x_79 = lean_ctor_get(x_59, 2); -x_80 = lean_ctor_get(x_59, 3); -x_81 = lean_ctor_get(x_59, 4); +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_79 = lean_ctor_get(x_58, 0); +x_80 = lean_ctor_get(x_58, 1); +x_81 = lean_ctor_get(x_58, 2); +x_82 = lean_ctor_get(x_58, 3); +x_83 = lean_ctor_get(x_58, 4); +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_59); -x_82 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_78); -lean_inc(x_8); -x_83 = l_Std_PersistentArray_append___rarg(x_8, x_82); -lean_dec(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_83); -lean_ctor_set(x_84, 2, x_79); -lean_ctor_set(x_84, 3, x_80); -lean_ctor_set(x_84, 4, x_81); +lean_dec(x_58); +x_84 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_80); +x_85 = l_Std_PersistentArray_append___rarg(x_8, x_84); +lean_dec(x_84); +x_86 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_86, 0, x_79); +lean_ctor_set(x_86, 1, x_85); +lean_ctor_set(x_86, 2, x_81); +lean_ctor_set(x_86, 3, x_82); +lean_ctor_set(x_86, 4, x_83); lean_inc(x_3); -x_85 = l___private_Lean_Elab_Command_3__setState(x_84, x_3, x_60); -if (lean_obj_tag(x_85) == 0) +x_87 = l___private_Lean_Elab_Command_3__setState(x_86, x_3, x_59); +if (lean_obj_tag(x_87) == 0) { -lean_dec(x_8); -if (x_56 == 0) +uint8_t x_88; +x_88 = lean_unbox(x_56); +lean_dec(x_56); +if (x_88 == 0) { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; +lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_dec(x_3); -x_86 = lean_ctor_get(x_85, 1); -lean_inc(x_86); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_87 = x_85; +x_89 = lean_ctor_get(x_87, 1); +lean_inc(x_89); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + x_90 = x_87; } else { - lean_dec_ref(x_85); - x_87 = lean_box(0); + lean_dec_ref(x_87); + x_90 = lean_box(0); } -x_88 = lean_box(0); -if (lean_is_scalar(x_87)) { - x_89 = lean_alloc_ctor(0, 2, 0); +x_91 = lean_box(0); +if (lean_is_scalar(x_90)) { + x_92 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_87; + x_92 = x_90; } -lean_ctor_set(x_89, 0, x_88); -lean_ctor_set(x_89, 1, x_86); -return x_89; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_85, 1); -lean_inc(x_90); -lean_dec(x_85); -x_91 = l_Lean_Elab_Command_failIfSucceeds___closed__3; -x_92 = l_Lean_Elab_Command_throwError___rarg(x_1, x_91, x_3, x_90); +lean_ctor_set(x_92, 0, x_91); +lean_ctor_set(x_92, 1, x_89); return x_92; } -} else { -lean_object* x_93; lean_object* x_94; -x_93 = lean_ctor_get(x_85, 0); +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_87, 1); lean_inc(x_93); -x_94 = lean_ctor_get(x_85, 1); -lean_inc(x_94); -lean_dec(x_85); -x_17 = x_93; -x_18 = x_94; -goto block_55; -} +lean_dec(x_87); +x_94 = l_Lean_Elab_Command_failIfSucceeds___closed__3; +x_95 = l_Lean_Elab_Command_throwError___rarg(x_1, x_94, x_3, x_93); +return x_95; } } else { -lean_object* x_95; lean_object* x_96; -x_95 = lean_ctor_get(x_58, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_58, 1); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +lean_dec(x_56); +lean_dec(x_3); +x_96 = lean_ctor_get(x_87, 0); lean_inc(x_96); -lean_dec(x_58); -x_17 = x_95; -x_18 = x_96; -goto block_55; +x_97 = lean_ctor_get(x_87, 1); +lean_inc(x_97); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + x_98 = x_87; +} else { + lean_dec_ref(x_87); + x_98 = lean_box(0); +} +if (lean_is_scalar(x_98)) { + x_99 = lean_alloc_ctor(1, 2, 0); +} else { + x_99 = x_98; +} +lean_ctor_set(x_99, 0, x_96); +lean_ctor_set(x_99, 1, x_97); +return x_99; } } -block_133: +} +else { -if (lean_obj_tag(x_98) == 0) +uint8_t x_100; +lean_dec(x_56); +lean_dec(x_8); +lean_dec(x_3); +x_100 = !lean_is_exclusive(x_57); +if (x_100 == 0) { -lean_object* x_100; lean_object* x_101; -x_100 = lean_ctor_get(x_98, 0); -lean_inc(x_100); -lean_dec(x_98); -lean_inc(x_3); -x_101 = l___private_Lean_Elab_Command_2__getState(x_3, x_99); -if (lean_obj_tag(x_101) == 0) +return x_57; +} +else { -lean_object* x_102; lean_object* x_103; uint8_t x_104; -x_102 = lean_ctor_get(x_101, 0); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_57, 0); +x_102 = lean_ctor_get(x_57, 1); lean_inc(x_102); -x_103 = lean_ctor_get(x_101, 1); -lean_inc(x_103); -lean_dec(x_101); -x_104 = !lean_is_exclusive(x_102); -if (x_104 == 0) -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_105 = lean_ctor_get(x_102, 1); -x_106 = l_Std_PersistentArray_push___rarg(x_105, x_100); -lean_ctor_set(x_102, 1, x_106); -lean_inc(x_3); -x_107 = l___private_Lean_Elab_Command_3__setState(x_102, x_3, x_103); -if (lean_obj_tag(x_107) == 0) -{ -lean_object* x_108; uint8_t x_109; -x_108 = lean_ctor_get(x_107, 1); -lean_inc(x_108); -lean_dec(x_107); -x_109 = 0; -x_56 = x_109; -x_57 = x_108; -goto block_97; +lean_inc(x_101); +lean_dec(x_57); +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 +} +} +} +block_144: { -lean_object* x_110; lean_object* x_111; -x_110 = lean_ctor_get(x_107, 0); +if (lean_obj_tag(x_105) == 0) +{ +lean_object* x_107; lean_object* x_108; +x_107 = lean_ctor_get(x_105, 0); +lean_inc(x_107); +lean_dec(x_105); +lean_inc(x_3); +x_108 = l___private_Lean_Elab_Command_2__getState(x_3, x_106); +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, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_108, 1); lean_inc(x_110); -x_111 = lean_ctor_get(x_107, 1); -lean_inc(x_111); -lean_dec(x_107); -x_17 = x_110; -x_18 = x_111; -goto block_55; -} -} -else +lean_dec(x_108); +x_111 = !lean_is_exclusive(x_109); +if (x_111 == 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_119; -x_112 = lean_ctor_get(x_102, 0); -x_113 = lean_ctor_get(x_102, 1); -x_114 = lean_ctor_get(x_102, 2); -x_115 = lean_ctor_get(x_102, 3); -x_116 = lean_ctor_get(x_102, 4); -lean_inc(x_116); +lean_object* x_112; lean_object* x_113; lean_object* x_114; +x_112 = lean_ctor_get(x_109, 1); +x_113 = l_Std_PersistentArray_push___rarg(x_112, x_107); +lean_ctor_set(x_109, 1, x_113); +lean_inc(x_3); +x_114 = l___private_Lean_Elab_Command_3__setState(x_109, x_3, x_110); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; lean_object* x_116; +x_115 = lean_ctor_get(x_114, 1); lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_102); -x_117 = l_Std_PersistentArray_push___rarg(x_113, x_100); -x_118 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_118, 0, x_112); -lean_ctor_set(x_118, 1, x_117); -lean_ctor_set(x_118, 2, x_114); -lean_ctor_set(x_118, 3, x_115); -lean_ctor_set(x_118, 4, x_116); -lean_inc(x_3); -x_119 = l___private_Lean_Elab_Command_3__setState(x_118, x_3, x_103); -if (lean_obj_tag(x_119) == 0) -{ -lean_object* x_120; uint8_t x_121; -x_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -lean_dec(x_119); -x_121 = 0; -x_56 = x_121; -x_57 = x_120; -goto block_97; +lean_dec(x_114); +x_116 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_17 = x_116; +x_18 = x_115; +goto block_104; } else { -lean_object* x_122; lean_object* x_123; -x_122 = lean_ctor_get(x_119, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_119, 1); -lean_inc(x_123); -lean_dec(x_119); -x_17 = x_122; -x_18 = x_123; -goto block_55; -} +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_114, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_114, 1); +lean_inc(x_118); +lean_dec(x_114); +x_119 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_119, 0, x_117); +x_17 = x_119; +x_18 = x_118; +goto block_104; } } else { -lean_object* x_124; lean_object* x_125; -lean_dec(x_100); -x_124 = lean_ctor_get(x_101, 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_127; +x_120 = lean_ctor_get(x_109, 0); +x_121 = lean_ctor_get(x_109, 1); +x_122 = lean_ctor_get(x_109, 2); +x_123 = lean_ctor_get(x_109, 3); +x_124 = lean_ctor_get(x_109, 4); lean_inc(x_124); -x_125 = lean_ctor_get(x_101, 1); -lean_inc(x_125); -lean_dec(x_101); -x_17 = x_124; -x_18 = x_125; -goto block_55; -} -} -else -{ -uint8_t x_126; lean_object* x_127; lean_object* x_128; -x_126 = 2; -x_127 = l_Lean_Elab_Command_failIfSucceeds___closed__5; +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_109); +x_125 = l_Std_PersistentArray_push___rarg(x_121, x_107); +x_126 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_126, 0, x_120); +lean_ctor_set(x_126, 1, x_125); +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_inc(x_3); -x_128 = l_Lean_Elab_log___at_Lean_Elab_Command_logTrace___spec__1(x_1, x_126, x_127, x_3, x_99); -if (lean_obj_tag(x_128) == 0) +x_127 = l___private_Lean_Elab_Command_3__setState(x_126, x_3, x_110); +if (lean_obj_tag(x_127) == 0) { -lean_object* x_129; uint8_t x_130; -x_129 = lean_ctor_get(x_128, 1); -lean_inc(x_129); -lean_dec(x_128); -x_130 = 0; -x_56 = x_130; -x_57 = x_129; -goto block_97; +lean_object* x_128; lean_object* x_129; +x_128 = lean_ctor_get(x_127, 1); +lean_inc(x_128); +lean_dec(x_127); +x_129 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_17 = x_129; +x_18 = x_128; +goto block_104; } else { -lean_object* x_131; lean_object* x_132; -x_131 = lean_ctor_get(x_128, 0); +lean_object* x_130; lean_object* x_131; lean_object* x_132; +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_128, 1); -lean_inc(x_132); -lean_dec(x_128); -x_17 = x_131; -x_18 = x_132; -goto block_55; +lean_dec(x_127); +x_132 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_132, 0, x_130); +x_17 = x_132; +x_18 = x_131; +goto block_104; +} +} +} +else +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; +lean_dec(x_107); +x_133 = lean_ctor_get(x_108, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_108, 1); +lean_inc(x_134); +lean_dec(x_108); +x_135 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_135, 0, x_133); +x_17 = x_135; +x_18 = x_134; +goto block_104; +} +} +else +{ +uint8_t x_136; lean_object* x_137; lean_object* x_138; +x_136 = 2; +x_137 = l_Lean_Elab_Command_failIfSucceeds___closed__6; +lean_inc(x_3); +x_138 = l_Lean_Elab_log___at_Lean_Elab_Command_logTrace___spec__1(x_1, x_136, x_137, x_3, x_106); +if (lean_obj_tag(x_138) == 0) +{ +lean_object* x_139; lean_object* x_140; +x_139 = lean_ctor_get(x_138, 1); +lean_inc(x_139); +lean_dec(x_138); +x_140 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_17 = x_140; +x_18 = x_139; +goto block_104; +} +else +{ +lean_object* x_141; lean_object* x_142; lean_object* x_143; +x_141 = lean_ctor_get(x_138, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_138, 1); +lean_inc(x_142); +lean_dec(x_138); +x_143 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_143, 0, x_141); +x_17 = x_143; +x_18 = x_142; +goto block_104; } } } } else { -uint8_t x_144; +uint8_t x_155; lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_144 = !lean_is_exclusive(x_15); -if (x_144 == 0) +x_155 = !lean_is_exclusive(x_15); +if (x_155 == 0) { return x_15; } else { -lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_145 = lean_ctor_get(x_15, 0); -x_146 = lean_ctor_get(x_15, 1); -lean_inc(x_146); -lean_inc(x_145); +lean_object* x_156; lean_object* x_157; lean_object* x_158; +x_156 = lean_ctor_get(x_15, 0); +x_157 = lean_ctor_get(x_15, 1); +lean_inc(x_157); +lean_inc(x_156); lean_dec(x_15); -x_147 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_147, 0, x_145); -lean_ctor_set(x_147, 1, x_146); -return x_147; +x_158 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_158, 0, x_156); +lean_ctor_set(x_158, 1, x_157); +return x_158; } } } else { -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_148 = lean_ctor_get(x_10, 0); -x_149 = lean_ctor_get(x_10, 2); -x_150 = lean_ctor_get(x_10, 3); -x_151 = lean_ctor_get(x_10, 4); -lean_inc(x_151); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); +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_159 = lean_ctor_get(x_10, 0); +x_160 = lean_ctor_get(x_10, 2); +x_161 = lean_ctor_get(x_10, 3); +x_162 = lean_ctor_get(x_10, 4); +lean_inc(x_162); +lean_inc(x_161); +lean_inc(x_160); +lean_inc(x_159); lean_dec(x_10); -x_152 = l_Std_PersistentArray_empty___closed__3; -x_153 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_153, 0, x_148); -lean_ctor_set(x_153, 1, x_152); -lean_ctor_set(x_153, 2, x_149); -lean_ctor_set(x_153, 3, x_150); -lean_ctor_set(x_153, 4, x_151); +x_163 = l_Std_PersistentArray_empty___closed__3; +x_164 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_164, 0, x_159); +lean_ctor_set(x_164, 1, x_163); +lean_ctor_set(x_164, 2, x_160); +lean_ctor_set(x_164, 3, x_161); +lean_ctor_set(x_164, 4, x_162); lean_inc(x_3); -x_154 = l___private_Lean_Elab_Command_3__setState(x_153, x_3, x_11); -if (lean_obj_tag(x_154) == 0) +x_165 = l___private_Lean_Elab_Command_3__setState(x_164, x_3, x_11); +if (lean_obj_tag(x_165) == 0) { -lean_object* x_155; lean_object* x_156; lean_object* x_157; uint8_t x_183; lean_object* x_184; lean_object* x_210; lean_object* x_211; lean_object* x_239; -x_155 = lean_ctor_get(x_154, 1); -lean_inc(x_155); -lean_dec(x_154); +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_225; lean_object* x_226; lean_object* x_257; +x_166 = lean_ctor_get(x_165, 1); +lean_inc(x_166); +lean_dec(x_165); lean_inc(x_3); -x_239 = lean_apply_2(x_2, x_3, x_155); +x_257 = lean_apply_2(x_2, x_3, x_166); +if (lean_obj_tag(x_257) == 0) +{ +lean_object* x_258; lean_object* x_259; +x_258 = lean_ctor_get(x_257, 1); +lean_inc(x_258); +lean_dec(x_257); +lean_inc(x_3); +x_259 = l_Lean_Elab_Command_hasNoErrorMessages(x_3, x_258); +if (lean_obj_tag(x_259) == 0) +{ +lean_object* x_260; lean_object* x_261; lean_object* x_262; +x_260 = lean_ctor_get(x_259, 0); +lean_inc(x_260); +x_261 = lean_ctor_get(x_259, 1); +lean_inc(x_261); +lean_dec(x_259); +x_262 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_262, 0, x_260); +x_167 = x_262; +x_168 = x_261; +goto block_224; +} +else +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_259, 0); +lean_inc(x_263); +x_264 = lean_ctor_get(x_259, 1); +lean_inc(x_264); +lean_dec(x_259); +x_225 = x_263; +x_226 = x_264; +goto block_256; +} +} +else +{ +lean_object* x_265; lean_object* x_266; +x_265 = lean_ctor_get(x_257, 0); +lean_inc(x_265); +x_266 = lean_ctor_get(x_257, 1); +lean_inc(x_266); +lean_dec(x_257); +x_225 = x_265; +x_226 = x_266; +goto block_256; +} +block_224: +{ +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_169; lean_object* x_170; +x_169 = lean_ctor_get(x_167, 0); +lean_inc(x_169); +lean_dec(x_167); +lean_inc(x_3); +x_170 = l___private_Lean_Elab_Command_2__getState(x_3, x_168); +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; 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_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_ctor_get(x_171, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_171, 1); +lean_inc(x_174); +x_175 = lean_ctor_get(x_171, 2); +lean_inc(x_175); +x_176 = lean_ctor_get(x_171, 3); +lean_inc(x_176); +x_177 = lean_ctor_get(x_171, 4); +lean_inc(x_177); +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_178 = x_171; +} else { + lean_dec_ref(x_171); + x_178 = lean_box(0); +} +x_179 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_174); +x_180 = l_Std_PersistentArray_append___rarg(x_8, x_179); +lean_dec(x_179); +if (lean_is_scalar(x_178)) { + x_181 = lean_alloc_ctor(0, 5, 0); +} else { + x_181 = x_178; +} +lean_ctor_set(x_181, 0, x_173); +lean_ctor_set(x_181, 1, x_180); +lean_ctor_set(x_181, 2, x_175); +lean_ctor_set(x_181, 3, x_176); +lean_ctor_set(x_181, 4, x_177); +x_182 = l___private_Lean_Elab_Command_3__setState(x_181, x_3, x_172); +if (lean_obj_tag(x_182) == 0) +{ +lean_object* x_183; lean_object* x_184; lean_object* x_185; +x_183 = lean_ctor_get(x_182, 1); +lean_inc(x_183); +if (lean_is_exclusive(x_182)) { + lean_ctor_release(x_182, 0); + lean_ctor_release(x_182, 1); + x_184 = x_182; +} else { + lean_dec_ref(x_182); + x_184 = lean_box(0); +} +if (lean_is_scalar(x_184)) { + x_185 = lean_alloc_ctor(1, 2, 0); +} else { + x_185 = x_184; + lean_ctor_set_tag(x_185, 1); +} +lean_ctor_set(x_185, 0, x_169); +lean_ctor_set(x_185, 1, x_183); +return x_185; +} +else +{ +lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; +lean_dec(x_169); +x_186 = lean_ctor_get(x_182, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_182, 1); +lean_inc(x_187); +if (lean_is_exclusive(x_182)) { + lean_ctor_release(x_182, 0); + lean_ctor_release(x_182, 1); + x_188 = x_182; +} else { + lean_dec_ref(x_182); + x_188 = lean_box(0); +} +if (lean_is_scalar(x_188)) { + x_189 = lean_alloc_ctor(1, 2, 0); +} else { + x_189 = x_188; +} +lean_ctor_set(x_189, 0, x_186); +lean_ctor_set(x_189, 1, x_187); +return x_189; +} +} +else +{ +lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; +lean_dec(x_169); +lean_dec(x_8); +lean_dec(x_3); +x_190 = lean_ctor_get(x_170, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_170, 1); +lean_inc(x_191); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + x_192 = x_170; +} else { + lean_dec_ref(x_170); + x_192 = lean_box(0); +} +if (lean_is_scalar(x_192)) { + x_193 = lean_alloc_ctor(1, 2, 0); +} else { + x_193 = x_192; +} +lean_ctor_set(x_193, 0, x_190); +lean_ctor_set(x_193, 1, x_191); +return x_193; +} +} +else +{ +lean_object* x_194; lean_object* x_195; +x_194 = lean_ctor_get(x_167, 0); +lean_inc(x_194); +lean_dec(x_167); +lean_inc(x_3); +x_195 = l___private_Lean_Elab_Command_2__getState(x_3, x_168); +if (lean_obj_tag(x_195) == 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; +x_196 = lean_ctor_get(x_195, 0); +lean_inc(x_196); +x_197 = lean_ctor_get(x_195, 1); +lean_inc(x_197); +lean_dec(x_195); +x_198 = lean_ctor_get(x_196, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_196, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_196, 2); +lean_inc(x_200); +x_201 = lean_ctor_get(x_196, 3); +lean_inc(x_201); +x_202 = lean_ctor_get(x_196, 4); +lean_inc(x_202); +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_203 = x_196; +} else { + lean_dec_ref(x_196); + x_203 = lean_box(0); +} +x_204 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_199); +x_205 = l_Std_PersistentArray_append___rarg(x_8, x_204); +lean_dec(x_204); +if (lean_is_scalar(x_203)) { + x_206 = lean_alloc_ctor(0, 5, 0); +} else { + x_206 = x_203; +} +lean_ctor_set(x_206, 0, x_198); +lean_ctor_set(x_206, 1, x_205); +lean_ctor_set(x_206, 2, x_200); +lean_ctor_set(x_206, 3, x_201); +lean_ctor_set(x_206, 4, x_202); +lean_inc(x_3); +x_207 = l___private_Lean_Elab_Command_3__setState(x_206, x_3, x_197); +if (lean_obj_tag(x_207) == 0) +{ +uint8_t x_208; +x_208 = lean_unbox(x_194); +lean_dec(x_194); +if (x_208 == 0) +{ +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; +lean_dec(x_3); +x_209 = lean_ctor_get(x_207, 1); +lean_inc(x_209); +if (lean_is_exclusive(x_207)) { + lean_ctor_release(x_207, 0); + lean_ctor_release(x_207, 1); + x_210 = x_207; +} else { + lean_dec_ref(x_207); + x_210 = lean_box(0); +} +x_211 = lean_box(0); +if (lean_is_scalar(x_210)) { + x_212 = lean_alloc_ctor(0, 2, 0); +} else { + x_212 = x_210; +} +lean_ctor_set(x_212, 0, x_211); +lean_ctor_set(x_212, 1, x_209); +return x_212; +} +else +{ +lean_object* x_213; lean_object* x_214; lean_object* x_215; +x_213 = lean_ctor_get(x_207, 1); +lean_inc(x_213); +lean_dec(x_207); +x_214 = l_Lean_Elab_Command_failIfSucceeds___closed__3; +x_215 = l_Lean_Elab_Command_throwError___rarg(x_1, x_214, x_3, x_213); +return x_215; +} +} +else +{ +lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +lean_dec(x_194); +lean_dec(x_3); +x_216 = lean_ctor_get(x_207, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_207, 1); +lean_inc(x_217); +if (lean_is_exclusive(x_207)) { + lean_ctor_release(x_207, 0); + lean_ctor_release(x_207, 1); + x_218 = x_207; +} else { + lean_dec_ref(x_207); + x_218 = lean_box(0); +} +if (lean_is_scalar(x_218)) { + x_219 = lean_alloc_ctor(1, 2, 0); +} else { + x_219 = x_218; +} +lean_ctor_set(x_219, 0, x_216); +lean_ctor_set(x_219, 1, x_217); +return x_219; +} +} +else +{ +lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; +lean_dec(x_194); +lean_dec(x_8); +lean_dec(x_3); +x_220 = lean_ctor_get(x_195, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_195, 1); +lean_inc(x_221); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + x_222 = x_195; +} else { + lean_dec_ref(x_195); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(1, 2, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_220); +lean_ctor_set(x_223, 1, x_221); +return x_223; +} +} +} +block_256: +{ +if (lean_obj_tag(x_225) == 0) +{ +lean_object* x_227; lean_object* x_228; +x_227 = lean_ctor_get(x_225, 0); +lean_inc(x_227); +lean_dec(x_225); +lean_inc(x_3); +x_228 = l___private_Lean_Elab_Command_2__getState(x_3, x_226); +if (lean_obj_tag(x_228) == 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; +x_229 = lean_ctor_get(x_228, 0); +lean_inc(x_229); +x_230 = lean_ctor_get(x_228, 1); +lean_inc(x_230); +lean_dec(x_228); +x_231 = lean_ctor_get(x_229, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_229, 1); +lean_inc(x_232); +x_233 = lean_ctor_get(x_229, 2); +lean_inc(x_233); +x_234 = lean_ctor_get(x_229, 3); +lean_inc(x_234); +x_235 = lean_ctor_get(x_229, 4); +lean_inc(x_235); +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_236 = x_229; +} else { + lean_dec_ref(x_229); + x_236 = lean_box(0); +} +x_237 = l_Std_PersistentArray_push___rarg(x_232, x_227); +if (lean_is_scalar(x_236)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_236; +} +lean_ctor_set(x_238, 0, x_231); +lean_ctor_set(x_238, 1, x_237); +lean_ctor_set(x_238, 2, x_233); +lean_ctor_set(x_238, 3, x_234); +lean_ctor_set(x_238, 4, x_235); +lean_inc(x_3); +x_239 = l___private_Lean_Elab_Command_3__setState(x_238, x_3, x_230); if (lean_obj_tag(x_239) == 0) { lean_object* x_240; lean_object* x_241; x_240 = lean_ctor_get(x_239, 1); lean_inc(x_240); lean_dec(x_239); -lean_inc(x_3); -x_241 = l_Lean_Elab_Command_hasNoErrorMessages(x_3, x_240); -if (lean_obj_tag(x_241) == 0) +x_241 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_167 = x_241; +x_168 = x_240; +goto block_224; +} +else { -lean_object* x_242; lean_object* x_243; uint8_t x_244; -x_242 = lean_ctor_get(x_241, 0); +lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_242 = lean_ctor_get(x_239, 0); lean_inc(x_242); -x_243 = lean_ctor_get(x_241, 1); +x_243 = lean_ctor_get(x_239, 1); lean_inc(x_243); -lean_dec(x_241); -x_244 = lean_unbox(x_242); -lean_dec(x_242); -x_183 = x_244; -x_184 = x_243; -goto block_209; -} -else -{ -lean_object* x_245; lean_object* x_246; -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_210 = x_245; -x_211 = x_246; -goto block_238; -} -} -else -{ -lean_object* x_247; lean_object* x_248; -x_247 = lean_ctor_get(x_239, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_239, 1); -lean_inc(x_248); lean_dec(x_239); -x_210 = x_247; -x_211 = x_248; -goto block_238; +x_244 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_244, 0, x_242); +x_167 = x_244; +x_168 = x_243; +goto block_224; } -block_182: +} +else { -lean_object* x_158; +lean_object* x_245; lean_object* x_246; lean_object* x_247; +lean_dec(x_227); +x_245 = lean_ctor_get(x_228, 0); +lean_inc(x_245); +x_246 = lean_ctor_get(x_228, 1); +lean_inc(x_246); +lean_dec(x_228); +x_247 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_247, 0, x_245); +x_167 = x_247; +x_168 = x_246; +goto block_224; +} +} +else +{ +uint8_t x_248; lean_object* x_249; lean_object* x_250; +x_248 = 2; +x_249 = l_Lean_Elab_Command_failIfSucceeds___closed__6; lean_inc(x_3); -x_158 = l___private_Lean_Elab_Command_2__getState(x_3, x_157); -if (lean_obj_tag(x_158) == 0) +x_250 = l_Lean_Elab_log___at_Lean_Elab_Command_logTrace___spec__1(x_1, x_248, x_249, x_3, x_226); +if (lean_obj_tag(x_250) == 0) { -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_159 = lean_ctor_get(x_158, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_158, 1); -lean_inc(x_160); -lean_dec(x_158); -x_161 = lean_ctor_get(x_159, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_159, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_159, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_159, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_159)) { - lean_ctor_release(x_159, 0); - lean_ctor_release(x_159, 1); - lean_ctor_release(x_159, 2); - lean_ctor_release(x_159, 3); - lean_ctor_release(x_159, 4); - x_166 = x_159; -} else { - lean_dec_ref(x_159); - x_166 = lean_box(0); -} -x_167 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_162); -x_168 = l_Std_PersistentArray_append___rarg(x_8, x_167); -lean_dec(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_168); -lean_ctor_set(x_169, 2, x_163); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l___private_Lean_Elab_Command_3__setState(x_169, x_3, x_160); -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, 1); -lean_inc(x_171); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_172 = x_170; -} else { - lean_dec_ref(x_170); - x_172 = lean_box(0); -} -if (lean_is_scalar(x_172)) { - x_173 = lean_alloc_ctor(1, 2, 0); -} else { - x_173 = x_172; - lean_ctor_set_tag(x_173, 1); -} -lean_ctor_set(x_173, 0, x_156); -lean_ctor_set(x_173, 1, x_171); -return x_173; +lean_object* x_251; lean_object* x_252; +x_251 = lean_ctor_get(x_250, 1); +lean_inc(x_251); +lean_dec(x_250); +x_252 = l_Lean_Elab_Command_failIfSucceeds___closed__4; +x_167 = x_252; +x_168 = x_251; +goto block_224; } else { -lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; -lean_dec(x_156); -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_176 = x_170; -} else { - lean_dec_ref(x_170); - x_176 = lean_box(0); -} -if (lean_is_scalar(x_176)) { - x_177 = lean_alloc_ctor(1, 2, 0); -} else { - x_177 = x_176; -} -lean_ctor_set(x_177, 0, x_174); -lean_ctor_set(x_177, 1, x_175); -return x_177; -} -} -else -{ -lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -lean_dec(x_156); -lean_dec(x_8); -lean_dec(x_3); -x_178 = lean_ctor_get(x_158, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_158, 1); -lean_inc(x_179); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_180 = x_158; -} else { - lean_dec_ref(x_158); - x_180 = lean_box(0); -} -if (lean_is_scalar(x_180)) { - x_181 = lean_alloc_ctor(1, 2, 0); -} else { - x_181 = x_180; -} -lean_ctor_set(x_181, 0, x_178); -lean_ctor_set(x_181, 1, x_179); -return x_181; -} -} -block_209: -{ -lean_object* x_185; -lean_inc(x_3); -x_185 = l___private_Lean_Elab_Command_2__getState(x_3, x_184); -if (lean_obj_tag(x_185) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; -x_186 = lean_ctor_get(x_185, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_185, 1); -lean_inc(x_187); -lean_dec(x_185); -x_188 = lean_ctor_get(x_186, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_186, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_186, 2); -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); -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); - x_193 = x_186; -} else { - lean_dec_ref(x_186); - x_193 = lean_box(0); -} -x_194 = l_Std_PersistentArray_mapM___at_Lean_MessageLog_errorsToWarnings___spec__1(x_189); -lean_inc(x_8); -x_195 = l_Std_PersistentArray_append___rarg(x_8, x_194); -lean_dec(x_194); -if (lean_is_scalar(x_193)) { - x_196 = lean_alloc_ctor(0, 5, 0); -} else { - x_196 = x_193; -} -lean_ctor_set(x_196, 0, x_188); -lean_ctor_set(x_196, 1, x_195); -lean_ctor_set(x_196, 2, x_190); -lean_ctor_set(x_196, 3, x_191); -lean_ctor_set(x_196, 4, x_192); -lean_inc(x_3); -x_197 = l___private_Lean_Elab_Command_3__setState(x_196, x_3, x_187); -if (lean_obj_tag(x_197) == 0) -{ -lean_dec(x_8); -if (x_183 == 0) -{ -lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -lean_dec(x_3); -x_198 = lean_ctor_get(x_197, 1); -lean_inc(x_198); -if (lean_is_exclusive(x_197)) { - lean_ctor_release(x_197, 0); - lean_ctor_release(x_197, 1); - x_199 = x_197; -} else { - lean_dec_ref(x_197); - x_199 = lean_box(0); -} -x_200 = lean_box(0); -if (lean_is_scalar(x_199)) { - x_201 = lean_alloc_ctor(0, 2, 0); -} else { - x_201 = x_199; -} -lean_ctor_set(x_201, 0, x_200); -lean_ctor_set(x_201, 1, x_198); -return x_201; -} -else -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_202 = lean_ctor_get(x_197, 1); -lean_inc(x_202); -lean_dec(x_197); -x_203 = l_Lean_Elab_Command_failIfSucceeds___closed__3; -x_204 = l_Lean_Elab_Command_throwError___rarg(x_1, x_203, x_3, x_202); -return x_204; -} -} -else -{ -lean_object* x_205; lean_object* x_206; -x_205 = lean_ctor_get(x_197, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_197, 1); -lean_inc(x_206); -lean_dec(x_197); -x_156 = x_205; -x_157 = x_206; -goto block_182; -} -} -else -{ -lean_object* x_207; lean_object* x_208; -x_207 = lean_ctor_get(x_185, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_185, 1); -lean_inc(x_208); -lean_dec(x_185); -x_156 = x_207; -x_157 = x_208; -goto block_182; -} -} -block_238: -{ -if (lean_obj_tag(x_210) == 0) -{ -lean_object* x_212; lean_object* x_213; -x_212 = lean_ctor_get(x_210, 0); -lean_inc(x_212); -lean_dec(x_210); -lean_inc(x_3); -x_213 = l___private_Lean_Elab_Command_2__getState(x_3, x_211); -if (lean_obj_tag(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; -x_214 = lean_ctor_get(x_213, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_213, 1); -lean_inc(x_215); -lean_dec(x_213); -x_216 = lean_ctor_get(x_214, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_214, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_214, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_214, 3); -lean_inc(x_219); -x_220 = lean_ctor_get(x_214, 4); -lean_inc(x_220); -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_221 = x_214; -} else { - lean_dec_ref(x_214); - x_221 = lean_box(0); -} -x_222 = l_Std_PersistentArray_push___rarg(x_217, x_212); -if (lean_is_scalar(x_221)) { - x_223 = lean_alloc_ctor(0, 5, 0); -} else { - x_223 = x_221; -} -lean_ctor_set(x_223, 0, x_216); -lean_ctor_set(x_223, 1, x_222); -lean_ctor_set(x_223, 2, x_218); -lean_ctor_set(x_223, 3, x_219); -lean_ctor_set(x_223, 4, x_220); -lean_inc(x_3); -x_224 = l___private_Lean_Elab_Command_3__setState(x_223, x_3, x_215); -if (lean_obj_tag(x_224) == 0) -{ -lean_object* x_225; uint8_t x_226; -x_225 = lean_ctor_get(x_224, 1); -lean_inc(x_225); -lean_dec(x_224); -x_226 = 0; -x_183 = x_226; -x_184 = x_225; -goto block_209; -} -else -{ -lean_object* x_227; lean_object* x_228; -x_227 = lean_ctor_get(x_224, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_224, 1); -lean_inc(x_228); -lean_dec(x_224); -x_156 = x_227; -x_157 = x_228; -goto block_182; -} -} -else -{ -lean_object* x_229; lean_object* x_230; -lean_dec(x_212); -x_229 = lean_ctor_get(x_213, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_213, 1); -lean_inc(x_230); -lean_dec(x_213); -x_156 = x_229; -x_157 = x_230; -goto block_182; -} -} -else -{ -uint8_t x_231; lean_object* x_232; lean_object* x_233; -x_231 = 2; -x_232 = l_Lean_Elab_Command_failIfSucceeds___closed__5; -lean_inc(x_3); -x_233 = l_Lean_Elab_log___at_Lean_Elab_Command_logTrace___spec__1(x_1, x_231, x_232, x_3, x_211); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; uint8_t x_235; -x_234 = lean_ctor_get(x_233, 1); -lean_inc(x_234); -lean_dec(x_233); -x_235 = 0; -x_183 = x_235; -x_184 = x_234; -goto block_209; -} -else -{ -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_233, 0); -lean_inc(x_236); -x_237 = lean_ctor_get(x_233, 1); -lean_inc(x_237); -lean_dec(x_233); -x_156 = x_236; -x_157 = x_237; -goto block_182; +lean_object* x_253; lean_object* x_254; lean_object* x_255; +x_253 = lean_ctor_get(x_250, 0); +lean_inc(x_253); +x_254 = lean_ctor_get(x_250, 1); +lean_inc(x_254); +lean_dec(x_250); +x_255 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_255, 0, x_253); +x_167 = x_255; +x_168 = x_254; +goto block_224; } } } } else { -lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_249 = lean_ctor_get(x_154, 0); -lean_inc(x_249); -x_250 = lean_ctor_get(x_154, 1); -lean_inc(x_250); -if (lean_is_exclusive(x_154)) { - lean_ctor_release(x_154, 0); - lean_ctor_release(x_154, 1); - x_251 = x_154; +x_267 = lean_ctor_get(x_165, 0); +lean_inc(x_267); +x_268 = lean_ctor_get(x_165, 1); +lean_inc(x_268); +if (lean_is_exclusive(x_165)) { + lean_ctor_release(x_165, 0); + lean_ctor_release(x_165, 1); + x_269 = x_165; } else { - lean_dec_ref(x_154); - x_251 = lean_box(0); + lean_dec_ref(x_165); + x_269 = lean_box(0); } -if (lean_is_scalar(x_251)) { - x_252 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_269)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_252 = x_251; + x_270 = x_269; } -lean_ctor_set(x_252, 0, x_249); -lean_ctor_set(x_252, 1, x_250); -return x_252; +lean_ctor_set(x_270, 0, x_267); +lean_ctor_set(x_270, 1, x_268); +return x_270; } } } else { -uint8_t x_253; +uint8_t x_271; lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_253 = !lean_is_exclusive(x_9); -if (x_253 == 0) +x_271 = !lean_is_exclusive(x_9); +if (x_271 == 0) { return x_9; } else { -lean_object* x_254; lean_object* x_255; lean_object* x_256; -x_254 = lean_ctor_get(x_9, 0); -x_255 = lean_ctor_get(x_9, 1); -lean_inc(x_255); -lean_inc(x_254); +lean_object* x_272; lean_object* x_273; lean_object* x_274; +x_272 = lean_ctor_get(x_9, 0); +x_273 = lean_ctor_get(x_9, 1); +lean_inc(x_273); +lean_inc(x_272); lean_dec(x_9); -x_256 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_256, 0, x_254); -lean_ctor_set(x_256, 1, x_255); -return x_256; +x_274 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_274, 0, x_272); +lean_ctor_set(x_274, 1, x_273); +return x_274; } } } else { -uint8_t x_257; +uint8_t x_275; lean_dec(x_3); lean_dec(x_2); -x_257 = !lean_is_exclusive(x_5); -if (x_257 == 0) +x_275 = !lean_is_exclusive(x_5); +if (x_275 == 0) { return x_5; } else { -lean_object* x_258; lean_object* x_259; lean_object* x_260; -x_258 = lean_ctor_get(x_5, 0); -x_259 = lean_ctor_get(x_5, 1); -lean_inc(x_259); -lean_inc(x_258); +lean_object* x_276; lean_object* x_277; lean_object* x_278; +x_276 = lean_ctor_get(x_5, 0); +x_277 = lean_ctor_get(x_5, 1); +lean_inc(x_277); +lean_inc(x_276); lean_dec(x_5); -x_260 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_260, 0, x_258); -lean_ctor_set(x_260, 1, x_259); -return x_260; +x_278 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_278, 0, x_276); +lean_ctor_set(x_278, 1, x_277); +return x_278; } } } @@ -21911,386 +22121,386 @@ lean_inc(x_2); x_6 = l_Lean_Elab_Command_getEnv(x_2, x_3); 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_21; lean_object* x_22; lean_object* x_62; +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_21; lean_object* x_22; lean_object* x_55; x_7 = lean_ctor_get(x_6, 0); lean_inc(x_7); x_8 = lean_ctor_get(x_6, 1); lean_inc(x_8); lean_dec(x_6); lean_inc(x_2); -x_62 = l_Lean_Elab_Command_getEnv(x_2, x_8); -if (lean_obj_tag(x_62) == 0) +x_55 = l_Lean_Elab_Command_getEnv(x_2, x_8); +if (lean_obj_tag(x_55) == 0) { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_63 = lean_ctor_get(x_62, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_62, 1); -lean_inc(x_64); -lean_dec(x_62); -x_65 = l_Lean_Elab_Command_elabEvalUnsafe___closed__2; +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_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = l_Lean_Elab_Command_elabEvalUnsafe___closed__2; lean_inc(x_1); -x_66 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabEvalUnsafe___lambda__3___boxed), 7, 4); -lean_closure_set(x_66, 0, x_5); -lean_closure_set(x_66, 1, x_63); -lean_closure_set(x_66, 2, x_1); -lean_closure_set(x_66, 3, x_65); +x_59 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabEvalUnsafe___lambda__3___boxed), 7, 4); +lean_closure_set(x_59, 0, x_5); +lean_closure_set(x_59, 1, x_56); +lean_closure_set(x_59, 2, x_1); +lean_closure_set(x_59, 3, x_58); lean_inc(x_2); -x_67 = l___private_Lean_Elab_Command_2__getState(x_2, x_64); -if (lean_obj_tag(x_67) == 0) +x_60 = l___private_Lean_Elab_Command_2__getState(x_2, x_57); +if (lean_obj_tag(x_60) == 0) { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_68 = lean_ctor_get(x_67, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_67, 1); -lean_inc(x_69); -lean_dec(x_67); -x_70 = l___private_Lean_Elab_Command_9__getVarDecls(x_68); -lean_dec(x_68); +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +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 = l___private_Lean_Elab_Command_9__getVarDecls(x_61); +lean_dec(x_61); lean_inc(x_2); -x_71 = l___private_Lean_Elab_Command_2__getState(x_2, x_69); -if (lean_obj_tag(x_71) == 0) +x_64 = l___private_Lean_Elab_Command_2__getState(x_2, x_62); +if (lean_obj_tag(x_64) == 0) { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_72 = lean_ctor_get(x_71, 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; +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 = l_Lean_Elab_Command_elabEvalUnsafe___closed__3; +x_68 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_65, x_67); +x_69 = l___private_Lean_Elab_Command_7__mkTermState(x_65); +lean_dec(x_65); +x_70 = l_Lean_Elab_Term_elabBinders___rarg(x_63, x_59, x_68, x_69); +lean_dec(x_63); +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); -x_73 = lean_ctor_get(x_71, 1); -lean_inc(x_73); -lean_dec(x_71); -x_74 = l_Lean_Elab_Command_elabEvalUnsafe___closed__3; -x_75 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_72, x_74); -x_76 = l___private_Lean_Elab_Command_7__mkTermState(x_72); -lean_dec(x_72); -x_77 = l_Lean_Elab_Term_elabBinders___rarg(x_70, x_66, x_75, x_76); lean_dec(x_70); -if (lean_obj_tag(x_77) == 0) +lean_inc(x_2); +x_73 = l___private_Lean_Elab_Command_2__getState(x_2, x_66); +if (lean_obj_tag(x_73) == 0) { -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_77, 0); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; uint8_t x_79; +x_74 = lean_ctor_get(x_72, 0); +lean_inc(x_74); +x_75 = lean_ctor_get(x_73, 0); +lean_inc(x_75); +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +lean_dec(x_73); +x_77 = lean_ctor_get(x_74, 0); +lean_inc(x_77); +lean_dec(x_74); +x_78 = lean_ctor_get(x_72, 2); lean_inc(x_78); -x_79 = lean_ctor_get(x_77, 1); -lean_inc(x_79); -lean_dec(x_77); -lean_inc(x_2); -x_80 = l___private_Lean_Elab_Command_2__getState(x_2, x_73); -if (lean_obj_tag(x_80) == 0) +lean_dec(x_72); +x_79 = !lean_is_exclusive(x_75); +if (x_79 == 0) { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_81 = lean_ctor_get(x_79, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_80, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_80, 1); -lean_inc(x_83); +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_75, 1); lean_dec(x_80); -x_84 = lean_ctor_get(x_81, 0); -lean_inc(x_84); +x_81 = lean_ctor_get(x_75, 0); lean_dec(x_81); -x_85 = lean_ctor_get(x_79, 2); -lean_inc(x_85); -lean_dec(x_79); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_82, 1); -lean_dec(x_87); -x_88 = lean_ctor_get(x_82, 0); -lean_dec(x_88); -lean_ctor_set(x_82, 1, x_85); -lean_ctor_set(x_82, 0, x_84); +lean_ctor_set(x_75, 1, x_78); +lean_ctor_set(x_75, 0, x_77); lean_inc(x_2); -x_89 = l___private_Lean_Elab_Command_3__setState(x_82, x_2, x_83); -if (lean_obj_tag(x_89) == 0) +x_82 = l___private_Lean_Elab_Command_3__setState(x_75, x_2, x_76); +if (lean_obj_tag(x_82) == 0) { -lean_object* x_90; -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -lean_dec(x_89); -x_21 = x_78; -x_22 = x_90; -goto block_61; -} -else -{ -lean_object* x_91; lean_object* x_92; -lean_dec(x_78); -lean_dec(x_1); -x_91 = lean_ctor_get(x_89, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_9 = x_91; -x_10 = x_92; -goto block_20; -} -} -else -{ -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_82, 2); -x_94 = lean_ctor_get(x_82, 3); -x_95 = lean_ctor_get(x_82, 4); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); +lean_object* x_83; +x_83 = lean_ctor_get(x_82, 1); +lean_inc(x_83); lean_dec(x_82); -x_96 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_96, 0, x_84); -lean_ctor_set(x_96, 1, x_85); -lean_ctor_set(x_96, 2, x_93); -lean_ctor_set(x_96, 3, x_94); -lean_ctor_set(x_96, 4, x_95); -lean_inc(x_2); -x_97 = l___private_Lean_Elab_Command_3__setState(x_96, x_2, x_83); -if (lean_obj_tag(x_97) == 0) +x_21 = x_71; +x_22 = x_83; +goto block_54; +} +else { -lean_object* x_98; -x_98 = lean_ctor_get(x_97, 1); +lean_object* x_84; lean_object* x_85; +lean_dec(x_71); +lean_dec(x_1); +x_84 = lean_ctor_get(x_82, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_82, 1); +lean_inc(x_85); +lean_dec(x_82); +x_9 = x_84; +x_10 = x_85; +goto block_20; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_86 = lean_ctor_get(x_75, 2); +x_87 = lean_ctor_get(x_75, 3); +x_88 = lean_ctor_get(x_75, 4); +lean_inc(x_88); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_75); +x_89 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_89, 0, x_77); +lean_ctor_set(x_89, 1, x_78); +lean_ctor_set(x_89, 2, x_86); +lean_ctor_set(x_89, 3, x_87); +lean_ctor_set(x_89, 4, x_88); +lean_inc(x_2); +x_90 = l___private_Lean_Elab_Command_3__setState(x_89, x_2, x_76); +if (lean_obj_tag(x_90) == 0) +{ +lean_object* x_91; +x_91 = lean_ctor_get(x_90, 1); +lean_inc(x_91); +lean_dec(x_90); +x_21 = x_71; +x_22 = x_91; +goto block_54; +} +else +{ +lean_object* x_92; lean_object* x_93; +lean_dec(x_71); +lean_dec(x_1); +x_92 = lean_ctor_get(x_90, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_90, 1); +lean_inc(x_93); +lean_dec(x_90); +x_9 = x_92; +x_10 = x_93; +goto block_20; +} +} +} +else +{ +lean_object* x_94; lean_object* x_95; +lean_dec(x_72); +lean_dec(x_71); +lean_dec(x_1); +x_94 = lean_ctor_get(x_73, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_73, 1); +lean_inc(x_95); +lean_dec(x_73); +x_9 = x_94; +x_10 = x_95; +goto block_20; +} +} +else +{ +lean_object* x_96; +x_96 = lean_ctor_get(x_70, 0); +lean_inc(x_96); +if (lean_obj_tag(x_96) == 0) +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; +lean_dec(x_1); +x_97 = lean_ctor_get(x_70, 1); +lean_inc(x_97); +lean_dec(x_70); +x_98 = lean_ctor_get(x_96, 0); lean_inc(x_98); -lean_dec(x_97); -x_21 = x_78; -x_22 = x_98; -goto block_61; -} -else +lean_dec(x_96); +lean_inc(x_2); +x_99 = l___private_Lean_Elab_Command_2__getState(x_2, x_66); +if (lean_obj_tag(x_99) == 0) { -lean_object* x_99; lean_object* x_100; -lean_dec(x_78); -lean_dec(x_1); -x_99 = lean_ctor_get(x_97, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_97, 1); +lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; uint8_t x_105; +x_100 = lean_ctor_get(x_97, 0); lean_inc(x_100); -lean_dec(x_97); -x_9 = x_99; -x_10 = x_100; -goto block_20; -} -} -} -else -{ -lean_object* x_101; lean_object* x_102; -lean_dec(x_79); -lean_dec(x_78); -lean_dec(x_1); -x_101 = lean_ctor_get(x_80, 0); +x_101 = lean_ctor_get(x_99, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_80, 1); +x_102 = lean_ctor_get(x_99, 1); lean_inc(x_102); -lean_dec(x_80); -x_9 = x_101; -x_10 = x_102; -goto block_20; -} -} -else -{ -lean_object* x_103; -x_103 = lean_ctor_get(x_77, 0); +lean_dec(x_99); +x_103 = lean_ctor_get(x_100, 0); lean_inc(x_103); -if (lean_obj_tag(x_103) == 0) -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -lean_dec(x_1); -x_104 = lean_ctor_get(x_77, 1); +lean_dec(x_100); +x_104 = lean_ctor_get(x_97, 2); lean_inc(x_104); -lean_dec(x_77); -x_105 = lean_ctor_get(x_103, 0); -lean_inc(x_105); -lean_dec(x_103); -lean_inc(x_2); -x_106 = l___private_Lean_Elab_Command_2__getState(x_2, x_73); -if (lean_obj_tag(x_106) == 0) +lean_dec(x_97); +x_105 = !lean_is_exclusive(x_101); +if (x_105 == 0) { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; uint8_t x_112; -x_107 = lean_ctor_get(x_104, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_106, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_106, 1); -lean_inc(x_109); +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_101, 1); lean_dec(x_106); -x_110 = lean_ctor_get(x_107, 0); -lean_inc(x_110); +x_107 = lean_ctor_get(x_101, 0); lean_dec(x_107); -x_111 = lean_ctor_get(x_104, 2); -lean_inc(x_111); -lean_dec(x_104); -x_112 = !lean_is_exclusive(x_108); -if (x_112 == 0) -{ -lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_113 = lean_ctor_get(x_108, 1); -lean_dec(x_113); -x_114 = lean_ctor_get(x_108, 0); -lean_dec(x_114); -lean_ctor_set(x_108, 1, x_111); -lean_ctor_set(x_108, 0, x_110); +lean_ctor_set(x_101, 1, x_104); +lean_ctor_set(x_101, 0, x_103); lean_inc(x_2); -x_115 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_109); -if (lean_obj_tag(x_115) == 0) +x_108 = l___private_Lean_Elab_Command_3__setState(x_101, x_2, x_102); +if (lean_obj_tag(x_108) == 0) { -lean_object* x_116; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -lean_dec(x_115); -x_9 = x_105; -x_10 = x_116; -goto block_20; -} -else -{ -lean_object* x_117; lean_object* x_118; -lean_dec(x_105); -x_117 = lean_ctor_get(x_115, 0); -lean_inc(x_117); -x_118 = lean_ctor_get(x_115, 1); -lean_inc(x_118); -lean_dec(x_115); -x_9 = x_117; -x_10 = x_118; -goto block_20; -} -} -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_108, 2); -x_120 = lean_ctor_get(x_108, 3); -x_121 = lean_ctor_get(x_108, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); +lean_object* x_109; +x_109 = lean_ctor_get(x_108, 1); +lean_inc(x_109); lean_dec(x_108); -x_122 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_122, 0, x_110); -lean_ctor_set(x_122, 1, x_111); -lean_ctor_set(x_122, 2, x_119); -lean_ctor_set(x_122, 3, x_120); -lean_ctor_set(x_122, 4, x_121); -lean_inc(x_2); -x_123 = l___private_Lean_Elab_Command_3__setState(x_122, x_2, x_109); -if (lean_obj_tag(x_123) == 0) -{ -lean_object* x_124; -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -lean_dec(x_123); -x_9 = x_105; -x_10 = x_124; +x_9 = x_98; +x_10 = x_109; goto block_20; } else { +lean_object* x_110; lean_object* x_111; +lean_dec(x_98); +x_110 = lean_ctor_get(x_108, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_108, 1); +lean_inc(x_111); +lean_dec(x_108); +x_9 = x_110; +x_10 = x_111; +goto block_20; +} +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_112 = lean_ctor_get(x_101, 2); +x_113 = lean_ctor_get(x_101, 3); +x_114 = lean_ctor_get(x_101, 4); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_dec(x_101); +x_115 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_115, 0, x_103); +lean_ctor_set(x_115, 1, x_104); +lean_ctor_set(x_115, 2, x_112); +lean_ctor_set(x_115, 3, x_113); +lean_ctor_set(x_115, 4, x_114); +lean_inc(x_2); +x_116 = l___private_Lean_Elab_Command_3__setState(x_115, x_2, x_102); +if (lean_obj_tag(x_116) == 0) +{ +lean_object* x_117; +x_117 = lean_ctor_get(x_116, 1); +lean_inc(x_117); +lean_dec(x_116); +x_9 = x_98; +x_10 = x_117; +goto block_20; +} +else +{ +lean_object* x_118; lean_object* x_119; +lean_dec(x_98); +x_118 = lean_ctor_get(x_116, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_116, 1); +lean_inc(x_119); +lean_dec(x_116); +x_9 = x_118; +x_10 = x_119; +goto block_20; +} +} +} +else +{ +lean_object* x_120; lean_object* x_121; +lean_dec(x_98); +lean_dec(x_97); +x_120 = lean_ctor_get(x_99, 0); +lean_inc(x_120); +x_121 = lean_ctor_get(x_99, 1); +lean_inc(x_121); +lean_dec(x_99); +x_9 = x_120; +x_10 = x_121; +goto block_20; +} +} +else +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; +lean_dec(x_70); +x_122 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_123 = l_unreachable_x21___rarg(x_122); +lean_inc(x_2); +x_124 = lean_apply_2(x_123, x_2, x_66); +if (lean_obj_tag(x_124) == 0) +{ lean_object* x_125; lean_object* x_126; -lean_dec(x_105); -x_125 = lean_ctor_get(x_123, 0); +x_125 = lean_ctor_get(x_124, 0); lean_inc(x_125); -x_126 = lean_ctor_get(x_123, 1); +x_126 = lean_ctor_get(x_124, 1); lean_inc(x_126); -lean_dec(x_123); -x_9 = x_125; -x_10 = x_126; -goto block_20; -} -} +lean_dec(x_124); +x_21 = x_125; +x_22 = x_126; +goto block_54; } else { lean_object* x_127; lean_object* x_128; -lean_dec(x_105); -lean_dec(x_104); -x_127 = lean_ctor_get(x_106, 0); +lean_dec(x_1); +x_127 = lean_ctor_get(x_124, 0); lean_inc(x_127); -x_128 = lean_ctor_get(x_106, 1); +x_128 = lean_ctor_get(x_124, 1); lean_inc(x_128); -lean_dec(x_106); +lean_dec(x_124); x_9 = x_127; x_10 = x_128; goto block_20; } } +} +} else { -lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_77); -x_129 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_130 = l_unreachable_x21___rarg(x_129); -lean_inc(x_2); -x_131 = lean_apply_2(x_130, x_2, x_73); -if (lean_obj_tag(x_131) == 0) +lean_object* x_129; lean_object* x_130; +lean_dec(x_63); +lean_dec(x_59); +lean_dec(x_1); +x_129 = lean_ctor_get(x_64, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_64, 1); +lean_inc(x_130); +lean_dec(x_64); +x_9 = x_129; +x_10 = x_130; +goto block_20; +} +} +else { -lean_object* x_132; lean_object* x_133; -x_132 = lean_ctor_get(x_131, 0); +lean_object* x_131; lean_object* x_132; +lean_dec(x_59); +lean_dec(x_1); +x_131 = lean_ctor_get(x_60, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_60, 1); lean_inc(x_132); -x_133 = lean_ctor_get(x_131, 1); -lean_inc(x_133); -lean_dec(x_131); -x_21 = x_132; -x_22 = x_133; -goto block_61; -} -else -{ -lean_object* x_134; lean_object* x_135; -lean_dec(x_1); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_131, 1); -lean_inc(x_135); -lean_dec(x_131); -x_9 = x_134; -x_10 = x_135; -goto block_20; -} -} -} -} -else -{ -lean_object* x_136; lean_object* x_137; -lean_dec(x_70); -lean_dec(x_66); -lean_dec(x_1); -x_136 = lean_ctor_get(x_71, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_71, 1); -lean_inc(x_137); -lean_dec(x_71); -x_9 = x_136; -x_10 = x_137; +lean_dec(x_60); +x_9 = x_131; +x_10 = x_132; goto block_20; } } else { -lean_object* x_138; lean_object* x_139; -lean_dec(x_66); -lean_dec(x_1); -x_138 = lean_ctor_get(x_67, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_67, 1); -lean_inc(x_139); -lean_dec(x_67); -x_9 = x_138; -x_10 = x_139; -goto block_20; -} -} -else -{ -lean_object* x_140; lean_object* x_141; +lean_object* x_133; lean_object* x_134; lean_dec(x_5); lean_dec(x_1); -x_140 = lean_ctor_get(x_62, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_62, 1); -lean_inc(x_141); -lean_dec(x_62); -x_9 = x_140; -x_10 = x_141; +x_133 = lean_ctor_get(x_55, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_55, 1); +lean_inc(x_134); +lean_dec(x_55); +x_9 = x_133; +x_10 = x_134; goto block_20; } block_20: @@ -22346,7 +22556,7 @@ return x_19; } } } -block_61: +block_54: { lean_object* x_23; x_23 = lean_with_isolated_streams(x_21, x_22); @@ -22398,14 +22608,10 @@ lean_dec(x_1); x_36 = lean_ctor_get(x_31, 1); lean_inc(x_36); lean_dec(x_31); -lean_inc(x_2); -lean_inc(x_7); x_37 = l_Lean_Elab_Command_setEnv(x_7, x_2, x_36); if (lean_obj_tag(x_37) == 0) { uint8_t x_38; -lean_dec(x_7); -lean_dec(x_2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { @@ -22431,121 +22637,85 @@ return x_43; } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_37, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_37, 1); +uint8_t x_44; +x_44 = !lean_is_exclusive(x_37); +if (x_44 == 0) +{ +return x_37; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_37, 0); +x_46 = lean_ctor_get(x_37, 1); +lean_inc(x_46); lean_inc(x_45); lean_dec(x_37); -x_46 = l_Lean_Elab_Command_setEnv(x_7, x_2, x_45); -if (lean_obj_tag(x_46) == 0) -{ -uint8_t x_47; -x_47 = !lean_is_exclusive(x_46); -if (x_47 == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_46, 0); -lean_dec(x_48); -lean_ctor_set_tag(x_46, 1); -lean_ctor_set(x_46, 0, x_44); -return x_46; -} -else -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_46, 1); -lean_inc(x_49); -lean_dec(x_46); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_44); -lean_ctor_set(x_50, 1, x_49); -return x_50; -} -} -else -{ -uint8_t x_51; -lean_dec(x_44); -x_51 = !lean_is_exclusive(x_46); -if (x_51 == 0) -{ -return x_46; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_46, 0); -x_53 = lean_ctor_get(x_46, 1); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_46); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; -} +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_55; lean_object* x_56; +lean_object* x_48; lean_object* x_49; lean_dec(x_27); lean_dec(x_1); -x_55 = lean_ctor_get(x_31, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_31, 1); -lean_inc(x_56); +x_48 = lean_ctor_get(x_31, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_31, 1); +lean_inc(x_49); lean_dec(x_31); -x_9 = x_55; -x_10 = x_56; +x_9 = x_48; +x_10 = x_49; goto block_20; } } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_23, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_23, 1); -lean_inc(x_58); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_50 = lean_ctor_get(x_23, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_23, 1); +lean_inc(x_51); lean_dec(x_23); lean_inc(x_2); -x_59 = l___private_Lean_Elab_Command_1__ioErrorToMessage(x_2, x_1, x_57); +x_52 = l___private_Lean_Elab_Command_1__ioErrorToMessage(x_2, x_1, x_50); lean_dec(x_1); -x_60 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_60, 0, x_59); -x_9 = x_60; -x_10 = x_58; +x_53 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_53, 0, x_52); +x_9 = x_53; +x_10 = x_51; goto block_20; } } } else { -uint8_t x_142; +uint8_t x_135; lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); -x_142 = !lean_is_exclusive(x_6); -if (x_142 == 0) +x_135 = !lean_is_exclusive(x_6); +if (x_135 == 0) { return x_6; } else { -lean_object* x_143; lean_object* x_144; lean_object* x_145; -x_143 = lean_ctor_get(x_6, 0); -x_144 = lean_ctor_get(x_6, 1); -lean_inc(x_144); -lean_inc(x_143); +lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_136 = lean_ctor_get(x_6, 0); +x_137 = lean_ctor_get(x_6, 1); +lean_inc(x_137); +lean_inc(x_136); lean_dec(x_6); -x_145 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_145, 0, x_143); -lean_ctor_set(x_145, 1, x_144); -return x_145; +x_138 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_138, 0, x_136); +lean_ctor_set(x_138, 1, x_137); +return x_138; } } } @@ -22910,360 +23080,356 @@ lean_inc(x_2); x_7 = l_Lean_Elab_Command_getEnv(x_2, x_3); if (lean_obj_tag(x_7) == 0) { -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_29; lean_object* x_30; lean_object* x_41; +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_22; lean_object* x_23; lean_object* x_34; x_8 = lean_ctor_get(x_7, 0); lean_inc(x_8); x_9 = lean_ctor_get(x_7, 1); lean_inc(x_9); lean_dec(x_7); lean_inc(x_2); -x_41 = l___private_Lean_Elab_Command_2__getState(x_2, x_9); -if (lean_obj_tag(x_41) == 0) +x_34 = l___private_Lean_Elab_Command_2__getState(x_2, x_9); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_41, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_41, 1); -lean_inc(x_43); -lean_dec(x_41); -x_44 = l___private_Lean_Elab_Command_9__getVarDecls(x_42); -lean_dec(x_42); +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); +lean_dec(x_34); +x_37 = l___private_Lean_Elab_Command_9__getVarDecls(x_35); +lean_dec(x_35); lean_inc(x_2); -x_45 = l___private_Lean_Elab_Command_2__getState(x_2, x_43); -if (lean_obj_tag(x_45) == 0) +x_38 = l___private_Lean_Elab_Command_2__getState(x_2, x_36); +if (lean_obj_tag(x_38) == 0) { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_46 = lean_ctor_get(x_45, 0); +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +lean_dec(x_38); +x_41 = l_Lean_Elab_Command_elabSynth___closed__3; +x_42 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_39, x_41); +x_43 = l___private_Lean_Elab_Command_7__mkTermState(x_39); +lean_dec(x_39); +x_44 = l_Lean_Elab_Term_elabBinders___rarg(x_37, x_6, x_42, x_43); +lean_dec(x_37); +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_44, 1); lean_inc(x_46); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -x_48 = l_Lean_Elab_Command_elabSynth___closed__3; -x_49 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_46, x_48); -x_50 = l___private_Lean_Elab_Command_7__mkTermState(x_46); -lean_dec(x_46); -x_51 = l_Lean_Elab_Term_elabBinders___rarg(x_44, x_6, x_49, x_50); lean_dec(x_44); -if (lean_obj_tag(x_51) == 0) +lean_inc(x_2); +x_47 = l___private_Lean_Elab_Command_2__getState(x_2, x_40); +if (lean_obj_tag(x_47) == 0) { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 0); +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; uint8_t x_53; +x_48 = lean_ctor_get(x_46, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_47, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_47, 1); +lean_inc(x_50); +lean_dec(x_47); +x_51 = lean_ctor_get(x_48, 0); +lean_inc(x_51); +lean_dec(x_48); +x_52 = lean_ctor_get(x_46, 2); lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -lean_inc(x_2); -x_54 = l___private_Lean_Elab_Command_2__getState(x_2, x_47); -if (lean_obj_tag(x_54) == 0) +lean_dec(x_46); +x_53 = !lean_is_exclusive(x_49); +if (x_53 == 0) { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -x_55 = lean_ctor_get(x_53, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_54, 1); -lean_inc(x_57); +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_49, 1); lean_dec(x_54); -x_58 = lean_ctor_get(x_55, 0); -lean_inc(x_58); +x_55 = lean_ctor_get(x_49, 0); lean_dec(x_55); -x_59 = lean_ctor_get(x_53, 2); -lean_inc(x_59); -lean_dec(x_53); -x_60 = !lean_is_exclusive(x_56); -if (x_60 == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_56, 1); -lean_dec(x_61); -x_62 = lean_ctor_get(x_56, 0); -lean_dec(x_62); -lean_ctor_set(x_56, 1, x_59); -lean_ctor_set(x_56, 0, x_58); +lean_ctor_set(x_49, 1, x_52); +lean_ctor_set(x_49, 0, x_51); lean_inc(x_2); -x_63 = l___private_Lean_Elab_Command_3__setState(x_56, x_2, x_57); -if (lean_obj_tag(x_63) == 0) +x_56 = l___private_Lean_Elab_Command_3__setState(x_49, x_2, x_50); +if (lean_obj_tag(x_56) == 0) { -lean_object* x_64; -x_64 = lean_ctor_get(x_63, 1); -lean_inc(x_64); -lean_dec(x_63); -x_10 = x_52; -x_11 = x_64; -goto block_28; -} -else -{ -lean_object* x_65; lean_object* x_66; -lean_dec(x_52); -x_65 = lean_ctor_get(x_63, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_63, 1); -lean_inc(x_66); -lean_dec(x_63); -x_29 = x_65; -x_30 = x_66; -goto block_40; -} -} -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_56, 2); -x_68 = lean_ctor_get(x_56, 3); -x_69 = lean_ctor_get(x_56, 4); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); +lean_object* x_57; +x_57 = lean_ctor_get(x_56, 1); +lean_inc(x_57); lean_dec(x_56); -x_70 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_70, 0, x_58); -lean_ctor_set(x_70, 1, x_59); -lean_ctor_set(x_70, 2, x_67); -lean_ctor_set(x_70, 3, x_68); -lean_ctor_set(x_70, 4, x_69); -lean_inc(x_2); -x_71 = l___private_Lean_Elab_Command_3__setState(x_70, x_2, x_57); -if (lean_obj_tag(x_71) == 0) +x_10 = x_45; +x_11 = x_57; +goto block_21; +} +else { -lean_object* x_72; -x_72 = lean_ctor_get(x_71, 1); +lean_object* x_58; lean_object* x_59; +lean_dec(x_45); +x_58 = lean_ctor_get(x_56, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +lean_dec(x_56); +x_22 = x_58; +x_23 = x_59; +goto block_33; +} +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_60 = lean_ctor_get(x_49, 2); +x_61 = lean_ctor_get(x_49, 3); +x_62 = lean_ctor_get(x_49, 4); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_49); +x_63 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_63, 0, x_51); +lean_ctor_set(x_63, 1, x_52); +lean_ctor_set(x_63, 2, x_60); +lean_ctor_set(x_63, 3, x_61); +lean_ctor_set(x_63, 4, x_62); +lean_inc(x_2); +x_64 = l___private_Lean_Elab_Command_3__setState(x_63, x_2, x_50); +if (lean_obj_tag(x_64) == 0) +{ +lean_object* x_65; +x_65 = lean_ctor_get(x_64, 1); +lean_inc(x_65); +lean_dec(x_64); +x_10 = x_45; +x_11 = x_65; +goto block_21; +} +else +{ +lean_object* x_66; lean_object* x_67; +lean_dec(x_45); +x_66 = lean_ctor_get(x_64, 0); +lean_inc(x_66); +x_67 = lean_ctor_get(x_64, 1); +lean_inc(x_67); +lean_dec(x_64); +x_22 = x_66; +x_23 = x_67; +goto block_33; +} +} +} +else +{ +lean_object* x_68; lean_object* x_69; +lean_dec(x_46); +lean_dec(x_45); +x_68 = lean_ctor_get(x_47, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_47, 1); +lean_inc(x_69); +lean_dec(x_47); +x_22 = x_68; +x_23 = x_69; +goto block_33; +} +} +else +{ +lean_object* x_70; +x_70 = lean_ctor_get(x_44, 0); +lean_inc(x_70); +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_44, 1); +lean_inc(x_71); +lean_dec(x_44); +x_72 = lean_ctor_get(x_70, 0); lean_inc(x_72); -lean_dec(x_71); -x_10 = x_52; -x_11 = x_72; -goto block_28; -} -else +lean_dec(x_70); +lean_inc(x_2); +x_73 = l___private_Lean_Elab_Command_2__getState(x_2, x_40); +if (lean_obj_tag(x_73) == 0) { -lean_object* x_73; lean_object* x_74; -lean_dec(x_52); -x_73 = lean_ctor_get(x_71, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_71, 1); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; uint8_t x_79; +x_74 = lean_ctor_get(x_71, 0); lean_inc(x_74); -lean_dec(x_71); -x_29 = x_73; -x_30 = x_74; -goto block_40; -} -} -} -else -{ -lean_object* x_75; lean_object* x_76; -lean_dec(x_53); -lean_dec(x_52); -x_75 = lean_ctor_get(x_54, 0); +x_75 = lean_ctor_get(x_73, 0); lean_inc(x_75); -x_76 = lean_ctor_get(x_54, 1); +x_76 = lean_ctor_get(x_73, 1); lean_inc(x_76); -lean_dec(x_54); -x_29 = x_75; -x_30 = x_76; -goto block_40; -} -} -else -{ -lean_object* x_77; -x_77 = lean_ctor_get(x_51, 0); +lean_dec(x_73); +x_77 = lean_ctor_get(x_74, 0); lean_inc(x_77); -if (lean_obj_tag(x_77) == 0) -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_51, 1); +lean_dec(x_74); +x_78 = lean_ctor_get(x_71, 2); lean_inc(x_78); -lean_dec(x_51); -x_79 = lean_ctor_get(x_77, 0); -lean_inc(x_79); -lean_dec(x_77); -lean_inc(x_2); -x_80 = l___private_Lean_Elab_Command_2__getState(x_2, x_47); -if (lean_obj_tag(x_80) == 0) +lean_dec(x_71); +x_79 = !lean_is_exclusive(x_75); +if (x_79 == 0) { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_81 = lean_ctor_get(x_78, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_80, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_80, 1); -lean_inc(x_83); +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_75, 1); lean_dec(x_80); -x_84 = lean_ctor_get(x_81, 0); -lean_inc(x_84); +x_81 = lean_ctor_get(x_75, 0); lean_dec(x_81); -x_85 = lean_ctor_get(x_78, 2); -lean_inc(x_85); -lean_dec(x_78); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_82, 1); -lean_dec(x_87); -x_88 = lean_ctor_get(x_82, 0); -lean_dec(x_88); -lean_ctor_set(x_82, 1, x_85); -lean_ctor_set(x_82, 0, x_84); +lean_ctor_set(x_75, 1, x_78); +lean_ctor_set(x_75, 0, x_77); lean_inc(x_2); -x_89 = l___private_Lean_Elab_Command_3__setState(x_82, x_2, x_83); -if (lean_obj_tag(x_89) == 0) +x_82 = l___private_Lean_Elab_Command_3__setState(x_75, x_2, x_76); +if (lean_obj_tag(x_82) == 0) { -lean_object* x_90; -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -lean_dec(x_89); -x_29 = x_79; -x_30 = x_90; -goto block_40; -} -else -{ -lean_object* x_91; lean_object* x_92; -lean_dec(x_79); -x_91 = lean_ctor_get(x_89, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_29 = x_91; -x_30 = x_92; -goto block_40; -} -} -else -{ -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_82, 2); -x_94 = lean_ctor_get(x_82, 3); -x_95 = lean_ctor_get(x_82, 4); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); +lean_object* x_83; +x_83 = lean_ctor_get(x_82, 1); +lean_inc(x_83); lean_dec(x_82); -x_96 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_96, 0, x_84); -lean_ctor_set(x_96, 1, x_85); -lean_ctor_set(x_96, 2, x_93); -lean_ctor_set(x_96, 3, x_94); -lean_ctor_set(x_96, 4, x_95); -lean_inc(x_2); -x_97 = l___private_Lean_Elab_Command_3__setState(x_96, x_2, x_83); -if (lean_obj_tag(x_97) == 0) -{ -lean_object* x_98; -x_98 = lean_ctor_get(x_97, 1); -lean_inc(x_98); -lean_dec(x_97); -x_29 = x_79; -x_30 = x_98; -goto block_40; +x_22 = x_72; +x_23 = x_83; +goto block_33; } else { +lean_object* x_84; lean_object* x_85; +lean_dec(x_72); +x_84 = lean_ctor_get(x_82, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_82, 1); +lean_inc(x_85); +lean_dec(x_82); +x_22 = x_84; +x_23 = x_85; +goto block_33; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_86 = lean_ctor_get(x_75, 2); +x_87 = lean_ctor_get(x_75, 3); +x_88 = lean_ctor_get(x_75, 4); +lean_inc(x_88); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_75); +x_89 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_89, 0, x_77); +lean_ctor_set(x_89, 1, x_78); +lean_ctor_set(x_89, 2, x_86); +lean_ctor_set(x_89, 3, x_87); +lean_ctor_set(x_89, 4, x_88); +lean_inc(x_2); +x_90 = l___private_Lean_Elab_Command_3__setState(x_89, x_2, x_76); +if (lean_obj_tag(x_90) == 0) +{ +lean_object* x_91; +x_91 = lean_ctor_get(x_90, 1); +lean_inc(x_91); +lean_dec(x_90); +x_22 = x_72; +x_23 = x_91; +goto block_33; +} +else +{ +lean_object* x_92; lean_object* x_93; +lean_dec(x_72); +x_92 = lean_ctor_get(x_90, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_90, 1); +lean_inc(x_93); +lean_dec(x_90); +x_22 = x_92; +x_23 = x_93; +goto block_33; +} +} +} +else +{ +lean_object* x_94; lean_object* x_95; +lean_dec(x_72); +lean_dec(x_71); +x_94 = lean_ctor_get(x_73, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_73, 1); +lean_inc(x_95); +lean_dec(x_73); +x_22 = x_94; +x_23 = x_95; +goto block_33; +} +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; +lean_dec(x_44); +x_96 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_97 = l_unreachable_x21___rarg(x_96); +lean_inc(x_2); +x_98 = lean_apply_2(x_97, x_2, x_40); +if (lean_obj_tag(x_98) == 0) +{ lean_object* x_99; lean_object* x_100; -lean_dec(x_79); -x_99 = lean_ctor_get(x_97, 0); +x_99 = lean_ctor_get(x_98, 0); lean_inc(x_99); -x_100 = lean_ctor_get(x_97, 1); +x_100 = lean_ctor_get(x_98, 1); lean_inc(x_100); -lean_dec(x_97); -x_29 = x_99; -x_30 = x_100; -goto block_40; -} -} +lean_dec(x_98); +x_10 = x_99; +x_11 = x_100; +goto block_21; } else { lean_object* x_101; lean_object* x_102; -lean_dec(x_79); -lean_dec(x_78); -x_101 = lean_ctor_get(x_80, 0); +x_101 = lean_ctor_get(x_98, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_80, 1); +x_102 = lean_ctor_get(x_98, 1); lean_inc(x_102); -lean_dec(x_80); -x_29 = x_101; -x_30 = x_102; -goto block_40; +lean_dec(x_98); +x_22 = x_101; +x_23 = x_102; +goto block_33; +} +} } } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; -lean_dec(x_51); -x_103 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_104 = l_unreachable_x21___rarg(x_103); -lean_inc(x_2); -x_105 = lean_apply_2(x_104, x_2, x_47); -if (lean_obj_tag(x_105) == 0) +lean_object* x_103; lean_object* x_104; +lean_dec(x_37); +lean_dec(x_6); +x_103 = lean_ctor_get(x_38, 0); +lean_inc(x_103); +x_104 = lean_ctor_get(x_38, 1); +lean_inc(x_104); +lean_dec(x_38); +x_22 = x_103; +x_23 = x_104; +goto block_33; +} +} +else { -lean_object* x_106; lean_object* x_107; -x_106 = lean_ctor_get(x_105, 0); +lean_object* x_105; lean_object* x_106; +lean_dec(x_6); +x_105 = lean_ctor_get(x_34, 0); +lean_inc(x_105); +x_106 = lean_ctor_get(x_34, 1); lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_10 = x_106; -x_11 = x_107; -goto block_28; +lean_dec(x_34); +x_22 = x_105; +x_23 = x_106; +goto block_33; } -else -{ -lean_object* x_108; lean_object* x_109; -x_108 = lean_ctor_get(x_105, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_105, 1); -lean_inc(x_109); -lean_dec(x_105); -x_29 = x_108; -x_30 = x_109; -goto block_40; -} -} -} -} -else -{ -lean_object* x_110; lean_object* x_111; -lean_dec(x_44); -lean_dec(x_6); -x_110 = lean_ctor_get(x_45, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_45, 1); -lean_inc(x_111); -lean_dec(x_45); -x_29 = x_110; -x_30 = x_111; -goto block_40; -} -} -else -{ -lean_object* x_112; lean_object* x_113; -lean_dec(x_6); -x_112 = lean_ctor_get(x_41, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_41, 1); -lean_inc(x_113); -lean_dec(x_41); -x_29 = x_112; -x_30 = x_113; -goto block_40; -} -block_28: +block_21: { lean_object* x_12; -lean_inc(x_2); -lean_inc(x_8); x_12 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_11); if (lean_obj_tag(x_12) == 0) { uint8_t x_13; -lean_dec(x_8); -lean_dec(x_2); x_13 = !lean_is_exclusive(x_12); if (x_13 == 0) { @@ -23287,140 +23453,104 @@ return x_16; } else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; +uint8_t x_17; lean_dec(x_10); -x_17 = lean_ctor_get(x_12, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_12, 1); +x_17 = !lean_is_exclusive(x_12); +if (x_17 == 0) +{ +return x_12; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_12, 0); +x_19 = lean_ctor_get(x_12, 1); +lean_inc(x_19); lean_inc(x_18); lean_dec(x_12); -x_19 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_18); -if (lean_obj_tag(x_19) == 0) +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +block_33: { -uint8_t x_20; -x_20 = !lean_is_exclusive(x_19); -if (x_20 == 0) +lean_object* x_24; +x_24 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_23); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_21; -x_21 = lean_ctor_get(x_19, 0); -lean_dec(x_21); -lean_ctor_set_tag(x_19, 1); -lean_ctor_set(x_19, 0, x_17); -return x_19; +uint8_t x_25; +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_24, 0); +lean_dec(x_26); +lean_ctor_set_tag(x_24, 1); +lean_ctor_set(x_24, 0, x_22); +return x_24; } else { -lean_object* x_22; lean_object* x_23; -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); -lean_dec(x_19); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_17); -lean_ctor_set(x_23, 1, x_22); -return x_23; +lean_object* x_27; lean_object* x_28; +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +lean_dec(x_24); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_22); +lean_ctor_set(x_28, 1, x_27); +return x_28; } } else { -uint8_t x_24; -lean_dec(x_17); -x_24 = !lean_is_exclusive(x_19); -if (x_24 == 0) +uint8_t x_29; +lean_dec(x_22); +x_29 = !lean_is_exclusive(x_24); +if (x_29 == 0) { -return x_19; +return x_24; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_19, 0); -x_26 = lean_ctor_get(x_19, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_19); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -} -block_40: -{ -lean_object* x_31; -x_31 = l_Lean_Elab_Command_setEnv(x_8, x_2, x_30); -if (lean_obj_tag(x_31) == 0) -{ -uint8_t x_32; -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_tag(x_31, 1); -lean_ctor_set(x_31, 0, x_29); -return x_31; -} -else -{ -lean_object* x_34; lean_object* x_35; -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); -lean_dec(x_31); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_29); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -else -{ -uint8_t x_36; -lean_dec(x_29); -x_36 = !lean_is_exclusive(x_31); -if (x_36 == 0) -{ -return x_31; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_31, 0); -x_38 = lean_ctor_get(x_31, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_31); -x_39 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_39, 0, x_37); -lean_ctor_set(x_39, 1, x_38); -return x_39; +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_24, 0); +x_31 = lean_ctor_get(x_24, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_24); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; } } } } else { -uint8_t x_114; +uint8_t x_107; lean_dec(x_6); lean_dec(x_2); -x_114 = !lean_is_exclusive(x_7); -if (x_114 == 0) +x_107 = !lean_is_exclusive(x_7); +if (x_107 == 0) { return x_7; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_7, 0); -x_116 = lean_ctor_get(x_7, 1); -lean_inc(x_116); -lean_inc(x_115); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_7, 0); +x_109 = lean_ctor_get(x_7, 1); +lean_inc(x_109); +lean_inc(x_108); lean_dec(x_7); -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; +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; } } } @@ -26452,554 +26582,7 @@ return x_121; } } } -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; uint8_t x_8; @@ -27065,7 +26648,7 @@ return x_21; } } } -lean_object* _init_l_Lean_Elab_Command_withDeclId___closed__1() { +lean_object* _init_l_Lean_Elab_Command_withDeclId___rarg___closed__1() { _start: { lean_object* x_1; @@ -27073,27 +26656,27 @@ x_1 = lean_mk_string("invalid declaration name"); return x_1; } } -lean_object* _init_l_Lean_Elab_Command_withDeclId___closed__2() { +lean_object* _init_l_Lean_Elab_Command_withDeclId___rarg___closed__2() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_withDeclId___closed__1; +x_1 = l_Lean_Elab_Command_withDeclId___rarg___closed__1; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l_Lean_Elab_Command_withDeclId___closed__3() { +lean_object* _init_l_Lean_Elab_Command_withDeclId___rarg___closed__3() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_withDeclId___closed__2; +x_1 = l_Lean_Elab_Command_withDeclId___rarg___closed__2; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l_Lean_Elab_Command_withDeclId(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Elab_Command_withDeclId___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; @@ -27107,66 +26690,66 @@ lean_inc(x_3); x_8 = l_Lean_Elab_Command_getLevelNames(x_3, x_4); if (lean_obj_tag(x_8) == 0) { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_174; +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_161; x_9 = lean_ctor_get(x_8, 0); lean_inc(x_9); x_10 = lean_ctor_get(x_8, 1); lean_inc(x_10); lean_dec(x_8); -x_174 = l_Lean_Syntax_isNone(x_7); -if (x_174 == 0) +x_161 = l_Lean_Syntax_isNone(x_7); +if (x_161 == 0) { -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_175 = lean_unsigned_to_nat(1u); -x_176 = l_Lean_Syntax_getArg(x_7, x_175); -x_177 = l_Lean_Syntax_getArgs(x_176); -lean_dec(x_176); -x_178 = lean_unsigned_to_nat(2u); -x_179 = lean_unsigned_to_nat(0u); -x_180 = l_Array_empty___closed__1; -x_181 = l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(x_178, x_177, x_179, x_180); -lean_dec(x_177); +lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +x_162 = lean_unsigned_to_nat(1u); +x_163 = l_Lean_Syntax_getArg(x_7, x_162); +x_164 = l_Lean_Syntax_getArgs(x_163); +lean_dec(x_163); +x_165 = lean_unsigned_to_nat(2u); +x_166 = lean_unsigned_to_nat(0u); +x_167 = l_Array_empty___closed__1; +x_168 = l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(x_165, x_164, x_166, x_167); +lean_dec(x_164); lean_inc(x_3); lean_inc(x_9); -x_182 = l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5(x_7, x_181, x_179, x_9, x_3, x_10); -lean_dec(x_181); +x_169 = l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4(x_7, x_168, x_166, x_9, x_3, x_10); +lean_dec(x_168); lean_dec(x_7); -if (lean_obj_tag(x_182) == 0) +if (lean_obj_tag(x_169) == 0) { -lean_object* x_183; lean_object* x_184; -x_183 = lean_ctor_get(x_182, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_182, 1); -lean_inc(x_184); -lean_dec(x_182); -x_11 = x_183; -x_12 = x_184; -goto block_173; +lean_object* x_170; lean_object* x_171; +x_170 = lean_ctor_get(x_169, 0); +lean_inc(x_170); +x_171 = lean_ctor_get(x_169, 1); +lean_inc(x_171); +lean_dec(x_169); +x_11 = x_170; +x_12 = x_171; +goto block_160; } else { -uint8_t x_185; +uint8_t x_172; lean_dec(x_9); lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); -x_185 = !lean_is_exclusive(x_182); -if (x_185 == 0) +x_172 = !lean_is_exclusive(x_169); +if (x_172 == 0) { -return x_182; +return x_169; } else { -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_182, 1); -lean_inc(x_187); -lean_inc(x_186); -lean_dec(x_182); -x_188 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_188, 0, x_186); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_173 = lean_ctor_get(x_169, 0); +x_174 = lean_ctor_get(x_169, 1); +lean_inc(x_174); +lean_inc(x_173); +lean_dec(x_169); +x_175 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_175, 0, x_173); +lean_ctor_set(x_175, 1, x_174); +return x_175; } } } @@ -27176,9 +26759,9 @@ lean_dec(x_7); lean_inc(x_9); x_11 = x_9; x_12 = x_10; -goto block_173; +goto block_160; } -block_173: +block_160: { lean_object* x_13; lean_object* x_14; x_13 = l_Lean_extractMacroScopes(x_6); @@ -27232,12 +26815,10 @@ x_30 = lean_ctor_get(x_28, 1); lean_inc(x_30); lean_dec(x_28); lean_inc(x_3); -lean_inc(x_9); x_31 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__2(x_9, x_3, x_30); if (lean_obj_tag(x_31) == 0) { lean_object* x_32; lean_object* x_33; -lean_dec(x_9); x_32 = lean_ctor_get(x_31, 1); lean_inc(x_32); lean_dec(x_31); @@ -27412,210 +26993,201 @@ return x_68; } else { -lean_object* x_69; lean_object* x_70; lean_object* x_71; +uint8_t x_69; lean_dec(x_29); lean_dec(x_17); -x_69 = lean_ctor_get(x_31, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_31, 1); +lean_dec(x_3); +x_69 = !lean_is_exclusive(x_31); +if (x_69 == 0) +{ +return x_31; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_31, 0); +x_71 = lean_ctor_get(x_31, 1); +lean_inc(x_71); lean_inc(x_70); lean_dec(x_31); -x_71 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__3(x_9, x_3, x_70); -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_tag(x_71, 1); -lean_ctor_set(x_71, 0, x_69); -return x_71; +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} } else { -lean_object* x_74; lean_object* x_75; -x_74 = lean_ctor_get(x_71, 1); +lean_object* x_73; lean_object* x_74; lean_object* x_75; +lean_dec(x_17); +x_73 = lean_ctor_get(x_28, 0); +lean_inc(x_73); +x_74 = lean_ctor_get(x_28, 1); lean_inc(x_74); -lean_dec(x_71); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_69); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -else +lean_dec(x_28); +x_75 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__3(x_9, x_3, x_74); +if (lean_obj_tag(x_75) == 0) { uint8_t x_76; -lean_dec(x_69); -x_76 = !lean_is_exclusive(x_71); +x_76 = !lean_is_exclusive(x_75); if (x_76 == 0) { -return x_71; +lean_object* x_77; +x_77 = lean_ctor_get(x_75, 0); +lean_dec(x_77); +lean_ctor_set_tag(x_75, 1); +lean_ctor_set(x_75, 0, x_73); +return x_75; } 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_object* x_78; lean_object* x_79; +x_78 = lean_ctor_get(x_75, 1); lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_71); +lean_dec(x_75); x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); +lean_ctor_set(x_79, 0, x_73); lean_ctor_set(x_79, 1, x_78); return x_79; } } -} +else +{ +uint8_t x_80; +lean_dec(x_73); +x_80 = !lean_is_exclusive(x_75); +if (x_80 == 0) +{ +return x_75; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_17); -x_80 = lean_ctor_get(x_28, 0); -lean_inc(x_80); -x_81 = lean_ctor_get(x_28, 1); +lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_81 = lean_ctor_get(x_75, 0); +x_82 = lean_ctor_get(x_75, 1); +lean_inc(x_82); lean_inc(x_81); -lean_dec(x_28); -x_82 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__4(x_9, x_3, x_81); -if (lean_obj_tag(x_82) == 0) -{ -uint8_t x_83; -x_83 = !lean_is_exclusive(x_82); -if (x_83 == 0) -{ -lean_object* x_84; -x_84 = lean_ctor_get(x_82, 0); -lean_dec(x_84); -lean_ctor_set_tag(x_82, 1); -lean_ctor_set(x_82, 0, x_80); -return x_82; -} -else -{ -lean_object* x_85; lean_object* x_86; -x_85 = lean_ctor_get(x_82, 1); -lean_inc(x_85); -lean_dec(x_82); -x_86 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_86, 0, x_80); -lean_ctor_set(x_86, 1, x_85); -return x_86; -} -} -else -{ -uint8_t x_87; -lean_dec(x_80); -x_87 = !lean_is_exclusive(x_82); -if (x_87 == 0) -{ -return x_82; -} -else -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_82, 0); -x_89 = lean_ctor_get(x_82, 1); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_82); -x_90 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_90, 0, x_88); -lean_ctor_set(x_90, 1, x_89); -return x_90; +lean_dec(x_75); +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; } } } } else { -uint8_t x_91; +uint8_t x_84; lean_dec(x_21); lean_dec(x_17); lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_91 = !lean_is_exclusive(x_26); -if (x_91 == 0) +x_84 = !lean_is_exclusive(x_26); +if (x_84 == 0) { return x_26; } else { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_26, 0); -x_93 = lean_ctor_get(x_26, 1); -lean_inc(x_93); -lean_inc(x_92); +lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_85 = lean_ctor_get(x_26, 0); +x_86 = lean_ctor_get(x_26, 1); +lean_inc(x_86); +lean_inc(x_85); lean_dec(x_26); -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; +x_87 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_87, 0, x_85); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } else { -uint8_t x_95; +uint8_t x_88; lean_dec(x_21); lean_dec(x_17); lean_dec(x_11); lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_95 = !lean_is_exclusive(x_24); -if (x_95 == 0) +x_88 = !lean_is_exclusive(x_24); +if (x_88 == 0) { return x_24; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_96 = lean_ctor_get(x_24, 0); -x_97 = lean_ctor_get(x_24, 1); -lean_inc(x_97); -lean_inc(x_96); +lean_object* x_89; lean_object* x_90; lean_object* x_91; +x_89 = lean_ctor_get(x_24, 0); +x_90 = lean_ctor_get(x_24, 1); +lean_inc(x_90); +lean_inc(x_89); lean_dec(x_24); -x_98 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_98, 0, x_96); -lean_ctor_set(x_98, 1, x_97); -return x_98; +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; } } } 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; uint8_t x_109; lean_object* x_110; -x_99 = lean_ctor_get(x_13, 1); -x_100 = lean_ctor_get(x_13, 2); -x_101 = lean_ctor_get(x_13, 3); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +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; uint8_t x_102; lean_object* x_103; +x_92 = lean_ctor_get(x_13, 1); +x_93 = lean_ctor_get(x_13, 2); +x_94 = lean_ctor_get(x_13, 3); +lean_inc(x_94); +lean_inc(x_93); +lean_inc(x_92); lean_dec(x_13); -x_102 = lean_ctor_get(x_14, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_14, 1); -lean_inc(x_103); +x_95 = lean_ctor_get(x_14, 0); +lean_inc(x_95); +x_96 = lean_ctor_get(x_14, 1); +lean_inc(x_96); lean_dec(x_14); -x_104 = lean_box(0); -x_105 = lean_name_mk_string(x_104, x_103); -x_106 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_99); -lean_ctor_set(x_106, 2, x_100); -lean_ctor_set(x_106, 3, x_101); -x_107 = l_Lean_MacroScopesView_review(x_106); -x_108 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; -x_109 = 1; +x_97 = lean_box(0); +x_98 = lean_name_mk_string(x_97, x_96); +x_99 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_99, 0, x_98); +lean_ctor_set(x_99, 1, x_92); +lean_ctor_set(x_99, 2, x_93); +lean_ctor_set(x_99, 3, x_94); +x_100 = l_Lean_MacroScopesView_review(x_99); +x_101 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; +x_102 = 1; lean_inc(x_3); -lean_inc(x_102); -x_110 = l___private_Lean_Elab_Command_12__addScopes___main(x_1, x_108, x_109, x_102, x_3, x_12); +lean_inc(x_95); +x_103 = l___private_Lean_Elab_Command_12__addScopes___main(x_1, x_101, x_102, x_95, x_3, x_12); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; lean_object* x_105; +x_104 = lean_ctor_get(x_103, 1); +lean_inc(x_104); +lean_dec(x_103); +lean_inc(x_3); +x_105 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__1(x_11, x_3, x_104); +if (lean_obj_tag(x_105) == 0) +{ +lean_object* x_106; lean_object* x_107; +x_106 = lean_ctor_get(x_105, 1); +lean_inc(x_106); +lean_dec(x_105); +lean_inc(x_3); +x_107 = lean_apply_3(x_2, x_100, x_3, x_106); +if (lean_obj_tag(x_107) == 0) +{ +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_107, 0); +lean_inc(x_108); +x_109 = lean_ctor_get(x_107, 1); +lean_inc(x_109); +lean_dec(x_107); +lean_inc(x_3); +x_110 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__2(x_9, x_3, x_109); if (lean_obj_tag(x_110) == 0) { lean_object* x_111; lean_object* x_112; @@ -27623,395 +27195,342 @@ x_111 = lean_ctor_get(x_110, 1); lean_inc(x_111); lean_dec(x_110); lean_inc(x_3); -x_112 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__1(x_11, x_3, x_111); +x_112 = l___private_Lean_Elab_Command_2__getState(x_3, x_111); if (lean_obj_tag(x_112) == 0) { -lean_object* x_113; lean_object* x_114; -x_113 = lean_ctor_get(x_112, 1); +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; +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); -lean_inc(x_3); -x_114 = lean_apply_3(x_2, x_107, x_3, x_113); -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); +x_115 = lean_ctor_get(x_113, 0); lean_inc(x_115); -x_116 = lean_ctor_get(x_114, 1); +x_116 = lean_ctor_get(x_113, 1); lean_inc(x_116); -lean_dec(x_114); -lean_inc(x_3); -lean_inc(x_9); -x_117 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__2(x_9, x_3, x_116); -if (lean_obj_tag(x_117) == 0) -{ -lean_object* x_118; lean_object* x_119; -lean_dec(x_9); -x_118 = lean_ctor_get(x_117, 1); +x_117 = lean_ctor_get(x_113, 2); +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); +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_120 = x_113; +} else { + lean_dec_ref(x_113); + x_120 = lean_box(0); +} +x_121 = l_Lean_Name_getNumParts___main(x_95); +lean_dec(x_95); +x_122 = l_List_drop___main___rarg(x_121, x_117); lean_dec(x_117); -lean_inc(x_3); -x_119 = l___private_Lean_Elab_Command_2__getState(x_3, x_118); -if (lean_obj_tag(x_119) == 0) +if (lean_is_scalar(x_120)) { + x_123 = lean_alloc_ctor(0, 5, 0); +} else { + x_123 = x_120; +} +lean_ctor_set(x_123, 0, x_115); +lean_ctor_set(x_123, 1, x_116); +lean_ctor_set(x_123, 2, x_122); +lean_ctor_set(x_123, 3, x_118); +lean_ctor_set(x_123, 4, x_119); +x_124 = l___private_Lean_Elab_Command_3__setState(x_123, x_3, x_114); +if (lean_obj_tag(x_124) == 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_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -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_ctor_get(x_120, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_120, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_120, 3); +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_124, 1); lean_inc(x_125); -x_126 = lean_ctor_get(x_120, 4); -lean_inc(x_126); -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_127 = x_120; +if (lean_is_exclusive(x_124)) { + lean_ctor_release(x_124, 0); + lean_ctor_release(x_124, 1); + x_126 = x_124; } else { - lean_dec_ref(x_120); - x_127 = lean_box(0); + lean_dec_ref(x_124); + x_126 = lean_box(0); } -x_128 = l_Lean_Name_getNumParts___main(x_102); -lean_dec(x_102); -x_129 = l_List_drop___main___rarg(x_128, x_124); -lean_dec(x_124); -if (lean_is_scalar(x_127)) { - x_130 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_126)) { + x_127 = lean_alloc_ctor(0, 2, 0); } else { - x_130 = x_127; + x_127 = x_126; } -lean_ctor_set(x_130, 0, x_122); -lean_ctor_set(x_130, 1, x_123); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_125); -lean_ctor_set(x_130, 4, x_126); -x_131 = l___private_Lean_Elab_Command_3__setState(x_130, x_3, x_121); -if (lean_obj_tag(x_131) == 0) +lean_ctor_set(x_127, 0, x_108); +lean_ctor_set(x_127, 1, x_125); +return x_127; +} +else { -lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_132 = lean_ctor_get(x_131, 1); +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; +lean_dec(x_108); +x_128 = lean_ctor_get(x_124, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_124, 1); +lean_inc(x_129); +if (lean_is_exclusive(x_124)) { + lean_ctor_release(x_124, 0); + lean_ctor_release(x_124, 1); + x_130 = x_124; +} else { + lean_dec_ref(x_124); + x_130 = lean_box(0); +} +if (lean_is_scalar(x_130)) { + x_131 = lean_alloc_ctor(1, 2, 0); +} else { + x_131 = x_130; +} +lean_ctor_set(x_131, 0, x_128); +lean_ctor_set(x_131, 1, x_129); +return x_131; +} +} +else +{ +lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; +lean_dec(x_108); +lean_dec(x_95); +lean_dec(x_3); +x_132 = lean_ctor_get(x_112, 0); lean_inc(x_132); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_133 = x_131; -} else { - lean_dec_ref(x_131); - x_133 = lean_box(0); -} -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_115); -lean_ctor_set(x_134, 1, x_132); -return x_134; -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -lean_dec(x_115); -x_135 = lean_ctor_get(x_131, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_131, 1); -lean_inc(x_136); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_137 = x_131; -} else { - lean_dec_ref(x_131); - x_137 = lean_box(0); -} -if (lean_is_scalar(x_137)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_137; -} -lean_ctor_set(x_138, 0, x_135); -lean_ctor_set(x_138, 1, x_136); -return x_138; -} -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_3); -x_139 = lean_ctor_get(x_119, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_119, 1); -lean_inc(x_140); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_141 = x_119; -} else { - lean_dec_ref(x_119); - x_141 = lean_box(0); -} -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_139); -lean_ctor_set(x_142, 1, x_140); -return x_142; -} -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; -lean_dec(x_115); -lean_dec(x_102); -x_143 = lean_ctor_get(x_117, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_117, 1); -lean_inc(x_144); -lean_dec(x_117); -x_145 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__3(x_9, x_3, x_144); -if (lean_obj_tag(x_145) == 0) -{ -lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_146 = lean_ctor_get(x_145, 1); -lean_inc(x_146); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - x_147 = x_145; -} else { - lean_dec_ref(x_145); - x_147 = lean_box(0); -} -if (lean_is_scalar(x_147)) { - x_148 = lean_alloc_ctor(1, 2, 0); -} else { - x_148 = x_147; - lean_ctor_set_tag(x_148, 1); -} -lean_ctor_set(x_148, 0, x_143); -lean_ctor_set(x_148, 1, x_146); -return x_148; -} -else -{ -lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -lean_dec(x_143); -x_149 = lean_ctor_get(x_145, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_145, 1); -lean_inc(x_150); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - x_151 = x_145; -} else { - lean_dec_ref(x_145); - x_151 = lean_box(0); -} -if (lean_is_scalar(x_151)) { - x_152 = lean_alloc_ctor(1, 2, 0); -} else { - x_152 = x_151; -} -lean_ctor_set(x_152, 0, x_149); -lean_ctor_set(x_152, 1, x_150); -return x_152; -} -} -} -else -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; -lean_dec(x_102); -x_153 = lean_ctor_get(x_114, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_114, 1); -lean_inc(x_154); -lean_dec(x_114); -x_155 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__4(x_9, x_3, x_154); -if (lean_obj_tag(x_155) == 0) -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_156 = lean_ctor_get(x_155, 1); -lean_inc(x_156); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_157 = x_155; -} else { - lean_dec_ref(x_155); - 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_tag(x_158, 1); -} -lean_ctor_set(x_158, 0, x_153); -lean_ctor_set(x_158, 1, x_156); -return x_158; -} -else -{ -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -lean_dec(x_153); -x_159 = lean_ctor_get(x_155, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_155, 1); -lean_inc(x_160); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_161 = x_155; -} else { - lean_dec_ref(x_155); - x_161 = lean_box(0); -} -if (lean_is_scalar(x_161)) { - x_162 = lean_alloc_ctor(1, 2, 0); -} else { - x_162 = x_161; -} -lean_ctor_set(x_162, 0, x_159); -lean_ctor_set(x_162, 1, x_160); -return x_162; -} -} -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_107); -lean_dec(x_102); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_163 = lean_ctor_get(x_112, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_112, 1); -lean_inc(x_164); +x_133 = lean_ctor_get(x_112, 1); +lean_inc(x_133); if (lean_is_exclusive(x_112)) { lean_ctor_release(x_112, 0); lean_ctor_release(x_112, 1); - x_165 = x_112; + x_134 = x_112; } else { lean_dec_ref(x_112); - x_165 = lean_box(0); + x_134 = lean_box(0); } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_134)) { + x_135 = lean_alloc_ctor(1, 2, 0); } else { - x_166 = x_165; + x_135 = x_134; } -lean_ctor_set(x_166, 0, x_163); -lean_ctor_set(x_166, 1, x_164); -return x_166; +lean_ctor_set(x_135, 0, x_132); +lean_ctor_set(x_135, 1, x_133); +return x_135; } } else { -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; +lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +lean_dec(x_108); +lean_dec(x_95); +lean_dec(x_3); +x_136 = lean_ctor_get(x_110, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_110, 1); +lean_inc(x_137); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + x_138 = x_110; +} else { + lean_dec_ref(x_110); + x_138 = lean_box(0); +} +if (lean_is_scalar(x_138)) { + x_139 = lean_alloc_ctor(1, 2, 0); +} else { + x_139 = x_138; +} +lean_ctor_set(x_139, 0, x_136); +lean_ctor_set(x_139, 1, x_137); +return x_139; +} +} +else +{ +lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_95); +x_140 = lean_ctor_get(x_107, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_107, 1); +lean_inc(x_141); lean_dec(x_107); -lean_dec(x_102); +x_142 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_withDeclId___spec__3(x_9, x_3, 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, 1); +lean_inc(x_143); +if (lean_is_exclusive(x_142)) { + lean_ctor_release(x_142, 0); + lean_ctor_release(x_142, 1); + x_144 = x_142; +} else { + lean_dec_ref(x_142); + x_144 = lean_box(0); +} +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(1, 2, 0); +} else { + x_145 = x_144; + lean_ctor_set_tag(x_145, 1); +} +lean_ctor_set(x_145, 0, x_140); +lean_ctor_set(x_145, 1, x_143); +return x_145; +} +else +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +lean_dec(x_140); +x_146 = lean_ctor_get(x_142, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_142, 1); +lean_inc(x_147); +if (lean_is_exclusive(x_142)) { + lean_ctor_release(x_142, 0); + lean_ctor_release(x_142, 1); + x_148 = x_142; +} else { + lean_dec_ref(x_142); + x_148 = lean_box(0); +} +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(1, 2, 0); +} else { + x_149 = x_148; +} +lean_ctor_set(x_149, 0, x_146); +lean_ctor_set(x_149, 1, x_147); +return x_149; +} +} +} +else +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; +lean_dec(x_100); +lean_dec(x_95); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +x_150 = lean_ctor_get(x_105, 0); +lean_inc(x_150); +x_151 = lean_ctor_get(x_105, 1); +lean_inc(x_151); +if (lean_is_exclusive(x_105)) { + lean_ctor_release(x_105, 0); + lean_ctor_release(x_105, 1); + x_152 = x_105; +} else { + lean_dec_ref(x_105); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(1, 2, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_150); +lean_ctor_set(x_153, 1, x_151); +return x_153; +} +} +else +{ +lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; +lean_dec(x_100); +lean_dec(x_95); lean_dec(x_11); lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_167 = lean_ctor_get(x_110, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_110, 1); -lean_inc(x_168); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_169 = x_110; +x_154 = lean_ctor_get(x_103, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_103, 1); +lean_inc(x_155); +if (lean_is_exclusive(x_103)) { + lean_ctor_release(x_103, 0); + lean_ctor_release(x_103, 1); + x_156 = x_103; } else { - lean_dec_ref(x_110); - x_169 = lean_box(0); + lean_dec_ref(x_103); + x_156 = lean_box(0); } -if (lean_is_scalar(x_169)) { - x_170 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(1, 2, 0); } else { - x_170 = x_169; + x_157 = x_156; } -lean_ctor_set(x_170, 0, x_167); -lean_ctor_set(x_170, 1, x_168); -return x_170; +lean_ctor_set(x_157, 0, x_154); +lean_ctor_set(x_157, 1, x_155); +return x_157; } } } else { -lean_object* x_171; lean_object* x_172; +lean_object* x_158; lean_object* x_159; lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_9); lean_dec(x_2); -x_171 = l_Lean_Elab_Command_withDeclId___closed__3; -x_172 = l_Lean_Elab_Command_throwError___rarg(x_1, x_171, x_3, x_12); -return x_172; +x_158 = l_Lean_Elab_Command_withDeclId___rarg___closed__3; +x_159 = l_Lean_Elab_Command_throwError___rarg(x_1, x_158, x_3, x_12); +return x_159; } } } else { -uint8_t x_189; +uint8_t x_176; lean_dec(x_7); lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); -x_189 = !lean_is_exclusive(x_8); -if (x_189 == 0) +x_176 = !lean_is_exclusive(x_8); +if (x_176 == 0) { return x_8; } else { -lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_190 = lean_ctor_get(x_8, 0); -x_191 = lean_ctor_get(x_8, 1); -lean_inc(x_191); -lean_inc(x_190); +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_8, 0); +x_178 = lean_ctor_get(x_8, 1); +lean_inc(x_178); +lean_inc(x_177); lean_dec(x_8); -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; +x_179 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_179, 0, x_177); +lean_ctor_set(x_179, 1, x_178); +return x_179; } } } } -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Elab_Command_withDeclId(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Elab_Command_withDeclId___rarg___boxed), 4, 0); +return x_2; +} +} +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__5(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Command_withDeclId___spec__4(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_2); lean_dec(x_1); return x_7; } } -lean_object* l_Lean_Elab_Command_withDeclId___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Elab_Command_withDeclId___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l_Lean_Elab_Command_withDeclId(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Elab_Command_withDeclId___rarg(x_1, x_2, x_3, x_4); lean_dec(x_1); return x_5; } @@ -28326,26 +27845,95 @@ return x_6; } } } -lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object* x_1, lean_object* x_2) { +uint8_t l_Lean_Elab_Command_sortDeclLevelParams___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_3 = lean_box(0); -lean_inc(x_1); -x_4 = l_List_foldl___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__1(x_2, x_3, x_1); -x_5 = lean_unsigned_to_nat(0u); -x_6 = l_Array_filterAux___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__2(x_1, x_2, x_5, x_5); -lean_dec(x_1); -x_7 = lean_array_get_size(x_6); -x_8 = lean_unsigned_to_nat(1u); -x_9 = lean_nat_sub(x_7, x_8); -lean_dec(x_7); -x_10 = l_Array_qsortAux___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__3(x_6, x_5, x_9); -lean_dec(x_9); -x_11 = l_Array_toList___rarg(x_10); +uint8_t x_4; +x_4 = l_Array_contains___at_Lean_findField_x3f___main___spec__1(x_1, x_3); +if (x_4 == 0) +{ +uint8_t x_5; +x_5 = l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(x_3, x_2); +if (x_5 == 0) +{ +uint8_t x_6; +x_6 = 1; +return x_6; +} +else +{ +uint8_t x_7; +x_7 = 0; +return x_7; +} +} +else +{ +uint8_t x_8; +x_8 = 0; +return x_8; +} +} +} +lean_object* _init_l_Lean_Elab_Command_sortDeclLevelParams___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unused universe parameter '"); +return x_1; +} +} +lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +lean_inc(x_3); +x_4 = lean_alloc_closure((void*)(l_Lean_Elab_Command_sortDeclLevelParams___lambda__1___boxed), 3, 2); +lean_closure_set(x_4, 0, x_3); +lean_closure_set(x_4, 1, x_1); +lean_inc(x_2); +x_5 = l_List_find_x3f___main___rarg(x_4, x_2); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_6 = lean_box(0); +lean_inc(x_2); +x_7 = l_List_foldl___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__1(x_3, x_6, x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_Array_filterAux___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__2(x_2, x_3, x_8, x_8); +lean_dec(x_2); +x_10 = lean_array_get_size(x_9); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_sub(x_10, x_11); lean_dec(x_10); -x_12 = l_List_append___rarg(x_4, x_11); -return x_12; +x_13 = l_Array_qsortAux___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__3(x_9, x_8, x_12); +lean_dec(x_12); +x_14 = l_Array_toList___rarg(x_13); +lean_dec(x_13); +x_15 = l_List_append___rarg(x_7, x_14); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +return x_16; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_dec(x_3); +lean_dec(x_2); +x_17 = lean_ctor_get(x_5, 0); +lean_inc(x_17); +lean_dec(x_5); +x_18 = l_Lean_Name_toString___closed__1; +x_19 = l_Lean_Name_toStringWithSep___main(x_18, x_17); +x_20 = l_Lean_Elab_Command_sortDeclLevelParams___closed__1; +x_21 = lean_string_append(x_20, x_19); +lean_dec(x_19); +x_22 = l_Char_HasRepr___closed__1; +x_23 = lean_string_append(x_21, x_22); +x_24 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_24, 0, x_23); +return x_24; +} } } lean_object* l_List_foldl___main___at_Lean_Elab_Command_sortDeclLevelParams___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { @@ -28385,6 +27973,18 @@ lean_dec(x_3); return x_4; } } +lean_object* l_Lean_Elab_Command_sortDeclLevelParams___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; lean_object* x_5; +x_4 = l_Lean_Elab_Command_sortDeclLevelParams___lambda__1(x_1, x_2, x_3); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_5 = lean_box(x_4); +return x_5; +} +} lean_object* initialize_Init(lean_object*); lean_object* initialize_Lean_Elab_Alias(lean_object*); lean_object* initialize_Lean_Elab_Log(lean_object*); @@ -28667,6 +28267,8 @@ l_Lean_Elab_Command_failIfSucceeds___closed__4 = _init_l_Lean_Elab_Command_failI lean_mark_persistent(l_Lean_Elab_Command_failIfSucceeds___closed__4); l_Lean_Elab_Command_failIfSucceeds___closed__5 = _init_l_Lean_Elab_Command_failIfSucceeds___closed__5(); lean_mark_persistent(l_Lean_Elab_Command_failIfSucceeds___closed__5); +l_Lean_Elab_Command_failIfSucceeds___closed__6 = _init_l_Lean_Elab_Command_failIfSucceeds___closed__6(); +lean_mark_persistent(l_Lean_Elab_Command_failIfSucceeds___closed__6); l___regBuiltin_Lean_Elab_Command_elabCheckFailure___closed__1 = _init_l___regBuiltin_Lean_Elab_Command_elabCheckFailure___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Command_elabCheckFailure___closed__1); res = l___regBuiltin_Lean_Elab_Command_elabCheckFailure(lean_io_mk_world()); @@ -28743,12 +28345,14 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Command_elabSetOption___closed__1) res = l___regBuiltin_Lean_Elab_Command_elabSetOption(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l_Lean_Elab_Command_withDeclId___closed__1 = _init_l_Lean_Elab_Command_withDeclId___closed__1(); -lean_mark_persistent(l_Lean_Elab_Command_withDeclId___closed__1); -l_Lean_Elab_Command_withDeclId___closed__2 = _init_l_Lean_Elab_Command_withDeclId___closed__2(); -lean_mark_persistent(l_Lean_Elab_Command_withDeclId___closed__2); -l_Lean_Elab_Command_withDeclId___closed__3 = _init_l_Lean_Elab_Command_withDeclId___closed__3(); -lean_mark_persistent(l_Lean_Elab_Command_withDeclId___closed__3); +l_Lean_Elab_Command_withDeclId___rarg___closed__1 = _init_l_Lean_Elab_Command_withDeclId___rarg___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_withDeclId___rarg___closed__1); +l_Lean_Elab_Command_withDeclId___rarg___closed__2 = _init_l_Lean_Elab_Command_withDeclId___rarg___closed__2(); +lean_mark_persistent(l_Lean_Elab_Command_withDeclId___rarg___closed__2); +l_Lean_Elab_Command_withDeclId___rarg___closed__3 = _init_l_Lean_Elab_Command_withDeclId___rarg___closed__3(); +lean_mark_persistent(l_Lean_Elab_Command_withDeclId___rarg___closed__3); +l_Lean_Elab_Command_sortDeclLevelParams___closed__1 = _init_l_Lean_Elab_Command_sortDeclLevelParams___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_sortDeclLevelParams___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/stdlib/Lean/Elab/DeclModifiers.c b/stage0/stdlib/Lean/Elab/DeclModifiers.c index dce30e8536..84cb8e651d 100644 --- a/stage0/stdlib/Lean/Elab/DeclModifiers.c +++ b/stage0/stdlib/Lean/Elab/DeclModifiers.c @@ -43,11 +43,13 @@ lean_object* lean_string_utf8_extract(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_applyAttributes(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* lean_string_utf8_byte_size(lean_object*); lean_object* l_Lean_Elab_Command_Modifiers_hasFormat(lean_object*); +lean_object* l_Lean_Elab_Command_applyVisibility(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__11; +lean_object* l_Lean_Elab_Command_Attribute_inhabited___closed__1; extern lean_object* l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; lean_object* l_Lean_Elab_Command_checkNotAlreadyDeclared___closed__2; -lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_AttributeApplicationTime_beq(uint8_t, uint8_t); lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__4; lean_object* lean_array_fget(lean_object*, lean_object*); @@ -75,6 +77,7 @@ lean_object* l_Function_comp___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Environment_contains(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_checkNotAlreadyDeclared___closed__1; +extern lean_object* l_Lean_protectedExt; extern lean_object* l_Lean_Parser_Command_docComment___elambda__1___closed__2; extern lean_object* l_Lean_Options_empty; extern lean_object* l_Lean_Parser_Command_attributes___elambda__1___closed__5; @@ -89,6 +92,7 @@ lean_object* l_Lean_Elab_Command_elabAttr___boxed(lean_object*, lean_object*, le lean_object* l_Lean_Elab_Command_Modifiers_hasToString___closed__2; lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__12; lean_object* l_Lean_Elab_Command_Attribute_hasFormat___closed__1; +lean_object* l_Lean_PersistentEnvExtension_addEntry___rarg(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Format_sbracket___closed__3; lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__10; uint8_t l_Lean_Syntax_isMissing(lean_object*); @@ -107,6 +111,7 @@ extern lean_object* l_Lean_Parser_Command_private___elambda__1___closed__1; lean_object* l_Lean_mkPrivateName(lean_object*, lean_object*); lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l_Lean_Syntax_getKind(lean_object*); +lean_object* l_Lean_Elab_Command_Attribute_inhabited; lean_object* l_Lean_Elab_Command_Modifiers_addAttribute(lean_object*, lean_object*); lean_object* lean_format_group(lean_object*); lean_object* l_Lean_Elab_Command_Attribute_hasFormat___closed__2; @@ -123,9 +128,13 @@ lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__14; lean_object* l_Lean_Elab_Command_Modifiers_hasFormat___closed__5; lean_object* l_Lean_Elab_Command_checkNotAlreadyDeclared___closed__6; lean_object* l_Array_toList___rarg(lean_object*); +lean_object* l_Lean_Elab_Command_applyVisibility___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_unsafe___elambda__1___closed__1; lean_object* l_Lean_Elab_Command_setEnv(lean_object*, lean_object*, lean_object*); lean_object* lean_string_length(lean_object*); +uint8_t l_Lean_Elab_Command_Modifiers_isProtected(lean_object*); +lean_object* l_Lean_Elab_Command_Modifiers_isPrivate___boxed(lean_object*); +uint8_t l_Lean_Elab_Command_Modifiers_isPrivate(lean_object*); lean_object* l_Lean_Elab_Command_Attribute_hasFormat(lean_object*); extern lean_object* l_Lean_Parser_Command_private___elambda__1___closed__2; lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); @@ -140,7 +149,8 @@ lean_object* l_Lean_getAttributeImpl(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabModifiers___closed__5; extern lean_object* l_addParenHeuristic___closed__1; extern lean_object* l_Lean_Parser_Command_docComment___elambda__1___closed__7; -lean_object* l_Lean_Elab_Command_mkDeclName___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDeclName___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_Modifiers_isProtected___boxed(lean_object*); lean_object* l_Lean_Elab_Command_elabModifiers___closed__3; uint8_t lean_nat_dec_lt(lean_object*, lean_object*); extern lean_object* l_Lean_mkProtectedExtension___closed__1; @@ -238,6 +248,26 @@ return x_32; } } } +lean_object* _init_l_Lean_Elab_Command_Attribute_inhabited___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = lean_box(0); +x_3 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_3, 0, x_1); +lean_ctor_set(x_3, 1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Elab_Command_Attribute_inhabited() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Elab_Command_Attribute_inhabited___closed__1; +return x_1; +} +} lean_object* _init_l_Lean_Elab_Command_Visibility_hasToString___closed__1() { _start: { @@ -281,6 +311,68 @@ x_3 = l_Lean_Elab_Command_Visibility_hasToString(x_2); return x_3; } } +uint8_t l_Lean_Elab_Command_Modifiers_isPrivate(lean_object* x_1) { +_start: +{ +uint8_t x_2; lean_object* x_3; +x_2 = lean_ctor_get_uint8(x_1, sizeof(void*)*2); +x_3 = lean_box(x_2); +if (lean_obj_tag(x_3) == 2) +{ +uint8_t x_4; +x_4 = 1; +return x_4; +} +else +{ +uint8_t x_5; +lean_dec(x_3); +x_5 = 0; +return x_5; +} +} +} +lean_object* l_Lean_Elab_Command_Modifiers_isPrivate___boxed(lean_object* x_1) { +_start: +{ +uint8_t x_2; lean_object* x_3; +x_2 = l_Lean_Elab_Command_Modifiers_isPrivate(x_1); +lean_dec(x_1); +x_3 = lean_box(x_2); +return x_3; +} +} +uint8_t l_Lean_Elab_Command_Modifiers_isProtected(lean_object* x_1) { +_start: +{ +uint8_t x_2; lean_object* x_3; +x_2 = lean_ctor_get_uint8(x_1, sizeof(void*)*2); +x_3 = lean_box(x_2); +if (lean_obj_tag(x_3) == 1) +{ +uint8_t x_4; +x_4 = 1; +return x_4; +} +else +{ +uint8_t x_5; +lean_dec(x_3); +x_5 = 0; +return x_5; +} +} +} +lean_object* l_Lean_Elab_Command_Modifiers_isProtected___boxed(lean_object* x_1) { +_start: +{ +uint8_t x_2; lean_object* x_3; +x_2 = l_Lean_Elab_Command_Modifiers_isProtected(x_1); +lean_dec(x_1); +x_3 = lean_box(x_2); +return x_3; +} +} lean_object* l_Lean_Elab_Command_Modifiers_addAttribute(lean_object* x_1, lean_object* x_2) { _start: { @@ -2055,203 +2147,6 @@ lean_dec(x_1); return x_4; } } -lean_object* l_Lean_Elab_Command_mkDeclName(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -x_5 = l_Lean_Elab_Command_getCurrNamespace(x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -uint8_t x_6; -x_6 = !lean_is_exclusive(x_5); -if (x_6 == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; -x_7 = lean_ctor_get(x_5, 0); -x_8 = lean_ctor_get(x_5, 1); -x_9 = l_Lean_Name_append___main(x_7, x_2); -lean_dec(x_7); -x_10 = lean_ctor_get_uint8(x_1, sizeof(void*)*2); -x_11 = lean_box(x_10); -if (lean_obj_tag(x_11) == 2) -{ -lean_object* x_12; -lean_free_object(x_5); -x_12 = l_Lean_Elab_Command_getEnv(x_3, x_8); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -x_15 = l_Lean_mkPrivateName(x_14, x_9); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 1); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_12); -x_18 = l_Lean_mkPrivateName(x_16, x_9); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_17); -return x_19; -} -} -else -{ -uint8_t x_20; -lean_dec(x_9); -x_20 = !lean_is_exclusive(x_12); -if (x_20 == 0) -{ -return x_12; -} -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = lean_ctor_get(x_12, 0); -x_22 = lean_ctor_get(x_12, 1); -lean_inc(x_22); -lean_inc(x_21); -lean_dec(x_12); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_21); -lean_ctor_set(x_23, 1, x_22); -return x_23; -} -} -} -else -{ -lean_dec(x_11); -lean_dec(x_3); -lean_ctor_set(x_5, 0, x_9); -return x_5; -} -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; -x_24 = lean_ctor_get(x_5, 0); -x_25 = lean_ctor_get(x_5, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_5); -x_26 = l_Lean_Name_append___main(x_24, x_2); -lean_dec(x_24); -x_27 = lean_ctor_get_uint8(x_1, sizeof(void*)*2); -x_28 = lean_box(x_27); -if (lean_obj_tag(x_28) == 2) -{ -lean_object* x_29; -x_29 = l_Lean_Elab_Command_getEnv(x_3, x_25); -if (lean_obj_tag(x_29) == 0) -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_29)) { - lean_ctor_release(x_29, 0); - lean_ctor_release(x_29, 1); - x_32 = x_29; -} else { - lean_dec_ref(x_29); - x_32 = lean_box(0); -} -x_33 = l_Lean_mkPrivateName(x_30, x_26); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -lean_dec(x_26); -x_35 = lean_ctor_get(x_29, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_29, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_29)) { - lean_ctor_release(x_29, 0); - lean_ctor_release(x_29, 1); - x_37 = x_29; -} else { - lean_dec_ref(x_29); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -else -{ -lean_object* x_39; -lean_dec(x_28); -lean_dec(x_3); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_26); -lean_ctor_set(x_39, 1, x_25); -return x_39; -} -} -} -else -{ -uint8_t x_40; -lean_dec(x_3); -lean_dec(x_2); -x_40 = !lean_is_exclusive(x_5); -if (x_40 == 0) -{ -return x_5; -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_5, 0); -x_42 = lean_ctor_get(x_5, 1); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_5); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_41); -lean_ctor_set(x_43, 1, x_42); -return x_43; -} -} -} -} -lean_object* l_Lean_Elab_Command_mkDeclName___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Elab_Command_mkDeclName(x_1, x_2, x_3, x_4); -lean_dec(x_1); -return x_5; -} -} lean_object* _init_l_Lean_Elab_Command_checkNotAlreadyDeclared___closed__1() { _start: { @@ -2617,6 +2512,346 @@ lean_dec(x_1); return x_5; } } +lean_object* l_Lean_Elab_Command_applyVisibility(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +switch (x_2) { +case 0: +{ +lean_object* x_6; +lean_inc(x_3); +x_6 = l_Lean_Elab_Command_checkNotAlreadyDeclared(x_1, x_3, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +uint8_t x_7; +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; +x_8 = lean_ctor_get(x_6, 0); +lean_dec(x_8); +lean_ctor_set(x_6, 0, x_3); +return x_6; +} +else +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_ctor_get(x_6, 1); +lean_inc(x_9); +lean_dec(x_6); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_3); +lean_ctor_set(x_10, 1, x_9); +return x_10; +} +} +else +{ +uint8_t x_11; +lean_dec(x_3); +x_11 = !lean_is_exclusive(x_6); +if (x_11 == 0) +{ +return x_6; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_6, 0); +x_13 = lean_ctor_get(x_6, 1); +lean_inc(x_13); +lean_inc(x_12); +lean_dec(x_6); +x_14 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_14, 0, x_12); +lean_ctor_set(x_14, 1, x_13); +return x_14; +} +} +} +case 1: +{ +lean_object* x_15; +lean_inc(x_4); +lean_inc(x_3); +x_15 = l_Lean_Elab_Command_checkNotAlreadyDeclared(x_1, x_3, x_4, x_5); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_15, 1); +lean_inc(x_16); +lean_dec(x_15); +lean_inc(x_4); +x_17 = l_Lean_Elab_Command_getEnv(x_4, x_16); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +lean_dec(x_17); +x_20 = l_Lean_protectedExt; +lean_inc(x_3); +x_21 = l_Lean_PersistentEnvExtension_addEntry___rarg(x_20, x_18, x_3); +x_22 = l_Lean_Elab_Command_setEnv(x_21, x_4, x_19); +if (lean_obj_tag(x_22) == 0) +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; +x_24 = lean_ctor_get(x_22, 0); +lean_dec(x_24); +lean_ctor_set(x_22, 0, x_3); +return x_22; +} +else +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_22, 1); +lean_inc(x_25); +lean_dec(x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_3); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +else +{ +uint8_t x_27; +lean_dec(x_3); +x_27 = !lean_is_exclusive(x_22); +if (x_27 == 0) +{ +return x_22; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_22, 0); +x_29 = lean_ctor_get(x_22, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_22); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +else +{ +uint8_t x_31; +lean_dec(x_4); +lean_dec(x_3); +x_31 = !lean_is_exclusive(x_17); +if (x_31 == 0) +{ +return x_17; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_17, 0); +x_33 = lean_ctor_get(x_17, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_17); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +else +{ +uint8_t x_35; +lean_dec(x_4); +lean_dec(x_3); +x_35 = !lean_is_exclusive(x_15); +if (x_35 == 0) +{ +return x_15; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_15, 0); +x_37 = lean_ctor_get(x_15, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_15); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +default: +{ +lean_object* x_39; +lean_inc(x_4); +x_39 = l_Lean_Elab_Command_getEnv(x_4, x_5); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +x_42 = l_Lean_mkPrivateName(x_40, x_3); +lean_inc(x_42); +x_43 = l_Lean_Elab_Command_checkNotAlreadyDeclared(x_1, x_42, x_4, x_41); +if (lean_obj_tag(x_43) == 0) +{ +uint8_t x_44; +x_44 = !lean_is_exclusive(x_43); +if (x_44 == 0) +{ +lean_object* x_45; +x_45 = lean_ctor_get(x_43, 0); +lean_dec(x_45); +lean_ctor_set(x_43, 0, x_42); +return x_43; +} +else +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_43, 1); +lean_inc(x_46); +lean_dec(x_43); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_46); +return x_47; +} +} +else +{ +uint8_t x_48; +lean_dec(x_42); +x_48 = !lean_is_exclusive(x_43); +if (x_48 == 0) +{ +return x_43; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_43, 0); +x_50 = lean_ctor_get(x_43, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_43); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +else +{ +uint8_t x_52; +lean_dec(x_4); +lean_dec(x_3); +x_52 = !lean_is_exclusive(x_39); +if (x_52 == 0) +{ +return x_39; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_39, 0); +x_54 = lean_ctor_get(x_39, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_39); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; +} +} +} +} +} +} +lean_object* l_Lean_Elab_Command_applyVisibility___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = lean_unbox(x_2); +lean_dec(x_2); +x_7 = l_Lean_Elab_Command_applyVisibility(x_1, x_6, x_3, x_4, x_5); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Lean_Elab_Command_mkDeclName(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +x_6 = l_Lean_Elab_Command_getCurrNamespace(x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_Name_append___main(x_7, x_3); +lean_dec(x_7); +x_10 = lean_ctor_get_uint8(x_2, sizeof(void*)*2); +x_11 = l_Lean_Elab_Command_applyVisibility(x_1, x_10, x_9, x_4, x_8); +return x_11; +} +else +{ +uint8_t x_12; +lean_dec(x_4); +lean_dec(x_3); +x_12 = !lean_is_exclusive(x_6); +if (x_12 == 0) +{ +return x_6; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_6, 0); +x_14 = lean_ctor_get(x_6, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_6); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +} +lean_object* l_Lean_Elab_Command_mkDeclName___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Elab_Command_mkDeclName(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { @@ -2918,6 +3153,10 @@ l_Lean_Elab_Command_Attribute_hasFormat___closed__1 = _init_l_Lean_Elab_Command_ lean_mark_persistent(l_Lean_Elab_Command_Attribute_hasFormat___closed__1); l_Lean_Elab_Command_Attribute_hasFormat___closed__2 = _init_l_Lean_Elab_Command_Attribute_hasFormat___closed__2(); lean_mark_persistent(l_Lean_Elab_Command_Attribute_hasFormat___closed__2); +l_Lean_Elab_Command_Attribute_inhabited___closed__1 = _init_l_Lean_Elab_Command_Attribute_inhabited___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_Attribute_inhabited___closed__1); +l_Lean_Elab_Command_Attribute_inhabited = _init_l_Lean_Elab_Command_Attribute_inhabited(); +lean_mark_persistent(l_Lean_Elab_Command_Attribute_inhabited); l_Lean_Elab_Command_Visibility_hasToString___closed__1 = _init_l_Lean_Elab_Command_Visibility_hasToString___closed__1(); lean_mark_persistent(l_Lean_Elab_Command_Visibility_hasToString___closed__1); l_Lean_Elab_Command_Modifiers_hasFormat___closed__1 = _init_l_Lean_Elab_Command_Modifiers_hasFormat___closed__1(); diff --git a/stage0/stdlib/Lean/Elab/Declaration.c b/stage0/stdlib/Lean/Elab/Declaration.c index 5a1f8606b0..2653ac24a0 100644 --- a/stage0/stdlib/Lean/Elab/Declaration.c +++ b/stage0/stdlib/Lean/Elab/Declaration.c @@ -15,27 +15,31 @@ extern "C" { #endif lean_object* l_Lean_Elab_Command_elabDeclaration(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_extractMacroScopes(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2; extern lean_object* l_Lean_Parser_Command_abbrev___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabConstant___closed__4; lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6; lean_object* l_Lean_Syntax_getOptional_x3f(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2; +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabConstant___closed__2; -lean_object* l_Lean_Elab_Command_elabDeclaration___closed__4; +lean_object* l_Lean_Syntax_getIdAt(lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Command_commandElabAttribute; lean_object* l_Lean_Elab_Command_elabExample(lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabAbbrev(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_withDeclId___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabExample___closed__1; lean_object* l_Lean_Elab_Command_elabConstant___closed__1; lean_object* l_Lean_Elab_Command_elabInductiveCore(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6; +lean_object* l___private_Lean_Elab_Declaration_4__classInductiveSyntaxToView(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Command_6__mkTermContext(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_expandDeclSig(lean_object*); lean_object* l_Lean_Elab_Command_elabExample___closed__2; @@ -44,71 +48,83 @@ lean_object* l_Lean_mkIdentFrom(lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabDeclaration(lean_object*); extern lean_object* l_Lean_Parser_Command_mutual___elambda__1___closed__2; lean_object* l___private_Lean_Elab_Command_3__setState(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Elab_Declaration_2__classInductiveSyntaxToView(lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Elab_Term_mkForallUsedOnly(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6; +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5; lean_object* l___regBuiltin_Lean_Elab_Command_elabMutual(lean_object*); lean_object* lean_string_utf8_byte_size(lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3; extern lean_object* l_Lean_Parser_Command_example___elambda__1___closed__2; lean_object* l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabAxiom___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Name_getNumParts___main(lean_object*); lean_object* l___regBuiltin_Lean_Elab_Command_elabDeclaration___closed__1; +lean_object* l_Lean_Elab_Command_applyVisibility(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__8; lean_object* lean_nat_add(lean_object*, lean_object*); -uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Elab_Quotation_4__getHeadInfo___elambda__3___closed__3; extern lean_object* l_Lean_Parser_Command_classInductive___elambda__1___closed__2; extern lean_object* l_Lean_mkTermIdFromIdent___closed__2; -lean_object* l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabInstance___closed__4; -lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5; lean_object* l_Lean_Elab_Command_expandOptDeclSig___boxed(lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t lean_nat_dec_eq(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3; +lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabStructure___rarg(lean_object*); lean_object* l_Lean_Elab_Command_elabAxiom(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabInstance___closed__1; lean_object* l_Lean_Elab_Command_elabInstance___closed__2; -lean_object* l_Lean_Elab_Command_expandDeclId(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7; +lean_object* l_Lean_Name_append___main(lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8; extern lean_object* l_Lean_Parser_Command_def___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Command_declValSimple___elambda__1___closed__2; -extern lean_object* l_Lean_Meta_registerInstanceAttr___closed__1; +lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabConstant(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1; +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_expandOptDeclSig(lean_object*); -extern lean_object* l_Lean_Meta_registerInstanceAttr___closed__2; -lean_object* l_Lean_Syntax_getId(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7; lean_object* l_Lean_Elab_Command_elabClassInductive(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__4(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Elab_Term_5__expandCDot___main___closed__4; -extern lean_object* l_Lean_Parser_Command_namespace___elambda__1___closed__1; +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3; lean_object* l_Lean_Elab_Command_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Parser_Command_docComment___elambda__1___closed__2; +lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5; +extern lean_object* l_Lean_Parser_Command_instance___elambda__1___closed__1; +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_6__elabMutualInductive___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabMutual___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_4__elabMutualInductive___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__3(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Elab_Declaration_3__isMutualInductive___boxed(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10; lean_object* l_Lean_Elab_Command_elabMutual___closed__2; lean_object* l_Lean_Elab_Command_elabTheorem(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Elab_Command_modifyScope___closed__1; lean_object* l_Lean_Elab_Command_elabDef(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Elab_Command_withDeclId___closed__3; -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*); +extern lean_object* l_Lean_registerClassAttr___closed__2; +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_addMacroScope(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabInstance___closed__5; lean_object* l___private_Lean_Elab_Command_2__getState(lean_object*, lean_object*); -uint8_t l___private_Lean_Elab_Declaration_3__isMutualInductive(lean_object*); +uint8_t l___private_Lean_Elab_Declaration_5__isMutualInductive(lean_object*); +lean_object* l_Lean_Elab_Command_elabClassInductive___closed__1; +extern lean_object* l_Lean_Parser_Command_instance___elambda__1___closed__2; extern lean_object* l_Lean_mkReducibilityAttrs___closed__4; lean_object* l_Lean_mkAtomFrom(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Elab_Quotation_8__letBindRhss___main___closed__11; -lean_object* l_List_drop___main___rarg(lean_object*, lean_object*); -lean_object* l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabAbbrev___closed__3; +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12; lean_object* l_Lean_Elab_Command_elabStructure___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabMutual(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabInstance(lean_object*, lean_object*, lean_object*, lean_object*); @@ -120,12 +136,14 @@ lean_object* l_Lean_Elab_Command_getMainModule(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabInstance___closed__3; lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l_Lean_Syntax_getKind(lean_object*); -lean_object* l_Lean_MacroScopesView_review(lean_object*); -lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_5__isMutualInductive___boxed(lean_object*); lean_object* l_Lean_Elab_Command_elabAbbrev___closed__2; +extern lean_object* l_Lean_Elab_Command_Attribute_inhabited; lean_object* l_Lean_Elab_Command_elabStructure(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_Modifiers_addAttribute(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabMutual___closed__3; +lean_object* l___private_Lean_Elab_Declaration_6__elabMutualInductive(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabType(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_structure___elambda__1___closed__2; extern lean_object* l_Lean_mkAppStx___closed__9; @@ -134,37 +152,46 @@ extern lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__5; extern lean_object* l_Lean_Parser_Command_inductive___elambda__1___closed__2; lean_object* l___private_Lean_Elab_Command_9__getVarDecls(lean_object*); uint8_t l_Lean_Syntax_isNone(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4; lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1; extern lean_object* l_Lean_mkOptionalNode___closed__1; lean_object* l_Lean_Elab_Command_getLevelNames(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabModifiers(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11; lean_object* l_Lean_Elab_Command_elabDefLike(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_expandDeclSig___boxed(lean_object*); lean_object* l_Lean_Elab_Command_elabDeclaration___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinders___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Elab_Declaration_4__elabMutualInductive(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4; +uint8_t l_Lean_Elab_Command_Modifiers_isProtected(lean_object*); +uint8_t l_Lean_Elab_Command_Modifiers_isPrivate(lean_object*); +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9; lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabDeclaration___closed__2; extern lean_object* l_Lean_mkOptionalNode___closed__2; -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabConstant___closed__5; +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1; lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabInductive(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabDeclaration___closed__1; -lean_object* l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabDeclaration___closed__3; +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2; lean_object* l_Lean_Elab_Command_elabConstant___closed__3; -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__2(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabAbbrev___closed__1; -lean_object* l___private_Lean_Elab_Command_12__addScopes___main(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9; +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8; lean_object* l_Lean_Elab_Command_elabAbbrev___closed__4; lean_object* l_Lean_CollectLevelParams_main___main(lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; lean_object* l___regBuiltin_Lean_Elab_Command_elabMutual___closed__1; -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__1(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_constant___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Command_theorem___elambda__1___closed__2; +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4; +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_declId___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_elabMutual___closed__1; @@ -607,7 +634,17 @@ lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Meta_registerInstanceAttr___closed__2; +x_1 = lean_box(0); +x_2 = l_Lean_Parser_Command_instance___elambda__1___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Elab_Command_elabInstance___closed__1; x_2 = lean_box(0); x_3 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_3, 0, x_1); @@ -615,7 +652,7 @@ lean_ctor_set(x_3, 1, x_2); return x_3; } } -lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__2() { +lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__3() { _start: { lean_object* x_1; @@ -623,21 +660,21 @@ x_1 = lean_mk_string("not implemented yet"); return x_1; } } -lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__3() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_elabInstance___closed__2; -x_2 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_2, 0, x_1); -return x_2; -} -} lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__4() { _start: { lean_object* x_1; lean_object* x_2; x_1 = l_Lean_Elab_Command_elabInstance___closed__3; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Elab_Command_elabInstance___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Command_elabInstance___closed__4; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; @@ -656,7 +693,7 @@ lean_inc(x_8); x_9 = lean_ctor_get(x_7, 1); lean_inc(x_9); lean_dec(x_7); -x_10 = l_Lean_Elab_Command_elabInstance___closed__1; +x_10 = l_Lean_Elab_Command_elabInstance___closed__2; x_11 = l_Lean_Elab_Command_Modifiers_addAttribute(x_1, x_10); x_12 = lean_unsigned_to_nat(1u); x_13 = l_Lean_Syntax_getArg(x_2, x_12); @@ -668,7 +705,7 @@ lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_dec(x_11); lean_dec(x_9); lean_dec(x_8); -x_15 = l_Lean_Elab_Command_elabInstance___closed__4; +x_15 = l_Lean_Elab_Command_elabInstance___closed__5; x_16 = l_Lean_Elab_Command_throwError___rarg(x_2, x_15, x_3, x_4); lean_dec(x_2); x_17 = !lean_is_exclusive(x_16); @@ -796,2238 +833,1338 @@ x_23 = l_Lean_Elab_Command_elabDefLike(x_22, x_3, x_4); return x_23; } } -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) +lean_object* x_11; +lean_inc(x_9); +lean_inc(x_1); +x_11 = l_Lean_Elab_Term_elabType(x_1, x_9, x_10); +if (lean_obj_tag(x_11) == 0) { -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); +lean_object* x_12; lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); +x_14 = 0; x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else +lean_inc(x_9); +x_16 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_14, x_15, x_9, x_13); +if (lean_obj_tag(x_16) == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +lean_inc(x_9); +x_18 = l_Lean_Elab_Term_instantiateMVars(x_1, x_12, x_9, x_17); +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else +lean_dec(x_18); +lean_inc(x_9); +x_21 = l_Lean_Elab_Term_mkForall(x_1, x_8, x_19, x_9, x_20); +if (lean_obj_tag(x_21) == 0) { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) +lean_dec(x_21); +lean_inc(x_9); +x_24 = l_Lean_Elab_Term_mkForallUsedOnly(x_1, x_2, x_22, x_9, x_23); +lean_dec(x_1); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = lean_ctor_get(x_25, 0); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +lean_inc(x_9); +x_29 = l_Lean_Elab_Term_levelMVarToParam(x_27, x_28, x_9, x_26); +x_30 = !lean_is_exclusive(x_29); +if (x_30 == 0) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_31 = lean_ctor_get(x_29, 0); +x_32 = lean_ctor_get(x_29, 1); +x_33 = lean_ctor_get(x_31, 0); +lean_inc(x_33); +lean_dec(x_31); +x_34 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; +lean_inc(x_33); +x_35 = l_Lean_CollectLevelParams_main___main(x_33, x_34); +x_36 = lean_ctor_get(x_35, 2); lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; +lean_dec(x_35); +x_37 = l_Lean_Elab_Command_sortDeclLevelParams(x_3, x_4, x_36); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +lean_dec(x_33); +lean_free_object(x_29); +lean_dec(x_6); +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +lean_dec(x_37); +x_39 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_39, 0, x_38); +x_40 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_40, 0, x_39); +x_41 = l_Lean_Elab_Term_throwError___rarg(x_5, x_40, x_9, x_32); +return x_41; } +else +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_9); +x_42 = lean_ctor_get(x_37, 0); +lean_inc(x_42); +lean_dec(x_37); +x_43 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_43, 0, x_6); +lean_ctor_set(x_43, 1, x_42); +lean_ctor_set(x_43, 2, x_33); +x_44 = lean_ctor_get_uint8(x_7, sizeof(void*)*2 + 3); +x_45 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set_uint8(x_45, sizeof(void*)*1, x_44); +x_46 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_29, 0, x_46); +return x_29; } } else { -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; +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_47 = lean_ctor_get(x_29, 0); +x_48 = lean_ctor_get(x_29, 1); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_29); x_49 = lean_ctor_get(x_47, 0); +lean_inc(x_49); +lean_dec(x_47); +x_50 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; +lean_inc(x_49); +x_51 = l_Lean_CollectLevelParams_main___main(x_49, x_50); +x_52 = lean_ctor_get(x_51, 2); +lean_inc(x_52); +lean_dec(x_51); +x_53 = l_Lean_Elab_Command_sortDeclLevelParams(x_3, x_4, x_52); +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); +lean_dec(x_6); +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +lean_dec(x_53); +x_55 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_55, 0, x_54); +x_56 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_56, 0, x_55); +x_57 = l_Lean_Elab_Term_throwError___rarg(x_5, x_56, x_9, x_48); 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_63; lean_object* x_64; lean_object* x_65; -x_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); +lean_object* x_58; lean_object* x_59; uint8_t x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +lean_dec(x_9); +x_58 = lean_ctor_get(x_53, 0); lean_inc(x_58); -lean_dec(x_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; +lean_dec(x_53); +x_59 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_59, 0, x_6); +lean_ctor_set(x_59, 1, x_58); +lean_ctor_set(x_59, 2, x_49); +x_60 = lean_ctor_get_uint8(x_7, sizeof(void*)*2 + 3); +x_61 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set_uint8(x_61, sizeof(void*)*1, x_60); +x_62 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_62, 0, x_61); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_48); +return x_63; } } } else { -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); +uint8_t x_64; +lean_dec(x_9); lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) +lean_dec(x_4); +lean_dec(x_3); +x_64 = !lean_is_exclusive(x_24); +if (x_64 == 0) { -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; +return x_24; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_24, 0); +x_66 = lean_ctor_get(x_24, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_24); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } } else { -lean_object* x_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_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; +uint8_t x_68; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) +x_68 = !lean_is_exclusive(x_21); +if (x_68 == 0) { -return x_4; +return x_21; } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_21, 0); +x_70 = lean_ctor_get(x_21, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_21); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_12); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_72 = !lean_is_exclusive(x_16); +if (x_72 == 0) +{ +return x_16; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_16, 0); +x_74 = lean_ctor_get(x_16, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_16); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +else +{ +uint8_t x_76; +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_76 = !lean_is_exclusive(x_11); +if (x_76 == 0) +{ +return x_11; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_11, 0); +x_78 = lean_ctor_get(x_11, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_11); +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_77); +lean_ctor_set(x_79, 1, x_78); +return x_79; } } } } -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = l_Lean_Syntax_getArgs(x_1); +x_12 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__1___boxed), 10, 7); +lean_closure_set(x_12, 0, x_2); +lean_closure_set(x_12, 1, x_8); +lean_closure_set(x_12, 2, x_3); +lean_closure_set(x_12, 3, x_4); +lean_closure_set(x_12, 4, x_5); +lean_closure_set(x_12, 5, x_6); +lean_closure_set(x_12, 6, x_7); +x_13 = l_Lean_Elab_Term_elabBinders___rarg(x_11, x_12, x_9, x_10); +lean_dec(x_11); +return x_13; +} +} +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: { -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) +lean_object* x_10; +lean_inc(x_8); +x_10 = l_Lean_Elab_Command_mkDeclName(x_1, x_2, x_7, x_8, x_9); +if (lean_obj_tag(x_10) == 0) { -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_33; lean_object* x_34; lean_object* x_35; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_ctor_get(x_2, 1); +lean_inc(x_13); +x_33 = 2; +x_34 = lean_unsigned_to_nat(0u); +lean_inc(x_8); +lean_inc(x_11); +x_35 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_11, x_33, x_13, x_34, x_8, x_12); +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_36; lean_object* x_37; +x_36 = lean_ctor_get(x_35, 1); +lean_inc(x_36); +lean_dec(x_35); +lean_inc(x_8); +x_37 = l_Lean_Elab_Command_getLevelNames(x_8, x_36); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_37, 1); +lean_inc(x_39); +lean_dec(x_37); +lean_inc(x_11); +x_40 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_40, 0, x_11); +lean_inc(x_11); +lean_inc(x_3); +x_41 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__2___boxed), 10, 7); +lean_closure_set(x_41, 0, x_4); +lean_closure_set(x_41, 1, x_5); +lean_closure_set(x_41, 2, x_6); +lean_closure_set(x_41, 3, x_38); +lean_closure_set(x_41, 4, x_3); +lean_closure_set(x_41, 5, x_11); +lean_closure_set(x_41, 6, x_2); +lean_inc(x_8); +x_42 = l___private_Lean_Elab_Command_2__getState(x_8, x_39); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = l___private_Lean_Elab_Command_9__getVarDecls(x_43); +lean_dec(x_43); +lean_inc(x_8); +x_46 = l___private_Lean_Elab_Command_2__getState(x_8, x_44); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +x_49 = l___private_Lean_Elab_Command_6__mkTermContext(x_8, x_47, x_40); +x_50 = l___private_Lean_Elab_Command_7__mkTermState(x_47); +lean_dec(x_47); +x_51 = l_Lean_Elab_Term_elabBinders___rarg(x_45, x_41, x_49, x_50); +lean_dec(x_45); +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +lean_inc(x_8); +x_54 = l___private_Lean_Elab_Command_2__getState(x_8, x_48); +if (lean_obj_tag(x_54) == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; +x_55 = lean_ctor_get(x_53, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_54, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_54, 1); +lean_inc(x_57); +lean_dec(x_54); +x_58 = lean_ctor_get(x_55, 0); +lean_inc(x_58); +lean_dec(x_55); +x_59 = lean_ctor_get(x_53, 2); +lean_inc(x_59); +lean_dec(x_53); +x_60 = !lean_is_exclusive(x_56); +if (x_60 == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_61 = lean_ctor_get(x_56, 1); +lean_dec(x_61); +x_62 = lean_ctor_get(x_56, 0); +lean_dec(x_62); +lean_ctor_set(x_56, 1, x_59); +lean_ctor_set(x_56, 0, x_58); +lean_inc(x_8); +x_63 = l___private_Lean_Elab_Command_3__setState(x_56, x_8, x_57); +if (lean_obj_tag(x_63) == 0) +{ +lean_object* x_64; +x_64 = lean_ctor_get(x_63, 1); +lean_inc(x_64); +lean_dec(x_63); +x_14 = x_52; +x_15 = x_64; +goto block_32; +} +else +{ +uint8_t x_65; +lean_dec(x_52); +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_65 = !lean_is_exclusive(x_63); +if (x_65 == 0) +{ +return x_63; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_63, 0); +x_67 = lean_ctor_get(x_63, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_63); +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; +} +} +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_69 = lean_ctor_get(x_56, 2); +x_70 = lean_ctor_get(x_56, 3); +x_71 = lean_ctor_get(x_56, 4); +lean_inc(x_71); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_56); +x_72 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_72, 0, x_58); +lean_ctor_set(x_72, 1, x_59); +lean_ctor_set(x_72, 2, x_69); +lean_ctor_set(x_72, 3, x_70); +lean_ctor_set(x_72, 4, x_71); +lean_inc(x_8); +x_73 = l___private_Lean_Elab_Command_3__setState(x_72, x_8, x_57); +if (lean_obj_tag(x_73) == 0) +{ +lean_object* x_74; +x_74 = lean_ctor_get(x_73, 1); +lean_inc(x_74); +lean_dec(x_73); +x_14 = x_52; +x_15 = x_74; +goto block_32; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +lean_dec(x_52); +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_75 = lean_ctor_get(x_73, 0); +lean_inc(x_75); +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_77 = x_73; +} else { + lean_dec_ref(x_73); + x_77 = lean_box(0); +} +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(1, 2, 0); +} else { + x_78 = x_77; +} +lean_ctor_set(x_78, 0, x_75); +lean_ctor_set(x_78, 1, x_76); +return x_78; +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_53); +lean_dec(x_52); +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_79 = !lean_is_exclusive(x_54); +if (x_79 == 0) +{ +return x_54; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_54, 0); +x_81 = lean_ctor_get(x_54, 1); +lean_inc(x_81); +lean_inc(x_80); +lean_dec(x_54); +x_82 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_82, 0, x_80); +lean_ctor_set(x_82, 1, x_81); +return x_82; +} +} +} +else +{ +lean_object* x_83; +x_83 = lean_ctor_get(x_51, 0); +lean_inc(x_83); +if (lean_obj_tag(x_83) == 0) +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_3); +x_84 = lean_ctor_get(x_51, 1); +lean_inc(x_84); +lean_dec(x_51); +x_85 = lean_ctor_get(x_83, 0); +lean_inc(x_85); +lean_dec(x_83); +lean_inc(x_8); +x_86 = l___private_Lean_Elab_Command_2__getState(x_8, x_48); +if (lean_obj_tag(x_86) == 0) +{ +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; +x_87 = lean_ctor_get(x_84, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_86, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_86, 1); +lean_inc(x_89); +lean_dec(x_86); +x_90 = lean_ctor_get(x_87, 0); +lean_inc(x_90); +lean_dec(x_87); +x_91 = lean_ctor_get(x_84, 2); +lean_inc(x_91); +lean_dec(x_84); +x_92 = !lean_is_exclusive(x_88); +if (x_92 == 0) +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_88, 1); +lean_dec(x_93); +x_94 = lean_ctor_get(x_88, 0); +lean_dec(x_94); +lean_ctor_set(x_88, 1, x_91); +lean_ctor_set(x_88, 0, x_90); +x_95 = l___private_Lean_Elab_Command_3__setState(x_88, x_8, x_89); +if (lean_obj_tag(x_95) == 0) +{ +uint8_t x_96; +x_96 = !lean_is_exclusive(x_95); +if (x_96 == 0) +{ +lean_object* x_97; +x_97 = lean_ctor_get(x_95, 0); +lean_dec(x_97); +lean_ctor_set_tag(x_95, 1); +lean_ctor_set(x_95, 0, x_85); +return x_95; +} +else +{ +lean_object* x_98; lean_object* x_99; +x_98 = lean_ctor_get(x_95, 1); +lean_inc(x_98); +lean_dec(x_95); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_85); +lean_ctor_set(x_99, 1, x_98); +return x_99; +} +} +else +{ +uint8_t x_100; +lean_dec(x_85); +x_100 = !lean_is_exclusive(x_95); +if (x_100 == 0) +{ +return x_95; +} +else +{ +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_95, 0); +x_102 = lean_ctor_get(x_95, 1); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_95); +x_103 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_103, 0, x_101); +lean_ctor_set(x_103, 1, x_102); +return x_103; +} +} +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_104 = lean_ctor_get(x_88, 2); +x_105 = lean_ctor_get(x_88, 3); +x_106 = lean_ctor_get(x_88, 4); +lean_inc(x_106); +lean_inc(x_105); +lean_inc(x_104); +lean_dec(x_88); +x_107 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_107, 0, x_90); +lean_ctor_set(x_107, 1, x_91); +lean_ctor_set(x_107, 2, x_104); +lean_ctor_set(x_107, 3, x_105); +lean_ctor_set(x_107, 4, x_106); +x_108 = l___private_Lean_Elab_Command_3__setState(x_107, x_8, x_89); +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, 1); +lean_inc(x_109); +if (lean_is_exclusive(x_108)) { + lean_ctor_release(x_108, 0); + lean_ctor_release(x_108, 1); + x_110 = x_108; +} else { + lean_dec_ref(x_108); + x_110 = lean_box(0); +} +if (lean_is_scalar(x_110)) { + x_111 = lean_alloc_ctor(1, 2, 0); +} else { + x_111 = x_110; + lean_ctor_set_tag(x_111, 1); +} +lean_ctor_set(x_111, 0, x_85); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; +lean_dec(x_85); +x_112 = lean_ctor_get(x_108, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_108, 1); +lean_inc(x_113); +if (lean_is_exclusive(x_108)) { + lean_ctor_release(x_108, 0); + lean_ctor_release(x_108, 1); + x_114 = x_108; +} else { + lean_dec_ref(x_108); + x_114 = lean_box(0); +} +if (lean_is_scalar(x_114)) { + x_115 = lean_alloc_ctor(1, 2, 0); +} else { + x_115 = x_114; +} +lean_ctor_set(x_115, 0, x_112); +lean_ctor_set(x_115, 1, x_113); +return x_115; +} +} +} +else +{ +uint8_t x_116; +lean_dec(x_85); +lean_dec(x_84); +lean_dec(x_8); +x_116 = !lean_is_exclusive(x_86); +if (x_116 == 0) +{ +return x_86; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_86, 0); +x_118 = lean_ctor_get(x_86, 1); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_86); +x_119 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_119, 0, x_117); +lean_ctor_set(x_119, 1, x_118); +return x_119; +} +} +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +lean_dec(x_51); +x_120 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_121 = l_unreachable_x21___rarg(x_120); +lean_inc(x_8); +x_122 = lean_apply_2(x_121, x_8, x_48); +if (lean_obj_tag(x_122) == 0) +{ +lean_object* x_123; lean_object* x_124; +x_123 = lean_ctor_get(x_122, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_122, 1); +lean_inc(x_124); +lean_dec(x_122); +x_14 = x_123; +x_15 = x_124; +goto block_32; +} +else +{ +uint8_t x_125; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_125 = !lean_is_exclusive(x_122); +if (x_125 == 0) +{ +return x_122; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_122, 0); +x_127 = lean_ctor_get(x_122, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_122); +x_128 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +return x_128; +} +} +} +} +} +else +{ +uint8_t x_129; +lean_dec(x_45); +lean_dec(x_41); +lean_dec(x_40); +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_129 = !lean_is_exclusive(x_46); +if (x_129 == 0) +{ +return x_46; +} +else +{ +lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_130 = lean_ctor_get(x_46, 0); +x_131 = lean_ctor_get(x_46, 1); +lean_inc(x_131); +lean_inc(x_130); +lean_dec(x_46); +x_132 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_132, 0, x_130); +lean_ctor_set(x_132, 1, x_131); +return x_132; +} +} +} +else +{ +uint8_t x_133; +lean_dec(x_41); +lean_dec(x_40); +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_133 = !lean_is_exclusive(x_42); +if (x_133 == 0) +{ +return x_42; +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; +x_134 = lean_ctor_get(x_42, 0); +x_135 = lean_ctor_get(x_42, 1); +lean_inc(x_135); +lean_inc(x_134); +lean_dec(x_42); +x_136 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_136, 0, x_134); +lean_ctor_set(x_136, 1, x_135); +return x_136; +} +} +} +else +{ +uint8_t x_137; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) +lean_dec(x_3); +lean_dec(x_2); +x_137 = !lean_is_exclusive(x_37); +if (x_137 == 0) { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) +return x_37; +} +else { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) +lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_138 = lean_ctor_get(x_37, 0); +x_139 = lean_ctor_get(x_37, 1); +lean_inc(x_139); +lean_inc(x_138); +lean_dec(x_37); +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_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); +uint8_t x_141; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_141 = !lean_is_exclusive(x_35); +if (x_141 == 0) +{ +return x_35; +} +else +{ +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_35, 0); +x_143 = lean_ctor_get(x_35, 1); +lean_inc(x_143); +lean_inc(x_142); +lean_dec(x_35); +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; +} +} +block_32: +{ +lean_object* x_16; +lean_inc(x_8); +x_16 = l_Lean_Elab_Command_addDecl(x_3, x_14, x_8, x_15); lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else +if (lean_obj_tag(x_16) == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else +lean_object* x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +x_18 = 0; +x_19 = lean_unsigned_to_nat(0u); +lean_inc(x_8); +lean_inc(x_11); +x_20 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_11, x_18, x_13, x_19, x_8, x_17); +if (lean_obj_tag(x_20) == 0) { -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); +lean_object* x_21; uint8_t x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_20, 1); lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} +lean_dec(x_20); +x_22 = 1; +x_23 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_11, x_22, x_13, x_19, x_8, x_21); +lean_dec(x_13); +lean_dec(x_3); +return x_23; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); +uint8_t x_24; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_24 = !lean_is_exclusive(x_20); +if (x_24 == 0) +{ +return x_20; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_20, 0); +x_26 = lean_ctor_get(x_20, 1); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; +lean_dec(x_20); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; } } } else { -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) +uint8_t x_28; +lean_dec(x_13); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_3); +x_28 = !lean_is_exclusive(x_16); +if (x_28 == 0) { -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; +return x_16; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_16, 0); +x_30 = lean_ctor_get(x_16, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_16); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; } } -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} } } else { -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); +uint8_t x_145; +lean_dec(x_8); lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; +lean_dec(x_3); +lean_dec(x_2); +x_145 = !lean_is_exclusive(x_10); +if (x_145 == 0) +{ +return x_10; +} +else +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_146 = lean_ctor_get(x_10, 0); +x_147 = lean_ctor_get(x_10, 1); +lean_inc(x_147); +lean_inc(x_146); +lean_dec(x_10); +x_148 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_148, 0, x_146); +lean_ctor_set(x_148, 1, x_147); +return x_148; } } } } -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Elab_Command_elabAxiom(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); +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_5 = lean_unsigned_to_nat(1u); +x_6 = l_Lean_Syntax_getArg(x_2, x_5); +x_7 = lean_unsigned_to_nat(2u); +x_8 = l_Lean_Syntax_getArg(x_2, x_7); +x_9 = l_Lean_Elab_Command_expandDeclSig(x_8); +lean_dec(x_8); +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); +lean_inc(x_3); +x_12 = l_Lean_Elab_Command_getLevelNames(x_3, x_4); if (lean_obj_tag(x_12) == 0) { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); +x_15 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__3___boxed), 9, 6); +lean_closure_set(x_15, 0, x_6); +lean_closure_set(x_15, 1, x_1); +lean_closure_set(x_15, 2, x_2); +lean_closure_set(x_15, 3, x_10); +lean_closure_set(x_15, 4, x_11); +lean_closure_set(x_15, 5, x_13); +x_16 = l_Lean_Elab_Command_withDeclId___rarg(x_6, x_15, x_3, x_14); lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; +return x_16; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; +uint8_t x_17; +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) +x_17 = !lean_is_exclusive(x_12); +if (x_17 == 0) { -return x_4; +return x_12; } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_12, 0); +x_19 = lean_ctor_get(x_12, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_12); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; } } } } -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_2); -x_8 = lean_nat_dec_lt(x_3, x_7); +lean_object* x_11; +x_11 = l_Lean_Elab_Command_elabAxiom___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_dec(x_5); -lean_dec(x_3); -x_9 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_9, 0, x_4); -lean_ctor_set(x_9, 1, x_6); -return x_9; +return x_11; +} +} +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +lean_object* x_11; +x_11 = l_Lean_Elab_Command_elabAxiom___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +lean_dec(x_1); +return x_11; +} +} +lean_object* l_Lean_Elab_Command_elabAxiom___lambda__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l_Lean_Elab_Command_elabAxiom___lambda__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_1); +return x_10; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of attributes in inductive declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of 'partial' in inductive declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of 'noncomputable' in inductive declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; uint8_t x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; uint8_t x_11; +x_5 = lean_ctor_get_uint8(x_2, sizeof(void*)*2 + 1); +x_6 = lean_ctor_get_uint8(x_2, sizeof(void*)*2 + 2); +x_7 = lean_ctor_get(x_2, 1); +x_8 = lean_array_get_size(x_7); +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_nat_dec_eq(x_8, x_9); +if (x_5 == 0) +{ +uint8_t x_53; +x_53 = 0; +x_11 = x_53; +goto block_52; } else { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_10 = lean_array_fget(x_2, x_3); -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_add(x_3, x_11); -lean_dec(x_3); -x_13 = l_Lean_Syntax_getId(x_10); -x_14 = l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(x_13, x_4); -if (x_14 == 0) +uint8_t x_54; +x_54 = 1; +x_11 = x_54; +goto block_52; +} +block_52: +{ +uint8_t x_12; +if (x_6 == 0) +{ +uint8_t x_50; +x_50 = 0; +x_12 = x_50; +goto block_49; +} +else +{ +uint8_t x_51; +x_51 = 1; +x_12 = x_51; +goto block_49; +} +block_49: +{ +uint8_t x_13; +if (x_10 == 0) +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_unsigned_to_nat(1u); +x_42 = lean_nat_dec_eq(x_8, x_41); +lean_dec(x_8); +if (x_42 == 0) +{ +x_13 = x_10; +goto block_40; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; uint8_t x_47; +x_43 = l_Lean_Elab_Command_Attribute_inhabited; +x_44 = lean_array_get(x_43, x_7, x_9); +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +lean_dec(x_44); +x_46 = l_Lean_registerClassAttr___closed__2; +x_47 = lean_name_eq(x_45, x_46); +lean_dec(x_45); +x_13 = x_47; +goto block_40; +} +} +else +{ +uint8_t x_48; +lean_dec(x_8); +x_48 = 1; +x_13 = x_48; +goto block_40; +} +block_40: +{ +uint8_t x_14; +if (x_13 == 0) +{ +uint8_t x_38; +x_38 = 0; +x_14 = x_38; +goto block_37; +} +else +{ +uint8_t x_39; +x_39 = 1; +x_14 = x_39; +goto block_37; +} +block_37: { lean_object* x_15; -lean_dec(x_10); -x_15 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_4); -x_3 = x_12; -x_4 = x_15; -goto _start; +if (x_11 == 0) +{ +x_15 = x_4; +goto block_30; } else { -lean_object* x_17; uint8_t x_18; -lean_dec(x_12); -lean_dec(x_4); -x_17 = l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg(x_10, x_13, x_5, x_6); -lean_dec(x_10); +lean_object* x_31; lean_object* x_32; uint8_t x_33; +x_31 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9; +x_32 = l_Lean_Elab_Command_throwError___rarg(x_1, x_31, x_3, x_4); +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +return x_32; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_32, 0); +x_35 = lean_ctor_get(x_32, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_32); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +block_30: +{ +if (x_12 == 0) +{ +if (x_14 == 0) +{ +lean_object* x_16; lean_object* x_17; uint8_t x_18; +x_16 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3; +x_17 = l_Lean_Elab_Command_throwError___rarg(x_1, x_16, x_3, x_15); x_18 = !lean_is_exclusive(x_17); if (x_18 == 0) { @@ -3047,1278 +2184,946 @@ lean_ctor_set(x_21, 1, x_20); return x_21; } } +else +{ +lean_object* x_22; lean_object* x_23; +lean_dec(x_3); +x_22 = lean_box(0); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_15); +return x_23; +} +} +else +{ +lean_object* x_24; lean_object* x_25; uint8_t x_26; +x_24 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6; +x_25 = l_Lean_Elab_Command_throwError___rarg(x_1, x_24, x_3, x_15); +x_26 = !lean_is_exclusive(x_25); +if (x_26 == 0) +{ +return x_25; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_25, 0); +x_28 = lean_ctor_get(x_25, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_25); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; } } } -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +} +} +} +} +} +} +lean_object* l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_9; -lean_inc(x_7); -lean_inc(x_1); -x_9 = l_Lean_Elab_Term_elabType(x_1, x_7, x_8); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = 0; -x_13 = lean_box(0); -lean_inc(x_7); -x_14 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_12, x_13, x_7, x_11); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_15 = lean_ctor_get(x_14, 1); -lean_inc(x_15); -lean_dec(x_14); -lean_inc(x_7); -x_16 = l_Lean_Elab_Term_instantiateMVars(x_1, x_10, x_7, x_15); -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -lean_inc(x_7); -x_19 = l_Lean_Elab_Term_mkForall(x_1, x_6, x_17, x_7, x_18); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -lean_inc(x_7); -x_22 = l_Lean_Elab_Term_mkForallUsedOnly(x_1, x_2, x_20, x_7, x_21); -lean_dec(x_1); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_ctor_get(x_23, 0); -lean_inc(x_25); -lean_dec(x_23); -x_26 = l_Lean_Elab_Term_levelMVarToParam(x_25, x_7, x_24); -x_27 = !lean_is_exclusive(x_26); -if (x_27 == 0) -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; -x_28 = lean_ctor_get(x_26, 0); -x_29 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; -lean_inc(x_28); -x_30 = l_Lean_CollectLevelParams_main___main(x_28, x_29); -x_31 = lean_ctor_get(x_30, 2); -lean_inc(x_31); -lean_dec(x_30); -x_32 = l_Lean_Elab_Command_sortDeclLevelParams(x_3, x_31); -x_33 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_33, 0, x_4); -lean_ctor_set(x_33, 1, x_32); -lean_ctor_set(x_33, 2, x_28); -x_34 = lean_ctor_get_uint8(x_5, sizeof(void*)*2 + 3); -x_35 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set_uint8(x_35, sizeof(void*)*1, x_34); -x_36 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_36, 0, x_35); -lean_ctor_set(x_26, 0, x_36); -return x_26; -} -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; uint8_t x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_37 = lean_ctor_get(x_26, 0); -x_38 = lean_ctor_get(x_26, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_26); -x_39 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; -lean_inc(x_37); -x_40 = l_Lean_CollectLevelParams_main___main(x_37, x_39); -x_41 = lean_ctor_get(x_40, 2); -lean_inc(x_41); -lean_dec(x_40); -x_42 = l_Lean_Elab_Command_sortDeclLevelParams(x_3, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_4); -lean_ctor_set(x_43, 1, x_42); -lean_ctor_set(x_43, 2, x_37); -x_44 = lean_ctor_get_uint8(x_5, sizeof(void*)*2 + 3); -x_45 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set_uint8(x_45, sizeof(void*)*1, x_44); -x_46 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_46, 0, x_45); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_38); -return x_47; -} -} -else -{ -uint8_t x_48; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_48 = !lean_is_exclusive(x_22); -if (x_48 == 0) -{ -return x_22; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_22, 0); -x_50 = lean_ctor_get(x_22, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_22); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -else -{ -uint8_t x_52; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); +lean_object* x_5; +x_5 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier(x_1, x_2, x_3, x_4); lean_dec(x_2); lean_dec(x_1); -x_52 = !lean_is_exclusive(x_19); -if (x_52 == 0) +return x_5; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1() { +_start: { -return x_19; +lean_object* x_1; +x_1 = lean_mk_string("invalid use of attributes in constructor declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of 'unsafe' in constructor declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of 'partial' in constructor declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid use of 'noncomputable' in constructor declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; uint8_t x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; uint8_t x_12; +x_5 = lean_ctor_get_uint8(x_2, sizeof(void*)*2 + 1); +x_6 = lean_ctor_get_uint8(x_2, sizeof(void*)*2 + 2); +x_7 = lean_ctor_get_uint8(x_2, sizeof(void*)*2 + 3); +x_8 = lean_ctor_get(x_2, 1); +x_9 = lean_array_get_size(x_8); +x_10 = lean_unsigned_to_nat(0u); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_9); +if (x_5 == 0) +{ +uint8_t x_58; +x_58 = 0; +x_12 = x_58; +goto block_57; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_19, 0); -x_54 = lean_ctor_get(x_19, 1); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_19); -x_55 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -return x_55; -} +uint8_t x_59; +x_59 = 1; +x_12 = x_59; +goto block_57; } +block_57: +{ +uint8_t x_13; +if (x_6 == 0) +{ +uint8_t x_55; +x_55 = 0; +x_13 = x_55; +goto block_54; } else { uint8_t x_56; -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); +x_56 = 1; +x_13 = x_56; +goto block_54; +} +block_54: +{ +uint8_t x_14; +if (x_7 == 0) +{ +uint8_t x_52; +x_52 = 0; +x_14 = x_52; +goto block_51; +} +else +{ +uint8_t x_53; +x_53 = 1; +x_14 = x_53; +goto block_51; +} +block_51: +{ +uint8_t x_15; +if (x_11 == 0) +{ +uint8_t x_49; +x_49 = 1; +x_15 = x_49; +goto block_48; +} +else +{ +uint8_t x_50; +x_50 = 0; +x_15 = x_50; +goto block_48; +} +block_48: +{ +uint8_t x_16; +if (x_15 == 0) +{ +uint8_t x_46; +x_46 = 0; +x_16 = x_46; +goto block_45; +} +else +{ +uint8_t x_47; +x_47 = 1; +x_16 = x_47; +goto block_45; +} +block_45: +{ +lean_object* x_17; +if (x_12 == 0) +{ +if (x_13 == 0) +{ +x_17 = x_4; +goto block_32; +} +else +{ +lean_object* x_33; lean_object* x_34; uint8_t x_35; +x_33 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9; +x_34 = l_Lean_Elab_Command_throwError___rarg(x_1, x_33, x_3, x_4); +x_35 = !lean_is_exclusive(x_34); +if (x_35 == 0) +{ +return x_34; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_34, 0); +x_37 = lean_ctor_get(x_34, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_34); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +else +{ +lean_object* x_39; lean_object* x_40; uint8_t x_41; +x_39 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12; +x_40 = l_Lean_Elab_Command_throwError___rarg(x_1, x_39, x_3, x_4); +x_41 = !lean_is_exclusive(x_40); +if (x_41 == 0) +{ +return x_40; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_40, 0); +x_43 = lean_ctor_get(x_40, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_40); +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; +} +} +block_32: +{ +if (x_14 == 0) +{ +if (x_16 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_56 = !lean_is_exclusive(x_14); -if (x_56 == 0) -{ -return x_14; +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_17); +return x_19; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_14, 0); -x_58 = lean_ctor_get(x_14, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_14); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -return x_59; -} -} -} -else -{ -uint8_t x_60; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_60 = !lean_is_exclusive(x_9); -if (x_60 == 0) -{ -return x_9; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_9, 0); -x_62 = lean_ctor_get(x_9, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_9); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} -} -} -} -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_9 = l_Lean_Syntax_getArgs(x_1); -x_10 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__1___boxed), 8, 5); -lean_closure_set(x_10, 0, x_2); -lean_closure_set(x_10, 1, x_6); -lean_closure_set(x_10, 2, x_3); -lean_closure_set(x_10, 3, x_4); -lean_closure_set(x_10, 4, x_5); -x_11 = l_Lean_Elab_Term_elabBinders___rarg(x_9, x_10, x_7, x_8); -lean_dec(x_9); -return x_11; -} -} -lean_object* l_Lean_Elab_Command_elabAxiom(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_5 = lean_unsigned_to_nat(1u); -x_6 = l_Lean_Syntax_getArg(x_2, x_5); -x_7 = lean_unsigned_to_nat(2u); -x_8 = l_Lean_Syntax_getArg(x_2, x_7); -x_9 = l_Lean_Elab_Command_expandDeclSig(x_8); -lean_dec(x_8); -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = l_Lean_Elab_Command_expandDeclId(x_6); -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -lean_inc(x_3); -x_15 = l_Lean_Elab_Command_getLevelNames(x_3, x_4); -if (lean_obj_tag(x_15) == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_385; -x_16 = lean_ctor_get(x_15, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_15, 1); -lean_inc(x_17); -lean_dec(x_15); -x_385 = l_Lean_Syntax_isNone(x_14); -if (x_385 == 0) -{ -lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; -x_386 = l_Lean_Syntax_getArg(x_14, x_5); -x_387 = l_Lean_Syntax_getArgs(x_386); -lean_dec(x_386); -x_388 = lean_unsigned_to_nat(0u); -x_389 = l_Array_empty___closed__1; -x_390 = l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(x_7, x_387, x_388, x_389); -lean_dec(x_387); -lean_inc(x_3); -lean_inc(x_16); -x_391 = l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5(x_14, x_390, x_388, x_16, x_3, x_17); -lean_dec(x_390); -lean_dec(x_14); -if (lean_obj_tag(x_391) == 0) -{ -lean_object* x_392; lean_object* x_393; -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_18 = x_392; -x_19 = x_393; -goto block_384; -} -else -{ -uint8_t x_394; -lean_dec(x_16); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_1); -x_394 = !lean_is_exclusive(x_391); -if (x_394 == 0) -{ -return x_391; -} -else -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_395 = lean_ctor_get(x_391, 0); -x_396 = lean_ctor_get(x_391, 1); -lean_inc(x_396); -lean_inc(x_395); -lean_dec(x_391); -x_397 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_397, 0, x_395); -lean_ctor_set(x_397, 1, x_396); -return x_397; -} -} -} -else -{ -lean_dec(x_14); -lean_inc(x_16); -x_18 = x_16; -x_19 = x_17; -goto block_384; -} -block_384: -{ -lean_object* x_20; lean_object* x_21; -x_20 = l_Lean_extractMacroScopes(x_13); -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -if (lean_obj_tag(x_21) == 1) -{ -uint8_t x_22; -x_22 = !lean_is_exclusive(x_20); +lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_20 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3; +x_21 = l_Lean_Elab_Command_throwError___rarg(x_1, x_20, x_3, x_17); +x_22 = !lean_is_exclusive(x_21); if (x_22 == 0) { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_41; uint8_t x_42; lean_object* x_43; -x_23 = lean_ctor_get(x_20, 0); -lean_dec(x_23); -x_24 = lean_ctor_get(x_21, 0); +return x_21; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_21, 0); +x_24 = lean_ctor_get(x_21, 1); lean_inc(x_24); -x_25 = lean_ctor_get(x_21, 1); -lean_inc(x_25); +lean_inc(x_23); lean_dec(x_21); -x_26 = lean_box(0); -x_27 = lean_name_mk_string(x_26, x_25); -lean_ctor_set(x_20, 0, x_27); -x_28 = l_Lean_MacroScopesView_review(x_20); -x_41 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; -x_42 = 1; -lean_inc(x_3); -lean_inc(x_24); -x_43 = l___private_Lean_Elab_Command_12__addScopes___main(x_6, x_41, x_42, x_24, x_3, x_19); -lean_dec(x_6); -if (lean_obj_tag(x_43) == 0) -{ -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_43, 1); -lean_inc(x_44); -lean_dec(x_43); -lean_inc(x_3); -x_45 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__2(x_18, x_3, x_44); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_45, 1); -lean_inc(x_46); -lean_dec(x_45); -lean_inc(x_3); -x_47 = l_Lean_Elab_Command_mkDeclName(x_1, x_28, x_3, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; uint8_t x_119; lean_object* x_120; lean_object* x_121; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_ctor_get(x_1, 1); -lean_inc(x_50); -x_119 = 2; -x_120 = lean_unsigned_to_nat(0u); -lean_inc(x_3); -lean_inc(x_48); -x_121 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_48, x_119, x_50, x_120, x_3, x_49); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -lean_dec(x_121); -lean_inc(x_3); -x_123 = l_Lean_Elab_Command_getLevelNames(x_3, x_122); -if (lean_obj_tag(x_123) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_124 = lean_ctor_get(x_123, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_123, 1); -lean_inc(x_125); -lean_dec(x_123); -lean_inc(x_48); -x_126 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_126, 0, x_48); -lean_inc(x_48); -x_127 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__2___boxed), 8, 5); -lean_closure_set(x_127, 0, x_10); -lean_closure_set(x_127, 1, x_11); -lean_closure_set(x_127, 2, x_124); -lean_closure_set(x_127, 3, x_48); -lean_closure_set(x_127, 4, x_1); -lean_inc(x_3); -x_128 = l___private_Lean_Elab_Command_2__getState(x_3, x_125); -if (lean_obj_tag(x_128) == 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 = l___private_Lean_Elab_Command_9__getVarDecls(x_129); -lean_dec(x_129); -lean_inc(x_3); -x_132 = l___private_Lean_Elab_Command_2__getState(x_3, x_130); -if (lean_obj_tag(x_132) == 0) -{ -lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_133 = lean_ctor_get(x_132, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_132, 1); -lean_inc(x_134); -lean_dec(x_132); -x_135 = l___private_Lean_Elab_Command_6__mkTermContext(x_3, x_133, x_126); -x_136 = l___private_Lean_Elab_Command_7__mkTermState(x_133); -lean_dec(x_133); -x_137 = l_Lean_Elab_Term_elabBinders___rarg(x_131, x_127, x_135, x_136); -lean_dec(x_131); -if (lean_obj_tag(x_137) == 0) -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; -x_138 = lean_ctor_get(x_137, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_137, 1); -lean_inc(x_139); -lean_dec(x_137); -lean_inc(x_3); -x_140 = l___private_Lean_Elab_Command_2__getState(x_3, x_134); -if (lean_obj_tag(x_140) == 0) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; uint8_t x_146; -x_141 = lean_ctor_get(x_139, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_140, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_140, 1); -lean_inc(x_143); -lean_dec(x_140); -x_144 = lean_ctor_get(x_141, 0); -lean_inc(x_144); -lean_dec(x_141); -x_145 = lean_ctor_get(x_139, 2); -lean_inc(x_145); -lean_dec(x_139); -x_146 = !lean_is_exclusive(x_142); -if (x_146 == 0) -{ -lean_object* x_147; lean_object* x_148; lean_object* x_149; -x_147 = lean_ctor_get(x_142, 1); -lean_dec(x_147); -x_148 = lean_ctor_get(x_142, 0); -lean_dec(x_148); -lean_ctor_set(x_142, 1, x_145); -lean_ctor_set(x_142, 0, x_144); -lean_inc(x_3); -x_149 = l___private_Lean_Elab_Command_3__setState(x_142, x_3, x_143); -if (lean_obj_tag(x_149) == 0) -{ -lean_object* x_150; -x_150 = lean_ctor_get(x_149, 1); -lean_inc(x_150); -lean_dec(x_149); -x_51 = x_138; -x_52 = x_150; -goto block_118; -} -else -{ -lean_object* x_151; lean_object* x_152; -lean_dec(x_138); -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_151 = lean_ctor_get(x_149, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_149, 1); -lean_inc(x_152); -lean_dec(x_149); -x_29 = x_151; -x_30 = x_152; -goto block_40; -} -} -else -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; -x_153 = lean_ctor_get(x_142, 2); -x_154 = lean_ctor_get(x_142, 3); -x_155 = lean_ctor_get(x_142, 4); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_dec(x_142); -x_156 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_156, 0, x_144); -lean_ctor_set(x_156, 1, x_145); -lean_ctor_set(x_156, 2, x_153); -lean_ctor_set(x_156, 3, x_154); -lean_ctor_set(x_156, 4, x_155); -lean_inc(x_3); -x_157 = l___private_Lean_Elab_Command_3__setState(x_156, x_3, x_143); -if (lean_obj_tag(x_157) == 0) -{ -lean_object* x_158; -x_158 = lean_ctor_get(x_157, 1); -lean_inc(x_158); -lean_dec(x_157); -x_51 = x_138; -x_52 = x_158; -goto block_118; -} -else -{ -lean_object* x_159; lean_object* x_160; -lean_dec(x_138); -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_159 = lean_ctor_get(x_157, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_157, 1); -lean_inc(x_160); -lean_dec(x_157); -x_29 = x_159; -x_30 = x_160; -goto block_40; +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; } } } else { -lean_object* x_161; lean_object* x_162; -lean_dec(x_139); -lean_dec(x_138); -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_161 = lean_ctor_get(x_140, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_140, 1); -lean_inc(x_162); -lean_dec(x_140); -x_29 = x_161; -x_30 = x_162; -goto block_40; -} +lean_object* x_26; lean_object* x_27; uint8_t x_28; +x_26 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6; +x_27 = l_Lean_Elab_Command_throwError___rarg(x_1, x_26, x_3, x_17); +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +return x_27; } else { -lean_object* x_163; -x_163 = lean_ctor_get(x_137, 0); -lean_inc(x_163); -if (lean_obj_tag(x_163) == 0) +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_27, 0); +x_30 = lean_ctor_get(x_27, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_27); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +} +} +} +} +} +} +} +lean_object* l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: { -lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_164 = lean_ctor_get(x_137, 1); -lean_inc(x_164); -lean_dec(x_137); -x_165 = lean_ctor_get(x_163, 0); -lean_inc(x_165); -lean_dec(x_163); -lean_inc(x_3); -x_166 = l___private_Lean_Elab_Command_2__getState(x_3, x_134); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; uint8_t x_172; -x_167 = lean_ctor_get(x_164, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_166, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_166, 1); -lean_inc(x_169); -lean_dec(x_166); -x_170 = lean_ctor_get(x_167, 0); -lean_inc(x_170); -lean_dec(x_167); -x_171 = lean_ctor_get(x_164, 2); -lean_inc(x_171); -lean_dec(x_164); -x_172 = !lean_is_exclusive(x_168); -if (x_172 == 0) -{ -lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_173 = lean_ctor_get(x_168, 1); -lean_dec(x_173); -x_174 = lean_ctor_get(x_168, 0); -lean_dec(x_174); -lean_ctor_set(x_168, 1, x_171); -lean_ctor_set(x_168, 0, x_170); -lean_inc(x_3); -x_175 = l___private_Lean_Elab_Command_3__setState(x_168, x_3, x_169); -if (lean_obj_tag(x_175) == 0) -{ -lean_object* x_176; -x_176 = lean_ctor_get(x_175, 1); -lean_inc(x_176); -lean_dec(x_175); -x_29 = x_165; -x_30 = x_176; -goto block_40; -} -else -{ -lean_object* x_177; lean_object* x_178; -lean_dec(x_165); -x_177 = lean_ctor_get(x_175, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_175, 1); -lean_inc(x_178); -lean_dec(x_175); -x_29 = x_177; -x_30 = x_178; -goto block_40; -} -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; -x_179 = lean_ctor_get(x_168, 2); -x_180 = lean_ctor_get(x_168, 3); -x_181 = lean_ctor_get(x_168, 4); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_179); -lean_dec(x_168); -x_182 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_182, 0, x_170); -lean_ctor_set(x_182, 1, x_171); -lean_ctor_set(x_182, 2, x_179); -lean_ctor_set(x_182, 3, x_180); -lean_ctor_set(x_182, 4, x_181); -lean_inc(x_3); -x_183 = l___private_Lean_Elab_Command_3__setState(x_182, x_3, x_169); -if (lean_obj_tag(x_183) == 0) -{ -lean_object* x_184; -x_184 = lean_ctor_get(x_183, 1); -lean_inc(x_184); -lean_dec(x_183); -x_29 = x_165; -x_30 = x_184; -goto block_40; -} -else -{ -lean_object* x_185; lean_object* x_186; -lean_dec(x_165); -x_185 = lean_ctor_get(x_183, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_183, 1); -lean_inc(x_186); -lean_dec(x_183); -x_29 = x_185; -x_30 = x_186; -goto block_40; -} -} -} -else -{ -lean_object* x_187; lean_object* x_188; -lean_dec(x_165); -lean_dec(x_164); -x_187 = lean_ctor_get(x_166, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_166, 1); -lean_inc(x_188); -lean_dec(x_166); -x_29 = x_187; -x_30 = x_188; -goto block_40; -} -} -else -{ -lean_object* x_189; lean_object* x_190; lean_object* x_191; -lean_dec(x_137); -x_189 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_190 = l_unreachable_x21___rarg(x_189); -lean_inc(x_3); -x_191 = lean_apply_2(x_190, x_3, x_134); -if (lean_obj_tag(x_191) == 0) -{ -lean_object* x_192; lean_object* x_193; -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_51 = x_192; -x_52 = x_193; -goto block_118; -} -else -{ -lean_object* x_194; lean_object* x_195; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_194 = lean_ctor_get(x_191, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_191, 1); -lean_inc(x_195); -lean_dec(x_191); -x_29 = x_194; -x_30 = x_195; -goto block_40; -} -} -} -} -else -{ -lean_object* x_196; lean_object* x_197; -lean_dec(x_131); -lean_dec(x_127); -lean_dec(x_126); -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_196 = lean_ctor_get(x_132, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_132, 1); -lean_inc(x_197); -lean_dec(x_132); -x_29 = x_196; -x_30 = x_197; -goto block_40; -} -} -else -{ -lean_object* x_198; lean_object* x_199; -lean_dec(x_127); -lean_dec(x_126); -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_198 = lean_ctor_get(x_128, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_128, 1); -lean_inc(x_199); -lean_dec(x_128); -x_29 = x_198; -x_30 = x_199; -goto block_40; -} -} -else -{ -lean_object* x_200; lean_object* x_201; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_10); +lean_object* x_5; +x_5 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier(x_1, x_2, x_3, x_4); +lean_dec(x_2); lean_dec(x_1); -x_200 = lean_ctor_get(x_123, 0); -lean_inc(x_200); -x_201 = lean_ctor_get(x_123, 1); -lean_inc(x_201); -lean_dec(x_123); -x_29 = x_200; -x_30 = x_201; -goto block_40; +return x_5; } } -else +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1() { +_start: { -lean_object* x_202; lean_object* x_203; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_1); -x_202 = lean_ctor_get(x_121, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_121, 1); -lean_inc(x_203); -lean_dec(x_121); -x_29 = x_202; -x_30 = x_203; -goto block_40; -} -block_118: -{ -lean_object* x_53; -lean_inc(x_3); -x_53 = l_Lean_Elab_Command_addDecl(x_2, x_51, x_3, x_52); -lean_dec(x_51); -if (lean_obj_tag(x_53) == 0) -{ -lean_object* x_54; uint8_t x_55; lean_object* x_56; lean_object* x_57; -x_54 = lean_ctor_get(x_53, 1); -lean_inc(x_54); -lean_dec(x_53); -x_55 = 0; -x_56 = lean_unsigned_to_nat(0u); -lean_inc(x_3); -lean_inc(x_48); -x_57 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_48, x_55, x_50, x_56, x_3, x_54); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; uint8_t x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_57, 1); -lean_inc(x_58); -lean_dec(x_57); -x_59 = 1; -lean_inc(x_3); -x_60 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_48, x_59, x_50, x_56, x_3, x_58); -lean_dec(x_50); -if (lean_obj_tag(x_60) == 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); -lean_inc(x_3); -lean_inc(x_16); -x_63 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__3(x_16, x_3, x_62); -if (lean_obj_tag(x_63) == 0) -{ -lean_object* x_64; lean_object* x_65; -lean_dec(x_16); -x_64 = lean_ctor_get(x_63, 1); -lean_inc(x_64); -lean_dec(x_63); -lean_inc(x_3); -x_65 = l___private_Lean_Elab_Command_2__getState(x_3, x_64); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_65, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_65, 1); -lean_inc(x_67); -lean_dec(x_65); -x_68 = !lean_is_exclusive(x_66); -if (x_68 == 0) -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_69 = lean_ctor_get(x_66, 2); -x_70 = l_Lean_Name_getNumParts___main(x_24); -lean_dec(x_24); -x_71 = l_List_drop___main___rarg(x_70, x_69); -lean_dec(x_69); -lean_ctor_set(x_66, 2, x_71); -x_72 = l___private_Lean_Elab_Command_3__setState(x_66, x_3, x_67); -if (lean_obj_tag(x_72) == 0) -{ -uint8_t x_73; -x_73 = !lean_is_exclusive(x_72); -if (x_73 == 0) -{ -lean_object* x_74; -x_74 = lean_ctor_get(x_72, 0); -lean_dec(x_74); -lean_ctor_set(x_72, 0, x_61); -return x_72; -} -else -{ -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_72, 1); -lean_inc(x_75); -lean_dec(x_72); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_61); -lean_ctor_set(x_76, 1, x_75); -return x_76; +lean_object* x_1; +x_1 = lean_mk_string("invalid 'protected' constructor in a 'private' inductive datatype"); +return x_1; } } -else +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2() { +_start: { -uint8_t x_77; -lean_dec(x_61); -x_77 = !lean_is_exclusive(x_72); -if (x_77 == 0) +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3() { +_start: { -return x_72; +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; } -else +} +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4() { +_start: { -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_72, 0); -x_79 = lean_ctor_get(x_72, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_72); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; +lean_object* x_1; +x_1 = lean_mk_string("invalid 'private' constructor in a 'private' inductive datatype"); +return x_1; } } -} -else +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5() { +_start: { -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_66, 0); -x_82 = lean_ctor_get(x_66, 1); -x_83 = lean_ctor_get(x_66, 2); -x_84 = lean_ctor_get(x_66, 3); -x_85 = lean_ctor_get(x_66, 4); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_66); -x_86 = l_Lean_Name_getNumParts___main(x_24); -lean_dec(x_24); -x_87 = l_List_drop___main___rarg(x_86, x_83); -lean_dec(x_83); -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 = l___private_Lean_Elab_Command_3__setState(x_88, x_3, x_67); -if (lean_obj_tag(x_89) == 0) +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6() { +_start: { -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_91 = x_89; -} else { - lean_dec_ref(x_89); - x_91 = lean_box(0); +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; } -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 2, 0); -} else { - x_92 = x_91; } -lean_ctor_set(x_92, 0, x_61); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -else +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -lean_dec(x_61); -x_93 = lean_ctor_get(x_89, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_89, 1); -lean_inc(x_94); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_95 = x_89; -} else { - lean_dec_ref(x_89); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(1, 2, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_93); -lean_ctor_set(x_96, 1, x_94); -return x_96; -} -} -} -else +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_4); +x_8 = lean_nat_dec_lt(x_3, x_7); +lean_dec(x_7); +if (x_8 == 0) { -uint8_t x_97; -lean_dec(x_61); -lean_dec(x_24); +lean_object* x_9; lean_object* x_10; +lean_dec(x_5); lean_dec(x_3); -x_97 = !lean_is_exclusive(x_65); -if (x_97 == 0) -{ -return x_65; +x_9 = x_4; +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_6); +return x_10; } else { -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_65, 0); -x_99 = lean_ctor_get(x_65, 1); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_65); -x_100 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_100, 0, x_98); -lean_ctor_set(x_100, 1, x_99); -return x_100; -} -} -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -lean_dec(x_61); -lean_dec(x_24); -x_101 = lean_ctor_get(x_63, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_63, 1); -lean_inc(x_102); -lean_dec(x_63); -x_103 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__4(x_16, x_3, x_102); -if (lean_obj_tag(x_103) == 0) -{ -uint8_t x_104; -x_104 = !lean_is_exclusive(x_103); -if (x_104 == 0) -{ -lean_object* x_105; -x_105 = lean_ctor_get(x_103, 0); -lean_dec(x_105); -lean_ctor_set_tag(x_103, 1); -lean_ctor_set(x_103, 0, x_101); -return x_103; -} -else -{ -lean_object* x_106; lean_object* x_107; -x_106 = lean_ctor_get(x_103, 1); -lean_inc(x_106); -lean_dec(x_103); -x_107 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_106); -return x_107; -} -} -else -{ -uint8_t x_108; -lean_dec(x_101); -x_108 = !lean_is_exclusive(x_103); -if (x_108 == 0) -{ -return x_103; -} -else -{ -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_103, 0); -x_110 = lean_ctor_get(x_103, 1); -lean_inc(x_110); -lean_inc(x_109); -lean_dec(x_103); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_109); -lean_ctor_set(x_111, 1, x_110); -return x_111; -} -} -} -} -else -{ -lean_object* x_112; lean_object* x_113; -lean_dec(x_24); -x_112 = lean_ctor_get(x_60, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_60, 1); -lean_inc(x_113); -lean_dec(x_60); -x_29 = x_112; -x_30 = x_113; -goto block_40; -} -} -else -{ -lean_object* x_114; lean_object* x_115; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_114 = lean_ctor_get(x_57, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_57, 1); -lean_inc(x_115); -lean_dec(x_57); -x_29 = x_114; -x_30 = x_115; -goto block_40; -} -} -else -{ -lean_object* x_116; lean_object* x_117; -lean_dec(x_50); -lean_dec(x_48); -lean_dec(x_24); -x_116 = lean_ctor_get(x_53, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_53, 1); -lean_inc(x_117); -lean_dec(x_53); -x_29 = x_116; -x_30 = x_117; -goto block_40; -} -} -} -else -{ -lean_object* x_204; lean_object* x_205; -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_1); -x_204 = lean_ctor_get(x_47, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_47, 1); -lean_inc(x_205); -lean_dec(x_47); -x_29 = x_204; -x_30 = x_205; -goto block_40; -} -} -else -{ -uint8_t x_206; -lean_dec(x_28); -lean_dec(x_24); +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_11 = lean_array_fget(x_4, x_3); +x_12 = lean_unsigned_to_nat(0u); +x_13 = lean_array_fset(x_4, x_3, x_12); +x_14 = x_11; +x_15 = lean_unsigned_to_nat(1u); +x_16 = l_Lean_Syntax_getArg(x_14, x_15); +lean_inc(x_5); +x_17 = l_Lean_Elab_Command_elabModifiers(x_16, x_5, x_6); lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_1); -x_206 = !lean_is_exclusive(x_45); -if (x_206 == 0) +if (lean_obj_tag(x_17) == 0) { -return x_45; +lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; uint8_t x_27; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +lean_dec(x_17); +x_20 = l_Lean_Elab_Command_Modifiers_isPrivate(x_18); +x_21 = l_Lean_Elab_Command_Modifiers_isProtected(x_18); +x_22 = lean_unsigned_to_nat(2u); +x_23 = l_Lean_Syntax_getIdAt(x_14, x_22); +x_24 = l_Lean_Name_append___main(x_2, x_23); +x_25 = l_Lean_Syntax_getArg(x_14, x_22); +x_26 = lean_ctor_get_uint8(x_18, sizeof(void*)*2); +if (x_20 == 0) +{ +uint8_t x_88; +x_88 = 0; +x_27 = x_88; +goto block_87; } else { -lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_207 = lean_ctor_get(x_45, 0); -x_208 = lean_ctor_get(x_45, 1); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_45); -x_209 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_209, 0, x_207); -lean_ctor_set(x_209, 1, x_208); -return x_209; -} +uint8_t x_89; +x_89 = l_Lean_Elab_Command_Modifiers_isPrivate(x_1); +x_27 = x_89; +goto block_87; } +block_87: +{ +uint8_t x_28; +if (x_27 == 0) +{ +uint8_t x_85; +x_85 = 0; +x_28 = x_85; +goto block_84; } else { -uint8_t x_210; -lean_dec(x_28); -lean_dec(x_24); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_1); -x_210 = !lean_is_exclusive(x_43); -if (x_210 == 0) +uint8_t x_86; +x_86 = 1; +x_28 = x_86; +goto block_84; +} +block_84: { -return x_43; +uint8_t x_29; +if (x_21 == 0) +{ +uint8_t x_82; +x_82 = 0; +x_29 = x_82; +goto block_81; } else { -lean_object* x_211; lean_object* x_212; lean_object* x_213; -x_211 = lean_ctor_get(x_43, 0); -x_212 = lean_ctor_get(x_43, 1); -lean_inc(x_212); -lean_inc(x_211); -lean_dec(x_43); -x_213 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_213, 0, x_211); -lean_ctor_set(x_213, 1, x_212); -return x_213; +uint8_t x_83; +x_83 = l_Lean_Elab_Command_Modifiers_isPrivate(x_1); +x_29 = x_83; +goto block_81; } +block_81: +{ +uint8_t x_30; +if (x_29 == 0) +{ +uint8_t x_79; +x_79 = 0; +x_30 = x_79; +goto block_78; } -block_40: +else +{ +uint8_t x_80; +x_80 = 1; +x_30 = x_80; +goto block_78; +} +block_78: +{ +if (x_28 == 0) +{ +if (x_30 == 0) { lean_object* x_31; -x_31 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__1(x_16, x_3, x_30); +lean_inc(x_5); +x_31 = l___private_Lean_Elab_Declaration_2__checkValidCtorModifier(x_14, x_18, x_5, x_19); if (lean_obj_tag(x_31) == 0) { -uint8_t x_32; -x_32 = !lean_is_exclusive(x_31); -if (x_32 == 0) +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_31, 1); +lean_inc(x_32); +lean_dec(x_31); +lean_inc(x_5); +x_33 = l_Lean_Elab_Command_applyVisibility(x_25, x_26, x_24, x_5, x_32); +lean_dec(x_25); +if (lean_obj_tag(x_33) == 0) { -lean_object* x_33; -x_33 = lean_ctor_get(x_31, 0); +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_ctor_get(x_33, 1); +lean_inc(x_35); lean_dec(x_33); -lean_ctor_set_tag(x_31, 1); -lean_ctor_set(x_31, 0, x_29); +x_36 = lean_unsigned_to_nat(3u); +x_37 = l_Lean_Syntax_getArg(x_14, x_36); +x_38 = l_Lean_Syntax_isNone(x_37); +lean_dec(x_37); +x_39 = lean_unsigned_to_nat(4u); +x_40 = l_Lean_Syntax_getArg(x_14, x_39); +x_41 = l_Lean_Elab_Command_expandOptDeclSig(x_40); +lean_dec(x_40); +if (x_38 == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_41, 1); +lean_inc(x_43); +lean_dec(x_41); +x_44 = 1; +x_45 = lean_alloc_ctor(0, 5, 1); +lean_ctor_set(x_45, 0, x_14); +lean_ctor_set(x_45, 1, x_18); +lean_ctor_set(x_45, 2, x_34); +lean_ctor_set(x_45, 3, x_42); +lean_ctor_set(x_45, 4, x_43); +lean_ctor_set_uint8(x_45, sizeof(void*)*5, x_44); +x_46 = lean_nat_add(x_3, x_15); +x_47 = x_45; +x_48 = lean_array_fset(x_13, x_3, x_47); +lean_dec(x_3); +x_3 = x_46; +x_4 = x_48; +x_6 = x_35; +goto _start; +} +else +{ +lean_object* x_50; lean_object* x_51; uint8_t x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_50 = lean_ctor_get(x_41, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_41, 1); +lean_inc(x_51); +lean_dec(x_41); +x_52 = 0; +x_53 = lean_alloc_ctor(0, 5, 1); +lean_ctor_set(x_53, 0, x_14); +lean_ctor_set(x_53, 1, x_18); +lean_ctor_set(x_53, 2, x_34); +lean_ctor_set(x_53, 3, x_50); +lean_ctor_set(x_53, 4, x_51); +lean_ctor_set_uint8(x_53, sizeof(void*)*5, x_52); +x_54 = lean_nat_add(x_3, x_15); +x_55 = x_53; +x_56 = lean_array_fset(x_13, x_3, x_55); +lean_dec(x_3); +x_3 = x_54; +x_4 = x_56; +x_6 = x_35; +goto _start; +} +} +else +{ +uint8_t x_58; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_3); +x_58 = !lean_is_exclusive(x_33); +if (x_58 == 0) +{ +return x_33; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_33, 0); +x_60 = lean_ctor_get(x_33, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_33); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +return x_61; +} +} +} +else +{ +uint8_t x_62; +lean_dec(x_25); +lean_dec(x_24); +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_3); +x_62 = !lean_is_exclusive(x_31); +if (x_62 == 0) +{ return x_31; } else { -lean_object* x_34; lean_object* x_35; -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); +lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_63 = lean_ctor_get(x_31, 0); +x_64 = lean_ctor_get(x_31, 1); +lean_inc(x_64); +lean_inc(x_63); lean_dec(x_31); +x_65 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_65, 0, x_63); +lean_ctor_set(x_65, 1, x_64); +return x_65; +} +} +} +else +{ +lean_object* x_66; lean_object* x_67; uint8_t x_68; +lean_dec(x_25); +lean_dec(x_24); +lean_dec(x_18); +lean_dec(x_13); +lean_dec(x_3); +x_66 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3; +x_67 = l_Lean_Elab_Command_throwError___rarg(x_14, x_66, x_5, x_19); +lean_dec(x_14); +x_68 = !lean_is_exclusive(x_67); +if (x_68 == 0) +{ +return x_67; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_67, 0); +x_70 = lean_ctor_get(x_67, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_67); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +lean_object* x_72; lean_object* x_73; uint8_t x_74; +lean_dec(x_25); +lean_dec(x_24); +lean_dec(x_18); +lean_dec(x_13); +lean_dec(x_3); +x_72 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6; +x_73 = l_Lean_Elab_Command_throwError___rarg(x_14, x_72, x_5, x_19); +lean_dec(x_14); +x_74 = !lean_is_exclusive(x_73); +if (x_74 == 0) +{ +return x_73; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_73, 0); +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_73); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +} +} +} +} +else +{ +uint8_t x_90; +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_3); +x_90 = !lean_is_exclusive(x_17); +if (x_90 == 0) +{ +return x_17; +} +else +{ +lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_91 = lean_ctor_get(x_17, 0); +x_92 = lean_ctor_get(x_17, 1); +lean_inc(x_92); +lean_inc(x_91); +lean_dec(x_17); +x_93 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_93, 0, x_91); +lean_ctor_set(x_93, 1, x_92); +return x_93; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +lean_inc(x_8); +x_10 = l_Lean_Elab_Command_getLevelNames(x_8, x_9); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +lean_inc(x_8); +lean_inc(x_7); +x_13 = l_Lean_Elab_Command_mkDeclName(x_1, x_2, x_7, x_8, x_12); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; 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_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = lean_unsigned_to_nat(2u); +x_17 = lean_nat_add(x_3, x_16); +x_18 = l_Lean_Syntax_getArg(x_4, x_17); +lean_dec(x_17); +x_19 = l_Lean_Syntax_getArgs(x_18); +lean_dec(x_18); +x_20 = x_19; +x_21 = lean_unsigned_to_nat(0u); +lean_inc(x_14); +lean_inc(x_2); +x_22 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___boxed), 6, 4); +lean_closure_set(x_22, 0, x_2); +lean_closure_set(x_22, 1, x_14); +lean_closure_set(x_22, 2, x_21); +lean_closure_set(x_22, 3, x_20); +x_23 = x_22; +x_24 = lean_apply_2(x_23, x_8, x_15); +if (lean_obj_tag(x_24) == 0) +{ +uint8_t x_25; +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_24, 0); +x_27 = lean_alloc_ctor(0, 8, 0); +lean_ctor_set(x_27, 0, x_4); +lean_ctor_set(x_27, 1, x_2); +lean_ctor_set(x_27, 2, x_7); +lean_ctor_set(x_27, 3, x_14); +lean_ctor_set(x_27, 4, x_11); +lean_ctor_set(x_27, 5, x_5); +lean_ctor_set(x_27, 6, x_6); +lean_ctor_set(x_27, 7, x_26); +lean_ctor_set(x_24, 0, x_27); +return x_24; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_28 = lean_ctor_get(x_24, 0); +x_29 = lean_ctor_get(x_24, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_24); +x_30 = lean_alloc_ctor(0, 8, 0); +lean_ctor_set(x_30, 0, x_4); +lean_ctor_set(x_30, 1, x_2); +lean_ctor_set(x_30, 2, x_7); +lean_ctor_set(x_30, 3, x_14); +lean_ctor_set(x_30, 4, x_11); +lean_ctor_set(x_30, 5, x_5); +lean_ctor_set(x_30, 6, x_6); +lean_ctor_set(x_30, 7, x_28); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set(x_31, 1, x_29); +return x_31; +} +} +else +{ +uint8_t x_32; +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_24); +if (x_32 == 0) +{ +return x_24; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_24, 0); +x_34 = lean_ctor_get(x_24, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_24); x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_29); +lean_ctor_set(x_35, 0, x_33); lean_ctor_set(x_35, 1, x_34); return x_35; } } +} else { uint8_t x_36; -lean_dec(x_29); -x_36 = !lean_is_exclusive(x_31); +lean_dec(x_11); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_36 = !lean_is_exclusive(x_13); if (x_36 == 0) { -return x_31; +return x_13; } else { lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_31, 0); -x_38 = lean_ctor_get(x_31, 1); +x_37 = lean_ctor_get(x_13, 0); +x_38 = lean_ctor_get(x_13, 1); lean_inc(x_38); lean_inc(x_37); -lean_dec(x_31); +lean_dec(x_13); x_39 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_39, 0, x_37); lean_ctor_set(x_39, 1, x_38); @@ -4326,1003 +3131,232 @@ return x_39; } } } -} 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_234; uint8_t x_235; lean_object* x_236; -x_214 = lean_ctor_get(x_20, 1); -x_215 = lean_ctor_get(x_20, 2); -x_216 = lean_ctor_get(x_20, 3); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_214); -lean_dec(x_20); -x_217 = lean_ctor_get(x_21, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_21, 1); -lean_inc(x_218); -lean_dec(x_21); -x_219 = lean_box(0); -x_220 = lean_name_mk_string(x_219, x_218); -x_221 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_221, 0, x_220); -lean_ctor_set(x_221, 1, x_214); -lean_ctor_set(x_221, 2, x_215); -lean_ctor_set(x_221, 3, x_216); -x_222 = l_Lean_MacroScopesView_review(x_221); -x_234 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; -x_235 = 1; -lean_inc(x_3); -lean_inc(x_217); -x_236 = l___private_Lean_Elab_Command_12__addScopes___main(x_6, x_234, x_235, x_217, x_3, x_19); +uint8_t x_40; +lean_dec(x_8); +lean_dec(x_7); lean_dec(x_6); -if (lean_obj_tag(x_236) == 0) +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_40 = !lean_is_exclusive(x_10); +if (x_40 == 0) { -lean_object* x_237; lean_object* x_238; -x_237 = lean_ctor_get(x_236, 1); -lean_inc(x_237); -lean_dec(x_236); -lean_inc(x_3); -x_238 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__2(x_18, x_3, x_237); -if (lean_obj_tag(x_238) == 0) -{ -lean_object* x_239; lean_object* x_240; -x_239 = lean_ctor_get(x_238, 1); -lean_inc(x_239); -lean_dec(x_238); -lean_inc(x_3); -x_240 = l_Lean_Elab_Command_mkDeclName(x_1, x_222, x_3, x_239); -if (lean_obj_tag(x_240) == 0) -{ -lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; uint8_t x_299; lean_object* x_300; lean_object* x_301; -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_ctor_get(x_1, 1); -lean_inc(x_243); -x_299 = 2; -x_300 = lean_unsigned_to_nat(0u); -lean_inc(x_3); -lean_inc(x_241); -x_301 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_241, x_299, x_243, x_300, x_3, x_242); -if (lean_obj_tag(x_301) == 0) -{ -lean_object* x_302; lean_object* x_303; -x_302 = lean_ctor_get(x_301, 1); -lean_inc(x_302); -lean_dec(x_301); -lean_inc(x_3); -x_303 = l_Lean_Elab_Command_getLevelNames(x_3, x_302); -if (lean_obj_tag(x_303) == 0) -{ -lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -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); -lean_inc(x_241); -x_306 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_306, 0, x_241); -lean_inc(x_241); -x_307 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabAxiom___lambda__2___boxed), 8, 5); -lean_closure_set(x_307, 0, x_10); -lean_closure_set(x_307, 1, x_11); -lean_closure_set(x_307, 2, x_304); -lean_closure_set(x_307, 3, x_241); -lean_closure_set(x_307, 4, x_1); -lean_inc(x_3); -x_308 = l___private_Lean_Elab_Command_2__getState(x_3, x_305); -if (lean_obj_tag(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_308, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_308, 1); -lean_inc(x_310); -lean_dec(x_308); -x_311 = l___private_Lean_Elab_Command_9__getVarDecls(x_309); -lean_dec(x_309); -lean_inc(x_3); -x_312 = l___private_Lean_Elab_Command_2__getState(x_3, x_310); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -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 = l___private_Lean_Elab_Command_6__mkTermContext(x_3, x_313, x_306); -x_316 = l___private_Lean_Elab_Command_7__mkTermState(x_313); -lean_dec(x_313); -x_317 = l_Lean_Elab_Term_elabBinders___rarg(x_311, x_307, x_315, x_316); -lean_dec(x_311); -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); -lean_inc(x_3); -x_320 = l___private_Lean_Elab_Command_2__getState(x_3, x_314); -if (lean_obj_tag(x_320) == 0) -{ -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; -x_321 = lean_ctor_get(x_319, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_320, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_320, 1); -lean_inc(x_323); -lean_dec(x_320); -x_324 = lean_ctor_get(x_321, 0); -lean_inc(x_324); -lean_dec(x_321); -x_325 = lean_ctor_get(x_319, 2); -lean_inc(x_325); -lean_dec(x_319); -x_326 = lean_ctor_get(x_322, 2); -lean_inc(x_326); -x_327 = lean_ctor_get(x_322, 3); -lean_inc(x_327); -x_328 = lean_ctor_get(x_322, 4); -lean_inc(x_328); -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); - lean_ctor_release(x_322, 4); - x_329 = x_322; -} else { - lean_dec_ref(x_322); - x_329 = lean_box(0); -} -if (lean_is_scalar(x_329)) { - x_330 = lean_alloc_ctor(0, 5, 0); -} else { - x_330 = x_329; -} -lean_ctor_set(x_330, 0, x_324); -lean_ctor_set(x_330, 1, x_325); -lean_ctor_set(x_330, 2, x_326); -lean_ctor_set(x_330, 3, x_327); -lean_ctor_set(x_330, 4, x_328); -lean_inc(x_3); -x_331 = l___private_Lean_Elab_Command_3__setState(x_330, x_3, x_323); -if (lean_obj_tag(x_331) == 0) -{ -lean_object* x_332; -x_332 = lean_ctor_get(x_331, 1); -lean_inc(x_332); -lean_dec(x_331); -x_244 = x_318; -x_245 = x_332; -goto block_298; +return x_10; } else { -lean_object* x_333; lean_object* x_334; -lean_dec(x_318); -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_333 = lean_ctor_get(x_331, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_331, 1); -lean_inc(x_334); -lean_dec(x_331); -x_223 = x_333; -x_224 = x_334; -goto block_233; -} -} -else -{ -lean_object* x_335; lean_object* x_336; -lean_dec(x_319); -lean_dec(x_318); -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_335 = lean_ctor_get(x_320, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_320, 1); -lean_inc(x_336); -lean_dec(x_320); -x_223 = x_335; -x_224 = x_336; -goto block_233; -} -} -else -{ -lean_object* x_337; -x_337 = lean_ctor_get(x_317, 0); -lean_inc(x_337); -if (lean_obj_tag(x_337) == 0) -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_338 = lean_ctor_get(x_317, 1); -lean_inc(x_338); -lean_dec(x_317); -x_339 = lean_ctor_get(x_337, 0); -lean_inc(x_339); -lean_dec(x_337); -lean_inc(x_3); -x_340 = l___private_Lean_Elab_Command_2__getState(x_3, x_314); -if (lean_obj_tag(x_340) == 0) -{ -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_341 = lean_ctor_get(x_338, 0); -lean_inc(x_341); -x_342 = lean_ctor_get(x_340, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_340, 1); -lean_inc(x_343); -lean_dec(x_340); -x_344 = lean_ctor_get(x_341, 0); -lean_inc(x_344); -lean_dec(x_341); -x_345 = lean_ctor_get(x_338, 2); -lean_inc(x_345); -lean_dec(x_338); -x_346 = lean_ctor_get(x_342, 2); -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); -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); - x_349 = x_342; -} else { - lean_dec_ref(x_342); - x_349 = lean_box(0); -} -if (lean_is_scalar(x_349)) { - x_350 = lean_alloc_ctor(0, 5, 0); -} else { - x_350 = x_349; -} -lean_ctor_set(x_350, 0, x_344); -lean_ctor_set(x_350, 1, x_345); -lean_ctor_set(x_350, 2, x_346); -lean_ctor_set(x_350, 3, x_347); -lean_ctor_set(x_350, 4, x_348); -lean_inc(x_3); -x_351 = l___private_Lean_Elab_Command_3__setState(x_350, x_3, x_343); -if (lean_obj_tag(x_351) == 0) -{ -lean_object* x_352; -x_352 = lean_ctor_get(x_351, 1); -lean_inc(x_352); -lean_dec(x_351); -x_223 = x_339; -x_224 = x_352; -goto block_233; -} -else -{ -lean_object* x_353; lean_object* x_354; -lean_dec(x_339); -x_353 = lean_ctor_get(x_351, 0); -lean_inc(x_353); -x_354 = lean_ctor_get(x_351, 1); -lean_inc(x_354); -lean_dec(x_351); -x_223 = x_353; -x_224 = x_354; -goto block_233; -} -} -else -{ -lean_object* x_355; lean_object* x_356; -lean_dec(x_339); -lean_dec(x_338); -x_355 = lean_ctor_get(x_340, 0); -lean_inc(x_355); -x_356 = lean_ctor_get(x_340, 1); -lean_inc(x_356); -lean_dec(x_340); -x_223 = x_355; -x_224 = x_356; -goto block_233; -} -} -else -{ -lean_object* x_357; lean_object* x_358; lean_object* x_359; -lean_dec(x_317); -x_357 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_358 = l_unreachable_x21___rarg(x_357); -lean_inc(x_3); -x_359 = lean_apply_2(x_358, x_3, x_314); -if (lean_obj_tag(x_359) == 0) -{ -lean_object* x_360; lean_object* x_361; -x_360 = lean_ctor_get(x_359, 0); -lean_inc(x_360); -x_361 = lean_ctor_get(x_359, 1); -lean_inc(x_361); -lean_dec(x_359); -x_244 = x_360; -x_245 = x_361; -goto block_298; -} -else -{ -lean_object* x_362; lean_object* x_363; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_362 = lean_ctor_get(x_359, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_359, 1); -lean_inc(x_363); -lean_dec(x_359); -x_223 = x_362; -x_224 = x_363; -goto block_233; -} -} -} -} -else -{ -lean_object* x_364; lean_object* x_365; -lean_dec(x_311); -lean_dec(x_307); -lean_dec(x_306); -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_364 = lean_ctor_get(x_312, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_312, 1); -lean_inc(x_365); -lean_dec(x_312); -x_223 = x_364; -x_224 = x_365; -goto block_233; -} -} -else -{ -lean_object* x_366; lean_object* x_367; -lean_dec(x_307); -lean_dec(x_306); -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_366 = lean_ctor_get(x_308, 0); -lean_inc(x_366); -x_367 = lean_ctor_get(x_308, 1); -lean_inc(x_367); -lean_dec(x_308); -x_223 = x_366; -x_224 = x_367; -goto block_233; -} -} -else -{ -lean_object* x_368; lean_object* x_369; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -lean_dec(x_11); +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_10, 0); +x_42 = lean_ctor_get(x_10, 1); +lean_inc(x_42); +lean_inc(x_41); lean_dec(x_10); -lean_dec(x_1); -x_368 = lean_ctor_get(x_303, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_303, 1); -lean_inc(x_369); -lean_dec(x_303); -x_223 = x_368; -x_224 = x_369; -goto block_233; +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_41); +lean_ctor_set(x_43, 1, x_42); +return x_43; } } -else +} +} +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: { -lean_object* x_370; lean_object* x_371; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -lean_dec(x_11); +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = lean_unsigned_to_nat(1u); +x_7 = lean_nat_add(x_3, x_6); +x_8 = l_Lean_Syntax_getArg(x_2, x_7); +lean_dec(x_7); +x_9 = l_Lean_Elab_Command_expandOptDeclSig(x_8); +lean_dec(x_8); +lean_inc(x_4); +x_10 = l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier(x_2, x_1, x_4, x_5); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); lean_dec(x_10); -lean_dec(x_1); -x_370 = lean_ctor_get(x_301, 0); -lean_inc(x_370); -x_371 = lean_ctor_get(x_301, 1); -lean_inc(x_371); -lean_dec(x_301); -x_223 = x_370; -x_224 = x_371; -goto block_233; -} -block_298: -{ -lean_object* x_246; -lean_inc(x_3); -x_246 = l_Lean_Elab_Command_addDecl(x_2, x_244, x_3, x_245); -lean_dec(x_244); -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_247; uint8_t x_248; lean_object* x_249; lean_object* x_250; -x_247 = lean_ctor_get(x_246, 1); -lean_inc(x_247); -lean_dec(x_246); -x_248 = 0; -x_249 = lean_unsigned_to_nat(0u); -lean_inc(x_3); -lean_inc(x_241); -x_250 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_241, x_248, x_243, x_249, x_3, x_247); -if (lean_obj_tag(x_250) == 0) -{ -lean_object* x_251; uint8_t x_252; lean_object* x_253; -x_251 = lean_ctor_get(x_250, 1); -lean_inc(x_251); -lean_dec(x_250); -x_252 = 1; -lean_inc(x_3); -x_253 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_2, x_241, x_252, x_243, x_249, x_3, x_251); -lean_dec(x_243); -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); -lean_inc(x_3); -lean_inc(x_16); -x_256 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__3(x_16, x_3, x_255); -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_257; lean_object* x_258; -lean_dec(x_16); -x_257 = lean_ctor_get(x_256, 1); -lean_inc(x_257); -lean_dec(x_256); -lean_inc(x_3); -x_258 = l___private_Lean_Elab_Command_2__getState(x_3, x_257); -if (lean_obj_tag(x_258) == 0) -{ -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_258, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_258, 1); -lean_inc(x_260); -lean_dec(x_258); -x_261 = lean_ctor_get(x_259, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_259, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_259, 2); -lean_inc(x_263); -x_264 = lean_ctor_get(x_259, 3); -lean_inc(x_264); -x_265 = lean_ctor_get(x_259, 4); -lean_inc(x_265); -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_266 = x_259; -} else { - lean_dec_ref(x_259); - x_266 = lean_box(0); -} -x_267 = l_Lean_Name_getNumParts___main(x_217); -lean_dec(x_217); -x_268 = l_List_drop___main___rarg(x_267, x_263); -lean_dec(x_263); -if (lean_is_scalar(x_266)) { - x_269 = lean_alloc_ctor(0, 5, 0); -} else { - x_269 = x_266; -} -lean_ctor_set(x_269, 0, x_261); -lean_ctor_set(x_269, 1, x_262); -lean_ctor_set(x_269, 2, x_268); -lean_ctor_set(x_269, 3, x_264); -lean_ctor_set(x_269, 4, x_265); -x_270 = l___private_Lean_Elab_Command_3__setState(x_269, x_3, x_260); -if (lean_obj_tag(x_270) == 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); -if (lean_is_exclusive(x_270)) { - lean_ctor_release(x_270, 0); - lean_ctor_release(x_270, 1); - x_272 = x_270; -} else { - lean_dec_ref(x_270); - x_272 = lean_box(0); -} -if (lean_is_scalar(x_272)) { - x_273 = lean_alloc_ctor(0, 2, 0); -} else { - x_273 = x_272; -} -lean_ctor_set(x_273, 0, x_254); -lean_ctor_set(x_273, 1, x_271); -return x_273; -} -else -{ -lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -lean_dec(x_254); -x_274 = lean_ctor_get(x_270, 0); -lean_inc(x_274); -x_275 = lean_ctor_get(x_270, 1); -lean_inc(x_275); -if (lean_is_exclusive(x_270)) { - lean_ctor_release(x_270, 0); - lean_ctor_release(x_270, 1); - x_276 = x_270; -} else { - lean_dec_ref(x_270); - x_276 = lean_box(0); -} -if (lean_is_scalar(x_276)) { - x_277 = lean_alloc_ctor(1, 2, 0); -} else { - x_277 = x_276; -} -lean_ctor_set(x_277, 0, x_274); -lean_ctor_set(x_277, 1, x_275); -return x_277; -} -} -else -{ -lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -lean_dec(x_254); -lean_dec(x_217); -lean_dec(x_3); -x_278 = lean_ctor_get(x_258, 0); -lean_inc(x_278); -x_279 = lean_ctor_get(x_258, 1); -lean_inc(x_279); -if (lean_is_exclusive(x_258)) { - lean_ctor_release(x_258, 0); - lean_ctor_release(x_258, 1); - x_280 = x_258; -} else { - lean_dec_ref(x_258); - x_280 = lean_box(0); -} -if (lean_is_scalar(x_280)) { - x_281 = lean_alloc_ctor(1, 2, 0); -} else { - x_281 = x_280; -} -lean_ctor_set(x_281, 0, x_278); -lean_ctor_set(x_281, 1, x_279); -return x_281; -} -} -else -{ -lean_object* x_282; lean_object* x_283; lean_object* x_284; -lean_dec(x_254); -lean_dec(x_217); -x_282 = lean_ctor_get(x_256, 0); -lean_inc(x_282); -x_283 = lean_ctor_get(x_256, 1); -lean_inc(x_283); -lean_dec(x_256); -x_284 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__4(x_16, x_3, x_283); -if (lean_obj_tag(x_284) == 0) -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -if (lean_is_exclusive(x_284)) { - lean_ctor_release(x_284, 0); - lean_ctor_release(x_284, 1); - x_286 = x_284; -} else { - lean_dec_ref(x_284); - x_286 = lean_box(0); -} -if (lean_is_scalar(x_286)) { - x_287 = lean_alloc_ctor(1, 2, 0); -} else { - x_287 = x_286; - lean_ctor_set_tag(x_287, 1); -} -lean_ctor_set(x_287, 0, x_282); -lean_ctor_set(x_287, 1, x_285); -return x_287; -} -else -{ -lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -lean_dec(x_282); -x_288 = lean_ctor_get(x_284, 0); -lean_inc(x_288); -x_289 = lean_ctor_get(x_284, 1); -lean_inc(x_289); -if (lean_is_exclusive(x_284)) { - lean_ctor_release(x_284, 0); - lean_ctor_release(x_284, 1); - 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(1, 2, 0); -} else { - x_291 = x_290; -} -lean_ctor_set(x_291, 0, x_288); -lean_ctor_set(x_291, 1, x_289); -return x_291; -} -} -} -else -{ -lean_object* x_292; lean_object* x_293; -lean_dec(x_217); -x_292 = lean_ctor_get(x_253, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_253, 1); -lean_inc(x_293); -lean_dec(x_253); -x_223 = x_292; -x_224 = x_293; -goto block_233; -} -} -else -{ -lean_object* x_294; lean_object* x_295; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_294 = lean_ctor_get(x_250, 0); -lean_inc(x_294); -x_295 = lean_ctor_get(x_250, 1); -lean_inc(x_295); -lean_dec(x_250); -x_223 = x_294; -x_224 = x_295; -goto block_233; -} -} -else -{ -lean_object* x_296; lean_object* x_297; -lean_dec(x_243); -lean_dec(x_241); -lean_dec(x_217); -x_296 = lean_ctor_get(x_246, 0); -lean_inc(x_296); -x_297 = lean_ctor_get(x_246, 1); -lean_inc(x_297); -lean_dec(x_246); -x_223 = x_296; -x_224 = x_297; -goto block_233; -} -} -} -else -{ -lean_object* x_372; lean_object* x_373; -lean_dec(x_217); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_1); -x_372 = lean_ctor_get(x_240, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_240, 1); -lean_inc(x_373); -lean_dec(x_240); -x_223 = x_372; -x_224 = x_373; -goto block_233; -} -} -else -{ -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; -lean_dec(x_222); -lean_dec(x_217); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_1); -x_374 = lean_ctor_get(x_238, 0); -lean_inc(x_374); -x_375 = lean_ctor_get(x_238, 1); -lean_inc(x_375); -if (lean_is_exclusive(x_238)) { - lean_ctor_release(x_238, 0); - lean_ctor_release(x_238, 1); - x_376 = x_238; -} else { - lean_dec_ref(x_238); - x_376 = lean_box(0); -} -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(1, 2, 0); -} else { - x_377 = x_376; -} -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -return x_377; -} -} -else -{ -lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; -lean_dec(x_222); -lean_dec(x_217); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_1); -x_378 = lean_ctor_get(x_236, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_236, 1); -lean_inc(x_379); -if (lean_is_exclusive(x_236)) { - lean_ctor_release(x_236, 0); - lean_ctor_release(x_236, 1); - x_380 = x_236; -} else { - lean_dec_ref(x_236); - x_380 = lean_box(0); -} -if (lean_is_scalar(x_380)) { - x_381 = lean_alloc_ctor(1, 2, 0); -} else { - x_381 = x_380; -} -lean_ctor_set(x_381, 0, x_378); -lean_ctor_set(x_381, 1, x_379); -return x_381; -} -block_233: -{ -lean_object* x_225; -x_225 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabAxiom___spec__1(x_16, x_3, x_224); -if (lean_obj_tag(x_225) == 0) -{ -lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_226 = lean_ctor_get(x_225, 1); -lean_inc(x_226); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_227 = x_225; -} else { - lean_dec_ref(x_225); - x_227 = lean_box(0); -} -if (lean_is_scalar(x_227)) { - x_228 = lean_alloc_ctor(1, 2, 0); -} else { - x_228 = x_227; - lean_ctor_set_tag(x_228, 1); -} -lean_ctor_set(x_228, 0, x_223); -lean_ctor_set(x_228, 1, x_226); -return x_228; -} -else -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; -lean_dec(x_223); -x_229 = lean_ctor_get(x_225, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_225, 1); -lean_inc(x_230); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_231 = x_225; -} else { - lean_dec_ref(x_225); - x_231 = lean_box(0); -} -if (lean_is_scalar(x_231)) { - x_232 = lean_alloc_ctor(1, 2, 0); -} else { - x_232 = x_231; -} -lean_ctor_set(x_232, 0, x_229); -lean_ctor_set(x_232, 1, x_230); -return x_232; -} -} -} -} -else -{ -lean_object* x_382; lean_object* x_383; -lean_dec(x_21); -lean_dec(x_20); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_1); -x_382 = l_Lean_Elab_Command_withDeclId___closed__3; -x_383 = l_Lean_Elab_Command_throwError___rarg(x_6, x_382, x_3, x_19); -lean_dec(x_6); -return x_383; -} -} -} -else -{ -uint8_t x_398; +x_12 = lean_ctor_get(x_9, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_9, 1); +lean_inc(x_13); +lean_dec(x_9); +x_14 = l_Lean_Syntax_getArg(x_2, x_3); +lean_inc(x_14); +x_15 = lean_alloc_closure((void*)(l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1___boxed), 9, 6); +lean_closure_set(x_15, 0, x_14); +lean_closure_set(x_15, 1, x_1); +lean_closure_set(x_15, 2, x_3); +lean_closure_set(x_15, 3, x_2); +lean_closure_set(x_15, 4, x_12); +lean_closure_set(x_15, 5, x_13); +x_16 = l_Lean_Elab_Command_withDeclId___rarg(x_14, x_15, x_4, x_11); lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_1); -x_398 = !lean_is_exclusive(x_15); -if (x_398 == 0) -{ -return x_15; +return x_16; } else { -lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_399 = lean_ctor_get(x_15, 0); -x_400 = lean_ctor_get(x_15, 1); -lean_inc(x_400); -lean_inc(x_399); -lean_dec(x_15); -x_401 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_401, 0, x_399); -lean_ctor_set(x_401, 1, x_400); -return x_401; +uint8_t x_17; +lean_dec(x_9); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_17 = !lean_is_exclusive(x_10); +if (x_17 == 0) +{ +return x_10; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_10, 0); +x_19 = lean_ctor_get(x_10, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_10); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; } } } } -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Command_elabAxiom___spec__5(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_2); lean_dec(x_1); return x_7; } } -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { -lean_object* x_9; -x_9 = l_Lean_Elab_Command_elabAxiom___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_5); -return x_9; -} -} -lean_object* l_Lean_Elab_Command_elabAxiom___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Elab_Command_elabAxiom___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_1); -return x_9; -} -} -lean_object* l_Lean_Elab_Command_elabAxiom___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Elab_Command_elabAxiom(x_1, x_2, x_3, x_4); -lean_dec(x_2); -return x_5; -} -} -lean_object* l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(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; lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_4 = lean_unsigned_to_nat(1u); -x_5 = lean_nat_add(x_3, x_4); -x_6 = l_Lean_Syntax_getArg(x_2, x_5); -lean_dec(x_5); -x_7 = l_Lean_Elab_Command_expandOptDeclSig(x_6); -lean_dec(x_6); -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_7, 1); -lean_inc(x_9); -lean_dec(x_7); -x_10 = l_Lean_Syntax_getArg(x_2, x_3); -x_11 = lean_unsigned_to_nat(2u); -x_12 = lean_nat_add(x_3, x_11); -x_13 = l_Lean_Syntax_getArg(x_2, x_12); -lean_dec(x_12); -x_14 = l_Lean_Syntax_getArgs(x_13); -lean_dec(x_13); -x_15 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_15, 0, x_2); -lean_ctor_set(x_15, 1, x_1); -lean_ctor_set(x_15, 2, x_10); -lean_ctor_set(x_15, 3, x_8); -lean_ctor_set(x_15, 4, x_9); -lean_ctor_set(x_15, 5, x_14); -return x_15; -} -} -lean_object* l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(x_1, x_2, x_3); +lean_object* x_10; +x_10 = l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); lean_dec(x_3); -return x_4; +lean_dec(x_1); +return x_10; } } -lean_object* l___private_Lean_Elab_Declaration_2__classInductiveSyntaxToView(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Lean_Elab_Declaration_4__classInductiveSyntaxToView(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_3; lean_object* x_4; -x_3 = lean_unsigned_to_nat(2u); -x_4 = l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(x_1, x_2, x_3); -return x_4; +lean_object* x_5; lean_object* x_6; +x_5 = lean_unsigned_to_nat(2u); +x_6 = l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(x_1, x_2, x_5, x_3, x_4); +return x_6; } } lean_object* l_Lean_Elab_Command_elabInductive(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +lean_object* x_5; lean_object* x_6; x_5 = lean_unsigned_to_nat(1u); -x_6 = l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(x_1, x_2, x_5); -x_7 = l_Lean_mkOptionalNode___closed__2; -x_8 = lean_array_push(x_7, x_6); -x_9 = l_Lean_Elab_Command_elabInductiveCore(x_8, x_3, x_4); -return x_9; +lean_inc(x_3); +x_6 = l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(x_1, x_2, x_5, x_3, x_4); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_mkOptionalNode___closed__2; +x_10 = lean_array_push(x_9, x_7); +x_11 = l_Lean_Elab_Command_elabInductiveCore(x_10, x_3, x_8); +return x_11; +} +else +{ +uint8_t x_12; +lean_dec(x_3); +x_12 = !lean_is_exclusive(x_6); +if (x_12 == 0) +{ +return x_6; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_6, 0); +x_14 = lean_ctor_get(x_6, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_6); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +} +lean_object* _init_l_Lean_Elab_Command_elabClassInductive___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_registerClassAttr___closed__2; +x_2 = lean_box(0); +x_3 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_3, 0, x_1); +lean_ctor_set(x_3, 1, x_2); +return x_3; } } lean_object* l_Lean_Elab_Command_elabClassInductive(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_5 = lean_unsigned_to_nat(2u); -x_6 = l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(x_1, x_2, x_5); -x_7 = l_Lean_mkOptionalNode___closed__2; -x_8 = lean_array_push(x_7, x_6); -x_9 = l_Lean_Elab_Command_elabInductiveCore(x_8, x_3, x_4); -return x_9; +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_5 = l_Lean_Elab_Command_elabClassInductive___closed__1; +x_6 = l_Lean_Elab_Command_Modifiers_addAttribute(x_1, x_5); +x_7 = lean_unsigned_to_nat(2u); +lean_inc(x_3); +x_8 = l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(x_6, x_2, x_7, x_3, x_4); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = l_Lean_mkOptionalNode___closed__2; +x_12 = lean_array_push(x_11, x_9); +x_13 = l_Lean_Elab_Command_elabInductiveCore(x_12, x_3, x_10); +return x_13; +} +else +{ +uint8_t x_14; +lean_dec(x_3); +x_14 = !lean_is_exclusive(x_8); +if (x_14 == 0) +{ +return x_8; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_8, 0); +x_16 = lean_ctor_get(x_8, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_8); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_15); +lean_ctor_set(x_17, 1, x_16); +return x_17; +} +} } } lean_object* l_Lean_Elab_Command_elabStructure___rarg(lean_object* x_1) { @@ -5358,19 +3392,19 @@ return x_4; lean_object* _init_l_Lean_Elab_Command_elabDeclaration___closed__1() { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_docComment___elambda__1___closed__2; -x_2 = l_Lean_Meta_registerInstanceAttr___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; +lean_object* x_1; +x_1 = lean_mk_string("unexpected declaration"); +return x_1; } } lean_object* _init_l_Lean_Elab_Command_elabDeclaration___closed__2() { _start: { -lean_object* x_1; -x_1 = lean_mk_string("unexpected declaration"); -return x_1; +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Command_elabDeclaration___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; } } lean_object* _init_l_Lean_Elab_Command_elabDeclaration___closed__3() { @@ -5378,16 +3412,6 @@ _start: { lean_object* x_1; lean_object* x_2; x_1 = l_Lean_Elab_Command_elabDeclaration___closed__2; -x_2 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_2, 0, x_1); -return x_2; -} -} -lean_object* _init_l_Lean_Elab_Command_elabDeclaration___closed__4() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_elabDeclaration___closed__3; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; @@ -5435,7 +3459,7 @@ x_20 = lean_name_eq(x_12, x_19); if (x_20 == 0) { lean_object* x_21; uint8_t x_22; -x_21 = l_Lean_Elab_Command_elabDeclaration___closed__1; +x_21 = l_Lean_Parser_Command_instance___elambda__1___closed__2; x_22 = lean_name_eq(x_12, x_21); if (x_22 == 0) { @@ -5469,7 +3493,7 @@ if (x_32 == 0) { lean_object* x_33; lean_object* x_34; lean_free_object(x_6); -x_33 = l_Lean_Elab_Command_elabDeclaration___closed__4; +x_33 = l_Lean_Elab_Command_elabDeclaration___closed__3; x_34 = l_Lean_Elab_Command_throwError___rarg(x_1, x_33, x_2, x_9); return x_34; } @@ -5515,7 +3539,6 @@ lean_object* x_39; lean_dec(x_12); lean_free_object(x_6); x_39 = l_Lean_Elab_Command_elabAxiom(x_8, x_11, x_2, x_9); -lean_dec(x_11); return x_39; } } @@ -5596,7 +3619,7 @@ x_57 = lean_name_eq(x_49, x_56); if (x_57 == 0) { lean_object* x_58; uint8_t x_59; -x_58 = l_Lean_Elab_Command_elabDeclaration___closed__1; +x_58 = l_Lean_Parser_Command_instance___elambda__1___closed__2; x_59 = lean_name_eq(x_49, x_58); if (x_59 == 0) { @@ -5629,7 +3652,7 @@ lean_dec(x_49); if (x_69 == 0) { lean_object* x_70; lean_object* x_71; -x_70 = l_Lean_Elab_Command_elabDeclaration___closed__4; +x_70 = l_Lean_Elab_Command_elabDeclaration___closed__3; x_71 = l_Lean_Elab_Command_throwError___rarg(x_1, x_70, x_2, x_46); return x_71; } @@ -5673,7 +3696,6 @@ else lean_object* x_77; lean_dec(x_49); x_77 = l_Lean_Elab_Command_elabAxiom(x_45, x_48, x_2, x_46); -lean_dec(x_48); return x_77; } } @@ -5771,7 +3793,7 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } -uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; @@ -5812,7 +3834,7 @@ goto _start; } } } -uint8_t l___private_Lean_Elab_Declaration_3__isMutualInductive(lean_object* x_1) { +uint8_t l___private_Lean_Elab_Declaration_5__isMutualInductive(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; @@ -5822,7 +3844,7 @@ x_4 = l_Lean_Syntax_getArgs(x_3); lean_dec(x_3); x_5 = lean_array_get_size(x_4); x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1(x_1, x_4, x_5, x_6); +x_7 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1(x_1, x_4, x_5, x_6); lean_dec(x_5); lean_dec(x_4); if (x_7 == 0) @@ -5839,11 +3861,11 @@ return x_9; } } } -lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; lean_object* x_6; -x_5 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_3__isMutualInductive___spec__1(x_1, x_2, x_3, x_4); +x_5 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Declaration_5__isMutualInductive___spec__1(x_1, x_2, x_3, x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); @@ -5851,17 +3873,17 @@ x_6 = lean_box(x_5); return x_6; } } -lean_object* l___private_Lean_Elab_Declaration_3__isMutualInductive___boxed(lean_object* x_1) { +lean_object* l___private_Lean_Elab_Declaration_5__isMutualInductive___boxed(lean_object* x_1) { _start: { uint8_t x_2; lean_object* x_3; -x_2 = l___private_Lean_Elab_Declaration_3__isMutualInductive(x_1); +x_2 = l___private_Lean_Elab_Declaration_5__isMutualInductive(x_1); lean_dec(x_1); x_3 = lean_box(x_2); return x_3; } } -lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_4__elabMutualInductive___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_6__elabMutualInductive___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; uint8_t x_6; @@ -5892,7 +3914,7 @@ x_14 = l_Lean_Elab_Command_elabModifiers(x_13, x_3, x_4); lean_dec(x_13); if (lean_obj_tag(x_14) == 0) { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; x_15 = lean_ctor_get(x_14, 0); lean_inc(x_15); x_16 = lean_ctor_get(x_14, 1); @@ -5901,52 +3923,87 @@ lean_dec(x_14); x_17 = lean_unsigned_to_nat(1u); x_18 = l_Lean_Syntax_getArg(x_12, x_17); lean_dec(x_12); -x_19 = l___private_Lean_Elab_Declaration_1__inductiveSyntaxToView(x_15, x_18, x_17); -x_20 = lean_nat_add(x_1, x_17); -x_21 = x_19; -x_22 = lean_array_fset(x_11, x_1, x_21); +lean_inc(x_3); +x_19 = l___private_Lean_Elab_Declaration_3__inductiveSyntaxToView(x_15, x_18, x_17, x_3, x_16); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = lean_nat_add(x_1, x_17); +x_23 = x_20; +x_24 = lean_array_fset(x_11, x_1, x_23); lean_dec(x_1); -x_1 = x_20; -x_2 = x_22; -x_4 = x_16; +x_1 = x_22; +x_2 = x_24; +x_4 = x_21; goto _start; } else { -uint8_t x_24; +uint8_t x_26; +lean_dec(x_11); +lean_dec(x_3); +lean_dec(x_1); +x_26 = !lean_is_exclusive(x_19); +if (x_26 == 0) +{ +return x_19; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_19, 0); +x_28 = lean_ctor_get(x_19, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_19); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +else +{ +uint8_t x_30; lean_dec(x_12); lean_dec(x_11); lean_dec(x_3); lean_dec(x_1); -x_24 = !lean_is_exclusive(x_14); -if (x_24 == 0) +x_30 = !lean_is_exclusive(x_14); +if (x_30 == 0) { return x_14; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_14, 0); -x_26 = lean_ctor_get(x_14, 1); -lean_inc(x_26); -lean_inc(x_25); +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_14, 0); +x_32 = lean_ctor_get(x_14, 1); +lean_inc(x_32); +lean_inc(x_31); lean_dec(x_14); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; +x_33 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_33, 0, x_31); +lean_ctor_set(x_33, 1, x_32); +return x_33; } } } } } -lean_object* l___private_Lean_Elab_Declaration_4__elabMutualInductive(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Lean_Elab_Declaration_6__elabMutualInductive(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; x_4 = x_1; x_5 = lean_unsigned_to_nat(0u); -x_6 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_4__elabMutualInductive___spec__1), 4, 2); +x_6 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_6__elabMutualInductive___spec__1), 4, 2); lean_closure_set(x_6, 0, x_5); lean_closure_set(x_6, 1, x_4); x_7 = x_6; @@ -6020,7 +4077,7 @@ lean_object* l_Lean_Elab_Command_elabMutual(lean_object* x_1, lean_object* x_2, _start: { uint8_t x_4; -x_4 = l___private_Lean_Elab_Declaration_3__isMutualInductive(x_1); +x_4 = l___private_Lean_Elab_Declaration_5__isMutualInductive(x_1); if (x_4 == 0) { lean_object* x_5; lean_object* x_6; @@ -6035,7 +4092,7 @@ x_7 = lean_unsigned_to_nat(1u); x_8 = l_Lean_Syntax_getArg(x_1, x_7); x_9 = l_Lean_Syntax_getArgs(x_8); lean_dec(x_8); -x_10 = l___private_Lean_Elab_Declaration_4__elabMutualInductive(x_9, x_2, x_3); +x_10 = l___private_Lean_Elab_Declaration_6__elabMutualInductive(x_9, x_2, x_3); return x_10; } } @@ -6117,18 +4174,74 @@ l_Lean_Elab_Command_elabInstance___closed__3 = _init_l_Lean_Elab_Command_elabIns lean_mark_persistent(l_Lean_Elab_Command_elabInstance___closed__3); l_Lean_Elab_Command_elabInstance___closed__4 = _init_l_Lean_Elab_Command_elabInstance___closed__4(); lean_mark_persistent(l_Lean_Elab_Command_elabInstance___closed__4); +l_Lean_Elab_Command_elabInstance___closed__5 = _init_l_Lean_Elab_Command_elabInstance___closed__5(); +lean_mark_persistent(l_Lean_Elab_Command_elabInstance___closed__5); l_Lean_Elab_Command_elabExample___closed__1 = _init_l_Lean_Elab_Command_elabExample___closed__1(); lean_mark_persistent(l_Lean_Elab_Command_elabExample___closed__1); l_Lean_Elab_Command_elabExample___closed__2 = _init_l_Lean_Elab_Command_elabExample___closed__2(); lean_mark_persistent(l_Lean_Elab_Command_elabExample___closed__2); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__1); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__2); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__3); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__4); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__5); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__6); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__7); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__8); +l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9 = _init_l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_1__checkValidInductiveModifier___closed__9); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__1); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__2); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__3); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__4); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__5); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__6); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__7); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__8); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__9); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__10); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__11); +l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12 = _init_l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12(); +lean_mark_persistent(l___private_Lean_Elab_Declaration_2__checkValidCtorModifier___closed__12); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__1); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__2); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__3); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__4); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__5); +l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6 = _init_l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Lean_Elab_Declaration_3__inductiveSyntaxToView___spec__1___closed__6); +l_Lean_Elab_Command_elabClassInductive___closed__1 = _init_l_Lean_Elab_Command_elabClassInductive___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_elabClassInductive___closed__1); l_Lean_Elab_Command_elabDeclaration___closed__1 = _init_l_Lean_Elab_Command_elabDeclaration___closed__1(); lean_mark_persistent(l_Lean_Elab_Command_elabDeclaration___closed__1); l_Lean_Elab_Command_elabDeclaration___closed__2 = _init_l_Lean_Elab_Command_elabDeclaration___closed__2(); lean_mark_persistent(l_Lean_Elab_Command_elabDeclaration___closed__2); l_Lean_Elab_Command_elabDeclaration___closed__3 = _init_l_Lean_Elab_Command_elabDeclaration___closed__3(); lean_mark_persistent(l_Lean_Elab_Command_elabDeclaration___closed__3); -l_Lean_Elab_Command_elabDeclaration___closed__4 = _init_l_Lean_Elab_Command_elabDeclaration___closed__4(); -lean_mark_persistent(l_Lean_Elab_Command_elabDeclaration___closed__4); l___regBuiltin_Lean_Elab_Command_elabDeclaration___closed__1 = _init_l___regBuiltin_Lean_Elab_Command_elabDeclaration___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Command_elabDeclaration___closed__1); res = l___regBuiltin_Lean_Elab_Command_elabDeclaration(lean_io_mk_world()); diff --git a/stage0/stdlib/Lean/Elab/Definition.c b/stage0/stdlib/Lean/Elab/Definition.c index ae2396cba3..c30ddecc4f 100644 --- a/stage0/stdlib/Lean/Elab/Definition.c +++ b/stage0/stdlib/Lean/Elab/Definition.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Lean.Elab.Definition -// Imports: Init Std.ShareCommon Lean.Util.CollectLevelParams Lean.Util.FoldConsts Lean.Util.CollectFVars Lean.Elab.DeclModifiers Lean.Elab.Binders +// Imports: Init Std.ShareCommon Lean.Util.CollectLevelParams Lean.Util.FoldConsts Lean.Elab.CollectFVars Lean.Elab.DeclModifiers Lean.Elab.Binders #include #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -13,29 +13,22 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l_Lean_Elab_Command_checkNotAlreadyDeclared(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getEnv___rarg(lean_object*); lean_object* l_Lean_Elab_Term_mkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_extractMacroScopes(lean_object*); +lean_object* l_Lean_Elab_Term_removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_registerTraceClass(lean_object*, lean_object*); extern lean_object* l___private_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__7; lean_object* l_Lean_Elab_Command_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkSort(lean_object*); lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen_x27___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_MessageData_ofList___closed__3; -lean_object* l_Lean_Elab_Term_inferType(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1; -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__2(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__4; -uint8_t l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_local_ctx_erase(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1; +lean_object* l_Lean_Elab_Command_withDeclId___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; extern lean_object* l___private_Lean_Elab_SyntheticMVars_2__resumePostponed___lambda__1___closed__1; uint8_t l_Lean_checkTraceOption(lean_object*, lean_object*); @@ -43,110 +36,77 @@ lean_object* l___private_Lean_Elab_Command_6__mkTermContext(lean_object*, lean_o lean_object* l_Lean_Elab_Command_elabDefVal___closed__2; extern lean_object* l_Std_ShareCommon_State_empty; lean_object* l_Lean_Elab_Command_compileDecl(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_reverseAux___main___rarg(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen(lean_object*); lean_object* l___private_Lean_Elab_Command_3__setState(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_array_push(lean_object*, lean_object*); -lean_object* lean_array_get_size(lean_object*); extern lean_object* l_Lean_Parser_Command_declValEqns___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque___boxed(lean_object*); lean_object* l_Lean_Elab_Command_elabDefVal___closed__1; lean_object* l_Lean_Elab_Command_elabDefVal(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(uint8_t, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_collectUsedFVarsAtFVars___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Elab_Command_DefKind_isExample(uint8_t); -lean_object* l_Lean_Name_getNumParts___main(lean_object*); -lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_ensureHasType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkFreshTypeMVar(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); uint32_t l_UInt32_add(uint32_t, uint32_t); lean_object* l_Lean_Elab_Term_getOptions(lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_collectUsedFVarsAtFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_array_fget(lean_object*, lean_object*); -uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDeclName(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_state_sharecommon(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen_x27___rarg(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_nat_sub(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(lean_object*); lean_object* l_Lean_Elab_Command_DefKind_isTheorem___boxed(lean_object*); -lean_object* l_Lean_Elab_Command_expandDeclId(lean_object*); uint8_t l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque(uint8_t); extern lean_object* l_Lean_Parser_Command_declValSimple___elambda__1___closed__2; -lean_object* l_Lean_Expr_fvarId_x21(lean_object*); lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__2; lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__1; lean_object* l_Lean_Elab_Term_elabTermAux___main(lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_logTrace(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Syntax_getId(lean_object*); -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_mkDef___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDef___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen(lean_object*); lean_object* l_Lean_Elab_Term_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_collectUsedFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Parser_Command_namespace___elambda__1___closed__1; -lean_object* l_Lean_Elab_Command_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_iterateMAux___main___at_Lean_ppGoal___spec__6___closed__6; -lean_object* l_Lean_LocalInstances_erase(lean_object*, lean_object*); -lean_object* l_Lean_CollectFVars_main___main(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen_x27(lean_object*); lean_object* l_Lean_getMaxHeight(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Elab_Util_4__regTraceClasses___closed__1; -lean_object* l_Lean_Elab_Term_getLocalInsts(lean_object*, lean_object*); -extern lean_object* l_Lean_Elab_Command_modifyScope___closed__1; -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Elab_Command_DefKind_isTheorem(uint8_t); -extern lean_object* l_Lean_Elab_Command_withDeclId___closed__3; extern lean_object* l_Lean_NameSet_empty; -lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabDefVal___closed__3; lean_object* l___private_Lean_Elab_Command_2__getState(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__3(lean_object*, lean_object*, lean_object*); extern lean_object* l_Std_HashSet_Inhabited___closed__1; -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_List_drop___main___rarg(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_withUsedWhen___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_getLCtx(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_removeUnused___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_1__removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Command_7__mkTermState(lean_object*); lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l_Lean_Syntax_getKind(lean_object*); -lean_object* l_Lean_MacroScopesView_review(lean_object*); -lean_object* l___private_Lean_Elab_Definition_1__regTraceClasses(lean_object*); lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__3; lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__6; +lean_object* l___private_Lean_Elab_Definition_1__removeUnused___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabType(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_1__removeUnused___closed__1; +lean_object* l___private_Lean_Elab_Definition_4__regTraceClasses(lean_object*); lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__5; lean_object* l___private_Lean_Elab_Command_9__getVarDecls(lean_object*); -uint8_t l_Lean_Syntax_isNone(lean_object*); -lean_object* l_Lean_Elab_Command_mkDef(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDef(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_collectUsedFVars___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_getLevelNames(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_elabDefLike(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinders___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_removeUnused___closed__1; -uint8_t l_Lean_NameSet_contains(lean_object*, lean_object*); lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_levelOne; +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* lean_task_pure(lean_object*); -lean_object* l___private_Lean_Elab_Command_12__addScopes___main(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_CollectLevelParams_main___main(lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; lean_object* l_Lean_Elab_Command_DefKind_isExample___boxed(lean_object*); -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_mkDef___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t lean_nat_dec_lt(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_mkDef___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27(lean_object*); uint8_t l_Lean_Elab_Command_DefKind_isTheorem(uint8_t x_1) { _start: { @@ -248,614 +208,7 @@ x_4 = lean_box(x_3); return x_4; } } -lean_object* l_Lean_Elab_Command_collectUsedFVars(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = l_Lean_Elab_Term_instantiateMVars(x_1, x_3, x_4, x_5); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_6, 0); -x_9 = l_Lean_CollectFVars_main___main(x_8, x_2); -lean_ctor_set(x_6, 0, x_9); -return x_6; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_10 = lean_ctor_get(x_6, 0); -x_11 = lean_ctor_get(x_6, 1); -lean_inc(x_11); -lean_inc(x_10); -lean_dec(x_6); -x_12 = l_Lean_CollectFVars_main___main(x_10, x_2); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_11); -return x_13; -} -} -} -lean_object* l_Lean_Elab_Command_collectUsedFVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_3); -x_9 = lean_nat_dec_lt(x_4, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_6); -lean_dec(x_4); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_5); -lean_ctor_set(x_10, 1, x_7); -return x_10; -} -else -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_11 = lean_array_fget(x_3, x_4); -x_12 = lean_unsigned_to_nat(1u); -x_13 = lean_nat_add(x_4, x_12); -lean_dec(x_4); -lean_inc(x_6); -x_14 = l_Lean_Elab_Term_inferType(x_1, x_11, x_6, x_7); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -lean_inc(x_6); -x_17 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_5, x_15, x_6, x_16); -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -x_4 = x_13; -x_5 = x_18; -x_7 = x_19; -goto _start; -} -else -{ -uint8_t x_21; -lean_dec(x_13); -lean_dec(x_6); -lean_dec(x_5); -x_21 = !lean_is_exclusive(x_14); -if (x_21 == 0) -{ -return x_14; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_14, 0); -x_23 = lean_ctor_get(x_14, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_14); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -} -} -lean_object* l_Lean_Elab_Command_collectUsedFVarsAtFVars(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; -x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1(x_1, x_3, x_3, x_6, x_2, x_4, x_5); -return x_7; -} -} -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Elab_Command_collectUsedFVarsAtFVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Elab_Command_collectUsedFVarsAtFVars(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -lean_dec(x_1); -return x_6; -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_4, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_4, x_11); -lean_dec(x_4); -x_13 = lean_array_fget(x_3, x_12); -x_14 = lean_ctor_get(x_6, 1); -lean_inc(x_14); -x_15 = lean_ctor_get(x_14, 1); -lean_inc(x_15); -x_16 = !lean_is_exclusive(x_6); -if (x_16 == 0) -{ -lean_object* x_17; lean_object* x_18; uint8_t x_19; -x_17 = lean_ctor_get(x_6, 0); -x_18 = lean_ctor_get(x_6, 1); -lean_dec(x_18); -x_19 = !lean_is_exclusive(x_14); -if (x_19 == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; -x_20 = lean_ctor_get(x_14, 0); -x_21 = lean_ctor_get(x_14, 1); -lean_dec(x_21); -x_22 = lean_ctor_get(x_15, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_15, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_23, 1); -lean_inc(x_24); -x_25 = l_Lean_Expr_fvarId_x21(x_13); -x_26 = l_Lean_NameSet_contains(x_24, x_25); -lean_dec(x_24); -if (x_26 == 0) -{ -lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_22); -lean_dec(x_13); -lean_inc(x_25); -x_27 = lean_local_ctx_erase(x_17, x_25); -x_28 = l_Lean_LocalInstances_erase(x_20, x_25); -lean_dec(x_25); -lean_ctor_set(x_14, 0, x_28); -lean_ctor_set(x_6, 0, x_27); -x_4 = x_12; -x_5 = lean_box(0); -goto _start; -} -else -{ -uint8_t x_30; -lean_dec(x_25); -x_30 = !lean_is_exclusive(x_15); -if (x_30 == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_31 = lean_ctor_get(x_15, 1); -lean_dec(x_31); -x_32 = lean_ctor_get(x_15, 0); -lean_dec(x_32); -lean_inc(x_7); -lean_inc(x_13); -x_33 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_34 = lean_ctor_get(x_33, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_33, 1); -lean_inc(x_35); -lean_dec(x_33); -lean_inc(x_7); -x_36 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_23, x_34, x_7, x_35); -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_array_push(x_22, x_13); -lean_ctor_set(x_15, 1, x_37); -lean_ctor_set(x_15, 0, x_39); -x_4 = x_12; -x_5 = lean_box(0); -x_8 = x_38; -goto _start; -} -else -{ -uint8_t x_41; -lean_free_object(x_15); -lean_dec(x_23); -lean_dec(x_22); -lean_free_object(x_14); -lean_dec(x_20); -lean_free_object(x_6); -lean_dec(x_17); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_7); -x_41 = !lean_is_exclusive(x_33); -if (x_41 == 0) -{ -return x_33; -} -else -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_42 = lean_ctor_get(x_33, 0); -x_43 = lean_ctor_get(x_33, 1); -lean_inc(x_43); -lean_inc(x_42); -lean_dec(x_33); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -return x_44; -} -} -} -else -{ -lean_object* x_45; -lean_dec(x_15); -lean_inc(x_7); -lean_inc(x_13); -x_45 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -lean_inc(x_7); -x_48 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_23, x_46, x_7, x_47); -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_array_push(x_22, x_13); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_49); -lean_ctor_set(x_14, 1, x_52); -x_4 = x_12; -x_5 = lean_box(0); -x_8 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -lean_dec(x_23); -lean_dec(x_22); -lean_free_object(x_14); -lean_dec(x_20); -lean_free_object(x_6); -lean_dec(x_17); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_7); -x_54 = lean_ctor_get(x_45, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_45, 1); -lean_inc(x_55); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - x_56 = x_45; -} else { - lean_dec_ref(x_45); - x_56 = lean_box(0); -} -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(1, 2, 0); -} else { - x_57 = x_56; -} -lean_ctor_set(x_57, 0, x_54); -lean_ctor_set(x_57, 1, x_55); -return x_57; -} -} -} -} -else -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; -x_58 = lean_ctor_get(x_14, 0); -lean_inc(x_58); -lean_dec(x_14); -x_59 = lean_ctor_get(x_15, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_15, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_60, 1); -lean_inc(x_61); -x_62 = l_Lean_Expr_fvarId_x21(x_13); -x_63 = l_Lean_NameSet_contains(x_61, x_62); -lean_dec(x_61); -if (x_63 == 0) -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_13); -lean_inc(x_62); -x_64 = lean_local_ctx_erase(x_17, x_62); -x_65 = l_Lean_LocalInstances_erase(x_58, x_62); -lean_dec(x_62); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_15); -lean_ctor_set(x_6, 1, x_66); -lean_ctor_set(x_6, 0, x_64); -x_4 = x_12; -x_5 = lean_box(0); -goto _start; -} -else -{ -lean_object* x_68; lean_object* x_69; -lean_dec(x_62); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - x_68 = x_15; -} else { - lean_dec_ref(x_15); - x_68 = lean_box(0); -} -lean_inc(x_7); -lean_inc(x_13); -x_69 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); -if (lean_obj_tag(x_69) == 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; -x_70 = lean_ctor_get(x_69, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_69, 1); -lean_inc(x_71); -lean_dec(x_69); -lean_inc(x_7); -x_72 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_60, x_70, x_7, x_71); -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_72, 1); -lean_inc(x_74); -lean_dec(x_72); -x_75 = lean_array_push(x_59, x_13); -if (lean_is_scalar(x_68)) { - x_76 = lean_alloc_ctor(0, 2, 0); -} else { - x_76 = x_68; -} -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_73); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_58); -lean_ctor_set(x_77, 1, x_76); -lean_ctor_set(x_6, 1, x_77); -x_4 = x_12; -x_5 = lean_box(0); -x_8 = x_74; -goto _start; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_68); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_58); -lean_free_object(x_6); -lean_dec(x_17); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_7); -x_79 = lean_ctor_get(x_69, 0); -lean_inc(x_79); -x_80 = lean_ctor_get(x_69, 1); -lean_inc(x_80); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - x_81 = x_69; -} else { - lean_dec_ref(x_69); - x_81 = lean_box(0); -} -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); -return x_82; -} -} -} -} -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; uint8_t x_90; -x_83 = lean_ctor_get(x_6, 0); -lean_inc(x_83); -lean_dec(x_6); -x_84 = lean_ctor_get(x_14, 0); -lean_inc(x_84); -if (lean_is_exclusive(x_14)) { - lean_ctor_release(x_14, 0); - lean_ctor_release(x_14, 1); - x_85 = x_14; -} else { - lean_dec_ref(x_14); - x_85 = lean_box(0); -} -x_86 = lean_ctor_get(x_15, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_15, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_87, 1); -lean_inc(x_88); -x_89 = l_Lean_Expr_fvarId_x21(x_13); -x_90 = l_Lean_NameSet_contains(x_88, x_89); -lean_dec(x_88); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -lean_dec(x_87); -lean_dec(x_86); -lean_dec(x_13); -lean_inc(x_89); -x_91 = lean_local_ctx_erase(x_83, x_89); -x_92 = l_Lean_LocalInstances_erase(x_84, x_89); -lean_dec(x_89); -if (lean_is_scalar(x_85)) { - x_93 = lean_alloc_ctor(0, 2, 0); -} else { - x_93 = x_85; -} -lean_ctor_set(x_93, 0, x_92); -lean_ctor_set(x_93, 1, x_15); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_91); -lean_ctor_set(x_94, 1, x_93); -x_4 = x_12; -x_5 = lean_box(0); -x_6 = x_94; -goto _start; -} -else -{ -lean_object* x_96; lean_object* x_97; -lean_dec(x_89); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - x_96 = x_15; -} else { - lean_dec_ref(x_15); - x_96 = lean_box(0); -} -lean_inc(x_7); -lean_inc(x_13); -x_97 = l_Lean_Elab_Term_inferType(x_1, x_13, x_7, x_8); -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; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -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); -lean_inc(x_7); -x_100 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_87, x_98, x_7, x_99); -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_array_push(x_86, x_13); -if (lean_is_scalar(x_96)) { - x_104 = lean_alloc_ctor(0, 2, 0); -} else { - x_104 = x_96; -} -lean_ctor_set(x_104, 0, x_103); -lean_ctor_set(x_104, 1, x_101); -if (lean_is_scalar(x_85)) { - x_105 = lean_alloc_ctor(0, 2, 0); -} else { - x_105 = x_85; -} -lean_ctor_set(x_105, 0, x_84); -lean_ctor_set(x_105, 1, x_104); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_83); -lean_ctor_set(x_106, 1, x_105); -x_4 = x_12; -x_5 = lean_box(0); -x_6 = x_106; -x_8 = x_102; -goto _start; -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -lean_dec(x_96); -lean_dec(x_87); -lean_dec(x_86); -lean_dec(x_85); -lean_dec(x_84); -lean_dec(x_83); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_7); -x_108 = lean_ctor_get(x_97, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_97, 1); -lean_inc(x_109); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - x_110 = x_97; -} else { - lean_dec_ref(x_97); - x_110 = lean_box(0); -} -if (lean_is_scalar(x_110)) { - x_111 = lean_alloc_ctor(1, 2, 0); -} else { - x_111 = x_110; -} -lean_ctor_set(x_111, 0, x_108); -lean_ctor_set(x_111, 1, x_109); -return x_111; -} -} -} -} -else -{ -lean_object* x_112; -lean_dec(x_7); -lean_dec(x_4); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_6); -lean_ctor_set(x_112, 1, x_8); -return x_112; -} -} -} -lean_object* _init_l_Lean_Elab_Command_removeUnused___closed__1() { +lean_object* _init_l___private_Lean_Elab_Definition_1__removeUnused___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -867,20 +220,20 @@ lean_ctor_set(x_3, 1, x_2); return x_3; } } -lean_object* l_Lean_Elab_Command_removeUnused(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Lean_Elab_Definition_1__removeUnused(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_8 = l_Lean_Elab_Command_removeUnused___closed__1; +x_8 = l___private_Lean_Elab_Definition_1__removeUnused___closed__1; lean_inc(x_6); -x_9 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_8, x_5, x_6, x_7); +x_9 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_8, x_5, x_6, x_7); x_10 = lean_ctor_get(x_9, 0); lean_inc(x_10); x_11 = lean_ctor_get(x_9, 1); lean_inc(x_11); lean_dec(x_9); lean_inc(x_6); -x_12 = l_Lean_Elab_Command_collectUsedFVars(x_1, x_10, x_4, x_6, x_11); +x_12 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_10, x_4, x_6, x_11); x_13 = lean_ctor_get(x_12, 0); lean_inc(x_13); x_14 = lean_ctor_get(x_12, 1); @@ -888,246 +241,55 @@ lean_inc(x_14); lean_dec(x_12); x_15 = lean_unsigned_to_nat(0u); lean_inc(x_6); -x_16 = l_Array_iterateMAux___main___at_Lean_Elab_Command_collectUsedFVarsAtFVars___spec__1(x_1, x_3, x_3, x_15, x_13, x_6, x_14); +x_16 = l_Array_iterateMAux___main___at_Lean_Elab_Term_collectUsedFVarsAtFVars___spec__1(x_1, x_3, x_3, x_15, x_13, x_6, x_14); if (lean_obj_tag(x_16) == 0) { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; 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_17; lean_object* x_18; lean_object* x_19; x_17 = lean_ctor_get(x_16, 0); lean_inc(x_17); x_18 = lean_ctor_get(x_16, 1); lean_inc(x_18); lean_dec(x_16); -x_19 = l_Lean_Elab_Term_getLocalInsts(x_6, x_18); -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_Elab_Term_getLCtx(x_6, x_21); -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Array_empty___closed__1; -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_17); -x_27 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_27, 0, x_20); -lean_ctor_set(x_27, 1, x_26); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_23); -lean_ctor_set(x_28, 1, x_27); -x_29 = lean_array_get_size(x_2); -x_30 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1(x_1, x_2, x_2, x_29, lean_box(0), x_28, x_6, x_24); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_31 = lean_ctor_get(x_30, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_31, 1); -lean_inc(x_32); -x_33 = lean_ctor_get(x_32, 1); -lean_inc(x_33); -x_34 = !lean_is_exclusive(x_30); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; uint8_t x_37; -x_35 = lean_ctor_get(x_30, 0); -lean_dec(x_35); -x_36 = lean_ctor_get(x_31, 0); -lean_inc(x_36); -lean_dec(x_31); -x_37 = !lean_is_exclusive(x_32); -if (x_37 == 0) -{ -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_32, 0); -x_39 = lean_ctor_get(x_32, 1); -lean_dec(x_39); -x_40 = !lean_is_exclusive(x_33); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_33, 0); -x_42 = lean_ctor_get(x_33, 1); -lean_dec(x_42); -x_43 = l_Array_reverseAux___main___rarg(x_41, x_15); -lean_ctor_set(x_33, 1, x_43); -lean_ctor_set(x_33, 0, x_38); -lean_ctor_set(x_32, 0, x_36); -lean_ctor_set(x_30, 0, x_32); -return x_30; +x_19 = l_Lean_Elab_Term_removeUnused(x_1, x_2, x_17, x_6, x_18); +return x_19; } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_33, 0); -lean_inc(x_44); -lean_dec(x_33); -x_45 = l_Array_reverseAux___main___rarg(x_44, x_15); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_38); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_32, 1, x_46); -lean_ctor_set(x_32, 0, x_36); -lean_ctor_set(x_30, 0, x_32); -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; -x_47 = lean_ctor_get(x_32, 0); -lean_inc(x_47); -lean_dec(x_32); -x_48 = lean_ctor_get(x_33, 0); -lean_inc(x_48); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_49 = x_33; -} else { - lean_dec_ref(x_33); - x_49 = lean_box(0); -} -x_50 = l_Array_reverseAux___main___rarg(x_48, x_15); -if (lean_is_scalar(x_49)) { - x_51 = lean_alloc_ctor(0, 2, 0); -} else { - x_51 = x_49; -} -lean_ctor_set(x_51, 0, x_47); -lean_ctor_set(x_51, 1, x_50); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_36); -lean_ctor_set(x_52, 1, x_51); -lean_ctor_set(x_30, 0, x_52); -return x_30; -} -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_53 = lean_ctor_get(x_30, 1); -lean_inc(x_53); -lean_dec(x_30); -x_54 = lean_ctor_get(x_31, 0); -lean_inc(x_54); -lean_dec(x_31); -x_55 = lean_ctor_get(x_32, 0); -lean_inc(x_55); -if (lean_is_exclusive(x_32)) { - lean_ctor_release(x_32, 0); - lean_ctor_release(x_32, 1); - x_56 = x_32; -} else { - lean_dec_ref(x_32); - x_56 = lean_box(0); -} -x_57 = lean_ctor_get(x_33, 0); -lean_inc(x_57); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_58 = x_33; -} else { - lean_dec_ref(x_33); - x_58 = lean_box(0); -} -x_59 = l_Array_reverseAux___main___rarg(x_57, x_15); -if (lean_is_scalar(x_58)) { - x_60 = lean_alloc_ctor(0, 2, 0); -} else { - x_60 = x_58; -} -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_59); -if (lean_is_scalar(x_56)) { - x_61 = lean_alloc_ctor(0, 2, 0); -} else { - x_61 = x_56; -} -lean_ctor_set(x_61, 0, x_54); -lean_ctor_set(x_61, 1, x_60); -x_62 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_62, 0, x_61); -lean_ctor_set(x_62, 1, x_53); -return x_62; -} -} -else -{ -uint8_t x_63; -x_63 = !lean_is_exclusive(x_30); -if (x_63 == 0) -{ -return x_30; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_30, 0); -x_65 = lean_ctor_get(x_30, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_30); -x_66 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_66, 0, x_64); -lean_ctor_set(x_66, 1, x_65); -return x_66; -} -} -} -else -{ -uint8_t x_67; +uint8_t x_20; lean_dec(x_6); -x_67 = !lean_is_exclusive(x_16); -if (x_67 == 0) +x_20 = !lean_is_exclusive(x_16); +if (x_20 == 0) { return x_16; } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_16, 0); -x_69 = lean_ctor_get(x_16, 1); -lean_inc(x_69); -lean_inc(x_68); +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_16, 0); +x_22 = lean_ctor_get(x_16, 1); +lean_inc(x_22); +lean_inc(x_21); lean_dec(x_16); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; } } } } -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Command_removeUnused___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -return x_9; -} -} -lean_object* l_Lean_Elab_Command_removeUnused___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Lean_Elab_Definition_1__removeUnused___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l_Lean_Elab_Command_removeUnused(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Lean_Elab_Definition_1__removeUnused(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); return x_8; } } -lean_object* l_Lean_Elab_Command_withUsedWhen___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, uint8_t x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, uint8_t x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { if (x_6 == 0) @@ -1142,7 +304,7 @@ else { lean_object* x_11; lean_inc(x_8); -x_11 = l_Lean_Elab_Command_removeUnused(x_1, x_2, x_3, x_4, x_5, x_8, x_9); +x_11 = l___private_Lean_Elab_Definition_1__removeUnused(x_1, x_2, x_3, x_4, x_5, x_8, x_9); lean_dec(x_2); if (lean_obj_tag(x_11) == 0) { @@ -1301,27 +463,27 @@ return x_52; } } } -lean_object* l_Lean_Elab_Command_withUsedWhen(lean_object* x_1) { +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Elab_Command_withUsedWhen___rarg___boxed), 9, 0); +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Definition_2__withUsedWhen___rarg___boxed), 9, 0); return x_2; } } -lean_object* l_Lean_Elab_Command_withUsedWhen___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Lean_Elab_Definition_2__withUsedWhen___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { uint8_t x_10; lean_object* x_11; x_10 = lean_unbox(x_6); lean_dec(x_6); -x_11 = l_Lean_Elab_Command_withUsedWhen___rarg(x_1, x_2, x_3, x_4, x_5, x_10, x_7, x_8, x_9); +x_11 = l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(x_1, x_2, x_3, x_4, x_5, x_10, x_7, x_8, x_9); lean_dec(x_3); lean_dec(x_1); return x_11; } } -lean_object* _init_l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1() { +lean_object* _init_l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1() { _start: { lean_object* x_1; lean_object* x_2; @@ -1330,30 +492,30 @@ x_2 = l_Lean_mkSort(x_1); return x_2; } } -lean_object* l_Lean_Elab_Command_withUsedWhen_x27___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { lean_object* x_9; lean_object* x_10; -x_9 = l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1; -x_10 = l_Lean_Elab_Command_withUsedWhen___rarg(x_1, x_2, x_3, x_4, x_9, x_5, x_6, x_7, x_8); +x_9 = l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1; +x_10 = l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(x_1, x_2, x_3, x_4, x_9, x_5, x_6, x_7, x_8); return x_10; } } -lean_object* l_Lean_Elab_Command_withUsedWhen_x27(lean_object* x_1) { +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Elab_Command_withUsedWhen_x27___rarg___boxed), 8, 0); +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___boxed), 8, 0); return x_2; } } -lean_object* l_Lean_Elab_Command_withUsedWhen_x27___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { uint8_t x_9; lean_object* x_10; x_9 = lean_unbox(x_5); lean_dec(x_5); -x_10 = l_Lean_Elab_Command_withUsedWhen_x27___rarg(x_1, x_2, x_3, x_4, x_9, x_6, x_7, x_8); +x_10 = l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg(x_1, x_2, x_3, x_4, x_9, x_6, x_7, x_8); lean_dec(x_3); lean_dec(x_1); return x_10; @@ -1418,674 +580,726 @@ lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l_Lean_Elab_Command_mkDef___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, uint8_t x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +lean_object* l_Lean_Elab_Command_mkDef___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, uint8_t x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { _start: { -lean_object* x_13; -lean_inc(x_11); +lean_object* x_14; +lean_inc(x_12); lean_inc(x_2); -x_13 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_3, x_11, x_12); -if (lean_obj_tag(x_13) == 0) +x_14 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_3, x_12, x_13); +if (lean_obj_tag(x_14) == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_14, 0); lean_inc(x_15); -lean_dec(x_13); -lean_inc(x_11); -lean_inc(x_10); -x_16 = l_Lean_Elab_Term_mkForall(x_1, x_10, x_14, x_11, x_15); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -lean_inc(x_11); -x_19 = l_Lean_Elab_Term_mkLambda(x_1, x_2, x_4, x_11, x_18); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -lean_inc(x_11); -x_22 = l_Lean_Elab_Term_mkLambda(x_1, x_10, x_20, x_11, x_21); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; 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; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; uint8_t x_107; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -lean_inc(x_11); -x_25 = l_Lean_Elab_Term_levelMVarToParam(x_17, x_11, x_24); -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -lean_inc(x_11); -x_28 = l_Lean_Elab_Term_levelMVarToParam(x_23, x_11, x_27); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -lean_inc(x_11); -x_31 = l_Lean_Elab_Term_instantiateMVars(x_1, x_26, x_11, x_30); -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_31, 1); -lean_inc(x_33); -lean_dec(x_31); -lean_inc(x_11); -x_34 = l_Lean_Elab_Term_instantiateMVars(x_5, x_29, x_11, x_33); -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_34, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_34)) { - lean_ctor_release(x_34, 0); - lean_ctor_release(x_34, 1); - x_37 = x_34; -} else { - lean_dec_ref(x_34); - x_37 = lean_box(0); -} -x_38 = l_Std_ShareCommon_State_empty; -x_39 = lean_state_sharecommon(x_38, x_32); -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -lean_dec(x_39); -x_42 = lean_state_sharecommon(x_41, x_35); -x_43 = lean_ctor_get(x_42, 0); -lean_inc(x_43); -lean_dec(x_42); -x_44 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; -lean_inc(x_40); -x_45 = l_Lean_CollectLevelParams_main___main(x_40, x_44); -lean_inc(x_43); -x_46 = l_Lean_CollectLevelParams_main___main(x_43, x_45); -x_47 = lean_ctor_get(x_46, 2); -lean_inc(x_47); -lean_dec(x_46); -x_48 = l_Lean_Elab_Command_sortDeclLevelParams(x_6, x_47); -x_103 = l_Lean_Elab_Term_getOptions(x_11, x_36); -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 = l_Lean_Elab_Command_mkDef___lambda__1___closed__4; -x_107 = l_Lean_checkTraceOption(x_104, x_106); -lean_dec(x_104); -if (x_107 == 0) -{ -x_49 = x_105; -goto block_102; -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -lean_inc(x_8); -x_108 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_108, 0, x_8); -x_109 = l___private_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__7; -x_110 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -lean_inc(x_40); -x_111 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_111, 0, x_40); -x_112 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -x_113 = l_Lean_Elab_Command_mkDef___lambda__1___closed__6; -x_114 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_114, 0, x_112); -lean_ctor_set(x_114, 1, x_113); -x_115 = l_Lean_MessageData_ofList___closed__3; -x_116 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_116, 0, x_114); -lean_ctor_set(x_116, 1, x_115); -lean_inc(x_43); -x_117 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_117, 0, x_43); -x_118 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_118, 0, x_116); -lean_ctor_set(x_118, 1, x_117); -lean_inc(x_11); -x_119 = l_Lean_Elab_Term_logTrace(x_106, x_1, x_118, x_11, x_105); -x_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -lean_dec(x_119); -x_49 = x_120; -goto block_102; -} -block_102: -{ -switch (x_7) { -case 0: -{ -lean_object* x_50; uint8_t x_51; -lean_dec(x_37); -lean_dec(x_11); -x_50 = l_Lean_Elab_Term_getEnv___rarg(x_49); -x_51 = !lean_is_exclusive(x_50); -if (x_51 == 0) -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; uint32_t x_55; uint32_t x_56; uint32_t x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_52 = lean_ctor_get(x_50, 0); -x_53 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_53, 0, x_8); -lean_ctor_set(x_53, 1, x_48); -lean_ctor_set(x_53, 2, x_40); -lean_inc(x_43); -x_54 = l_Lean_getMaxHeight(x_52, x_43); -x_55 = lean_unbox_uint32(x_54); -lean_dec(x_54); -x_56 = 1; -x_57 = x_55 + x_56; -x_58 = lean_alloc_ctor(2, 0, 4); -lean_ctor_set_uint32(x_58, 0, x_57); -x_59 = lean_ctor_get(x_9, 1); -x_60 = lean_ctor_get_uint8(x_59, sizeof(void*)*2 + 3); -x_61 = lean_alloc_ctor(0, 3, 1); -lean_ctor_set(x_61, 0, x_53); -lean_ctor_set(x_61, 1, x_43); -lean_ctor_set(x_61, 2, x_58); -lean_ctor_set_uint8(x_61, sizeof(void*)*3, x_60); -x_62 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_62, 0, x_61); -x_63 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_63, 0, x_62); -lean_ctor_set(x_50, 0, x_63); -return x_50; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; uint32_t x_68; uint32_t x_69; uint32_t x_70; lean_object* x_71; lean_object* x_72; uint8_t x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_64 = lean_ctor_get(x_50, 0); -x_65 = lean_ctor_get(x_50, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_50); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_8); -lean_ctor_set(x_66, 1, x_48); -lean_ctor_set(x_66, 2, x_40); -lean_inc(x_43); -x_67 = l_Lean_getMaxHeight(x_64, x_43); -x_68 = lean_unbox_uint32(x_67); -lean_dec(x_67); -x_69 = 1; -x_70 = x_68 + x_69; -x_71 = lean_alloc_ctor(2, 0, 4); -lean_ctor_set_uint32(x_71, 0, x_70); -x_72 = lean_ctor_get(x_9, 1); -x_73 = lean_ctor_get_uint8(x_72, sizeof(void*)*2 + 3); -x_74 = lean_alloc_ctor(0, 3, 1); -lean_ctor_set(x_74, 0, x_66); -lean_ctor_set(x_74, 1, x_43); -lean_ctor_set(x_74, 2, x_71); -lean_ctor_set_uint8(x_74, sizeof(void*)*3, x_73); -x_75 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_75, 0, x_74); -x_76 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_76, 0, x_75); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_65); -return x_77; -} -} -case 1: -{ -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_dec(x_11); -x_78 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_78, 0, x_8); -lean_ctor_set(x_78, 1, x_48); -lean_ctor_set(x_78, 2, x_40); -x_79 = lean_task_pure(x_43); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -x_81 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_81, 0, x_80); -x_82 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_82, 0, x_81); -if (lean_is_scalar(x_37)) { - x_83 = lean_alloc_ctor(0, 2, 0); -} else { - x_83 = x_37; -} -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_49); -return x_83; -} -case 2: -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_48); -lean_dec(x_43); -lean_dec(x_40); -lean_dec(x_37); -lean_dec(x_8); -x_84 = l___private_Lean_Elab_SyntheticMVars_2__resumePostponed___lambda__1___closed__1; -x_85 = l_unreachable_x21___rarg(x_84); -x_86 = lean_apply_2(x_85, x_11, x_49); -return x_86; -} -case 3: -{ -lean_object* x_87; lean_object* x_88; uint8_t x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -lean_dec(x_11); -x_87 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_87, 0, x_8); -lean_ctor_set(x_87, 1, x_48); -lean_ctor_set(x_87, 2, x_40); -x_88 = lean_ctor_get(x_9, 1); -x_89 = lean_ctor_get_uint8(x_88, sizeof(void*)*2 + 3); -x_90 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_90, 0, x_87); -lean_ctor_set(x_90, 1, x_43); -lean_ctor_set_uint8(x_90, sizeof(void*)*2, x_89); -x_91 = lean_alloc_ctor(3, 1, 0); -lean_ctor_set(x_91, 0, x_90); -x_92 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_92, 0, x_91); -if (lean_is_scalar(x_37)) { - x_93 = lean_alloc_ctor(0, 2, 0); -} else { - x_93 = x_37; -} -lean_ctor_set(x_93, 0, x_92); -lean_ctor_set(x_93, 1, x_49); -return x_93; -} -default: -{ -lean_object* x_94; lean_object* x_95; uint8_t x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -lean_dec(x_11); -x_94 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_94, 0, x_8); -lean_ctor_set(x_94, 1, x_48); -lean_ctor_set(x_94, 2, x_40); -x_95 = lean_ctor_get(x_9, 1); -x_96 = lean_ctor_get_uint8(x_95, sizeof(void*)*2 + 3); -x_97 = lean_box(1); -x_98 = lean_alloc_ctor(0, 3, 1); -lean_ctor_set(x_98, 0, x_94); -lean_ctor_set(x_98, 1, x_43); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set_uint8(x_98, sizeof(void*)*3, x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_98); -x_100 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_100, 0, x_99); -if (lean_is_scalar(x_37)) { - x_101 = lean_alloc_ctor(0, 2, 0); -} else { - x_101 = x_37; -} -lean_ctor_set(x_101, 0, x_100); -lean_ctor_set(x_101, 1, x_49); -return x_101; -} -} -} -} -else -{ -uint8_t x_121; -lean_dec(x_17); -lean_dec(x_11); -lean_dec(x_8); -lean_dec(x_6); -x_121 = !lean_is_exclusive(x_22); -if (x_121 == 0) -{ -return x_22; -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_22, 0); -x_123 = lean_ctor_get(x_22, 1); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_22); -x_124 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -return x_124; -} -} -} -else -{ -uint8_t x_125; -lean_dec(x_17); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_6); -x_125 = !lean_is_exclusive(x_19); -if (x_125 == 0) -{ -return x_19; -} -else -{ -lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_126 = lean_ctor_get(x_19, 0); -x_127 = lean_ctor_get(x_19, 1); -lean_inc(x_127); -lean_inc(x_126); -lean_dec(x_19); -x_128 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_128, 0, x_126); -lean_ctor_set(x_128, 1, x_127); -return x_128; -} -} -} -else -{ -uint8_t x_129; -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -x_129 = !lean_is_exclusive(x_16); -if (x_129 == 0) -{ -return x_16; -} -else -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_130 = lean_ctor_get(x_16, 0); -x_131 = lean_ctor_get(x_16, 1); -lean_inc(x_131); -lean_inc(x_130); -lean_dec(x_16); -x_132 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_132, 0, x_130); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -} -} -else -{ -uint8_t x_133; -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -x_133 = !lean_is_exclusive(x_13); -if (x_133 == 0) -{ -return x_13; -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_134 = lean_ctor_get(x_13, 0); -x_135 = lean_ctor_get(x_13, 1); -lean_inc(x_135); -lean_inc(x_134); -lean_dec(x_13); -x_136 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_136, 0, x_134); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -} -} -} -lean_object* l_Lean_Elab_Command_mkDef(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; -x_10 = lean_ctor_get(x_1, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_1, 5); -lean_inc(x_11); -lean_inc(x_6); -x_12 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_12, 0, x_6); -x_13 = 1; -x_14 = lean_box(0); -lean_inc(x_8); -x_15 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_13, x_14, x_8, x_9); -if (lean_obj_tag(x_15) == 0) -{ -lean_object* x_16; lean_object* x_17; -x_16 = lean_ctor_get(x_15, 1); +x_16 = lean_ctor_get(x_14, 1); lean_inc(x_16); -lean_dec(x_15); -lean_inc(x_8); +lean_dec(x_14); +lean_inc(x_12); lean_inc(x_11); -x_17 = l_Lean_Elab_Term_ensureHasType(x_11, x_12, x_7, x_8, x_16); +x_17 = l_Lean_Elab_Term_mkForall(x_1, x_11, x_15, x_12, x_16); if (lean_obj_tag(x_17) == 0) { -lean_object* x_18; lean_object* x_19; uint8_t x_20; lean_object* x_21; +lean_object* x_18; lean_object* x_19; lean_object* x_20; x_18 = lean_ctor_get(x_17, 0); lean_inc(x_18); x_19 = lean_ctor_get(x_17, 1); lean_inc(x_19); lean_dec(x_17); -x_20 = 0; -lean_inc(x_8); -x_21 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_20, x_14, x_8, x_19); -if (lean_obj_tag(x_21) == 0) +lean_inc(x_12); +x_20 = l_Lean_Elab_Term_mkLambda(x_1, x_2, x_4, x_12, x_19); +if (lean_obj_tag(x_20) == 0) { -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; -x_22 = lean_ctor_get(x_21, 1); +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); lean_inc(x_22); -lean_dec(x_21); -lean_inc(x_8); -x_23 = l_Lean_Elab_Term_instantiateMVars(x_10, x_6, x_8, x_22); +lean_dec(x_20); +lean_inc(x_12); +x_23 = l_Lean_Elab_Term_mkLambda(x_1, x_11, x_21, x_12, x_22); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; 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; 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_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; uint8_t x_120; x_24 = lean_ctor_get(x_23, 0); lean_inc(x_24); x_25 = lean_ctor_get(x_23, 1); lean_inc(x_25); lean_dec(x_23); -lean_inc(x_8); -x_26 = l_Lean_Elab_Term_instantiateMVars(x_11, x_18, x_8, x_25); -x_27 = !lean_is_exclusive(x_26); -if (x_27 == 0) -{ -lean_object* x_28; lean_object* x_29; uint8_t x_30; uint8_t x_31; -x_28 = lean_ctor_get(x_26, 0); -x_29 = lean_ctor_get(x_26, 1); -x_30 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); -x_31 = l_Lean_Elab_Command_DefKind_isExample(x_30); -if (x_31 == 0) -{ -uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -lean_free_object(x_26); -x_32 = l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque(x_30); -x_33 = lean_box(x_30); +x_26 = lean_unsigned_to_nat(1u); +lean_inc(x_12); +x_27 = l_Lean_Elab_Term_levelMVarToParam(x_18, x_26, x_12, x_25); +x_28 = lean_ctor_get(x_27, 0); lean_inc(x_28); -lean_inc(x_24); -lean_inc(x_5); -lean_inc(x_10); -x_34 = lean_alloc_closure((void*)(l_Lean_Elab_Command_mkDef___lambda__1___boxed), 12, 9); -lean_closure_set(x_34, 0, x_10); -lean_closure_set(x_34, 1, x_5); -lean_closure_set(x_34, 2, x_24); -lean_closure_set(x_34, 3, x_28); -lean_closure_set(x_34, 4, x_11); -lean_closure_set(x_34, 5, x_3); -lean_closure_set(x_34, 6, x_33); -lean_closure_set(x_34, 7, x_2); -lean_closure_set(x_34, 8, x_1); -x_35 = l_Lean_Elab_Command_withUsedWhen___rarg(x_10, x_4, x_5, x_28, x_24, x_32, x_34, x_8, x_29); -lean_dec(x_5); -lean_dec(x_10); -return x_35; -} -else -{ -lean_object* x_36; +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +lean_dec(x_27); +x_30 = lean_ctor_get(x_28, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_28, 1); +lean_inc(x_31); lean_dec(x_28); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_36 = lean_box(0); -lean_ctor_set(x_26, 0, x_36); -return x_26; -} -} -else -{ -lean_object* x_37; lean_object* x_38; uint8_t x_39; uint8_t x_40; -x_37 = lean_ctor_get(x_26, 0); -x_38 = lean_ctor_get(x_26, 1); +lean_inc(x_12); +x_32 = l_Lean_Elab_Term_levelMVarToParam(x_24, x_31, x_12, x_29); +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_32, 1); +lean_inc(x_34); +lean_dec(x_32); +x_35 = lean_ctor_get(x_33, 0); +lean_inc(x_35); +lean_dec(x_33); +lean_inc(x_12); +x_36 = l_Lean_Elab_Term_instantiateMVars(x_1, x_30, x_12, x_34); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_36, 1); lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_26); -x_39 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); -x_40 = l_Lean_Elab_Command_DefKind_isExample(x_39); -if (x_40 == 0) -{ -uint8_t x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_41 = l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque(x_39); -x_42 = lean_box(x_39); -lean_inc(x_37); -lean_inc(x_24); -lean_inc(x_5); -lean_inc(x_10); -x_43 = lean_alloc_closure((void*)(l_Lean_Elab_Command_mkDef___lambda__1___boxed), 12, 9); -lean_closure_set(x_43, 0, x_10); -lean_closure_set(x_43, 1, x_5); -lean_closure_set(x_43, 2, x_24); -lean_closure_set(x_43, 3, x_37); -lean_closure_set(x_43, 4, x_11); -lean_closure_set(x_43, 5, x_3); -lean_closure_set(x_43, 6, x_42); -lean_closure_set(x_43, 7, x_2); -lean_closure_set(x_43, 8, x_1); -x_44 = l_Lean_Elab_Command_withUsedWhen___rarg(x_10, x_4, x_5, x_37, x_24, x_41, x_43, x_8, x_38); -lean_dec(x_5); -lean_dec(x_10); -return x_44; +lean_dec(x_36); +lean_inc(x_12); +x_39 = l_Lean_Elab_Term_instantiateMVars(x_5, x_35, x_12, x_38); +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + x_42 = x_39; +} else { + lean_dec_ref(x_39); + x_42 = lean_box(0); } -else -{ -lean_object* x_45; lean_object* x_46; -lean_dec(x_37); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_45 = lean_box(0); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_38); -return x_46; -} -} -} -else -{ -uint8_t x_47; -lean_dec(x_18); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_47 = !lean_is_exclusive(x_21); -if (x_47 == 0) -{ -return x_21; -} -else -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_48 = lean_ctor_get(x_21, 0); -x_49 = lean_ctor_get(x_21, 1); -lean_inc(x_49); +x_43 = l_Std_ShareCommon_State_empty; +x_44 = lean_state_sharecommon(x_43, x_37); +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_44, 1); +lean_inc(x_46); +lean_dec(x_44); +x_47 = lean_state_sharecommon(x_46, x_40); +x_48 = lean_ctor_get(x_47, 0); lean_inc(x_48); -lean_dec(x_21); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_48); -lean_ctor_set(x_50, 1, x_49); -return x_50; +lean_dec(x_47); +x_49 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; +lean_inc(x_45); +x_50 = l_Lean_CollectLevelParams_main___main(x_45, x_49); +lean_inc(x_48); +x_51 = l_Lean_CollectLevelParams_main___main(x_48, x_50); +x_52 = lean_ctor_get(x_51, 2); +lean_inc(x_52); +lean_dec(x_51); +x_53 = l_Lean_Elab_Command_sortDeclLevelParams(x_6, x_7, x_52); +x_116 = l_Lean_Elab_Term_getOptions(x_12, x_41); +x_117 = lean_ctor_get(x_116, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_116, 1); +lean_inc(x_118); +lean_dec(x_116); +x_119 = l_Lean_Elab_Command_mkDef___lambda__1___closed__4; +x_120 = l_Lean_checkTraceOption(x_117, x_119); +lean_dec(x_117); +if (x_120 == 0) +{ +x_54 = x_118; +goto block_115; +} +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_inc(x_9); +x_121 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_121, 0, x_9); +x_122 = l___private_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__7; +x_123 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_123, 0, x_121); +lean_ctor_set(x_123, 1, x_122); +lean_inc(x_45); +x_124 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_124, 0, x_45); +x_125 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_125, 0, x_123); +lean_ctor_set(x_125, 1, x_124); +x_126 = l_Lean_Elab_Command_mkDef___lambda__1___closed__6; +x_127 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_127, 0, x_125); +lean_ctor_set(x_127, 1, x_126); +x_128 = l_Lean_MessageData_ofList___closed__3; +x_129 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_129, 0, x_127); +lean_ctor_set(x_129, 1, x_128); +lean_inc(x_48); +x_130 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_130, 0, x_48); +x_131 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_131, 0, x_129); +lean_ctor_set(x_131, 1, x_130); +lean_inc(x_12); +x_132 = l_Lean_Elab_Term_logTrace(x_119, x_1, x_131, x_12, x_118); +x_133 = lean_ctor_get(x_132, 1); +lean_inc(x_133); +lean_dec(x_132); +x_54 = x_133; +goto block_115; +} +block_115: +{ +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +lean_dec(x_48); +lean_dec(x_45); +lean_dec(x_42); +lean_dec(x_9); +x_55 = lean_ctor_get(x_53, 0); +lean_inc(x_55); +lean_dec(x_53); +x_56 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_56, 0, x_55); +x_57 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_57, 0, x_56); +x_58 = l_Lean_Elab_Term_throwError___rarg(x_1, x_57, x_12, x_54); +return x_58; +} +else +{ +switch (x_8) { +case 0: +{ +lean_object* x_59; lean_object* x_60; uint8_t x_61; +lean_dec(x_42); +lean_dec(x_12); +x_59 = lean_ctor_get(x_53, 0); +lean_inc(x_59); +lean_dec(x_53); +x_60 = l_Lean_Elab_Term_getEnv___rarg(x_54); +x_61 = !lean_is_exclusive(x_60); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; uint32_t x_65; uint32_t x_66; uint32_t x_67; lean_object* x_68; lean_object* x_69; uint8_t x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_62 = lean_ctor_get(x_60, 0); +x_63 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_63, 0, x_9); +lean_ctor_set(x_63, 1, x_59); +lean_ctor_set(x_63, 2, x_45); +lean_inc(x_48); +x_64 = l_Lean_getMaxHeight(x_62, x_48); +x_65 = lean_unbox_uint32(x_64); +lean_dec(x_64); +x_66 = 1; +x_67 = x_65 + x_66; +x_68 = lean_alloc_ctor(2, 0, 4); +lean_ctor_set_uint32(x_68, 0, x_67); +x_69 = lean_ctor_get(x_10, 1); +x_70 = lean_ctor_get_uint8(x_69, sizeof(void*)*2 + 3); +x_71 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_71, 0, x_63); +lean_ctor_set(x_71, 1, x_48); +lean_ctor_set(x_71, 2, x_68); +lean_ctor_set_uint8(x_71, sizeof(void*)*3, x_70); +x_72 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_72, 0, x_71); +x_73 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_73, 0, x_72); +lean_ctor_set(x_60, 0, x_73); +return x_60; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; uint32_t x_78; uint32_t x_79; uint32_t x_80; lean_object* x_81; lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_74 = lean_ctor_get(x_60, 0); +x_75 = lean_ctor_get(x_60, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_60); +x_76 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_76, 0, x_9); +lean_ctor_set(x_76, 1, x_59); +lean_ctor_set(x_76, 2, x_45); +lean_inc(x_48); +x_77 = l_Lean_getMaxHeight(x_74, x_48); +x_78 = lean_unbox_uint32(x_77); +lean_dec(x_77); +x_79 = 1; +x_80 = x_78 + x_79; +x_81 = lean_alloc_ctor(2, 0, 4); +lean_ctor_set_uint32(x_81, 0, x_80); +x_82 = lean_ctor_get(x_10, 1); +x_83 = lean_ctor_get_uint8(x_82, sizeof(void*)*2 + 3); +x_84 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_84, 0, x_76); +lean_ctor_set(x_84, 1, x_48); +lean_ctor_set(x_84, 2, x_81); +lean_ctor_set_uint8(x_84, sizeof(void*)*3, x_83); +x_85 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_85, 0, x_84); +x_86 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_86, 0, x_85); +x_87 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_87, 0, x_86); +lean_ctor_set(x_87, 1, x_75); +return x_87; +} +} +case 1: +{ +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +lean_dec(x_12); +x_88 = lean_ctor_get(x_53, 0); +lean_inc(x_88); +lean_dec(x_53); +x_89 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_89, 0, x_9); +lean_ctor_set(x_89, 1, x_88); +lean_ctor_set(x_89, 2, x_45); +x_90 = lean_task_pure(x_48); +x_91 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_91, 0, x_89); +lean_ctor_set(x_91, 1, x_90); +x_92 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_92, 0, x_91); +x_93 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_93, 0, x_92); +if (lean_is_scalar(x_42)) { + x_94 = lean_alloc_ctor(0, 2, 0); +} else { + x_94 = x_42; +} +lean_ctor_set(x_94, 0, x_93); +lean_ctor_set(x_94, 1, x_54); +return x_94; +} +case 2: +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; +lean_dec(x_53); +lean_dec(x_48); +lean_dec(x_45); +lean_dec(x_42); +lean_dec(x_9); +x_95 = l___private_Lean_Elab_SyntheticMVars_2__resumePostponed___lambda__1___closed__1; +x_96 = l_unreachable_x21___rarg(x_95); +x_97 = lean_apply_2(x_96, x_12, x_54); +return x_97; +} +case 3: +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +lean_dec(x_12); +x_98 = lean_ctor_get(x_53, 0); +lean_inc(x_98); +lean_dec(x_53); +x_99 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_99, 0, x_9); +lean_ctor_set(x_99, 1, x_98); +lean_ctor_set(x_99, 2, x_45); +x_100 = lean_ctor_get(x_10, 1); +x_101 = lean_ctor_get_uint8(x_100, sizeof(void*)*2 + 3); +x_102 = lean_alloc_ctor(0, 2, 1); +lean_ctor_set(x_102, 0, x_99); +lean_ctor_set(x_102, 1, x_48); +lean_ctor_set_uint8(x_102, sizeof(void*)*2, x_101); +x_103 = lean_alloc_ctor(3, 1, 0); +lean_ctor_set(x_103, 0, x_102); +x_104 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_104, 0, x_103); +if (lean_is_scalar(x_42)) { + x_105 = lean_alloc_ctor(0, 2, 0); +} else { + x_105 = x_42; +} +lean_ctor_set(x_105, 0, x_104); +lean_ctor_set(x_105, 1, x_54); +return x_105; +} +default: +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; uint8_t x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; +lean_dec(x_12); +x_106 = lean_ctor_get(x_53, 0); +lean_inc(x_106); +lean_dec(x_53); +x_107 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_107, 0, x_9); +lean_ctor_set(x_107, 1, x_106); +lean_ctor_set(x_107, 2, x_45); +x_108 = lean_ctor_get(x_10, 1); +x_109 = lean_ctor_get_uint8(x_108, sizeof(void*)*2 + 3); +x_110 = lean_box(1); +x_111 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_111, 0, x_107); +lean_ctor_set(x_111, 1, x_48); +lean_ctor_set(x_111, 2, x_110); +lean_ctor_set_uint8(x_111, sizeof(void*)*3, x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_111); +x_113 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_113, 0, x_112); +if (lean_is_scalar(x_42)) { + x_114 = lean_alloc_ctor(0, 2, 0); +} else { + x_114 = x_42; +} +lean_ctor_set(x_114, 0, x_113); +lean_ctor_set(x_114, 1, x_54); +return x_114; +} +} } } } else { -uint8_t x_51; -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); +uint8_t x_134; +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +x_134 = !lean_is_exclusive(x_23); +if (x_134 == 0) +{ +return x_23; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; +x_135 = lean_ctor_get(x_23, 0); +x_136 = lean_ctor_get(x_23, 1); +lean_inc(x_136); +lean_inc(x_135); +lean_dec(x_23); +x_137 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_137, 0, x_135); +lean_ctor_set(x_137, 1, x_136); +return x_137; +} +} +} +else +{ +uint8_t x_138; +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +x_138 = !lean_is_exclusive(x_20); +if (x_138 == 0) +{ +return x_20; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_139 = lean_ctor_get(x_20, 0); +x_140 = lean_ctor_get(x_20, 1); +lean_inc(x_140); +lean_inc(x_139); +lean_dec(x_20); +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 +{ +uint8_t x_142; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_7); lean_dec(x_6); -lean_dec(x_5); lean_dec(x_4); -lean_dec(x_3); lean_dec(x_2); -lean_dec(x_1); -x_51 = !lean_is_exclusive(x_17); -if (x_51 == 0) +x_142 = !lean_is_exclusive(x_17); +if (x_142 == 0) { return x_17; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_17, 0); -x_53 = lean_ctor_get(x_17, 1); -lean_inc(x_53); -lean_inc(x_52); +lean_object* x_143; lean_object* x_144; lean_object* x_145; +x_143 = lean_ctor_get(x_17, 0); +x_144 = lean_ctor_get(x_17, 1); +lean_inc(x_144); +lean_inc(x_143); lean_dec(x_17); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; +x_145 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_145, 0, x_143); +lean_ctor_set(x_145, 1, x_144); +return x_145; } } } else { -uint8_t x_55; +uint8_t x_146; lean_dec(x_12); lean_dec(x_11); -lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_2); +x_146 = !lean_is_exclusive(x_14); +if (x_146 == 0) +{ +return x_14; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_147 = lean_ctor_get(x_14, 0); +x_148 = lean_ctor_get(x_14, 1); +lean_inc(x_148); +lean_inc(x_147); +lean_dec(x_14); +x_149 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_149, 0, x_147); +lean_ctor_set(x_149, 1, x_148); +return x_149; +} +} +} +} +lean_object* l_Lean_Elab_Command_mkDef(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; +x_11 = lean_ctor_get(x_1, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_1, 5); +lean_inc(x_12); +lean_inc(x_7); +x_13 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_13, 0, x_7); +x_14 = 1; +x_15 = lean_box(0); +lean_inc(x_9); +x_16 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_14, x_15, x_9, x_10); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +lean_inc(x_9); +lean_inc(x_12); +x_18 = l_Lean_Elab_Term_ensureHasType(x_12, x_13, x_8, x_9, x_17); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; uint8_t x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = 0; +lean_inc(x_9); +x_22 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_21, x_15, x_9, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_28; +x_23 = lean_ctor_get(x_22, 1); +lean_inc(x_23); +lean_dec(x_22); +lean_inc(x_9); +x_24 = l_Lean_Elab_Term_instantiateMVars(x_11, x_7, x_9, x_23); +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +lean_inc(x_9); +x_27 = l_Lean_Elab_Term_instantiateMVars(x_12, x_19, x_9, x_26); +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; uint8_t x_32; +x_29 = lean_ctor_get(x_27, 0); +x_30 = lean_ctor_get(x_27, 1); +x_31 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); +x_32 = l_Lean_Elab_Command_DefKind_isExample(x_31); +if (x_32 == 0) +{ +uint8_t x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +lean_free_object(x_27); +x_33 = l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque(x_31); +x_34 = lean_box(x_31); +lean_inc(x_29); +lean_inc(x_25); +lean_inc(x_6); +lean_inc(x_11); +x_35 = lean_alloc_closure((void*)(l_Lean_Elab_Command_mkDef___lambda__1___boxed), 13, 10); +lean_closure_set(x_35, 0, x_11); +lean_closure_set(x_35, 1, x_6); +lean_closure_set(x_35, 2, x_25); +lean_closure_set(x_35, 3, x_29); +lean_closure_set(x_35, 4, x_12); +lean_closure_set(x_35, 5, x_3); +lean_closure_set(x_35, 6, x_4); +lean_closure_set(x_35, 7, x_34); +lean_closure_set(x_35, 8, x_2); +lean_closure_set(x_35, 9, x_1); +x_36 = l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(x_11, x_5, x_6, x_29, x_25, x_33, x_35, x_9, x_30); +lean_dec(x_6); +lean_dec(x_11); +return x_36; +} +else +{ +lean_object* x_37; +lean_dec(x_29); +lean_dec(x_25); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_37 = lean_box(0); +lean_ctor_set(x_27, 0, x_37); +return x_27; +} +} +else +{ +lean_object* x_38; lean_object* x_39; uint8_t x_40; uint8_t x_41; +x_38 = lean_ctor_get(x_27, 0); +x_39 = lean_ctor_get(x_27, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_27); +x_40 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); +x_41 = l_Lean_Elab_Command_DefKind_isExample(x_40); +if (x_41 == 0) +{ +uint8_t x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_42 = l_Lean_Elab_Command_DefKind_isDefOrAbbrevOrOpaque(x_40); +x_43 = lean_box(x_40); +lean_inc(x_38); +lean_inc(x_25); +lean_inc(x_6); +lean_inc(x_11); +x_44 = lean_alloc_closure((void*)(l_Lean_Elab_Command_mkDef___lambda__1___boxed), 13, 10); +lean_closure_set(x_44, 0, x_11); +lean_closure_set(x_44, 1, x_6); +lean_closure_set(x_44, 2, x_25); +lean_closure_set(x_44, 3, x_38); +lean_closure_set(x_44, 4, x_12); +lean_closure_set(x_44, 5, x_3); +lean_closure_set(x_44, 6, x_4); +lean_closure_set(x_44, 7, x_43); +lean_closure_set(x_44, 8, x_2); +lean_closure_set(x_44, 9, x_1); +x_45 = l___private_Lean_Elab_Definition_2__withUsedWhen___rarg(x_11, x_5, x_6, x_38, x_25, x_42, x_44, x_9, x_39); +lean_dec(x_6); +lean_dec(x_11); +return x_45; +} +else +{ +lean_object* x_46; lean_object* x_47; +lean_dec(x_38); +lean_dec(x_25); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_46 = lean_box(0); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_39); +return x_47; +} +} +} +else +{ +uint8_t x_48; +lean_dec(x_19); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_48 = !lean_is_exclusive(x_22); +if (x_48 == 0) +{ +return x_22; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_22, 0); +x_50 = lean_ctor_get(x_22, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_22); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +else +{ +uint8_t x_52; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_52 = !lean_is_exclusive(x_18); +if (x_52 == 0) +{ +return x_18; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_18, 0); +x_54 = lean_ctor_get(x_18, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_18); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; +} +} +} +else +{ +uint8_t x_56; +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); @@ -2094,38 +1308,38 @@ lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_55 = !lean_is_exclusive(x_15); -if (x_55 == 0) +x_56 = !lean_is_exclusive(x_16); +if (x_56 == 0) { -return x_15; +return x_16; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_15, 0); -x_57 = lean_ctor_get(x_15, 1); +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_16, 0); +x_58 = lean_ctor_get(x_16, 1); +lean_inc(x_58); lean_inc(x_57); -lean_inc(x_56); -lean_dec(x_15); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_56); -lean_ctor_set(x_58, 1, x_57); -return x_58; +lean_dec(x_16); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } } } -lean_object* l_Lean_Elab_Command_mkDef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +lean_object* l_Lean_Elab_Command_mkDef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { _start: { -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_7); -lean_dec(x_7); -x_14 = l_Lean_Elab_Command_mkDef___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_13, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); +uint8_t x_14; lean_object* x_15; +x_14 = lean_unbox(x_8); +lean_dec(x_8); +x_15 = l_Lean_Elab_Command_mkDef___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_14, x_9, x_10, x_11, x_12, x_13); +lean_dec(x_10); lean_dec(x_5); lean_dec(x_1); -return x_14; +return x_15; } } lean_object* _init_l_Lean_Elab_Command_elabDefVal___closed__1() { @@ -2203,4613 +1417,1118 @@ return x_17; } } } -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; uint8_t x_8; -lean_dec(x_1); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_5, 2); -lean_dec(x_9); -x_10 = l_Lean_Elab_Command_modifyScope___closed__1; -x_11 = l_unreachable_x21___rarg(x_10); -lean_ctor_set(x_5, 2, x_11); -x_12 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_7); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 0); -lean_dec(x_14); -x_15 = lean_box(0); -lean_ctor_set(x_12, 0, x_15); -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 1); -lean_inc(x_16); -lean_dec(x_12); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -return x_12; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_12, 0); -x_21 = lean_ctor_get(x_12, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_12); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; 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_23 = lean_ctor_get(x_5, 0); -x_24 = lean_ctor_get(x_5, 1); -x_25 = lean_ctor_get(x_5, 3); -x_26 = lean_ctor_get(x_5, 4); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_5); -x_27 = l_Lean_Elab_Command_modifyScope___closed__1; -x_28 = l_unreachable_x21___rarg(x_27); -x_29 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -x_30 = l___private_Lean_Elab_Command_3__setState(x_29, x_2, x_7); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_30, 1); -lean_inc(x_31); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_32 = x_30; -} else { - lean_dec_ref(x_30); - x_32 = lean_box(0); -} -x_33 = lean_box(0); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 2, 0); -} else { - x_34 = x_32; -} -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 1); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - x_37 = x_30; -} else { - lean_dec_ref(x_30); - x_37 = lean_box(0); -} -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(1, 2, 0); -} else { - x_38 = x_37; -} -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -return x_38; -} -} -} -else -{ -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_6, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_4, 1); -lean_inc(x_40); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_5); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_5, 2); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_6); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_6, 0); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_39); -if (x_45 == 0) -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_39, 5); -lean_dec(x_46); -lean_ctor_set(x_39, 5, x_1); -x_47 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_47) == 0) -{ -uint8_t x_48; -x_48 = !lean_is_exclusive(x_47); -if (x_48 == 0) -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 0); -lean_dec(x_49); -x_50 = lean_box(0); -lean_ctor_set(x_47, 0, x_50); -return x_47; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_47, 1); -lean_inc(x_51); -lean_dec(x_47); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_51); -return x_53; -} -} -else -{ -uint8_t x_54; -x_54 = !lean_is_exclusive(x_47); -if (x_54 == 0) -{ -return x_47; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_47, 0); -x_56 = lean_ctor_get(x_47, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_47); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -lean_object* x_58; 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_58 = lean_ctor_get(x_39, 0); -x_59 = lean_ctor_get(x_39, 1); -x_60 = lean_ctor_get(x_39, 2); -x_61 = lean_ctor_get(x_39, 3); -x_62 = lean_ctor_get(x_39, 4); -x_63 = lean_ctor_get(x_39, 6); -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_39); -x_64 = lean_alloc_ctor(0, 7, 0); -lean_ctor_set(x_64, 0, x_58); -lean_ctor_set(x_64, 1, x_59); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_1); -lean_ctor_set(x_64, 6, x_63); -lean_ctor_set(x_6, 0, x_64); -x_65 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_67 = x_65; -} else { - lean_dec_ref(x_65); - x_67 = lean_box(0); -} -x_68 = lean_box(0); -if (lean_is_scalar(x_67)) { - x_69 = lean_alloc_ctor(0, 2, 0); -} else { - x_69 = x_67; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_66); -return x_69; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_70 = lean_ctor_get(x_65, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_65, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_72 = x_65; -} else { - lean_dec_ref(x_65); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(1, 2, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -return x_73; -} -} -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_74 = lean_ctor_get(x_6, 1); -lean_inc(x_74); -lean_dec(x_6); -x_75 = lean_ctor_get(x_39, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_39, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_39, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_39, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_39, 6); -lean_inc(x_80); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_81 = x_39; -} else { - lean_dec_ref(x_39); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 7, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_75); -lean_ctor_set(x_82, 1, x_76); -lean_ctor_set(x_82, 2, x_77); -lean_ctor_set(x_82, 3, x_78); -lean_ctor_set(x_82, 4, x_79); -lean_ctor_set(x_82, 5, x_1); -lean_ctor_set(x_82, 6, x_80); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_5, 2, x_83); -x_84 = l___private_Lean_Elab_Command_3__setState(x_5, x_2, x_40); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_86 = x_84; -} else { - lean_dec_ref(x_84); - x_86 = lean_box(0); -} -x_87 = lean_box(0); -if (lean_is_scalar(x_86)) { - x_88 = lean_alloc_ctor(0, 2, 0); -} else { - x_88 = x_86; -} -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_84, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_91 = x_84; -} else { - lean_dec_ref(x_84); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(1, 2, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -return x_92; -} -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 3); -x_96 = lean_ctor_get(x_5, 4); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_98 = x_6; -} else { - lean_dec_ref(x_6); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_39, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_39, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_39, 2); -lean_inc(x_101); -x_102 = lean_ctor_get(x_39, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_39, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_39, 6); -lean_inc(x_104); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - lean_ctor_release(x_39, 6); - x_105 = x_39; -} else { - lean_dec_ref(x_39); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 7, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_99); -lean_ctor_set(x_106, 1, x_100); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_1); -lean_ctor_set(x_106, 6, x_104); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_97); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_93); -lean_ctor_set(x_108, 1, x_94); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_95); -lean_ctor_set(x_108, 4, x_96); -x_109 = l___private_Lean_Elab_Command_3__setState(x_108, x_2, x_40); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_110 = lean_ctor_get(x_109, 1); -lean_inc(x_110); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_111 = x_109; -} else { - lean_dec_ref(x_109); - x_111 = lean_box(0); -} -x_112 = lean_box(0); -if (lean_is_scalar(x_111)) { - x_113 = lean_alloc_ctor(0, 2, 0); -} else { - x_113 = x_111; -} -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_110); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_114 = lean_ctor_get(x_109, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_116 = x_109; -} else { - lean_dec_ref(x_109); - x_116 = lean_box(0); -} -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(1, 2, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -return x_117; -} -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_2); -lean_dec(x_1); -x_118 = !lean_is_exclusive(x_4); -if (x_118 == 0) -{ -return x_4; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_4, 0); -x_120 = lean_ctor_get(x_4, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_4); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -} -} -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_2); -x_8 = lean_nat_dec_lt(x_3, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_5); -lean_dec(x_3); -x_9 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_9, 0, x_4); -lean_ctor_set(x_9, 1, x_6); -return x_9; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_10 = lean_array_fget(x_2, x_3); -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_add(x_3, x_11); -lean_dec(x_3); -x_13 = l_Lean_Syntax_getId(x_10); -x_14 = l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(x_13, x_4); -if (x_14 == 0) -{ -lean_object* x_15; -lean_dec(x_10); -x_15 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_4); -x_3 = x_12; -x_4 = x_15; -goto _start; -} -else -{ -lean_object* x_17; uint8_t x_18; -lean_dec(x_12); -lean_dec(x_4); -x_17 = l_Lean_Elab_Command_throwAlreadyDeclaredUniverseLevel___rarg(x_10, x_13, x_5, x_6); -lean_dec(x_10); -x_18 = !lean_is_exclusive(x_17); -if (x_18 == 0) -{ -return x_17; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_19 = lean_ctor_get(x_17, 0); -x_20 = lean_ctor_get(x_17, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_17); -x_21 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_21, 0, x_19); -lean_ctor_set(x_21, 1, x_20); -return x_21; -} -} -} -} -} -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; -x_9 = lean_ctor_get(x_1, 5); -lean_inc(x_9); -lean_inc(x_7); -lean_inc(x_2); -x_10 = l_Lean_Elab_Command_elabDefVal(x_9, x_2, x_7, x_8); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l_Lean_Elab_Command_mkDef(x_1, x_3, x_4, x_6, x_5, x_2, x_11, x_7, x_12); -return x_13; -} -else -{ -uint8_t x_14; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_14 = !lean_is_exclusive(x_10); -if (x_14 == 0) -{ -return x_10; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_10, 0); -x_16 = lean_ctor_get(x_10, 1); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_10); -x_17 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_17, 0, x_15); -lean_ctor_set(x_17, 1, x_16); -return x_17; -} -} -} -} -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -x_10 = lean_ctor_get(x_1, 4); +lean_object* x_10; lean_object* x_11; +x_10 = lean_ctor_get(x_1, 5); lean_inc(x_10); -if (lean_obj_tag(x_10) == 0) -{ -uint8_t x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_11 = 0; -x_12 = lean_box(0); lean_inc(x_8); -x_13 = l_Lean_Elab_Term_mkFreshTypeMVar(x_2, x_11, x_12, x_8, x_9); -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_16 = lean_ctor_get(x_1, 5); -lean_inc(x_16); -lean_inc(x_8); -lean_inc(x_14); -x_17 = l_Lean_Elab_Command_elabDefVal(x_16, x_14, x_8, x_15); -if (lean_obj_tag(x_17) == 0) +lean_inc(x_2); +x_11 = l_Lean_Elab_Command_elabDefVal(x_10, x_2, x_8, x_9); +if (lean_obj_tag(x_11) == 0) { -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -x_20 = l_Lean_Elab_Command_mkDef(x_1, x_3, x_4, x_5, x_7, x_14, x_18, x_8, x_19); -return x_20; +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); +x_14 = l_Lean_Elab_Command_mkDef(x_1, x_3, x_4, x_5, x_7, x_6, x_2, x_12, x_8, x_13); +return x_14; } else { -uint8_t x_21; -lean_dec(x_14); +uint8_t x_15; lean_dec(x_8); lean_dec(x_7); +lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); +lean_dec(x_2); lean_dec(x_1); -x_21 = !lean_is_exclusive(x_17); -if (x_21 == 0) +x_15 = !lean_is_exclusive(x_11); +if (x_15 == 0) { -return x_17; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_17, 0); -x_23 = lean_ctor_get(x_17, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_17); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -lean_object* x_25; lean_object* x_26; -x_25 = lean_ctor_get(x_10, 0); -lean_inc(x_25); -lean_dec(x_10); -lean_inc(x_8); -lean_inc(x_25); -x_26 = l_Lean_Elab_Term_elabType(x_25, x_8, x_9); -if (lean_obj_tag(x_26) == 0) -{ -lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; -x_27 = lean_ctor_get(x_26, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_26, 1); -lean_inc(x_28); -lean_dec(x_26); -x_29 = 0; -x_30 = lean_box(0); -lean_inc(x_8); -x_31 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_29, x_30, x_8, x_28); -if (lean_obj_tag(x_31) == 0) -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; uint8_t x_37; lean_object* x_38; lean_object* x_39; -x_32 = lean_ctor_get(x_31, 1); -lean_inc(x_32); -lean_dec(x_31); -lean_inc(x_8); -x_33 = l_Lean_Elab_Term_instantiateMVars(x_25, x_27, x_8, x_32); -lean_dec(x_25); -x_34 = lean_ctor_get(x_33, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_33, 1); -lean_inc(x_35); -lean_dec(x_33); -x_36 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); -x_37 = l_Lean_Elab_Command_DefKind_isTheorem(x_36); -lean_inc(x_7); -lean_inc(x_34); -x_38 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__1), 8, 5); -lean_closure_set(x_38, 0, x_1); -lean_closure_set(x_38, 1, x_34); -lean_closure_set(x_38, 2, x_3); -lean_closure_set(x_38, 3, x_4); -lean_closure_set(x_38, 4, x_7); -x_39 = l_Lean_Elab_Command_withUsedWhen_x27___rarg(x_6, x_5, x_7, x_34, x_37, x_38, x_8, x_35); -lean_dec(x_7); -return x_39; -} -else -{ -uint8_t x_40; -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_40 = !lean_is_exclusive(x_31); -if (x_40 == 0) -{ -return x_31; -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_31, 0); -x_42 = lean_ctor_get(x_31, 1); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_31); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_41); -lean_ctor_set(x_43, 1, x_42); -return x_43; -} -} -} -else -{ -uint8_t x_44; -lean_dec(x_25); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_44 = !lean_is_exclusive(x_26); -if (x_44 == 0) -{ -return x_26; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_26, 0); -x_46 = lean_ctor_get(x_26, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_26); -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; -} -} -} -} -} -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_8 = lean_ctor_get(x_1, 3); -lean_inc(x_8); -x_9 = l_Lean_Syntax_getArgs(x_8); -x_10 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__2___boxed), 9, 6); -lean_closure_set(x_10, 0, x_1); -lean_closure_set(x_10, 1, x_8); -lean_closure_set(x_10, 2, x_2); -lean_closure_set(x_10, 3, x_3); -lean_closure_set(x_10, 4, x_5); -lean_closure_set(x_10, 5, x_4); -x_11 = l_Lean_Elab_Term_elabBinders___rarg(x_9, x_10, x_6, x_7); -lean_dec(x_9); return x_11; } +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_11, 0); +x_17 = lean_ctor_get(x_11, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_11); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; } -lean_object* l_Lean_Elab_Command_elabDefLike(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +} +} +} +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_4 = lean_ctor_get(x_1, 0); -lean_inc(x_4); -x_5 = lean_ctor_get(x_1, 2); -lean_inc(x_5); -x_6 = l_Lean_Elab_Command_expandDeclId(x_5); -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -lean_inc(x_2); -x_9 = l_Lean_Elab_Command_getLevelNames(x_2, x_3); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_407; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); +lean_object* x_11; +x_11 = lean_ctor_get(x_1, 4); lean_inc(x_11); -lean_dec(x_9); -x_407 = l_Lean_Syntax_isNone(x_8); -if (x_407 == 0) +if (lean_obj_tag(x_11) == 0) { -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; -x_408 = lean_unsigned_to_nat(1u); -x_409 = l_Lean_Syntax_getArg(x_8, x_408); -x_410 = l_Lean_Syntax_getArgs(x_409); -lean_dec(x_409); -x_411 = lean_unsigned_to_nat(2u); -x_412 = lean_unsigned_to_nat(0u); -x_413 = l_Array_empty___closed__1; -x_414 = l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1(x_411, x_410, x_412, x_413); -lean_dec(x_410); -lean_inc(x_2); -lean_inc(x_10); -x_415 = l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5(x_8, x_414, x_412, x_10, x_2, x_11); -lean_dec(x_414); -lean_dec(x_8); -if (lean_obj_tag(x_415) == 0) -{ -lean_object* x_416; lean_object* x_417; -x_416 = lean_ctor_get(x_415, 0); -lean_inc(x_416); -x_417 = lean_ctor_get(x_415, 1); -lean_inc(x_417); -lean_dec(x_415); -x_12 = x_416; -x_13 = x_417; -goto block_406; -} -else -{ -uint8_t x_418; -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_418 = !lean_is_exclusive(x_415); -if (x_418 == 0) -{ -return x_415; -} -else -{ -lean_object* x_419; lean_object* x_420; lean_object* x_421; -x_419 = lean_ctor_get(x_415, 0); -x_420 = lean_ctor_get(x_415, 1); -lean_inc(x_420); -lean_inc(x_419); -lean_dec(x_415); -x_421 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_421, 0, x_419); -lean_ctor_set(x_421, 1, x_420); -return x_421; -} -} -} -else -{ -lean_dec(x_8); -lean_inc(x_10); -x_12 = x_10; -x_13 = x_11; -goto block_406; -} -block_406: -{ -lean_object* x_14; lean_object* x_15; -x_14 = l_Lean_extractMacroScopes(x_7); +uint8_t 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; +x_12 = 0; +x_13 = lean_box(0); +lean_inc(x_9); +x_14 = l_Lean_Elab_Term_mkFreshTypeMVar(x_2, x_12, x_13, x_9, x_10); x_15 = lean_ctor_get(x_14, 0); lean_inc(x_15); -if (lean_obj_tag(x_15) == 1) +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +x_17 = lean_ctor_get(x_1, 5); +lean_inc(x_17); +lean_inc(x_9); +lean_inc(x_15); +x_18 = l_Lean_Elab_Command_elabDefVal(x_17, x_15, x_9, x_16); +if (lean_obj_tag(x_18) == 0) { -uint8_t x_16; -x_16 = !lean_is_exclusive(x_14); -if (x_16 == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_75; lean_object* x_76; lean_object* x_87; uint8_t x_88; lean_object* x_89; -x_17 = lean_ctor_get(x_14, 0); -lean_dec(x_17); -x_18 = lean_ctor_get(x_15, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_15, 1); +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_18, 0); lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_Elab_Command_mkDef(x_1, x_3, x_4, x_5, x_6, x_8, x_15, x_19, x_9, x_20); +return x_21; +} +else +{ +uint8_t x_22; lean_dec(x_15); -x_20 = lean_box(0); -x_21 = lean_name_mk_string(x_20, x_19); -lean_ctor_set(x_14, 0, x_21); -x_22 = l_Lean_MacroScopesView_review(x_14); -x_87 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; -x_88 = 1; -lean_inc(x_2); -lean_inc(x_18); -x_89 = l___private_Lean_Elab_Command_12__addScopes___main(x_5, x_87, x_88, x_18, x_2, x_13); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); lean_dec(x_5); -if (lean_obj_tag(x_89) == 0) -{ -lean_object* x_90; lean_object* x_91; -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -lean_dec(x_89); -lean_inc(x_2); -x_91 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__4(x_12, x_2, x_90); -if (lean_obj_tag(x_91) == 0) -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_91, 1); -lean_inc(x_92); -lean_dec(x_91); -x_93 = lean_ctor_get(x_1, 1); -lean_inc(x_93); -lean_inc(x_2); -x_94 = l_Lean_Elab_Command_mkDeclName(x_93, x_22, x_2, x_92); -if (lean_obj_tag(x_94) == 0) -{ -lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_123; -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_ctor_get(x_93, 1); -lean_inc(x_97); -lean_dec(x_93); -lean_inc(x_2); -lean_inc(x_95); -x_123 = l_Lean_Elab_Command_checkNotAlreadyDeclared(x_4, x_95, x_2, x_96); -if (lean_obj_tag(x_123) == 0) -{ -lean_object* x_124; uint8_t x_125; lean_object* x_126; lean_object* x_127; -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -lean_dec(x_123); -x_125 = 2; -x_126 = lean_unsigned_to_nat(0u); -lean_inc(x_2); -lean_inc(x_95); -x_127 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_95, x_125, x_97, x_126, x_2, x_124); -if (lean_obj_tag(x_127) == 0) -{ -lean_object* x_128; lean_object* x_129; -x_128 = lean_ctor_get(x_127, 1); -lean_inc(x_128); -lean_dec(x_127); -lean_inc(x_2); -x_129 = l_Lean_Elab_Command_getLevelNames(x_2, x_128); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_130 = lean_ctor_get(x_129, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_129, 1); -lean_inc(x_131); -lean_dec(x_129); -lean_inc(x_95); -x_132 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_132, 0, x_95); -lean_inc(x_4); -lean_inc(x_95); -x_133 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__3), 7, 4); -lean_closure_set(x_133, 0, x_1); -lean_closure_set(x_133, 1, x_95); -lean_closure_set(x_133, 2, x_130); -lean_closure_set(x_133, 3, x_4); -lean_inc(x_2); -x_134 = l___private_Lean_Elab_Command_2__getState(x_2, x_131); -if (lean_obj_tag(x_134) == 0) -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -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 = l___private_Lean_Elab_Command_9__getVarDecls(x_135); -lean_dec(x_135); -lean_inc(x_2); -x_138 = l___private_Lean_Elab_Command_2__getState(x_2, x_136); -if (lean_obj_tag(x_138) == 0) -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; -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); -x_141 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_139, x_132); -x_142 = l___private_Lean_Elab_Command_7__mkTermState(x_139); -lean_dec(x_139); -x_143 = l_Lean_Elab_Term_elabBinders___rarg(x_137, x_133, x_141, x_142); -lean_dec(x_137); -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); -lean_inc(x_2); -x_146 = l___private_Lean_Elab_Command_2__getState(x_2, x_140); -if (lean_obj_tag(x_146) == 0) -{ -lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; uint8_t x_152; -x_147 = lean_ctor_get(x_145, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_146, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_146, 1); -lean_inc(x_149); -lean_dec(x_146); -x_150 = lean_ctor_get(x_147, 0); -lean_inc(x_150); -lean_dec(x_147); -x_151 = lean_ctor_get(x_145, 2); -lean_inc(x_151); -lean_dec(x_145); -x_152 = !lean_is_exclusive(x_148); -if (x_152 == 0) -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_153 = lean_ctor_get(x_148, 1); -lean_dec(x_153); -x_154 = lean_ctor_get(x_148, 0); -lean_dec(x_154); -lean_ctor_set(x_148, 1, x_151); -lean_ctor_set(x_148, 0, x_150); -lean_inc(x_2); -x_155 = l___private_Lean_Elab_Command_3__setState(x_148, x_2, x_149); -if (lean_obj_tag(x_155) == 0) -{ -lean_object* x_156; -x_156 = lean_ctor_get(x_155, 1); -lean_inc(x_156); -lean_dec(x_155); -x_98 = x_144; -x_99 = x_156; -goto block_122; -} -else -{ -lean_object* x_157; lean_object* x_158; -lean_dec(x_144); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_157 = lean_ctor_get(x_155, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_155, 1); -lean_inc(x_158); -lean_dec(x_155); -x_75 = x_157; -x_76 = x_158; -goto block_86; -} -} -else -{ -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_159 = lean_ctor_get(x_148, 2); -x_160 = lean_ctor_get(x_148, 3); -x_161 = lean_ctor_get(x_148, 4); -lean_inc(x_161); -lean_inc(x_160); -lean_inc(x_159); -lean_dec(x_148); -x_162 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_162, 0, x_150); -lean_ctor_set(x_162, 1, x_151); -lean_ctor_set(x_162, 2, x_159); -lean_ctor_set(x_162, 3, x_160); -lean_ctor_set(x_162, 4, x_161); -lean_inc(x_2); -x_163 = l___private_Lean_Elab_Command_3__setState(x_162, x_2, x_149); -if (lean_obj_tag(x_163) == 0) -{ -lean_object* x_164; -x_164 = lean_ctor_get(x_163, 1); -lean_inc(x_164); -lean_dec(x_163); -x_98 = x_144; -x_99 = x_164; -goto block_122; -} -else -{ -lean_object* x_165; lean_object* x_166; -lean_dec(x_144); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_165 = lean_ctor_get(x_163, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_163, 1); -lean_inc(x_166); -lean_dec(x_163); -x_75 = x_165; -x_76 = x_166; -goto block_86; -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; -lean_dec(x_145); -lean_dec(x_144); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_167 = lean_ctor_get(x_146, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_146, 1); -lean_inc(x_168); -lean_dec(x_146); -x_75 = x_167; -x_76 = x_168; -goto block_86; -} -} -else -{ -lean_object* x_169; -x_169 = lean_ctor_get(x_143, 0); -lean_inc(x_169); -if (lean_obj_tag(x_169) == 0) -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_170 = lean_ctor_get(x_143, 1); -lean_inc(x_170); -lean_dec(x_143); -x_171 = lean_ctor_get(x_169, 0); -lean_inc(x_171); -lean_dec(x_169); -lean_inc(x_2); -x_172 = l___private_Lean_Elab_Command_2__getState(x_2, x_140); -if (lean_obj_tag(x_172) == 0) -{ -lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; uint8_t x_178; -x_173 = lean_ctor_get(x_170, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_172, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 1); -lean_inc(x_175); -lean_dec(x_172); -x_176 = lean_ctor_get(x_173, 0); -lean_inc(x_176); -lean_dec(x_173); -x_177 = lean_ctor_get(x_170, 2); -lean_inc(x_177); -lean_dec(x_170); -x_178 = !lean_is_exclusive(x_174); -if (x_178 == 0) -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_179 = lean_ctor_get(x_174, 1); -lean_dec(x_179); -x_180 = lean_ctor_get(x_174, 0); -lean_dec(x_180); -lean_ctor_set(x_174, 1, x_177); -lean_ctor_set(x_174, 0, x_176); -lean_inc(x_2); -x_181 = l___private_Lean_Elab_Command_3__setState(x_174, x_2, x_175); -if (lean_obj_tag(x_181) == 0) -{ -lean_object* x_182; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -lean_dec(x_181); -x_75 = x_171; -x_76 = x_182; -goto block_86; -} -else -{ -lean_object* x_183; lean_object* x_184; -lean_dec(x_171); -x_183 = lean_ctor_get(x_181, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 1); -lean_inc(x_184); -lean_dec(x_181); -x_75 = x_183; -x_76 = x_184; -goto block_86; -} -} -else -{ -lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; -x_185 = lean_ctor_get(x_174, 2); -x_186 = lean_ctor_get(x_174, 3); -x_187 = lean_ctor_get(x_174, 4); -lean_inc(x_187); -lean_inc(x_186); -lean_inc(x_185); -lean_dec(x_174); -x_188 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_188, 0, x_176); -lean_ctor_set(x_188, 1, x_177); -lean_ctor_set(x_188, 2, x_185); -lean_ctor_set(x_188, 3, x_186); -lean_ctor_set(x_188, 4, x_187); -lean_inc(x_2); -x_189 = l___private_Lean_Elab_Command_3__setState(x_188, x_2, x_175); -if (lean_obj_tag(x_189) == 0) -{ -lean_object* x_190; -x_190 = lean_ctor_get(x_189, 1); -lean_inc(x_190); -lean_dec(x_189); -x_75 = x_171; -x_76 = x_190; -goto block_86; -} -else -{ -lean_object* x_191; lean_object* x_192; -lean_dec(x_171); -x_191 = lean_ctor_get(x_189, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_189, 1); -lean_inc(x_192); -lean_dec(x_189); -x_75 = x_191; -x_76 = x_192; -goto block_86; -} -} -} -else -{ -lean_object* x_193; lean_object* x_194; -lean_dec(x_171); -lean_dec(x_170); -x_193 = lean_ctor_get(x_172, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_172, 1); -lean_inc(x_194); -lean_dec(x_172); -x_75 = x_193; -x_76 = x_194; -goto block_86; -} -} -else -{ -lean_object* x_195; lean_object* x_196; lean_object* x_197; -lean_dec(x_143); -x_195 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_196 = l_unreachable_x21___rarg(x_195); -lean_inc(x_2); -x_197 = lean_apply_2(x_196, x_2, x_140); -if (lean_obj_tag(x_197) == 0) -{ -lean_object* x_198; lean_object* x_199; -x_198 = lean_ctor_get(x_197, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_197, 1); -lean_inc(x_199); -lean_dec(x_197); -x_98 = x_198; -x_99 = x_199; -goto block_122; -} -else -{ -lean_object* x_200; lean_object* x_201; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_200 = lean_ctor_get(x_197, 0); -lean_inc(x_200); -x_201 = lean_ctor_get(x_197, 1); -lean_inc(x_201); -lean_dec(x_197); -x_75 = x_200; -x_76 = x_201; -goto block_86; -} -} -} -} -else -{ -lean_object* x_202; lean_object* x_203; -lean_dec(x_137); -lean_dec(x_133); -lean_dec(x_132); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_202 = lean_ctor_get(x_138, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_138, 1); -lean_inc(x_203); -lean_dec(x_138); -x_75 = x_202; -x_76 = x_203; -goto block_86; -} -} -else -{ -lean_object* x_204; lean_object* x_205; -lean_dec(x_133); -lean_dec(x_132); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_204 = lean_ctor_get(x_134, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_134, 1); -lean_inc(x_205); -lean_dec(x_134); -x_75 = x_204; -x_76 = x_205; -goto block_86; -} -} -else -{ -lean_object* x_206; lean_object* x_207; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); lean_dec(x_4); +lean_dec(x_3); lean_dec(x_1); -x_206 = lean_ctor_get(x_129, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_129, 1); -lean_inc(x_207); -lean_dec(x_129); -x_75 = x_206; -x_76 = x_207; -goto block_86; -} +x_22 = !lean_is_exclusive(x_18); +if (x_22 == 0) +{ +return x_18; } else { -lean_object* x_208; lean_object* x_209; -lean_dec(x_97); -lean_dec(x_95); +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_18, 0); +x_24 = lean_ctor_get(x_18, 1); +lean_inc(x_24); +lean_inc(x_23); lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_1); -x_208 = lean_ctor_get(x_127, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_127, 1); -lean_inc(x_209); -lean_dec(x_127); -x_75 = x_208; -x_76 = x_209; -goto block_86; -} -} -else -{ -lean_object* x_210; lean_object* x_211; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_1); -x_210 = lean_ctor_get(x_123, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_123, 1); -lean_inc(x_211); -lean_dec(x_123); -x_75 = x_210; -x_76 = x_211; -goto block_86; -} -block_122: -{ -if (lean_obj_tag(x_98) == 0) -{ -lean_object* x_100; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_4); -x_100 = lean_box(0); -x_23 = x_100; -x_24 = x_99; -goto block_74; -} -else -{ -lean_object* x_101; lean_object* x_102; -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -lean_dec(x_98); -lean_inc(x_2); -x_102 = l_Lean_Elab_Command_addDecl(x_4, x_101, x_2, x_99); -if (lean_obj_tag(x_102) == 0) -{ -lean_object* x_103; uint8_t x_104; lean_object* x_105; lean_object* x_106; -x_103 = lean_ctor_get(x_102, 1); -lean_inc(x_103); -lean_dec(x_102); -x_104 = 0; -x_105 = lean_unsigned_to_nat(0u); -lean_inc(x_2); -lean_inc(x_95); -x_106 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_95, x_104, x_97, x_105, x_2, x_103); -if (lean_obj_tag(x_106) == 0) -{ -lean_object* x_107; lean_object* x_108; -x_107 = lean_ctor_get(x_106, 1); -lean_inc(x_107); -lean_dec(x_106); -lean_inc(x_2); -x_108 = l_Lean_Elab_Command_compileDecl(x_4, x_101, x_2, x_107); -lean_dec(x_101); -if (lean_obj_tag(x_108) == 0) -{ -lean_object* x_109; uint8_t x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_108, 1); -lean_inc(x_109); -lean_dec(x_108); -x_110 = 1; -lean_inc(x_2); -x_111 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_95, x_110, x_97, x_105, x_2, x_109); -lean_dec(x_97); -lean_dec(x_4); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; -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_23 = x_112; -x_24 = x_113; -goto block_74; -} -else -{ -lean_object* x_114; lean_object* x_115; -lean_dec(x_18); -x_114 = lean_ctor_get(x_111, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_111, 1); -lean_inc(x_115); -lean_dec(x_111); -x_75 = x_114; -x_76 = x_115; -goto block_86; -} -} -else -{ -lean_object* x_116; lean_object* x_117; -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_116 = lean_ctor_get(x_108, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_108, 1); -lean_inc(x_117); -lean_dec(x_108); -x_75 = x_116; -x_76 = x_117; -goto block_86; -} -} -else -{ -lean_object* x_118; lean_object* x_119; -lean_dec(x_101); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_118 = lean_ctor_get(x_106, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_106, 1); -lean_inc(x_119); -lean_dec(x_106); -x_75 = x_118; -x_76 = x_119; -goto block_86; -} -} -else -{ -lean_object* x_120; lean_object* x_121; -lean_dec(x_101); -lean_dec(x_97); -lean_dec(x_95); -lean_dec(x_18); -lean_dec(x_4); -x_120 = lean_ctor_get(x_102, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_102, 1); -lean_inc(x_121); -lean_dec(x_102); -x_75 = x_120; -x_76 = x_121; -goto block_86; -} -} -} -} -else -{ -lean_object* x_212; lean_object* x_213; -lean_dec(x_93); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_1); -x_212 = lean_ctor_get(x_94, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_94, 1); -lean_inc(x_213); -lean_dec(x_94); -x_75 = x_212; -x_76 = x_213; -goto block_86; -} -} -else -{ -uint8_t x_214; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_214 = !lean_is_exclusive(x_91); -if (x_214 == 0) -{ -return x_91; -} -else -{ -lean_object* x_215; lean_object* x_216; lean_object* x_217; -x_215 = lean_ctor_get(x_91, 0); -x_216 = lean_ctor_get(x_91, 1); -lean_inc(x_216); -lean_inc(x_215); -lean_dec(x_91); -x_217 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_217, 0, x_215); -lean_ctor_set(x_217, 1, x_216); -return x_217; +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; } } } else { -uint8_t x_218; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_218 = !lean_is_exclusive(x_89); -if (x_218 == 0) -{ -return x_89; -} -else -{ -lean_object* x_219; lean_object* x_220; lean_object* x_221; -x_219 = lean_ctor_get(x_89, 0); -x_220 = lean_ctor_get(x_89, 1); -lean_inc(x_220); -lean_inc(x_219); -lean_dec(x_89); -x_221 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_221, 0, x_219); -lean_ctor_set(x_221, 1, x_220); -return x_221; -} -} -block_74: -{ -lean_object* x_25; -lean_inc(x_2); -lean_inc(x_10); -x_25 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__1(x_10, x_2, x_24); -if (lean_obj_tag(x_25) == 0) -{ lean_object* x_26; lean_object* x_27; -lean_dec(x_10); -x_26 = lean_ctor_get(x_25, 1); +x_26 = lean_ctor_get(x_11, 0); lean_inc(x_26); -lean_dec(x_25); -lean_inc(x_2); -x_27 = l___private_Lean_Elab_Command_2__getState(x_2, x_26); +lean_dec(x_11); +lean_inc(x_9); +lean_inc(x_26); +x_27 = l_Lean_Elab_Term_elabType(x_26, x_9, x_10); if (lean_obj_tag(x_27) == 0) { -lean_object* x_28; lean_object* x_29; uint8_t x_30; +lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_object* x_31; lean_object* x_32; x_28 = lean_ctor_get(x_27, 0); lean_inc(x_28); x_29 = lean_ctor_get(x_27, 1); lean_inc(x_29); lean_dec(x_27); -x_30 = !lean_is_exclusive(x_28); -if (x_30 == 0) +x_30 = 0; +x_31 = lean_box(0); +lean_inc(x_9); +x_32 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_30, x_31, x_9, x_29); +if (lean_obj_tag(x_32) == 0) { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_28, 2); -x_32 = l_Lean_Name_getNumParts___main(x_18); -lean_dec(x_18); -x_33 = l_List_drop___main___rarg(x_32, x_31); -lean_dec(x_31); -lean_ctor_set(x_28, 2, x_33); -x_34 = l___private_Lean_Elab_Command_3__setState(x_28, x_2, x_29); -if (lean_obj_tag(x_34) == 0) -{ -uint8_t x_35; -x_35 = !lean_is_exclusive(x_34); -if (x_35 == 0) -{ -lean_object* x_36; -x_36 = lean_ctor_get(x_34, 0); -lean_dec(x_36); -lean_ctor_set(x_34, 0, x_23); -return x_34; -} -else -{ -lean_object* x_37; lean_object* x_38; -x_37 = lean_ctor_get(x_34, 1); -lean_inc(x_37); +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; uint8_t x_38; lean_object* x_39; lean_object* x_40; +x_33 = lean_ctor_get(x_32, 1); +lean_inc(x_33); +lean_dec(x_32); +lean_inc(x_9); +x_34 = l_Lean_Elab_Term_instantiateMVars(x_26, x_28, x_9, x_33); +lean_dec(x_26); +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); lean_dec(x_34); -x_38 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_38, 0, x_23); -lean_ctor_set(x_38, 1, x_37); -return x_38; -} +x_37 = lean_ctor_get_uint8(x_1, sizeof(void*)*6); +x_38 = l_Lean_Elab_Command_DefKind_isTheorem(x_37); +lean_inc(x_8); +lean_inc(x_35); +x_39 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__1), 9, 6); +lean_closure_set(x_39, 0, x_1); +lean_closure_set(x_39, 1, x_35); +lean_closure_set(x_39, 2, x_3); +lean_closure_set(x_39, 3, x_4); +lean_closure_set(x_39, 4, x_5); +lean_closure_set(x_39, 5, x_8); +x_40 = l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg(x_7, x_6, x_8, x_35, x_38, x_39, x_9, x_36); +lean_dec(x_8); +return x_40; } else { -uint8_t x_39; -lean_dec(x_23); -x_39 = !lean_is_exclusive(x_34); -if (x_39 == 0) -{ -return x_34; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_34, 0); -x_41 = lean_ctor_get(x_34, 1); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_34); -x_42 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -return x_42; -} -} -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_43 = lean_ctor_get(x_28, 0); -x_44 = lean_ctor_get(x_28, 1); -x_45 = lean_ctor_get(x_28, 2); -x_46 = lean_ctor_get(x_28, 3); -x_47 = lean_ctor_get(x_28, 4); -lean_inc(x_47); -lean_inc(x_46); -lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); +uint8_t x_41; lean_dec(x_28); -x_48 = l_Lean_Name_getNumParts___main(x_18); -lean_dec(x_18); -x_49 = l_List_drop___main___rarg(x_48, x_45); -lean_dec(x_45); -x_50 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_50, 0, x_43); -lean_ctor_set(x_50, 1, x_44); -lean_ctor_set(x_50, 2, x_49); -lean_ctor_set(x_50, 3, x_46); -lean_ctor_set(x_50, 4, x_47); -x_51 = l___private_Lean_Elab_Command_3__setState(x_50, x_2, x_29); -if (lean_obj_tag(x_51) == 0) +lean_dec(x_26); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_41 = !lean_is_exclusive(x_32); +if (x_41 == 0) { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 1); -lean_inc(x_52); -if (lean_is_exclusive(x_51)) { - lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - x_53 = x_51; -} else { - lean_dec_ref(x_51); - x_53 = lean_box(0); -} -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(0, 2, 0); -} else { - x_54 = x_53; -} -lean_ctor_set(x_54, 0, x_23); -lean_ctor_set(x_54, 1, x_52); -return x_54; +return x_32; } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -lean_dec(x_23); -x_55 = lean_ctor_get(x_51, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_51, 1); -lean_inc(x_56); -if (lean_is_exclusive(x_51)) { - lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - x_57 = x_51; -} else { - lean_dec_ref(x_51); - x_57 = lean_box(0); -} -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(1, 2, 0); -} else { - x_58 = x_57; -} -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -return x_58; +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_32, 0); +x_43 = lean_ctor_get(x_32, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_32); +x_44 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_44, 0, x_42); +lean_ctor_set(x_44, 1, x_43); +return x_44; } } } else { -uint8_t x_59; -lean_dec(x_23); -lean_dec(x_18); -lean_dec(x_2); -x_59 = !lean_is_exclusive(x_27); -if (x_59 == 0) +uint8_t x_45; +lean_dec(x_26); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_45 = !lean_is_exclusive(x_27); +if (x_45 == 0) { return x_27; } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_27, 0); -x_61 = lean_ctor_get(x_27, 1); -lean_inc(x_61); -lean_inc(x_60); +lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_27, 0); +x_47 = lean_ctor_get(x_27, 1); +lean_inc(x_47); +lean_inc(x_46); lean_dec(x_27); -x_62 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_62, 0, x_60); -lean_ctor_set(x_62, 1, x_61); -return x_62; +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_46); +lean_ctor_set(x_48, 1, x_47); +return x_48; } } } -else +} +} +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: { -lean_object* x_63; lean_object* x_64; lean_object* x_65; -lean_dec(x_23); -lean_dec(x_18); -x_63 = lean_ctor_get(x_25, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_25, 1); -lean_inc(x_64); -lean_dec(x_25); -x_65 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__2(x_10, x_2, x_64); -if (lean_obj_tag(x_65) == 0) -{ -uint8_t x_66; -x_66 = !lean_is_exclusive(x_65); -if (x_66 == 0) -{ -lean_object* x_67; -x_67 = lean_ctor_get(x_65, 0); -lean_dec(x_67); -lean_ctor_set_tag(x_65, 1); -lean_ctor_set(x_65, 0, x_63); -return x_65; -} -else -{ -lean_object* x_68; lean_object* x_69; -x_68 = lean_ctor_get(x_65, 1); -lean_inc(x_68); -lean_dec(x_65); -x_69 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_69, 0, x_63); -lean_ctor_set(x_69, 1, x_68); -return x_69; -} -} -else -{ -uint8_t x_70; -lean_dec(x_63); -x_70 = !lean_is_exclusive(x_65); -if (x_70 == 0) -{ -return x_65; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_65, 0); -x_72 = lean_ctor_get(x_65, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_65); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -block_86: -{ -lean_object* x_77; -x_77 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__3(x_10, x_2, x_76); -if (lean_obj_tag(x_77) == 0) -{ -uint8_t x_78; -x_78 = !lean_is_exclusive(x_77); -if (x_78 == 0) -{ -lean_object* x_79; -x_79 = lean_ctor_get(x_77, 0); -lean_dec(x_79); -lean_ctor_set_tag(x_77, 1); -lean_ctor_set(x_77, 0, x_75); -return x_77; -} -else -{ -lean_object* x_80; lean_object* x_81; -x_80 = lean_ctor_get(x_77, 1); -lean_inc(x_80); -lean_dec(x_77); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_75); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -else -{ -uint8_t x_82; -lean_dec(x_75); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -return x_77; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_77, 0); -x_84 = lean_ctor_get(x_77, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_77); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -} -else -{ -lean_object* x_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_270; lean_object* x_271; lean_object* x_281; uint8_t x_282; lean_object* x_283; -x_222 = lean_ctor_get(x_14, 1); -x_223 = lean_ctor_get(x_14, 2); -x_224 = lean_ctor_get(x_14, 3); -lean_inc(x_224); -lean_inc(x_223); -lean_inc(x_222); -lean_dec(x_14); -x_225 = lean_ctor_get(x_15, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_15, 1); -lean_inc(x_226); -lean_dec(x_15); -x_227 = lean_box(0); -x_228 = lean_name_mk_string(x_227, x_226); -x_229 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_229, 0, x_228); -lean_ctor_set(x_229, 1, x_222); -lean_ctor_set(x_229, 2, x_223); -lean_ctor_set(x_229, 3, x_224); -x_230 = l_Lean_MacroScopesView_review(x_229); -x_281 = l_Lean_Parser_Command_namespace___elambda__1___closed__1; -x_282 = 1; -lean_inc(x_2); -lean_inc(x_225); -x_283 = l___private_Lean_Elab_Command_12__addScopes___main(x_5, x_281, x_282, x_225, x_2, x_13); -lean_dec(x_5); -if (lean_obj_tag(x_283) == 0) -{ -lean_object* x_284; lean_object* x_285; -x_284 = lean_ctor_get(x_283, 1); -lean_inc(x_284); -lean_dec(x_283); -lean_inc(x_2); -x_285 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__4(x_12, x_2, x_284); -if (lean_obj_tag(x_285) == 0) -{ -lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_286 = lean_ctor_get(x_285, 1); -lean_inc(x_286); -lean_dec(x_285); -x_287 = lean_ctor_get(x_1, 1); -lean_inc(x_287); -lean_inc(x_2); -x_288 = l_Lean_Elab_Command_mkDeclName(x_287, x_230, x_2, x_286); -if (lean_obj_tag(x_288) == 0) -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_317; -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_ctor_get(x_287, 1); -lean_inc(x_291); -lean_dec(x_287); -lean_inc(x_2); -lean_inc(x_289); -x_317 = l_Lean_Elab_Command_checkNotAlreadyDeclared(x_4, x_289, x_2, x_290); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; uint8_t x_319; lean_object* x_320; lean_object* x_321; -x_318 = lean_ctor_get(x_317, 1); -lean_inc(x_318); -lean_dec(x_317); -x_319 = 2; -x_320 = lean_unsigned_to_nat(0u); -lean_inc(x_2); -lean_inc(x_289); -x_321 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_289, x_319, x_291, x_320, x_2, x_318); -if (lean_obj_tag(x_321) == 0) -{ -lean_object* x_322; lean_object* x_323; -x_322 = lean_ctor_get(x_321, 1); -lean_inc(x_322); -lean_dec(x_321); -lean_inc(x_2); -x_323 = l_Lean_Elab_Command_getLevelNames(x_2, x_322); -if (lean_obj_tag(x_323) == 0) -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; -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); -lean_inc(x_289); -x_326 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_326, 0, x_289); -lean_inc(x_4); -lean_inc(x_289); -x_327 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__3), 7, 4); -lean_closure_set(x_327, 0, x_1); -lean_closure_set(x_327, 1, x_289); -lean_closure_set(x_327, 2, x_324); -lean_closure_set(x_327, 3, x_4); -lean_inc(x_2); -x_328 = l___private_Lean_Elab_Command_2__getState(x_2, x_325); -if (lean_obj_tag(x_328) == 0) -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; -x_329 = lean_ctor_get(x_328, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_328, 1); -lean_inc(x_330); -lean_dec(x_328); -x_331 = l___private_Lean_Elab_Command_9__getVarDecls(x_329); -lean_dec(x_329); -lean_inc(x_2); -x_332 = l___private_Lean_Elab_Command_2__getState(x_2, x_330); -if (lean_obj_tag(x_332) == 0) -{ -lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; -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 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_333, x_326); -x_336 = l___private_Lean_Elab_Command_7__mkTermState(x_333); -lean_dec(x_333); -x_337 = l_Lean_Elab_Term_elabBinders___rarg(x_331, x_327, x_335, x_336); -lean_dec(x_331); -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); -lean_inc(x_2); -x_340 = l___private_Lean_Elab_Command_2__getState(x_2, x_334); -if (lean_obj_tag(x_340) == 0) -{ -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_341 = lean_ctor_get(x_339, 0); -lean_inc(x_341); -x_342 = lean_ctor_get(x_340, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_340, 1); -lean_inc(x_343); -lean_dec(x_340); -x_344 = lean_ctor_get(x_341, 0); -lean_inc(x_344); -lean_dec(x_341); -x_345 = lean_ctor_get(x_339, 2); -lean_inc(x_345); -lean_dec(x_339); -x_346 = lean_ctor_get(x_342, 2); -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); -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); - x_349 = x_342; -} else { - lean_dec_ref(x_342); - x_349 = lean_box(0); -} -if (lean_is_scalar(x_349)) { - x_350 = lean_alloc_ctor(0, 5, 0); -} else { - x_350 = x_349; -} -lean_ctor_set(x_350, 0, x_344); -lean_ctor_set(x_350, 1, x_345); -lean_ctor_set(x_350, 2, x_346); -lean_ctor_set(x_350, 3, x_347); -lean_ctor_set(x_350, 4, x_348); -lean_inc(x_2); -x_351 = l___private_Lean_Elab_Command_3__setState(x_350, x_2, x_343); -if (lean_obj_tag(x_351) == 0) -{ -lean_object* x_352; -x_352 = lean_ctor_get(x_351, 1); -lean_inc(x_352); -lean_dec(x_351); -x_292 = x_338; -x_293 = x_352; -goto block_316; -} -else -{ -lean_object* x_353; lean_object* x_354; -lean_dec(x_338); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_353 = lean_ctor_get(x_351, 0); -lean_inc(x_353); -x_354 = lean_ctor_get(x_351, 1); -lean_inc(x_354); -lean_dec(x_351); -x_270 = x_353; -x_271 = x_354; -goto block_280; -} -} -else -{ -lean_object* x_355; lean_object* x_356; -lean_dec(x_339); -lean_dec(x_338); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_355 = lean_ctor_get(x_340, 0); -lean_inc(x_355); -x_356 = lean_ctor_get(x_340, 1); -lean_inc(x_356); -lean_dec(x_340); -x_270 = x_355; -x_271 = x_356; -goto block_280; -} -} -else -{ -lean_object* x_357; -x_357 = lean_ctor_get(x_337, 0); -lean_inc(x_357); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_358 = lean_ctor_get(x_337, 1); -lean_inc(x_358); -lean_dec(x_337); -x_359 = lean_ctor_get(x_357, 0); -lean_inc(x_359); -lean_dec(x_357); -lean_inc(x_2); -x_360 = l___private_Lean_Elab_Command_2__getState(x_2, x_334); -if (lean_obj_tag(x_360) == 0) -{ -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_361 = lean_ctor_get(x_358, 0); -lean_inc(x_361); -x_362 = lean_ctor_get(x_360, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_360, 1); -lean_inc(x_363); -lean_dec(x_360); -x_364 = lean_ctor_get(x_361, 0); -lean_inc(x_364); -lean_dec(x_361); -x_365 = lean_ctor_get(x_358, 2); -lean_inc(x_365); -lean_dec(x_358); -x_366 = lean_ctor_get(x_362, 2); -lean_inc(x_366); -x_367 = lean_ctor_get(x_362, 3); -lean_inc(x_367); -x_368 = lean_ctor_get(x_362, 4); -lean_inc(x_368); -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_369 = x_362; -} else { - lean_dec_ref(x_362); - 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_364); -lean_ctor_set(x_370, 1, x_365); -lean_ctor_set(x_370, 2, x_366); -lean_ctor_set(x_370, 3, x_367); -lean_ctor_set(x_370, 4, x_368); -lean_inc(x_2); -x_371 = l___private_Lean_Elab_Command_3__setState(x_370, x_2, x_363); -if (lean_obj_tag(x_371) == 0) -{ -lean_object* x_372; -x_372 = lean_ctor_get(x_371, 1); -lean_inc(x_372); -lean_dec(x_371); -x_270 = x_359; -x_271 = x_372; -goto block_280; -} -else -{ -lean_object* x_373; lean_object* x_374; -lean_dec(x_359); -x_373 = lean_ctor_get(x_371, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_371, 1); -lean_inc(x_374); -lean_dec(x_371); -x_270 = x_373; -x_271 = x_374; -goto block_280; -} -} -else -{ -lean_object* x_375; lean_object* x_376; -lean_dec(x_359); -lean_dec(x_358); -x_375 = lean_ctor_get(x_360, 0); -lean_inc(x_375); -x_376 = lean_ctor_get(x_360, 1); -lean_inc(x_376); -lean_dec(x_360); -x_270 = x_375; -x_271 = x_376; -goto block_280; -} -} -else -{ -lean_object* x_377; lean_object* x_378; lean_object* x_379; -lean_dec(x_337); -x_377 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; -x_378 = l_unreachable_x21___rarg(x_377); -lean_inc(x_2); -x_379 = lean_apply_2(x_378, x_2, x_334); -if (lean_obj_tag(x_379) == 0) -{ -lean_object* x_380; lean_object* x_381; -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_292 = x_380; -x_293 = x_381; -goto block_316; -} -else -{ -lean_object* x_382; lean_object* x_383; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_382 = lean_ctor_get(x_379, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_379, 1); -lean_inc(x_383); -lean_dec(x_379); -x_270 = x_382; -x_271 = x_383; -goto block_280; -} -} -} -} -else -{ -lean_object* x_384; lean_object* x_385; -lean_dec(x_331); -lean_dec(x_327); -lean_dec(x_326); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_384 = lean_ctor_get(x_332, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_332, 1); -lean_inc(x_385); -lean_dec(x_332); -x_270 = x_384; -x_271 = x_385; -goto block_280; -} -} -else -{ -lean_object* x_386; lean_object* x_387; -lean_dec(x_327); -lean_dec(x_326); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_386 = lean_ctor_get(x_328, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_328, 1); -lean_inc(x_387); -lean_dec(x_328); -x_270 = x_386; -x_271 = x_387; -goto block_280; -} -} -else -{ -lean_object* x_388; lean_object* x_389; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -lean_dec(x_1); -x_388 = lean_ctor_get(x_323, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_323, 1); -lean_inc(x_389); -lean_dec(x_323); -x_270 = x_388; -x_271 = x_389; -goto block_280; -} -} -else -{ -lean_object* x_390; lean_object* x_391; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -lean_dec(x_1); -x_390 = lean_ctor_get(x_321, 0); -lean_inc(x_390); -x_391 = lean_ctor_get(x_321, 1); -lean_inc(x_391); -lean_dec(x_321); -x_270 = x_390; -x_271 = x_391; -goto block_280; -} -} -else -{ -lean_object* x_392; lean_object* x_393; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -lean_dec(x_1); -x_392 = lean_ctor_get(x_317, 0); -lean_inc(x_392); -x_393 = lean_ctor_get(x_317, 1); -lean_inc(x_393); -lean_dec(x_317); -x_270 = x_392; -x_271 = x_393; -goto block_280; -} -block_316: -{ -if (lean_obj_tag(x_292) == 0) -{ -lean_object* x_294; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_4); -x_294 = lean_box(0); -x_231 = x_294; -x_232 = x_293; -goto block_269; -} -else -{ -lean_object* x_295; lean_object* x_296; -x_295 = lean_ctor_get(x_292, 0); -lean_inc(x_295); -lean_dec(x_292); -lean_inc(x_2); -x_296 = l_Lean_Elab_Command_addDecl(x_4, x_295, x_2, x_293); -if (lean_obj_tag(x_296) == 0) -{ -lean_object* x_297; uint8_t x_298; lean_object* x_299; lean_object* x_300; -x_297 = lean_ctor_get(x_296, 1); -lean_inc(x_297); -lean_dec(x_296); -x_298 = 0; -x_299 = lean_unsigned_to_nat(0u); -lean_inc(x_2); -lean_inc(x_289); -x_300 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_289, x_298, x_291, x_299, x_2, x_297); -if (lean_obj_tag(x_300) == 0) -{ -lean_object* x_301; lean_object* x_302; -x_301 = lean_ctor_get(x_300, 1); -lean_inc(x_301); -lean_dec(x_300); -lean_inc(x_2); -x_302 = l_Lean_Elab_Command_compileDecl(x_4, x_295, x_2, x_301); -lean_dec(x_295); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; uint8_t x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 1); -lean_inc(x_303); -lean_dec(x_302); -x_304 = 1; -lean_inc(x_2); -x_305 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_4, x_289, x_304, x_291, x_299, x_2, x_303); -lean_dec(x_291); -lean_dec(x_4); -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_231 = x_306; -x_232 = x_307; -goto block_269; -} -else -{ -lean_object* x_308; lean_object* x_309; -lean_dec(x_225); -x_308 = lean_ctor_get(x_305, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_305, 1); -lean_inc(x_309); -lean_dec(x_305); -x_270 = x_308; -x_271 = x_309; -goto block_280; -} -} -else -{ -lean_object* x_310; lean_object* x_311; -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_310 = lean_ctor_get(x_302, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_302, 1); -lean_inc(x_311); -lean_dec(x_302); -x_270 = x_310; -x_271 = x_311; -goto block_280; -} -} -else -{ -lean_object* x_312; lean_object* x_313; -lean_dec(x_295); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_312 = lean_ctor_get(x_300, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_300, 1); -lean_inc(x_313); -lean_dec(x_300); -x_270 = x_312; -x_271 = x_313; -goto block_280; -} -} -else -{ -lean_object* x_314; lean_object* x_315; -lean_dec(x_295); -lean_dec(x_291); -lean_dec(x_289); -lean_dec(x_225); -lean_dec(x_4); -x_314 = lean_ctor_get(x_296, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_296, 1); -lean_inc(x_315); -lean_dec(x_296); -x_270 = x_314; -x_271 = x_315; -goto block_280; -} -} -} -} -else -{ -lean_object* x_394; lean_object* x_395; -lean_dec(x_287); -lean_dec(x_225); -lean_dec(x_4); -lean_dec(x_1); -x_394 = lean_ctor_get(x_288, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_288, 1); -lean_inc(x_395); -lean_dec(x_288); -x_270 = x_394; -x_271 = x_395; -goto block_280; -} -} -else -{ -lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; -lean_dec(x_230); -lean_dec(x_225); +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_9 = lean_ctor_get(x_1, 3); +lean_inc(x_9); +x_10 = l_Lean_Syntax_getArgs(x_9); +x_11 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__2___boxed), 10, 7); +lean_closure_set(x_11, 0, x_1); +lean_closure_set(x_11, 1, x_9); +lean_closure_set(x_11, 2, x_2); +lean_closure_set(x_11, 3, x_3); +lean_closure_set(x_11, 4, x_4); +lean_closure_set(x_11, 5, x_6); +lean_closure_set(x_11, 6, x_5); +x_12 = l_Lean_Elab_Term_elabBinders___rarg(x_10, x_11, x_7, x_8); lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_396 = lean_ctor_get(x_285, 0); -lean_inc(x_396); -x_397 = lean_ctor_get(x_285, 1); -lean_inc(x_397); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - x_398 = x_285; -} else { - lean_dec_ref(x_285); - x_398 = lean_box(0); -} -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(1, 2, 0); -} else { - x_399 = x_398; -} -lean_ctor_set(x_399, 0, x_396); -lean_ctor_set(x_399, 1, x_397); -return x_399; +return x_12; } } -else +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: { -lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; -lean_dec(x_230); -lean_dec(x_225); -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_400 = lean_ctor_get(x_283, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_283, 1); -lean_inc(x_401); -if (lean_is_exclusive(x_283)) { - lean_ctor_release(x_283, 0); - lean_ctor_release(x_283, 1); - x_402 = x_283; -} else { - lean_dec_ref(x_283); - x_402 = lean_box(0); -} -if (lean_is_scalar(x_402)) { - x_403 = lean_alloc_ctor(1, 2, 0); -} else { - x_403 = x_402; -} -lean_ctor_set(x_403, 0, x_400); -lean_ctor_set(x_403, 1, x_401); -return x_403; -} -block_269: +lean_object* x_8; lean_object* x_9; +x_8 = lean_ctor_get(x_1, 1); +lean_inc(x_8); +lean_inc(x_6); +x_9 = l_Lean_Elab_Command_mkDeclName(x_2, x_8, x_5, x_6, x_7); +if (lean_obj_tag(x_9) == 0) { -lean_object* x_233; -lean_inc(x_2); +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_42; lean_object* x_43; lean_object* x_44; +x_10 = lean_ctor_get(x_9, 0); lean_inc(x_10); -x_233 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__1(x_10, x_2, x_232); -if (lean_obj_tag(x_233) == 0) +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +if (lean_is_exclusive(x_9)) { + lean_ctor_release(x_9, 0); + lean_ctor_release(x_9, 1); + x_12 = x_9; +} else { + lean_dec_ref(x_9); + x_12 = lean_box(0); +} +x_13 = lean_ctor_get(x_8, 1); +lean_inc(x_13); +lean_dec(x_8); +x_42 = 2; +x_43 = lean_unsigned_to_nat(0u); +lean_inc(x_6); +lean_inc(x_10); +x_44 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_10, x_42, x_13, x_43, x_6, x_11); +if (lean_obj_tag(x_44) == 0) { -lean_object* x_234; lean_object* x_235; -lean_dec(x_10); -x_234 = lean_ctor_get(x_233, 1); -lean_inc(x_234); -lean_dec(x_233); -lean_inc(x_2); -x_235 = l___private_Lean_Elab_Command_2__getState(x_2, x_234); -if (lean_obj_tag(x_235) == 0) +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_44, 1); +lean_inc(x_45); +lean_dec(x_44); +lean_inc(x_6); +x_46 = l_Lean_Elab_Command_getLevelNames(x_6, x_45); +if (lean_obj_tag(x_46) == 0) { -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_236 = lean_ctor_get(x_235, 0); -lean_inc(x_236); -x_237 = lean_ctor_get(x_235, 1); -lean_inc(x_237); -lean_dec(x_235); -x_238 = lean_ctor_get(x_236, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_236, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_236, 2); -lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 3); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 4); -lean_inc(x_242); -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); - x_243 = x_236; -} else { - lean_dec_ref(x_236); - x_243 = lean_box(0); -} -x_244 = l_Lean_Name_getNumParts___main(x_225); -lean_dec(x_225); -x_245 = l_List_drop___main___rarg(x_244, x_240); -lean_dec(x_240); -if (lean_is_scalar(x_243)) { - x_246 = lean_alloc_ctor(0, 5, 0); -} else { - x_246 = x_243; -} -lean_ctor_set(x_246, 0, x_238); -lean_ctor_set(x_246, 1, x_239); -lean_ctor_set(x_246, 2, x_245); -lean_ctor_set(x_246, 3, x_241); -lean_ctor_set(x_246, 4, x_242); -x_247 = l___private_Lean_Elab_Command_3__setState(x_246, x_2, x_237); -if (lean_obj_tag(x_247) == 0) +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +lean_inc(x_10); +x_49 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_49, 0, x_10); +lean_inc(x_3); +lean_inc(x_10); +x_50 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__3), 8, 5); +lean_closure_set(x_50, 0, x_1); +lean_closure_set(x_50, 1, x_10); +lean_closure_set(x_50, 2, x_4); +lean_closure_set(x_50, 3, x_47); +lean_closure_set(x_50, 4, x_3); +lean_inc(x_6); +x_51 = l___private_Lean_Elab_Command_2__getState(x_6, x_48); +if (lean_obj_tag(x_51) == 0) { -lean_object* x_248; lean_object* x_249; lean_object* x_250; -x_248 = lean_ctor_get(x_247, 1); -lean_inc(x_248); -if (lean_is_exclusive(x_247)) { - lean_ctor_release(x_247, 0); - lean_ctor_release(x_247, 1); - x_249 = x_247; -} else { - lean_dec_ref(x_247); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 2, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_231); -lean_ctor_set(x_250, 1, x_248); -return x_250; +lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +x_54 = l___private_Lean_Elab_Command_9__getVarDecls(x_52); +lean_dec(x_52); +lean_inc(x_6); +x_55 = l___private_Lean_Elab_Command_2__getState(x_6, x_53); +if (lean_obj_tag(x_55) == 0) +{ +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_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = l___private_Lean_Elab_Command_6__mkTermContext(x_6, x_56, x_49); +x_59 = l___private_Lean_Elab_Command_7__mkTermState(x_56); +lean_dec(x_56); +x_60 = l_Lean_Elab_Term_elabBinders___rarg(x_54, x_50, x_58, x_59); +lean_dec(x_54); +if (lean_obj_tag(x_60) == 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); +lean_inc(x_6); +x_63 = l___private_Lean_Elab_Command_2__getState(x_6, x_57); +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; uint8_t x_69; +x_64 = lean_ctor_get(x_62, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_63, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_63, 1); +lean_inc(x_66); +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_62, 2); +lean_inc(x_68); +lean_dec(x_62); +x_69 = !lean_is_exclusive(x_65); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_65, 1); +lean_dec(x_70); +x_71 = lean_ctor_get(x_65, 0); +lean_dec(x_71); +lean_ctor_set(x_65, 1, x_68); +lean_ctor_set(x_65, 0, x_67); +lean_inc(x_6); +x_72 = l___private_Lean_Elab_Command_3__setState(x_65, x_6, x_66); +if (lean_obj_tag(x_72) == 0) +{ +lean_object* x_73; +x_73 = lean_ctor_get(x_72, 1); +lean_inc(x_73); +lean_dec(x_72); +x_14 = x_61; +x_15 = x_73; +goto block_41; } else { -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; -lean_dec(x_231); -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -if (lean_is_exclusive(x_247)) { - lean_ctor_release(x_247, 0); - lean_ctor_release(x_247, 1); - x_253 = x_247; -} else { - lean_dec_ref(x_247); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_251); -lean_ctor_set(x_254, 1, x_252); -return x_254; -} -} -else -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; -lean_dec(x_231); -lean_dec(x_225); -lean_dec(x_2); -x_255 = lean_ctor_get(x_235, 0); -lean_inc(x_255); -x_256 = lean_ctor_get(x_235, 1); -lean_inc(x_256); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_257 = x_235; -} else { - lean_dec_ref(x_235); - x_257 = lean_box(0); -} -if (lean_is_scalar(x_257)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_257; -} -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -return x_258; -} -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; -lean_dec(x_231); -lean_dec(x_225); -x_259 = lean_ctor_get(x_233, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_233, 1); -lean_inc(x_260); -lean_dec(x_233); -x_261 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__2(x_10, x_2, x_260); -if (lean_obj_tag(x_261) == 0) -{ -lean_object* x_262; lean_object* x_263; lean_object* x_264; -x_262 = lean_ctor_get(x_261, 1); -lean_inc(x_262); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - x_263 = x_261; -} else { - lean_dec_ref(x_261); - 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_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_259); -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_259); -x_265 = lean_ctor_get(x_261, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_261, 1); -lean_inc(x_266); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - x_267 = x_261; -} else { - lean_dec_ref(x_261); - 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_280: -{ -lean_object* x_272; -x_272 = l_Lean_Elab_Command_modifyScope___at_Lean_Elab_Command_elabDefLike___spec__3(x_10, x_2, x_271); -if (lean_obj_tag(x_272) == 0) -{ -lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_273 = lean_ctor_get(x_272, 1); -lean_inc(x_273); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - x_274 = x_272; -} else { - lean_dec_ref(x_272); - x_274 = lean_box(0); -} -if (lean_is_scalar(x_274)) { - x_275 = lean_alloc_ctor(1, 2, 0); -} else { - x_275 = x_274; - lean_ctor_set_tag(x_275, 1); -} -lean_ctor_set(x_275, 0, x_270); -lean_ctor_set(x_275, 1, x_273); -return x_275; -} -else -{ -lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -lean_dec(x_270); -x_276 = lean_ctor_get(x_272, 0); -lean_inc(x_276); -x_277 = lean_ctor_get(x_272, 1); -lean_inc(x_277); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - x_278 = x_272; -} else { - lean_dec_ref(x_272); - x_278 = lean_box(0); -} -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(1, 2, 0); -} else { - x_279 = x_278; -} -lean_ctor_set(x_279, 0, x_276); -lean_ctor_set(x_279, 1, x_277); -return x_279; -} -} -} -} -else -{ -lean_object* x_404; lean_object* x_405; -lean_dec(x_15); -lean_dec(x_14); +uint8_t x_74; +lean_dec(x_61); +lean_dec(x_13); lean_dec(x_12); lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_1); -x_404 = l_Lean_Elab_Command_withDeclId___closed__3; -x_405 = l_Lean_Elab_Command_throwError___rarg(x_5, x_404, x_2, x_13); -lean_dec(x_5); -return x_405; +lean_dec(x_6); +lean_dec(x_3); +x_74 = !lean_is_exclusive(x_72); +if (x_74 == 0) +{ +return x_72; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_72, 0); +x_76 = lean_ctor_get(x_72, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_72); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; } } } else { -uint8_t x_422; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_5); +lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_78 = lean_ctor_get(x_65, 2); +x_79 = lean_ctor_get(x_65, 3); +x_80 = lean_ctor_get(x_65, 4); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_65); +x_81 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_81, 0, x_67); +lean_ctor_set(x_81, 1, x_68); +lean_ctor_set(x_81, 2, x_78); +lean_ctor_set(x_81, 3, x_79); +lean_ctor_set(x_81, 4, x_80); +lean_inc(x_6); +x_82 = l___private_Lean_Elab_Command_3__setState(x_81, x_6, x_66); +if (lean_obj_tag(x_82) == 0) +{ +lean_object* x_83; +x_83 = lean_ctor_get(x_82, 1); +lean_inc(x_83); +lean_dec(x_82); +x_14 = x_61; +x_15 = x_83; +goto block_41; +} +else +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +lean_dec(x_61); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_84 = lean_ctor_get(x_82, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_82, 1); +lean_inc(x_85); +if (lean_is_exclusive(x_82)) { + lean_ctor_release(x_82, 0); + lean_ctor_release(x_82, 1); + x_86 = x_82; +} else { + lean_dec_ref(x_82); + x_86 = lean_box(0); +} +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(1, 2, 0); +} else { + x_87 = x_86; +} +lean_ctor_set(x_87, 0, x_84); +lean_ctor_set(x_87, 1, x_85); +return x_87; +} +} +} +else +{ +uint8_t x_88; +lean_dec(x_62); +lean_dec(x_61); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_88 = !lean_is_exclusive(x_63); +if (x_88 == 0) +{ +return x_63; +} +else +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; +x_89 = lean_ctor_get(x_63, 0); +x_90 = lean_ctor_get(x_63, 1); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_63); +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; +} +} +} +else +{ +lean_object* x_92; +x_92 = lean_ctor_get(x_60, 0); +lean_inc(x_92); +if (lean_obj_tag(x_92) == 0) +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_3); +x_93 = lean_ctor_get(x_60, 1); +lean_inc(x_93); +lean_dec(x_60); +x_94 = lean_ctor_get(x_92, 0); +lean_inc(x_94); +lean_dec(x_92); +lean_inc(x_6); +x_95 = l___private_Lean_Elab_Command_2__getState(x_6, x_57); +if (lean_obj_tag(x_95) == 0) +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; +x_96 = lean_ctor_get(x_93, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_95, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_95, 1); +lean_inc(x_98); +lean_dec(x_95); +x_99 = lean_ctor_get(x_96, 0); +lean_inc(x_99); +lean_dec(x_96); +x_100 = lean_ctor_get(x_93, 2); +lean_inc(x_100); +lean_dec(x_93); +x_101 = !lean_is_exclusive(x_97); +if (x_101 == 0) +{ +lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_102 = lean_ctor_get(x_97, 1); +lean_dec(x_102); +x_103 = lean_ctor_get(x_97, 0); +lean_dec(x_103); +lean_ctor_set(x_97, 1, x_100); +lean_ctor_set(x_97, 0, x_99); +x_104 = l___private_Lean_Elab_Command_3__setState(x_97, x_6, x_98); +if (lean_obj_tag(x_104) == 0) +{ +uint8_t x_105; +x_105 = !lean_is_exclusive(x_104); +if (x_105 == 0) +{ +lean_object* x_106; +x_106 = lean_ctor_get(x_104, 0); +lean_dec(x_106); +lean_ctor_set_tag(x_104, 1); +lean_ctor_set(x_104, 0, x_94); +return x_104; +} +else +{ +lean_object* x_107; lean_object* x_108; +x_107 = lean_ctor_get(x_104, 1); +lean_inc(x_107); +lean_dec(x_104); +x_108 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_108, 0, x_94); +lean_ctor_set(x_108, 1, x_107); +return x_108; +} +} +else +{ +uint8_t x_109; +lean_dec(x_94); +x_109 = !lean_is_exclusive(x_104); +if (x_109 == 0) +{ +return x_104; +} +else +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_104, 0); +x_111 = lean_ctor_get(x_104, 1); +lean_inc(x_111); +lean_inc(x_110); +lean_dec(x_104); +x_112 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_112, 0, x_110); +lean_ctor_set(x_112, 1, x_111); +return x_112; +} +} +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_113 = lean_ctor_get(x_97, 2); +x_114 = lean_ctor_get(x_97, 3); +x_115 = lean_ctor_get(x_97, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_dec(x_97); +x_116 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_116, 0, x_99); +lean_ctor_set(x_116, 1, x_100); +lean_ctor_set(x_116, 2, x_113); +lean_ctor_set(x_116, 3, x_114); +lean_ctor_set(x_116, 4, x_115); +x_117 = l___private_Lean_Elab_Command_3__setState(x_116, x_6, x_98); +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, 1); +lean_inc(x_118); +if (lean_is_exclusive(x_117)) { + lean_ctor_release(x_117, 0); + lean_ctor_release(x_117, 1); + x_119 = x_117; +} else { + lean_dec_ref(x_117); + x_119 = lean_box(0); +} +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(1, 2, 0); +} else { + x_120 = x_119; + lean_ctor_set_tag(x_120, 1); +} +lean_ctor_set(x_120, 0, x_94); +lean_ctor_set(x_120, 1, x_118); +return x_120; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; +lean_dec(x_94); +x_121 = lean_ctor_get(x_117, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_117, 1); +lean_inc(x_122); +if (lean_is_exclusive(x_117)) { + lean_ctor_release(x_117, 0); + lean_ctor_release(x_117, 1); + x_123 = x_117; +} else { + lean_dec_ref(x_117); + x_123 = lean_box(0); +} +if (lean_is_scalar(x_123)) { + x_124 = lean_alloc_ctor(1, 2, 0); +} else { + x_124 = x_123; +} +lean_ctor_set(x_124, 0, x_121); +lean_ctor_set(x_124, 1, x_122); +return x_124; +} +} +} +else +{ +uint8_t x_125; +lean_dec(x_94); +lean_dec(x_93); +lean_dec(x_6); +x_125 = !lean_is_exclusive(x_95); +if (x_125 == 0) +{ +return x_95; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_95, 0); +x_127 = lean_ctor_get(x_95, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_95); +x_128 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +return x_128; +} +} +} +else +{ +lean_object* x_129; lean_object* x_130; lean_object* x_131; +lean_dec(x_60); +x_129 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_130 = l_unreachable_x21___rarg(x_129); +lean_inc(x_6); +x_131 = lean_apply_2(x_130, x_6, x_57); +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_132; lean_object* x_133; +x_132 = lean_ctor_get(x_131, 0); +lean_inc(x_132); +x_133 = lean_ctor_get(x_131, 1); +lean_inc(x_133); +lean_dec(x_131); +x_14 = x_132; +x_15 = x_133; +goto block_41; +} +else +{ +uint8_t x_134; +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_134 = !lean_is_exclusive(x_131); +if (x_134 == 0) +{ +return x_131; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; +x_135 = lean_ctor_get(x_131, 0); +x_136 = lean_ctor_get(x_131, 1); +lean_inc(x_136); +lean_inc(x_135); +lean_dec(x_131); +x_137 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_137, 0, x_135); +lean_ctor_set(x_137, 1, x_136); +return x_137; +} +} +} +} +} +else +{ +uint8_t x_138; +lean_dec(x_54); +lean_dec(x_50); +lean_dec(x_49); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_138 = !lean_is_exclusive(x_55); +if (x_138 == 0) +{ +return x_55; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_139 = lean_ctor_get(x_55, 0); +x_140 = lean_ctor_get(x_55, 1); +lean_inc(x_140); +lean_inc(x_139); +lean_dec(x_55); +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 +{ +uint8_t x_142; +lean_dec(x_50); +lean_dec(x_49); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_142 = !lean_is_exclusive(x_51); +if (x_142 == 0) +{ +return x_51; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; +x_143 = lean_ctor_get(x_51, 0); +x_144 = lean_ctor_get(x_51, 1); +lean_inc(x_144); +lean_inc(x_143); +lean_dec(x_51); +x_145 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_145, 0, x_143); +lean_ctor_set(x_145, 1, x_144); +return x_145; +} +} +} +else +{ +uint8_t x_146; +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_3); lean_dec(x_1); -x_422 = !lean_is_exclusive(x_9); -if (x_422 == 0) +x_146 = !lean_is_exclusive(x_46); +if (x_146 == 0) +{ +return x_46; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_147 = lean_ctor_get(x_46, 0); +x_148 = lean_ctor_get(x_46, 1); +lean_inc(x_148); +lean_inc(x_147); +lean_dec(x_46); +x_149 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_149, 0, x_147); +lean_ctor_set(x_149, 1, x_148); +return x_149; +} +} +} +else +{ +uint8_t x_150; +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_150 = !lean_is_exclusive(x_44); +if (x_150 == 0) +{ +return x_44; +} +else +{ +lean_object* x_151; lean_object* x_152; lean_object* x_153; +x_151 = lean_ctor_get(x_44, 0); +x_152 = lean_ctor_get(x_44, 1); +lean_inc(x_152); +lean_inc(x_151); +lean_dec(x_44); +x_153 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_153, 0, x_151); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +block_41: +{ +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_16; lean_object* x_17; +lean_dec(x_13); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_16 = lean_box(0); +if (lean_is_scalar(x_12)) { + x_17 = lean_alloc_ctor(0, 2, 0); +} else { + x_17 = x_12; +} +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_15); +return x_17; +} +else +{ +lean_object* x_18; lean_object* x_19; +lean_dec(x_12); +x_18 = lean_ctor_get(x_14, 0); +lean_inc(x_18); +lean_dec(x_14); +lean_inc(x_6); +x_19 = l_Lean_Elab_Command_addDecl(x_3, x_18, x_6, x_15); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_19, 1); +lean_inc(x_20); +lean_dec(x_19); +x_21 = 0; +x_22 = lean_unsigned_to_nat(0u); +lean_inc(x_6); +lean_inc(x_10); +x_23 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_10, x_21, x_13, x_22, x_6, x_20); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; lean_object* x_25; +x_24 = lean_ctor_get(x_23, 1); +lean_inc(x_24); +lean_dec(x_23); +lean_inc(x_6); +x_25 = l_Lean_Elab_Command_compileDecl(x_3, x_18, x_6, x_24); +lean_dec(x_18); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; uint8_t x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_25, 1); +lean_inc(x_26); +lean_dec(x_25); +x_27 = 1; +x_28 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_3, x_10, x_27, x_13, x_22, x_6, x_26); +lean_dec(x_13); +lean_dec(x_3); +return x_28; +} +else +{ +uint8_t x_29; +lean_dec(x_13); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_29 = !lean_is_exclusive(x_25); +if (x_29 == 0) +{ +return x_25; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_25, 0); +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_25); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +else +{ +uint8_t x_33; +lean_dec(x_18); +lean_dec(x_13); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_33 = !lean_is_exclusive(x_23); +if (x_33 == 0) +{ +return x_23; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_23, 0); +x_35 = lean_ctor_get(x_23, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_23); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +else +{ +uint8_t x_37; +lean_dec(x_18); +lean_dec(x_13); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +x_37 = !lean_is_exclusive(x_19); +if (x_37 == 0) +{ +return x_19; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_19, 0); +x_39 = lean_ctor_get(x_19, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_19); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_38); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +} +} +else +{ +uint8_t x_154; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_154 = !lean_is_exclusive(x_9); +if (x_154 == 0) { return x_9; } else { -lean_object* x_423; lean_object* x_424; lean_object* x_425; -x_423 = lean_ctor_get(x_9, 0); -x_424 = lean_ctor_get(x_9, 1); -lean_inc(x_424); -lean_inc(x_423); +lean_object* x_155; lean_object* x_156; lean_object* x_157; +x_155 = lean_ctor_get(x_9, 0); +x_156 = lean_ctor_get(x_9, 1); +lean_inc(x_156); +lean_inc(x_155); lean_dec(x_9); -x_425 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_425, 0, x_423); -lean_ctor_set(x_425, 1, x_424); -return x_425; +x_157 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_157, 0, x_155); +lean_ctor_set(x_157, 1, x_156); +return x_157; } } } } -lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Elab_Command_elabDefLike(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_7; -x_7 = l_Array_iterateMAux___main___at_Lean_Elab_Command_elabDefLike___spec__5(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_2); -lean_dec(x_1); -return x_7; -} -} -lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: +lean_object* x_4; lean_object* x_5; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_inc(x_2); +x_5 = l_Lean_Elab_Command_getLevelNames(x_2, x_3); +if (lean_obj_tag(x_5) == 0) { -lean_object* x_10; -x_10 = l_Lean_Elab_Command_elabDefLike___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_6); -lean_dec(x_2); +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +x_8 = lean_ctor_get(x_1, 2); +lean_inc(x_8); +lean_inc(x_8); +x_9 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabDefLike___lambda__4___boxed), 7, 4); +lean_closure_set(x_9, 0, x_1); +lean_closure_set(x_9, 1, x_8); +lean_closure_set(x_9, 2, x_4); +lean_closure_set(x_9, 3, x_6); +x_10 = l_Lean_Elab_Command_withDeclId___rarg(x_8, x_9, x_2, x_7); +lean_dec(x_8); return x_10; } +else +{ +uint8_t x_11; +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_11 = !lean_is_exclusive(x_5); +if (x_11 == 0) +{ +return x_5; } -lean_object* l___private_Lean_Elab_Definition_1__regTraceClasses(lean_object* x_1) { +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_5, 0); +x_13 = lean_ctor_get(x_5, 1); +lean_inc(x_13); +lean_inc(x_12); +lean_dec(x_5); +x_14 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_14, 0, x_12); +lean_ctor_set(x_14, 1, x_13); +return x_14; +} +} +} +} +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +lean_object* x_11; +x_11 = l_Lean_Elab_Command_elabDefLike___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +lean_dec(x_7); +lean_dec(x_2); +return x_11; +} +} +lean_object* l_Lean_Elab_Command_elabDefLike___lambda__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Lean_Elab_Command_elabDefLike___lambda__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +return x_8; +} +} +lean_object* l___private_Lean_Elab_Definition_4__regTraceClasses(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; @@ -6869,7 +2588,7 @@ lean_object* initialize_Init(lean_object*); lean_object* initialize_Std_ShareCommon(lean_object*); lean_object* initialize_Lean_Util_CollectLevelParams(lean_object*); lean_object* initialize_Lean_Util_FoldConsts(lean_object*); -lean_object* initialize_Lean_Util_CollectFVars(lean_object*); +lean_object* initialize_Lean_Elab_CollectFVars(lean_object*); lean_object* initialize_Lean_Elab_DeclModifiers(lean_object*); lean_object* initialize_Lean_Elab_Binders(lean_object*); static bool _G_initialized = false; @@ -6889,7 +2608,7 @@ lean_dec_ref(res); res = initialize_Lean_Util_FoldConsts(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -res = initialize_Lean_Util_CollectFVars(lean_io_mk_world()); +res = initialize_Lean_Elab_CollectFVars(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); res = initialize_Lean_Elab_DeclModifiers(lean_io_mk_world()); @@ -6898,10 +2617,10 @@ lean_dec_ref(res); res = initialize_Lean_Elab_Binders(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l_Lean_Elab_Command_removeUnused___closed__1 = _init_l_Lean_Elab_Command_removeUnused___closed__1(); -lean_mark_persistent(l_Lean_Elab_Command_removeUnused___closed__1); -l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1 = _init_l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1(); -lean_mark_persistent(l_Lean_Elab_Command_withUsedWhen_x27___rarg___closed__1); +l___private_Lean_Elab_Definition_1__removeUnused___closed__1 = _init_l___private_Lean_Elab_Definition_1__removeUnused___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Definition_1__removeUnused___closed__1); +l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1 = _init_l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Definition_3__withUsedWhen_x27___rarg___closed__1); l_Lean_Elab_Command_mkDef___lambda__1___closed__1 = _init_l_Lean_Elab_Command_mkDef___lambda__1___closed__1(); lean_mark_persistent(l_Lean_Elab_Command_mkDef___lambda__1___closed__1); l_Lean_Elab_Command_mkDef___lambda__1___closed__2 = _init_l_Lean_Elab_Command_mkDef___lambda__1___closed__2(); @@ -6920,7 +2639,7 @@ l_Lean_Elab_Command_elabDefVal___closed__2 = _init_l_Lean_Elab_Command_elabDefVa lean_mark_persistent(l_Lean_Elab_Command_elabDefVal___closed__2); l_Lean_Elab_Command_elabDefVal___closed__3 = _init_l_Lean_Elab_Command_elabDefVal___closed__3(); lean_mark_persistent(l_Lean_Elab_Command_elabDefVal___closed__3); -res = l___private_Lean_Elab_Definition_1__regTraceClasses(lean_io_mk_world()); +res = l___private_Lean_Elab_Definition_4__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)); diff --git a/stage0/stdlib/Lean/Elab/Inductive.c b/stage0/stdlib/Lean/Elab/Inductive.c index 53b3d6eca1..f076afe6a5 100644 --- a/stage0/stdlib/Lean/Elab/Inductive.c +++ b/stage0/stdlib/Lean/Elab/Inductive.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Lean.Elab.Inductive -// Imports: Init Lean.Elab.Command Lean.Elab.Definition +// Imports: Init Lean.Util.ReplaceLevel Lean.Util.ReplaceExpr Lean.Util.CollectLevelParams Lean.Util.Constructions Lean.Elab.Command Lean.Elab.CollectFVars Lean.Elab.Definition #include #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -13,41 +13,406 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l_List_toString___at_Lean_Elab_Command_elabInductiveCore___spec__2(lean_object*); -extern lean_object* l_List_repr___rarg___closed__1; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5; +lean_object* l_Lean_Elab_Term_getLevelNames(lean_object*, lean_object*); +lean_object* l_List_reverse___rarg(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3; +extern lean_object* l_Lean_Name_toString___closed__1; +lean_object* lean_expr_update_forall(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_mkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_prod_x3f___closed__2; +lean_object* l_Lean_Elab_Term_removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_cases_on(lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_eq_x3f___closed__2; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1; +lean_object* l_Lean_Elab_Command_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_mkSort(lean_object*); +lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15; +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Array_iterateMAux___main___at_Lean_ppGoal___spec__6___closed__3; +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_unreachable_x21___rarg(lean_object*); +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_elabInductiveCore___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_MessageData_ofList___closed__3; +uint8_t l_USize_decEq(size_t, size_t); +lean_object* lean_array_uget(lean_object*, size_t); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1; +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___closed__1; +lean_object* l_Lean_Elab_Term_inferType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_mdata(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_2__checkNumParams(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_15__isInductiveFamily___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_InductiveView_inhabited; -lean_object* l_Lean_Format_pretty(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabInductiveCore___closed__1; +lean_object* l___private_Lean_Elab_Inductive_30__updateParams___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3; +uint8_t lean_name_eq(lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkForall(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Std_HashMap_inhabited___closed__1; +lean_object* lean_array_uset(lean_object*, size_t, lean_object*); +lean_object* l_Std_HashMapImp_find_x3f___at_Lean_hasOutParams___spec__5(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3; +lean_object* l___private_Lean_Elab_Inductive_29__withUsed(lean_object*); lean_object* l_Lean_Elab_Command_elabInductiveCore(lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; -lean_object* l_Array_umapMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_16__elabCtors(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__5(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_27__traceIndTypes(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_28__removeUnused___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Util_1__mkPanicMessage(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16; +uint8_t l_Lean_Level_hasMVar(lean_object*); +lean_object* lean_dbg_trace(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Command_6__mkTermContext(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Std_HashMapImp_insert___at___private_Lean_MetavarContext_2__visit___spec__3(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_24__collectUniversesFromCtorType___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Command_3__setState(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4; +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_instantiate1(lean_object*, lean_object*); +lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2; +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_string_append(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_elabInductiveCore___closed__2; -extern lean_object* l_String_splitAux___main___closed__1; -extern lean_object* l_List_repr___rarg___closed__3; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3; +lean_object* l___private_Lean_Elab_Inductive_32__mkIndFVar2Const___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_ElabHeaderResult_inhabited; +lean_object* l___private_Lean_Elab_Inductive_35__applyInferMod___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_withLocalContext___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2; +lean_object* l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10; +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2; +lean_object* l___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive(lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9; +lean_object* l___private_Lean_Elab_Term_3__fromMetaState(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); -extern lean_object* l_Array_HasRepr___rarg___closed__1; +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1; +lean_object* l___private_Lean_Elab_Inductive_15__isInductiveFamily(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_ibelow(lean_object*, lean_object*); +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2; +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_whnf(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_CtorView_inhabited; +extern lean_object* l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1; +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___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* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6; +lean_object* l_Lean_Elab_Term_isTypeFormerType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___boxed(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_LocalContext_Inhabited___closed__2; +lean_object* l___private_Lean_Elab_Inductive_17__levelMVarToParamAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_3__checkUnsafe___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_dbgTrace___rarg___closed__1; +lean_object* l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Level_getLevelOffset___main(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main(lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); -lean_object* l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3___boxed(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_List_beq___main___at_Lean_Elab_OpenDecl_HasToString___spec__1(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1; +lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_Inhabited___closed__1; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(lean_object*, lean_object*, lean_object*); +uint8_t lean_nat_dec_eq(lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6; +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1(uint8_t, uint8_t, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2; +uint8_t l_Lean_Level_isParam(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_16__elabCtors___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_below(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_getLevel(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_nat_sub(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux(lean_object*); +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_isType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_heq_x3f___closed__2; +lean_object* l___private_Lean_Elab_Inductive_2__checkNumParams___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_5__mkTypeFor(lean_object*, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_22__addLevel(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Std_PersistentHashMap_find_x21___rarg___closed__2; +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2; +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions(lean_object*, lean_object*, lean_object*); +lean_object* l_List_map___main___at_Lean_Meta_addGlobalInstance___spec__1(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_25__collectUniverses(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); -extern lean_object* l_List_repr___rarg___closed__2; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_32__mkIndFVar2Const(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12; +lean_object* l_Lean_Elab_Term_assignLevelMVar(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2(lean_object*, lean_object*); +lean_object* lean_mk_brec_on(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_elabTermAux___main(lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3; +lean_object* l___private_Lean_Elab_Inductive_24__collectUniversesFromCtorType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3; +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2; +lean_object* lean_name_mk_string(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_List_reprAux___main___rarg___closed__1; -lean_object* l_Lean_Elab_Command_throwError___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Options_empty; +lean_object* l___private_Lean_Elab_Inductive_29__withUsed___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1; +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__3(lean_object*, lean_object*); +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Environment_contains(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(lean_object*, size_t, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_withLocalDecl___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Level_getOffsetAux___main(lean_object*, lean_object*); +lean_object* lean_expr_dbg_to_string(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3; +extern lean_object* l_Lean_Meta_AbstractMVars_abstractExprMVars___main___closed__3; +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1; +lean_object* l___private_Lean_Elab_Inductive_17__levelMVarToParamAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_no_confusion(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_getLocalInsts(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_collectUsedFVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_let(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_isForall(lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2; +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___boxed(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___private_Lean_Elab_Inductive_30__updateParams(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_10__checkHeader(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4; +lean_object* l_Lean_Elab_Command_sortDeclLevelParams(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_proj(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Command_2__getState(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2; +lean_object* l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1; +lean_object* lean_mk_binduction_on(lean_object*, lean_object*); +size_t l_USize_mod(size_t, size_t); +lean_object* l_Lean_Elab_Term_isDefEq(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2; +lean_object* l_Lean_LocalDecl_type(lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4; +lean_object* l___private_Lean_Elab_Inductive_34__mkCtor2InferMod(lean_object*); +lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); +lean_object* l_Lean_Elab_Term_levelMVarToParam_x27(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5; +lean_object* l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___spec__2(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___spec__1(lean_object*, lean_object*); +size_t lean_ptr_addr(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_20__tmpIndParam; +lean_object* l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_34__mkCtor2InferMod___boxed(lean_object*); +uint8_t l_Lean_BinderInfo_beq(uint8_t, uint8_t); +lean_object* l___private_Lean_Elab_Inductive_4__checkLevelNames(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Std_HashMapImp_find_x3f___at___private_Lean_MetavarContext_2__visit___spec__1(lean_object*, lean_object*); +lean_object* l_Lean_mkLevelSucc(lean_object*); +lean_object* l_Lean_Elab_Term_getLCtx(lean_object*, lean_object*); +uint8_t lean_expr_eqv(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4; +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_sort(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_29__withUsed___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Command_7__mkTermState(lean_object*); +uint8_t l_Lean_Level_occurs___main(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_18__levelMVarToParam___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Command_InductiveView_inhabited___closed__1; -lean_object* l_Lean_Elab_Command_InductiveView_inhabited___closed__2; -lean_object* l_Lean_Elab_Command_mkInductive(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Command_mkInductive___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9; +lean_object* l_Lean_Syntax_getArgs(lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1; +extern uint8_t l_Bool_Inhabited; +lean_object* lean_panic_fn(lean_object*, lean_object*); +lean_object* l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_25__collectUniverses___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_ReplaceLevelImpl_initCache; +extern lean_object* l_Std_HashMap_find_x21___rarg___closed__1; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11; +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1; +lean_object* l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(lean_object*, lean_object*); +extern lean_object* l___private_Lean_Elab_Definition_1__removeUnused___closed__1; +uint8_t l_Lean_Expr_isFVar(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Elab_Command_mkDef___lambda__1___closed__5; +lean_object* lean_expr_update_lambda(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Command_9__getVarDecls(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_12__elabHeader(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2; +lean_object* l_Lean_Elab_Command_getEnv(lean_object*, lean_object*); +extern lean_object* l_Lean_TraceState_Inhabited___closed__1; +lean_object* l_Lean_Meta_isExprDefEq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_35__applyInferMod(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1; +lean_object* lean_mk_rec_on(lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2; +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_toList___rarg(lean_object*); -lean_object* l_Lean_Syntax_formatStxAux___main(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_Inhabited; +lean_object* l_Lean_Elab_Command_CtorView_inhabited___closed__1; +lean_object* l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Command_CtorView_inhabited___closed__2; +lean_object* l_Lean_Elab_Term_mkFreshLevelMVar(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(lean_object*, size_t, lean_object*, lean_object*); +lean_object* l_Lean_Level_replace___main(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_elabBinders___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13; +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1; +lean_object* l_Lean_Expr_inferImplicit___main(lean_object*, lean_object*, uint8_t); +lean_object* l___private_Lean_Elab_Inductive_28__removeUnused(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6; lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); -lean_object* l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3(uint8_t, lean_object*); -lean_object* l_Lean_Elab_Command_elabInductiveCore___closed__3; +lean_object* l___private_Lean_Elab_Inductive_18__levelMVarToParam(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_4__checkLevelNames___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Name_toStringWithSep___main(lean_object*, lean_object*); +lean_object* l_Lean_Level_mkNaryMax___main(lean_object*); +lean_object* l_Lean_mkLevelParam(lean_object*); +lean_object* lean_expr_update_app(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8; +uint8_t lean_level_eq(lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_indentExpr(lean_object*); +lean_object* l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(lean_object*, lean_object*, size_t, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1; +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Term_2__fromMetaException(lean_object*, lean_object*, lean_object*); +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1; +lean_object* l_Lean_mkConst(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_instantiateLevelMVars(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1___boxed(lean_object*, lean_object*); +lean_object* l_Std_HashMapImp_insert___at_Lean_ClassState_addEntry___spec__6(lean_object*, lean_object*, uint8_t); +lean_object* l_Lean_CollectLevelParams_main___main(lean_object*, lean_object*); +extern lean_object* l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_mkForall___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_const(lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5; +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5; +lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_isSort(lean_object*); +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__2(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_ReplaceImpl_initCache; +lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); -lean_object* _init_l_Lean_Elab_Command_InductiveView_inhabited___closed__1() { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2; +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3; +lean_object* l_monadInhabited___rarg(lean_object*, lean_object*); +lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2(uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Inductive_3__checkUnsafe(lean_object*, lean_object*, lean_object*); +lean_object* _init_l_Lean_Elab_Command_CtorView_inhabited___closed__1() { _start: { lean_object* x_1; uint8_t x_2; uint8_t x_3; lean_object* x_4; lean_object* x_5; @@ -65,252 +430,20169 @@ lean_ctor_set_uint8(x_5, sizeof(void*)*2 + 3, x_3); return x_5; } } -lean_object* _init_l_Lean_Elab_Command_InductiveView_inhabited___closed__2() { +lean_object* _init_l_Lean_Elab_Command_CtorView_inhabited___closed__2() { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +lean_object* x_1; lean_object* x_2; lean_object* x_3; uint8_t x_4; lean_object* x_5; lean_object* x_6; x_1 = lean_box(0); x_2 = lean_box(0); -x_3 = l_Lean_Elab_Command_InductiveView_inhabited___closed__1; -x_4 = l_Array_empty___closed__1; -x_5 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_5, 0, x_2); -lean_ctor_set(x_5, 1, x_3); -lean_ctor_set(x_5, 2, x_2); -lean_ctor_set(x_5, 3, x_2); -lean_ctor_set(x_5, 4, x_1); -lean_ctor_set(x_5, 5, x_4); -return x_5; +x_3 = l_Lean_Elab_Command_CtorView_inhabited___closed__1; +x_4 = 0; +x_5 = lean_box(0); +x_6 = lean_alloc_ctor(0, 5, 1); +lean_ctor_set(x_6, 0, x_2); +lean_ctor_set(x_6, 1, x_3); +lean_ctor_set(x_6, 2, x_5); +lean_ctor_set(x_6, 3, x_2); +lean_ctor_set(x_6, 4, x_1); +lean_ctor_set_uint8(x_6, sizeof(void*)*5, x_4); +return x_6; +} +} +lean_object* _init_l_Lean_Elab_Command_CtorView_inhabited() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Elab_Command_CtorView_inhabited___closed__2; +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Command_InductiveView_inhabited___closed__1() { +_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 = lean_box(0); +x_2 = lean_box(0); +x_3 = lean_box(0); +x_4 = l_Lean_Elab_Command_CtorView_inhabited___closed__1; +x_5 = lean_box(0); +x_6 = l_Array_empty___closed__1; +x_7 = lean_alloc_ctor(0, 8, 0); +lean_ctor_set(x_7, 0, x_3); +lean_ctor_set(x_7, 1, x_4); +lean_ctor_set(x_7, 2, x_5); +lean_ctor_set(x_7, 3, x_5); +lean_ctor_set(x_7, 4, x_2); +lean_ctor_set(x_7, 5, x_3); +lean_ctor_set(x_7, 6, x_1); +lean_ctor_set(x_7, 7, x_6); +return x_7; } } lean_object* _init_l_Lean_Elab_Command_InductiveView_inhabited() { _start: { lean_object* x_1; -x_1 = l_Lean_Elab_Command_InductiveView_inhabited___closed__2; +x_1 = l_Lean_Elab_Command_InductiveView_inhabited___closed__1; return x_1; } } -lean_object* l_Lean_Elab_Command_mkInductive(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* _init_l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1() { _start: { -lean_object* x_10; lean_object* x_11; -lean_inc(x_1); -x_10 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_10, 0, x_1); -x_11 = l_Lean_Elab_Term_throwError___rarg(x_1, x_10, x_8, x_9); -lean_dec(x_1); -return x_11; -} -} -lean_object* l_Lean_Elab_Command_mkInductive___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -x_10 = l_Lean_Elab_Command_mkInductive(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -return x_10; -} -} -lean_object* l_Array_umapMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(lean_object* x_1, lean_object* x_2) { -_start: -{ -lean_object* x_3; uint8_t x_4; -x_3 = lean_array_get_size(x_2); -x_4 = lean_nat_dec_lt(x_1, x_3); -lean_dec(x_3); -if (x_4 == 0) -{ -lean_object* x_5; -lean_dec(x_1); -x_5 = x_2; +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_1 = l_Lean_Elab_Command_InductiveView_inhabited___closed__1; +x_2 = l_Lean_LocalContext_Inhabited___closed__2; +x_3 = l_Array_empty___closed__1; +x_4 = l_Lean_Expr_Inhabited___closed__1; +x_5 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_5, 0, x_1); +lean_ctor_set(x_5, 1, x_2); +lean_ctor_set(x_5, 2, x_3); +lean_ctor_set(x_5, 3, x_3); +lean_ctor_set(x_5, 4, x_4); 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_12; lean_object* x_13; lean_object* x_14; -x_6 = lean_array_fget(x_2, x_1); -x_7 = lean_unsigned_to_nat(0u); -x_8 = lean_array_fset(x_2, x_1, x_7); -x_9 = x_6; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_add(x_1, x_11); -x_13 = x_10; -x_14 = lean_array_fset(x_8, x_1, x_13); -lean_dec(x_1); -x_1 = x_12; -x_2 = x_14; -goto _start; } -} -} -lean_object* l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3(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; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -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 = lean_box(0); -x_7 = 0; -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_Lean_Syntax_formatStxAux___main(x_6, x_7, x_8, x_4); -x_10 = l_Lean_Options_empty; -x_11 = l_Lean_Format_pretty(x_9, x_10); -x_12 = l_List_reprAux___main___rarg___closed__1; -x_13 = lean_string_append(x_12, x_11); -lean_dec(x_11); -x_14 = l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3(x_1, x_5); -x_15 = lean_string_append(x_13, x_14); -lean_dec(x_14); -return x_15; -} -} -else -{ -if (lean_obj_tag(x_2) == 0) -{ -lean_object* x_16; -x_16 = l_String_splitAux___main___closed__1; -return x_16; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_17 = lean_ctor_get(x_2, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_2, 1); -lean_inc(x_18); -lean_dec(x_2); -x_19 = lean_box(0); -x_20 = 0; -x_21 = lean_unsigned_to_nat(0u); -x_22 = l_Lean_Syntax_formatStxAux___main(x_19, x_20, x_21, x_17); -x_23 = l_Lean_Options_empty; -x_24 = l_Lean_Format_pretty(x_22, x_23); -x_25 = l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3(x_20, x_18); -x_26 = lean_string_append(x_24, x_25); -lean_dec(x_25); -return x_26; -} -} -} -} -lean_object* l_List_toString___at_Lean_Elab_Command_elabInductiveCore___spec__2(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_Elab_Command_elabInductiveCore___spec__3(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* _init_l_Lean_Elab_Command_elabInductiveCore___closed__1() { +lean_object* _init_l_Lean_Elab_Command_ElabHeaderResult_inhabited() { _start: { lean_object* x_1; -x_1 = lean_mk_string("WIP\n"); +x_1 = l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1; return x_1; } } -lean_object* _init_l_Lean_Elab_Command_elabInductiveCore___closed__2() { +lean_object* _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid inductive type, resultant type is not a sort"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_elabInductiveCore___closed__1; +x_1 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l_Lean_Elab_Command_elabInductiveCore___closed__3() { +lean_object* _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Command_elabInductiveCore___closed__2; +x_1 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l_Lean_Elab_Command_elabInductiveCore(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _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; 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_4 = l_Lean_Elab_Command_InductiveView_inhabited; +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_8 = l_Lean_Elab_Term_getLCtx(x_6, x_7); +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = l_Lean_Elab_Term_getLocalInsts(x_6, x_10); +x_12 = lean_ctor_get(x_1, 6); +lean_inc(x_12); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_13 = lean_ctor_get(x_11, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_11, 1); +lean_inc(x_14); +lean_dec(x_11); +x_15 = lean_ctor_get(x_1, 0); +lean_inc(x_15); +lean_inc(x_6); +x_16 = l_Lean_Elab_Term_mkFreshLevelMVar(x_15, x_6, x_14); +lean_dec(x_15); +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +x_19 = l_Lean_mkLevelSucc(x_17); +x_20 = l_Lean_mkSort(x_19); +x_21 = lean_unsigned_to_nat(1u); +x_22 = lean_nat_add(x_2, x_21); +x_23 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_23, 0, x_1); +lean_ctor_set(x_23, 1, x_9); +lean_ctor_set(x_23, 2, x_13); +lean_ctor_set(x_23, 3, x_5); +lean_ctor_set(x_23, 4, x_20); +x_24 = lean_array_push(x_3, x_23); +x_25 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(x_4, x_22, x_24, x_6, x_18); +return x_25; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_object* x_31; +x_26 = lean_ctor_get(x_11, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_11, 1); +lean_inc(x_27); +lean_dec(x_11); +x_28 = lean_ctor_get(x_12, 0); +lean_inc(x_28); +lean_dec(x_12); +x_29 = lean_box(0); +x_30 = 1; +lean_inc(x_6); +lean_inc(x_28); +x_31 = l_Lean_Elab_Term_elabTermAux___main(x_29, x_30, x_30, x_28, x_6, x_27); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +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_ctor_get(x_1, 0); +lean_inc(x_34); +x_35 = lean_unsigned_to_nat(1u); +x_36 = lean_nat_add(x_2, x_35); +lean_inc(x_32); +x_37 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_37, 0, x_1); +lean_ctor_set(x_37, 1, x_9); +lean_ctor_set(x_37, 2, x_26); +lean_ctor_set(x_37, 3, x_5); +lean_ctor_set(x_37, 4, x_32); +x_38 = lean_array_push(x_3, x_37); +lean_inc(x_6); +x_39 = l_Lean_Elab_Term_isTypeFormerType(x_34, x_32, x_6, x_33); +lean_dec(x_34); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_unbox(x_40); +lean_dec(x_40); +if (x_41 == 0) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; uint8_t x_45; +lean_dec(x_38); +lean_dec(x_36); +lean_dec(x_4); +x_42 = lean_ctor_get(x_39, 1); +lean_inc(x_42); +lean_dec(x_39); +x_43 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3; +x_44 = l_Lean_Elab_Term_throwError___rarg(x_28, x_43, x_6, x_42); +lean_dec(x_28); +x_45 = !lean_is_exclusive(x_44); +if (x_45 == 0) +{ +return x_44; +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_44, 0); +x_47 = lean_ctor_get(x_44, 1); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_44); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_46); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +else +{ +lean_object* x_49; lean_object* x_50; +lean_dec(x_28); +x_49 = lean_ctor_get(x_39, 1); +lean_inc(x_49); +lean_dec(x_39); +x_50 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(x_4, x_36, x_38, x_6, x_49); +return x_50; +} +} +else +{ +uint8_t x_51; +lean_dec(x_38); +lean_dec(x_36); +lean_dec(x_28); +lean_dec(x_6); +lean_dec(x_4); +x_51 = !lean_is_exclusive(x_39); +if (x_51 == 0) +{ +return x_39; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_39, 0); +x_53 = lean_ctor_get(x_39, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_39); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +else +{ +uint8_t x_55; +lean_dec(x_28); +lean_dec(x_26); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_55 = !lean_is_exclusive(x_31); +if (x_55 == 0) +{ +return x_31; +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_31, 0); +x_57 = lean_ctor_get(x_31, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_31); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); +return x_58; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_1); +x_7 = lean_nat_dec_lt(x_2, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_3); +lean_ctor_set(x_8, 1, x_5); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_array_fget(x_1, x_2); +x_10 = lean_ctor_get(x_9, 5); +lean_inc(x_10); +x_11 = l_Lean_Syntax_getArgs(x_10); +lean_dec(x_10); +x_12 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___boxed), 7, 4); +lean_closure_set(x_12, 0, x_9); +lean_closure_set(x_12, 1, x_2); +lean_closure_set(x_12, 2, x_3); +lean_closure_set(x_12, 3, x_1); +x_13 = l_Lean_Elab_Term_elabBinders___rarg(x_11, x_12, x_4, x_5); +lean_dec(x_11); +return x_13; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___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: +{ +lean_object* x_8; +x_8 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +return x_8; +} +} +lean_object* l___private_Lean_Elab_Inductive_1__elabHeaderAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(x_1, x_2, x_3, x_4, x_5); +return x_6; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid inductive type, number of parameters mismatch in mutually inductive datatypes"); +return x_1; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_4); +lean_dec(x_3); +x_8 = lean_box(0); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +x_10 = lean_array_fget(x_2, x_3); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +x_13 = lean_ctor_get(x_10, 3); +lean_inc(x_13); +x_14 = lean_array_get_size(x_13); +lean_dec(x_13); +x_15 = lean_nat_dec_eq(x_14, x_1); +lean_dec(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_20; +lean_dec(x_12); +x_16 = lean_ctor_get(x_10, 0); +lean_inc(x_16); +lean_dec(x_10); +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +lean_dec(x_16); +x_18 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3; +x_19 = l_Lean_Elab_Term_throwError___rarg(x_17, x_18, x_4, x_5); +lean_dec(x_17); +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +return x_19; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_19, 0); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_19); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +else +{ +lean_dec(x_10); +x_3 = x_12; +goto _start; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_2__checkNumParams(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; +x_4 = l_Lean_Elab_Command_ElabHeaderResult_inhabited; +x_5 = lean_unsigned_to_nat(0u); +x_6 = lean_array_get(x_4, x_1, x_5); +x_7 = lean_ctor_get(x_6, 3); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_array_get_size(x_7); +lean_dec(x_7); +x_9 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1(x_8, x_1, x_5, x_2, x_3); +if (lean_obj_tag(x_9) == 0) +{ +uint8_t x_10; +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) +{ +lean_object* x_11; +x_11 = lean_ctor_get(x_9, 0); +lean_dec(x_11); +lean_ctor_set(x_9, 0, x_8); +return x_9; +} +else +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_9, 1); +lean_inc(x_12); +lean_dec(x_9); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_8); +lean_ctor_set(x_13, 1, x_12); +return x_13; +} +} +else +{ +uint8_t x_14; +lean_dec(x_8); +x_14 = !lean_is_exclusive(x_9); +if (x_14 == 0) +{ +return x_9; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_9, 0); +x_16 = lean_ctor_get(x_9, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_9); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_15); +lean_ctor_set(x_17, 1, x_16); +return x_17; +} +} +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_2__checkNumParams___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_2__checkNumParams(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid inductive type, cannot mix unsafe and safe declarations in a mutually inductive datatypes"); +return x_1; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_4); +lean_dec(x_3); +x_8 = lean_box(0); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; uint8_t x_16; +x_10 = lean_array_fget(x_2, x_3); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +x_13 = lean_ctor_get(x_10, 0); +lean_inc(x_13); +lean_dec(x_10); +x_14 = lean_ctor_get(x_13, 1); +lean_inc(x_14); +x_15 = lean_ctor_get_uint8(x_14, sizeof(void*)*2 + 3); +lean_dec(x_14); +if (x_15 == 0) +{ +if (x_1 == 0) +{ +uint8_t x_26; +x_26 = 1; +x_16 = x_26; +goto block_25; +} +else +{ +uint8_t x_27; +x_27 = 0; +x_16 = x_27; +goto block_25; +} +} +else +{ +if (x_1 == 0) +{ +uint8_t x_28; +x_28 = 0; +x_16 = x_28; +goto block_25; +} +else +{ +uint8_t x_29; +x_29 = 1; +x_16 = x_29; +goto block_25; +} +} +block_25: +{ +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_20; +lean_dec(x_12); +x_17 = lean_ctor_get(x_13, 0); +lean_inc(x_17); +lean_dec(x_13); +x_18 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3; +x_19 = l_Lean_Elab_Term_throwError___rarg(x_17, x_18, x_4, x_5); +lean_dec(x_17); +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +return x_19; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_19, 0); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_19); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +else +{ +lean_dec(x_13); +x_3 = x_12; +goto _start; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_3__checkUnsafe(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; uint8_t x_9; lean_object* x_10; +x_4 = l_Lean_Elab_Command_ElabHeaderResult_inhabited; x_5 = lean_unsigned_to_nat(0u); x_6 = lean_array_get(x_4, x_1, x_5); x_7 = lean_ctor_get(x_6, 0); lean_inc(x_7); lean_dec(x_6); -x_8 = x_1; -x_9 = l_Array_umapMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(x_5, x_8); -x_10 = x_9; -x_11 = l_Array_toList___rarg(x_10); -lean_dec(x_10); -x_12 = l_List_toString___at_Lean_Elab_Command_elabInductiveCore___spec__2(x_11); -x_13 = l_Array_HasRepr___rarg___closed__1; -x_14 = lean_string_append(x_13, x_12); -lean_dec(x_12); -x_15 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_15, 0, x_14); -x_16 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_16, 0, x_15); -x_17 = l_Lean_Elab_Command_elabInductiveCore___closed__3; -x_18 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -x_19 = l_Lean_Elab_Command_throwError___rarg(x_7, x_18, x_2, x_3); +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); lean_dec(x_7); -return x_19; +x_9 = lean_ctor_get_uint8(x_8, sizeof(void*)*2 + 3); +lean_dec(x_8); +x_10 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1(x_9, x_1, x_5, x_2, x_3); +return x_10; } } -lean_object* l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -uint8_t x_3; lean_object* x_4; -x_3 = lean_unbox(x_1); +uint8_t x_6; lean_object* x_7; +x_6 = lean_unbox(x_1); +lean_dec(x_1); +x_7 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1(x_6, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_3__checkUnsafe___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_3__checkUnsafe(x_1, x_2, x_3); lean_dec(x_1); -x_4 = l_List_toStringAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__3(x_3, x_2); return x_4; } } +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid inductive type, universe parameters mismatch in mutually inductive datatypes"); +return x_1; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_4); +lean_dec(x_3); +x_8 = lean_box(0); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_10 = lean_array_fget(x_2, x_3); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +x_13 = lean_ctor_get(x_10, 4); +lean_inc(x_13); +x_14 = l_List_beq___main___at_Lean_Elab_OpenDecl_HasToString___spec__1(x_13, x_1); +lean_dec(x_13); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_dec(x_12); +x_15 = lean_ctor_get(x_10, 0); +lean_inc(x_15); +lean_dec(x_10); +x_16 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3; +x_17 = l_Lean_Elab_Term_throwError___rarg(x_15, x_16, x_4, x_5); +lean_dec(x_15); +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +return x_17; +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_17, 0); +x_20 = lean_ctor_get(x_17, 1); +lean_inc(x_20); +lean_inc(x_19); +lean_dec(x_17); +x_21 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_21, 0, x_19); +lean_ctor_set(x_21, 1, x_20); +return x_21; +} +} +else +{ +lean_dec(x_10); +x_3 = x_12; +goto _start; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_4__checkLevelNames(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; uint8_t x_6; +x_4 = lean_array_get_size(x_1); +x_5 = lean_unsigned_to_nat(1u); +x_6 = lean_nat_dec_lt(x_5, x_4); +lean_dec(x_4); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_2); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_3); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = l_Lean_Elab_Command_InductiveView_inhabited; +x_10 = lean_unsigned_to_nat(0u); +x_11 = lean_array_get(x_9, x_1, x_10); +x_12 = lean_ctor_get(x_11, 4); +lean_inc(x_12); +lean_dec(x_11); +x_13 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1(x_12, x_1, x_10, x_2, x_3); +lean_dec(x_12); +return x_13; +} +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_4__checkLevelNames___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_4__checkLevelNames(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} +lean_object* l___private_Lean_Elab_Inductive_5__mkTypeFor(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; +x_4 = lean_ctor_get(x_1, 1); +lean_inc(x_4); +x_5 = lean_ctor_get(x_1, 2); +lean_inc(x_5); +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_ctor_get(x_1, 3); +lean_inc(x_8); +x_9 = lean_ctor_get(x_1, 4); +lean_inc(x_9); +lean_dec(x_1); +x_10 = lean_alloc_closure((void*)(l_Lean_Elab_Term_mkForall___boxed), 5, 3); +lean_closure_set(x_10, 0, x_7); +lean_closure_set(x_10, 1, x_8); +lean_closure_set(x_10, 2, x_9); +x_11 = l_Lean_Elab_Term_withLocalContext___rarg(x_4, x_5, x_10, x_2, x_3); +return x_11; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unexpected inductive resulting type"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3; +x_5 = l_Lean_Elab_Term_throwError___rarg(x_1, x_4, x_2, x_3); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___boxed), 3, 0); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_5, 0, x_2); +lean_ctor_set(x_5, 1, x_4); +return x_5; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_7__getResultingType___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1___boxed), 4, 0); +return x_1; +} +} +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_7 = lean_ctor_get(x_5, 4); +x_8 = lean_ctor_get(x_3, 0); +lean_inc(x_8); +x_9 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_5, 4, x_9); +x_10 = l___private_Lean_Elab_Inductive_7__getResultingType___closed__1; +x_11 = l_Lean_Meta_forallTelescopeReducing___rarg(x_2, x_10, x_8, x_5); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_11, 1); +x_14 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_13, x_7); +lean_ctor_set(x_11, 1, x_14); +return x_11; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_15 = lean_ctor_get(x_11, 0); +x_16 = lean_ctor_get(x_11, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_11); +x_17 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_16, x_7); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_15); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +else +{ +uint8_t x_19; +x_19 = !lean_is_exclusive(x_11); +if (x_19 == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_11, 0); +x_21 = lean_ctor_get(x_11, 1); +lean_inc(x_3); +x_22 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_20); +x_23 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_21, x_7); +lean_ctor_set(x_11, 1, x_23); +lean_ctor_set(x_11, 0, x_22); +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +lean_inc(x_3); +x_26 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_24); +x_27 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_25, x_7); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_29 = lean_ctor_get(x_5, 0); +x_30 = lean_ctor_get(x_5, 1); +x_31 = lean_ctor_get(x_5, 2); +x_32 = lean_ctor_get(x_5, 3); +x_33 = lean_ctor_get(x_5, 4); +x_34 = lean_ctor_get(x_5, 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_5); +x_35 = lean_ctor_get(x_3, 0); +lean_inc(x_35); +x_36 = l_Lean_TraceState_Inhabited___closed__1; +x_37 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_37, 0, x_29); +lean_ctor_set(x_37, 1, x_30); +lean_ctor_set(x_37, 2, x_31); +lean_ctor_set(x_37, 3, x_32); +lean_ctor_set(x_37, 4, x_36); +lean_ctor_set(x_37, 5, x_34); +x_38 = l___private_Lean_Elab_Inductive_7__getResultingType___closed__1; +x_39 = l_Lean_Meta_forallTelescopeReducing___rarg(x_2, x_38, x_35, x_37); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + x_42 = x_39; +} else { + lean_dec_ref(x_39); + x_42 = lean_box(0); +} +x_43 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_41, x_33); +if (lean_is_scalar(x_42)) { + x_44 = lean_alloc_ctor(0, 2, 0); +} else { + x_44 = x_42; +} +lean_ctor_set(x_44, 0, x_40); +lean_ctor_set(x_44, 1, x_43); +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; +x_45 = lean_ctor_get(x_39, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_39, 1); +lean_inc(x_46); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + x_47 = x_39; +} else { + lean_dec_ref(x_39); + x_47 = lean_box(0); +} +lean_inc(x_3); +x_48 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_45); +x_49 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_46, x_33); +if (lean_is_scalar(x_47)) { + x_50 = lean_alloc_ctor(1, 2, 0); +} else { + x_50 = x_47; +} +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_7__getResultingType___lambda__1(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_1); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_7__getResultingType___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_7__getResultingType(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Meta_isExprDefEq(x_3, x_1, x_4, x_5); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; +x_5 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1___boxed), 5, 1); +lean_closure_set(x_5, 0, x_2); +x_6 = l_Lean_Meta_forallTelescopeReducing___rarg(x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult___lambda__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_9 = lean_expr_instantiate1(x_1, x_6); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_2, x_10); +x_12 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(x_3, x_4, x_11, x_9, x_5, x_7, x_8); +return x_12; +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_expr_instantiate1(x_1, x_6); +x_10 = lean_expr_instantiate1(x_2, x_6); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +x_13 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(x_4, x_5, x_12, x_9, x_10, x_7, x_8); +return x_13; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid mutually inductive types, resulting universe mismatch, given "); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("expected type"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid mutually inductive types, binder annotation mismatch at parameter '"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid mutually inductive types, type mismatch at parameter '"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid mutually inductive types, parameter name mismatch '"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("', expected '"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +lean_inc(x_6); +x_8 = l_Lean_Elab_Term_whnf(x_1, x_4, x_6, x_7); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = lean_nat_dec_lt(x_3, x_2); +if (x_11 == 0) +{ +switch (lean_obj_tag(x_9)) { +case 3: +{ +lean_object* x_12; uint8_t x_13; +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_ctor_get(x_10, 0); +lean_inc(x_12); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_14 = lean_ctor_get(x_12, 4); +x_15 = lean_ctor_get(x_6, 0); +lean_inc(x_15); +x_16 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_12, 4, x_16); +lean_inc(x_9); +lean_inc(x_5); +x_17 = l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult(x_5, x_9, x_15, x_12); +if (lean_obj_tag(x_17) == 0) +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_19 = lean_ctor_get(x_17, 0); +x_20 = lean_ctor_get(x_17, 1); +lean_inc(x_6); +x_21 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_20, x_14); +x_22 = lean_unbox(x_19); +lean_dec(x_19); +if (x_22 == 0) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +lean_free_object(x_17); +x_23 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_23, 0, x_9); +x_24 = l_Lean_indentExpr(x_23); +x_25 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3; +x_26 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_24); +x_27 = l_Lean_MessageData_ofList___closed__3; +x_28 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +x_29 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6; +x_30 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +x_31 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_31, 0, x_5); +x_32 = l_Lean_indentExpr(x_31); +x_33 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_33, 0, x_30); +lean_ctor_set(x_33, 1, x_32); +x_34 = l_Lean_Elab_Term_throwError___rarg(x_1, x_33, x_6, x_21); +lean_dec(x_1); +return x_34; +} +else +{ +lean_object* x_35; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_35 = lean_box(0); +lean_ctor_set(x_17, 1, x_21); +lean_ctor_set(x_17, 0, x_35); +return x_17; +} +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_36 = lean_ctor_get(x_17, 0); +x_37 = lean_ctor_get(x_17, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_17); +lean_inc(x_6); +x_38 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_37, x_14); +x_39 = lean_unbox(x_36); +lean_dec(x_36); +if (x_39 == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_40 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_40, 0, x_9); +x_41 = l_Lean_indentExpr(x_40); +x_42 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3; +x_43 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_41); +x_44 = l_Lean_MessageData_ofList___closed__3; +x_45 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_44); +x_46 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6; +x_47 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +x_48 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_48, 0, x_5); +x_49 = l_Lean_indentExpr(x_48); +x_50 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_50, 0, x_47); +lean_ctor_set(x_50, 1, x_49); +x_51 = l_Lean_Elab_Term_throwError___rarg(x_1, x_50, x_6, x_38); +lean_dec(x_1); +return x_51; +} +else +{ +lean_object* x_52; lean_object* x_53; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_52 = lean_box(0); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_38); +return x_53; +} +} +} +else +{ +uint8_t x_54; +lean_dec(x_9); +lean_dec(x_5); +x_54 = !lean_is_exclusive(x_17); +if (x_54 == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_55 = lean_ctor_get(x_17, 0); +x_56 = lean_ctor_get(x_17, 1); +lean_inc(x_6); +x_57 = l___private_Lean_Elab_Term_2__fromMetaException(x_6, x_1, x_55); +x_58 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_56, x_14); +lean_dec(x_1); +lean_ctor_set(x_17, 1, x_58); +lean_ctor_set(x_17, 0, x_57); +return x_17; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_59 = lean_ctor_get(x_17, 0); +x_60 = lean_ctor_get(x_17, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_17); +lean_inc(x_6); +x_61 = l___private_Lean_Elab_Term_2__fromMetaException(x_6, x_1, x_59); +x_62 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_60, x_14); +lean_dec(x_1); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_61); +lean_ctor_set(x_63, 1, x_62); +return x_63; +} +} +} +else +{ +lean_object* x_64; lean_object* x_65; lean_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_64 = lean_ctor_get(x_12, 0); +x_65 = lean_ctor_get(x_12, 1); +x_66 = lean_ctor_get(x_12, 2); +x_67 = lean_ctor_get(x_12, 3); +x_68 = lean_ctor_get(x_12, 4); +x_69 = lean_ctor_get(x_12, 5); +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_12); +x_70 = lean_ctor_get(x_6, 0); +lean_inc(x_70); +x_71 = l_Lean_TraceState_Inhabited___closed__1; +x_72 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_72, 0, x_64); +lean_ctor_set(x_72, 1, x_65); +lean_ctor_set(x_72, 2, x_66); +lean_ctor_set(x_72, 3, x_67); +lean_ctor_set(x_72, 4, x_71); +lean_ctor_set(x_72, 5, x_69); +lean_inc(x_9); +lean_inc(x_5); +x_73 = l___private_Lean_Elab_Inductive_8__eqvFirstTypeResult(x_5, x_9, x_70, 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; uint8_t 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); +} +lean_inc(x_6); +x_77 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_75, x_68); +x_78 = lean_unbox(x_74); +lean_dec(x_74); +if (x_78 == 0) +{ +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_dec(x_76); +x_79 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_79, 0, x_9); +x_80 = l_Lean_indentExpr(x_79); +x_81 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3; +x_82 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_82, 0, x_81); +lean_ctor_set(x_82, 1, x_80); +x_83 = l_Lean_MessageData_ofList___closed__3; +x_84 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +x_85 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6; +x_86 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_86, 0, x_84); +lean_ctor_set(x_86, 1, x_85); +x_87 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_87, 0, x_5); +x_88 = l_Lean_indentExpr(x_87); +x_89 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_89, 0, x_86); +lean_ctor_set(x_89, 1, x_88); +x_90 = l_Lean_Elab_Term_throwError___rarg(x_1, x_89, x_6, x_77); +lean_dec(x_1); +return x_90; +} +else +{ +lean_object* x_91; lean_object* x_92; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_91 = lean_box(0); +if (lean_is_scalar(x_76)) { + x_92 = lean_alloc_ctor(0, 2, 0); +} else { + x_92 = x_76; +} +lean_ctor_set(x_92, 0, x_91); +lean_ctor_set(x_92, 1, x_77); +return x_92; +} +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +lean_dec(x_9); +lean_dec(x_5); +x_93 = lean_ctor_get(x_73, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_73, 1); +lean_inc(x_94); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_95 = x_73; +} else { + lean_dec_ref(x_73); + x_95 = lean_box(0); +} +lean_inc(x_6); +x_96 = l___private_Lean_Elab_Term_2__fromMetaException(x_6, x_1, x_93); +x_97 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_6, x_10, x_94, x_68); +lean_dec(x_1); +if (lean_is_scalar(x_95)) { + x_98 = lean_alloc_ctor(1, 2, 0); +} else { + x_98 = x_95; +} +lean_ctor_set(x_98, 0, x_96); +lean_ctor_set(x_98, 1, x_97); +return x_98; +} +} +} +case 7: +{ +lean_object* x_99; lean_object* x_100; lean_object* x_101; uint64_t x_102; uint8_t x_103; lean_object* x_104; lean_object* x_105; +x_99 = lean_ctor_get(x_9, 0); +lean_inc(x_99); +x_100 = lean_ctor_get(x_9, 1); +lean_inc(x_100); +x_101 = lean_ctor_get(x_9, 2); +lean_inc(x_101); +x_102 = lean_ctor_get_uint64(x_9, sizeof(void*)*3); +lean_dec(x_9); +x_103 = (uint8_t)((x_102 << 24) >> 61); +lean_inc(x_1); +x_104 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1___boxed), 8, 5); +lean_closure_set(x_104, 0, x_101); +lean_closure_set(x_104, 1, x_3); +lean_closure_set(x_104, 2, x_1); +lean_closure_set(x_104, 3, x_2); +lean_closure_set(x_104, 4, x_5); +x_105 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_99, x_103, x_100, x_104, x_6, x_10); +lean_dec(x_1); +return x_105; +} +default: +{ +lean_object* x_106; +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_106 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(x_1, x_6, x_10); +lean_dec(x_1); +return x_106; +} +} +} +else +{ +lean_object* x_107; +lean_inc(x_6); +x_107 = l_Lean_Elab_Term_whnf(x_1, x_5, x_6, x_10); +if (lean_obj_tag(x_107) == 0) +{ +if (lean_obj_tag(x_9) == 7) +{ +lean_object* x_108; +x_108 = lean_ctor_get(x_107, 0); +lean_inc(x_108); +if (lean_obj_tag(x_108) == 7) +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; uint64_t x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; uint64_t x_117; uint8_t x_118; uint8_t x_119; uint8_t x_120; uint8_t x_121; lean_object* x_122; uint8_t x_123; +x_109 = lean_ctor_get(x_107, 1); +lean_inc(x_109); +lean_dec(x_107); +x_110 = lean_ctor_get(x_9, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_9, 1); +lean_inc(x_111); +x_112 = lean_ctor_get(x_9, 2); +lean_inc(x_112); +x_113 = lean_ctor_get_uint64(x_9, sizeof(void*)*3); +lean_dec(x_9); +x_114 = lean_ctor_get(x_108, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_108, 1); +lean_inc(x_115); +x_116 = lean_ctor_get(x_108, 2); +lean_inc(x_116); +x_117 = lean_ctor_get_uint64(x_108, sizeof(void*)*3); +lean_dec(x_108); +x_118 = lean_name_eq(x_110, x_114); +x_119 = (uint8_t)((x_113 << 24) >> 61); +x_120 = (uint8_t)((x_117 << 24) >> 61); +x_121 = l_Lean_BinderInfo_beq(x_119, x_120); +lean_inc(x_1); +x_122 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2___boxed), 8, 5); +lean_closure_set(x_122, 0, x_112); +lean_closure_set(x_122, 1, x_116); +lean_closure_set(x_122, 2, x_3); +lean_closure_set(x_122, 3, x_1); +lean_closure_set(x_122, 4, x_2); +if (x_118 == 0) +{ +uint8_t x_187; +x_187 = 0; +x_123 = x_187; +goto block_186; +} +else +{ +uint8_t x_188; +x_188 = 1; +x_123 = x_188; +goto block_186; +} +block_186: +{ +uint8_t x_124; +if (x_121 == 0) +{ +uint8_t x_184; +x_184 = 0; +x_124 = x_184; +goto block_183; +} +else +{ +uint8_t x_185; +x_185 = 1; +x_124 = x_185; +goto block_183; +} +block_183: +{ +lean_object* x_125; lean_object* x_138; +if (x_123 == 0) +{ +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; uint8_t x_179; +lean_dec(x_122); +lean_dec(x_115); +lean_dec(x_111); +x_169 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_169, 0, x_110); +x_170 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15; +x_171 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_171, 0, x_170); +lean_ctor_set(x_171, 1, x_169); +x_172 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18; +x_173 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_173, 0, x_171); +lean_ctor_set(x_173, 1, x_172); +x_174 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_174, 0, x_114); +x_175 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_175, 0, x_173); +lean_ctor_set(x_175, 1, x_174); +x_176 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; +x_177 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_177, 0, x_175); +lean_ctor_set(x_177, 1, x_176); +x_178 = l_Lean_Elab_Term_throwError___rarg(x_1, x_177, x_6, x_109); +lean_dec(x_1); +x_179 = !lean_is_exclusive(x_178); +if (x_179 == 0) +{ +return x_178; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_178, 0); +x_181 = lean_ctor_get(x_178, 1); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_178); +x_182 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_182, 0, x_180); +lean_ctor_set(x_182, 1, x_181); +return x_182; +} +} +else +{ +lean_dec(x_114); +x_138 = x_109; +goto block_168; +} +block_137: +{ +if (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; uint8_t x_132; +lean_dec(x_122); +lean_dec(x_111); +x_126 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_126, 0, x_110); +x_127 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9; +x_128 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_128, 0, x_127); +lean_ctor_set(x_128, 1, x_126); +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_128); +lean_ctor_set(x_130, 1, x_129); +x_131 = l_Lean_Elab_Term_throwError___rarg(x_1, x_130, x_6, x_125); +lean_dec(x_1); +x_132 = !lean_is_exclusive(x_131); +if (x_132 == 0) +{ +return x_131; +} +else +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_133 = lean_ctor_get(x_131, 0); +x_134 = lean_ctor_get(x_131, 1); +lean_inc(x_134); +lean_inc(x_133); +lean_dec(x_131); +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; +} +} +else +{ +lean_object* x_136; +x_136 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_110, x_119, x_111, x_122, x_6, x_125); +lean_dec(x_1); +return x_136; +} +} +block_168: +{ +lean_object* x_139; +lean_inc(x_6); +lean_inc(x_115); +lean_inc(x_111); +x_139 = l_Lean_Elab_Term_isDefEq(x_1, x_111, x_115, x_6, x_138); +if (lean_obj_tag(x_139) == 0) +{ +lean_object* x_140; uint8_t x_141; +x_140 = lean_ctor_get(x_139, 0); +lean_inc(x_140); +x_141 = lean_unbox(x_140); +lean_dec(x_140); +if (x_141 == 0) +{ +lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; 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_dec(x_122); +x_142 = lean_ctor_get(x_139, 1); +lean_inc(x_142); +lean_dec(x_139); +x_143 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_143, 0, x_110); +x_144 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12; +x_145 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_145, 0, x_144); +lean_ctor_set(x_145, 1, x_143); +x_146 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; +x_147 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_147, 0, x_145); +lean_ctor_set(x_147, 1, x_146); +x_148 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_148, 0, x_111); +x_149 = l_Lean_indentExpr(x_148); +x_150 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_150, 0, x_147); +lean_ctor_set(x_150, 1, x_149); +x_151 = l_Lean_MessageData_ofList___closed__3; +x_152 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_152, 0, x_150); +lean_ctor_set(x_152, 1, x_151); +x_153 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6; +x_154 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_154, 0, x_152); +lean_ctor_set(x_154, 1, x_153); +x_155 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_155, 0, x_115); +x_156 = l_Lean_indentExpr(x_155); +x_157 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_157, 0, x_154); +lean_ctor_set(x_157, 1, x_156); +x_158 = l_Lean_Elab_Term_throwError___rarg(x_1, x_157, x_6, x_142); +lean_dec(x_1); +x_159 = !lean_is_exclusive(x_158); +if (x_159 == 0) +{ +return x_158; +} +else +{ +lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_160 = lean_ctor_get(x_158, 0); +x_161 = lean_ctor_get(x_158, 1); +lean_inc(x_161); +lean_inc(x_160); +lean_dec(x_158); +x_162 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_162, 0, x_160); +lean_ctor_set(x_162, 1, x_161); +return x_162; +} +} +else +{ +lean_object* x_163; +lean_dec(x_115); +x_163 = lean_ctor_get(x_139, 1); +lean_inc(x_163); +lean_dec(x_139); +x_125 = x_163; +goto block_137; +} +} +else +{ +uint8_t x_164; +lean_dec(x_122); +lean_dec(x_115); +lean_dec(x_111); +lean_dec(x_110); +lean_dec(x_6); +lean_dec(x_1); +x_164 = !lean_is_exclusive(x_139); +if (x_164 == 0) +{ +return x_139; +} +else +{ +lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_165 = lean_ctor_get(x_139, 0); +x_166 = lean_ctor_get(x_139, 1); +lean_inc(x_166); +lean_inc(x_165); +lean_dec(x_139); +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; +} +} +} +} +} +} +else +{ +lean_object* x_189; lean_object* x_190; +lean_dec(x_108); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +x_189 = lean_ctor_get(x_107, 1); +lean_inc(x_189); +lean_dec(x_107); +x_190 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(x_1, x_6, x_189); +lean_dec(x_1); +return x_190; +} +} +else +{ +lean_object* x_191; lean_object* x_192; +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +x_191 = lean_ctor_get(x_107, 1); +lean_inc(x_191); +lean_dec(x_107); +x_192 = l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg(x_1, x_6, x_191); +lean_dec(x_1); +return x_192; +} +} +else +{ +uint8_t x_193; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_193 = !lean_is_exclusive(x_107); +if (x_193 == 0) +{ +return x_107; +} +else +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_107, 0); +x_195 = lean_ctor_get(x_107, 1); +lean_inc(x_195); +lean_inc(x_194); +lean_dec(x_107); +x_196 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_196, 0, x_194); +lean_ctor_set(x_196, 1, x_195); +return x_196; +} +} +} +} +else +{ +uint8_t x_197; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_197 = !lean_is_exclusive(x_8); +if (x_197 == 0) +{ +return x_8; +} +else +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_198 = lean_ctor_get(x_8, 0); +x_199 = lean_ctor_get(x_8, 1); +lean_inc(x_199); +lean_inc(x_198); +lean_dec(x_8); +x_200 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_200, 0, x_198); +lean_ctor_set(x_200, 1, x_199); +return x_200; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_9__checkParamsAndResultType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +return x_8; +} +} +lean_object* l___private_Lean_Elab_Inductive_10__checkHeader(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_1); +x_6 = l___private_Lean_Elab_Inductive_5__mkTypeFor(x_1, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +if (lean_obj_tag(x_3) == 0) +{ +uint8_t x_7; +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +return x_6; +} +else +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_6, 0); +x_9 = lean_ctor_get(x_6, 1); +lean_inc(x_9); +lean_inc(x_8); +lean_dec(x_6); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_8); +lean_ctor_set(x_10, 1, x_9); +return x_10; +} +} +else +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_11 = lean_ctor_get(x_6, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_6, 1); +lean_inc(x_12); +lean_dec(x_6); +x_13 = lean_ctor_get(x_3, 0); +lean_inc(x_13); +lean_dec(x_3); +x_14 = lean_ctor_get(x_1, 0); +lean_inc(x_14); +lean_dec(x_1); +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +lean_dec(x_14); +x_16 = lean_unsigned_to_nat(0u); +lean_inc(x_13); +x_17 = l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main(x_15, x_2, x_16, x_11, x_13, x_4, x_12); +if (lean_obj_tag(x_17) == 0) +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_17, 0); +lean_dec(x_19); +lean_ctor_set(x_17, 0, x_13); +return x_17; +} +else +{ +lean_object* x_20; lean_object* x_21; +x_20 = lean_ctor_get(x_17, 1); +lean_inc(x_20); +lean_dec(x_17); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_13); +lean_ctor_set(x_21, 1, x_20); +return x_21; +} +} +else +{ +uint8_t x_22; +lean_dec(x_13); +x_22 = !lean_is_exclusive(x_17); +if (x_22 == 0) +{ +return x_17; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_17, 0); +x_24 = lean_ctor_get(x_17, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_17); +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; +} +} +} +} +else +{ +uint8_t x_26; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_26 = !lean_is_exclusive(x_6); +if (x_26 == 0) +{ +return x_6; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_6, 0); +x_28 = lean_ctor_get(x_6, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_6); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_1); +x_8 = lean_nat_dec_lt(x_3, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_9 = lean_box(0); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_6); +return x_10; +} +else +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = l_Lean_Elab_Command_ElabHeaderResult_inhabited; +x_12 = lean_array_get(x_11, x_1, x_3); +lean_inc(x_5); +lean_inc(x_2); +x_13 = l___private_Lean_Elab_Inductive_10__checkHeader(x_12, x_2, x_4, x_5, x_6); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = lean_unsigned_to_nat(1u); +x_17 = lean_nat_add(x_3, x_16); +lean_dec(x_3); +x_18 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_18, 0, x_14); +x_3 = x_17; +x_4 = x_18; +x_6 = x_15; +goto _start; +} +else +{ +uint8_t x_20; +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_20 = !lean_is_exclusive(x_13); +if (x_20 == 0) +{ +return x_13; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_13, 0); +x_22 = lean_ctor_get(x_13, 1); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_13); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Lean_Elab_Inductive_11__checkHeaders___main(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Lean_Elab_Inductive_11__checkHeaders___main(x_1, x_2, x_3, x_4, x_5, x_6); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_11__checkHeaders___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Lean_Elab_Inductive_11__checkHeaders(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_12__elabHeader(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_4 = lean_unsigned_to_nat(0u); +x_5 = l_Array_empty___closed__1; +lean_inc(x_2); +x_6 = l___private_Lean_Elab_Inductive_1__elabHeaderAux___main(x_1, x_4, x_5, x_2, x_3); +if (lean_obj_tag(x_6) == 0) +{ +uint8_t x_7; +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_8 = lean_ctor_get(x_6, 0); +x_9 = lean_ctor_get(x_6, 1); +x_10 = lean_array_get_size(x_8); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_dec_lt(x_11, x_10); +lean_dec(x_10); +if (x_12 == 0) +{ +lean_dec(x_2); +return x_6; +} +else +{ +lean_object* x_13; +lean_free_object(x_6); +lean_inc(x_2); +x_13 = l___private_Lean_Elab_Inductive_3__checkUnsafe(x_8, x_2, x_9); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_13, 1); +lean_inc(x_14); +lean_dec(x_13); +lean_inc(x_2); +x_15 = l___private_Lean_Elab_Inductive_2__checkNumParams(x_8, x_2, x_14); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = lean_box(0); +x_19 = l___private_Lean_Elab_Inductive_11__checkHeaders___main(x_8, x_16, x_4, x_18, x_2, x_17); +if (lean_obj_tag(x_19) == 0) +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 0); +lean_dec(x_21); +lean_ctor_set(x_19, 0, x_8); +return x_19; +} +else +{ +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_dec(x_19); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_8); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +else +{ +uint8_t x_24; +lean_dec(x_8); +x_24 = !lean_is_exclusive(x_19); +if (x_24 == 0) +{ +return x_19; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_19, 0); +x_26 = lean_ctor_get(x_19, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_19); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +uint8_t x_28; +lean_dec(x_8); +lean_dec(x_2); +x_28 = !lean_is_exclusive(x_15); +if (x_28 == 0) +{ +return x_15; +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_15, 0); +x_30 = lean_ctor_get(x_15, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_15); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +else +{ +uint8_t x_32; +lean_dec(x_8); +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_13); +if (x_32 == 0) +{ +return x_13; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_13, 0); +x_34 = lean_ctor_get(x_13, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_13); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_33); +lean_ctor_set(x_35, 1, x_34); +return x_35; +} +} +} +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_36 = lean_ctor_get(x_6, 0); +x_37 = lean_ctor_get(x_6, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_6); +x_38 = lean_array_get_size(x_36); +x_39 = lean_unsigned_to_nat(1u); +x_40 = lean_nat_dec_lt(x_39, x_38); +lean_dec(x_38); +if (x_40 == 0) +{ +lean_object* x_41; +lean_dec(x_2); +x_41 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_37); +return x_41; +} +else +{ +lean_object* x_42; +lean_inc(x_2); +x_42 = l___private_Lean_Elab_Inductive_3__checkUnsafe(x_36, x_2, x_37); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_42, 1); +lean_inc(x_43); +lean_dec(x_42); +lean_inc(x_2); +x_44 = l___private_Lean_Elab_Inductive_2__checkNumParams(x_36, x_2, x_43); +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_44, 1); +lean_inc(x_46); +lean_dec(x_44); +x_47 = lean_box(0); +x_48 = l___private_Lean_Elab_Inductive_11__checkHeaders___main(x_36, x_45, x_4, x_47, x_2, x_46); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_48, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_48)) { + lean_ctor_release(x_48, 0); + lean_ctor_release(x_48, 1); + x_50 = x_48; +} else { + lean_dec_ref(x_48); + x_50 = lean_box(0); +} +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(0, 2, 0); +} else { + x_51 = x_50; +} +lean_ctor_set(x_51, 0, x_36); +lean_ctor_set(x_51, 1, x_49); +return x_51; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_dec(x_36); +x_52 = lean_ctor_get(x_48, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_48, 1); +lean_inc(x_53); +if (lean_is_exclusive(x_48)) { + lean_ctor_release(x_48, 0); + lean_ctor_release(x_48, 1); + x_54 = x_48; +} else { + lean_dec_ref(x_48); + x_54 = lean_box(0); +} +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_54; +} +lean_ctor_set(x_55, 0, x_52); +lean_ctor_set(x_55, 1, x_53); +return x_55; +} +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +lean_dec(x_36); +lean_dec(x_2); +x_56 = lean_ctor_get(x_44, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_44, 1); +lean_inc(x_57); +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + x_58 = x_44; +} else { + lean_dec_ref(x_44); + x_58 = lean_box(0); +} +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_58; +} +lean_ctor_set(x_59, 0, x_56); +lean_ctor_set(x_59, 1, x_57); +return x_59; +} +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +lean_dec(x_36); +lean_dec(x_2); +x_60 = lean_ctor_get(x_42, 0); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 1); +lean_inc(x_61); +if (lean_is_exclusive(x_42)) { + lean_ctor_release(x_42, 0); + lean_ctor_release(x_42, 1); + x_62 = x_42; +} else { + lean_dec_ref(x_42); + x_62 = lean_box(0); +} +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(1, 2, 0); +} else { + x_63 = x_62; +} +lean_ctor_set(x_63, 0, x_60); +lean_ctor_set(x_63, 1, x_61); +return x_63; +} +} +} +} +else +{ +uint8_t x_64; +lean_dec(x_2); +x_64 = !lean_is_exclusive(x_6); +if (x_64 == 0) +{ +return x_6; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_6, 0); +x_66 = lean_ctor_get(x_6, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_6); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_1, x_10); +x_12 = lean_array_push(x_2, x_7); +x_13 = l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg(x_3, x_4, x_5, x_6, x_11, x_12, x_8, x_9); +return x_13; +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_array_get_size(x_2); +x_10 = lean_nat_dec_lt(x_5, x_9); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_11 = lean_apply_4(x_4, x_3, x_6, x_7, x_8); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_12 = lean_array_fget(x_2, x_5); +x_13 = lean_ctor_get(x_8, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_12, 1); +lean_inc(x_15); +lean_dec(x_12); +x_16 = !lean_is_exclusive(x_13); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_17 = lean_ctor_get(x_13, 4); +x_18 = lean_ctor_get(x_7, 0); +lean_inc(x_18); +x_19 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_13, 4, x_19); +x_20 = lean_unsigned_to_nat(0u); +x_21 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main(x_3, x_20, x_15, x_18, x_13); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +lean_inc(x_7); +x_24 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_7, x_8, x_23, x_17); +lean_inc(x_1); +x_25 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1___boxed), 9, 6); +lean_closure_set(x_25, 0, x_5); +lean_closure_set(x_25, 1, x_6); +lean_closure_set(x_25, 2, x_1); +lean_closure_set(x_25, 3, x_2); +lean_closure_set(x_25, 4, x_3); +lean_closure_set(x_25, 5, x_4); +x_26 = 0; +x_27 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_14, x_26, x_22, x_25, x_7, x_24); +lean_dec(x_1); +return x_27; +} +else +{ +uint8_t x_28; +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_28 = !lean_is_exclusive(x_21); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_21, 0); +x_30 = lean_ctor_get(x_21, 1); +lean_inc(x_7); +x_31 = l___private_Lean_Elab_Term_2__fromMetaException(x_7, x_1, x_29); +x_32 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_7, x_8, x_30, x_17); +lean_dec(x_1); +lean_ctor_set(x_21, 1, x_32); +lean_ctor_set(x_21, 0, x_31); +return x_21; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_33 = lean_ctor_get(x_21, 0); +x_34 = lean_ctor_get(x_21, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_21); +lean_inc(x_7); +x_35 = l___private_Lean_Elab_Term_2__fromMetaException(x_7, x_1, x_33); +x_36 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_7, x_8, x_34, x_17); +lean_dec(x_1); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_38 = lean_ctor_get(x_13, 0); +x_39 = lean_ctor_get(x_13, 1); +x_40 = lean_ctor_get(x_13, 2); +x_41 = lean_ctor_get(x_13, 3); +x_42 = lean_ctor_get(x_13, 4); +x_43 = lean_ctor_get(x_13, 5); +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_13); +x_44 = lean_ctor_get(x_7, 0); +lean_inc(x_44); +x_45 = l_Lean_TraceState_Inhabited___closed__1; +x_46 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_46, 0, x_38); +lean_ctor_set(x_46, 1, x_39); +lean_ctor_set(x_46, 2, x_40); +lean_ctor_set(x_46, 3, x_41); +lean_ctor_set(x_46, 4, x_45); +lean_ctor_set(x_46, 5, x_43); +x_47 = lean_unsigned_to_nat(0u); +x_48 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main(x_3, x_47, x_15, x_44, x_46); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; uint8_t x_53; lean_object* x_54; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +lean_inc(x_7); +x_51 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_7, x_8, x_50, x_42); +lean_inc(x_1); +x_52 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1___boxed), 9, 6); +lean_closure_set(x_52, 0, x_5); +lean_closure_set(x_52, 1, x_6); +lean_closure_set(x_52, 2, x_1); +lean_closure_set(x_52, 3, x_2); +lean_closure_set(x_52, 4, x_3); +lean_closure_set(x_52, 5, x_4); +x_53 = 0; +x_54 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_14, x_53, x_49, x_52, x_7, x_51); +lean_dec(x_1); +return x_54; +} +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_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_55 = lean_ctor_get(x_48, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_48, 1); +lean_inc(x_56); +if (lean_is_exclusive(x_48)) { + lean_ctor_release(x_48, 0); + lean_ctor_release(x_48, 1); + x_57 = x_48; +} else { + lean_dec_ref(x_48); + x_57 = lean_box(0); +} +lean_inc(x_7); +x_58 = l___private_Lean_Elab_Term_2__fromMetaException(x_7, x_1, x_55); +x_59 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_7, x_8, x_56, x_42); +lean_dec(x_1); +if (lean_is_scalar(x_57)) { + x_60 = lean_alloc_ctor(1, 2, 0); +} else { + x_60 = x_57; +} +lean_ctor_set(x_60, 0, x_58); +lean_ctor_set(x_60, 1, x_59); +return x_60; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg), 8, 0); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_1); +return x_10; +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___main___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___rarg), 8, 0); +return x_2; +} +} +lean_object* l_Array_umapMAux___main___at___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_array_get_size(x_2); +x_6 = lean_nat_dec_lt(x_1, x_5); +lean_dec(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_3); +lean_dec(x_1); +x_7 = x_2; +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_4); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_array_fget(x_2, x_1); +x_10 = lean_unsigned_to_nat(0u); +x_11 = lean_array_fset(x_2, x_1, x_10); +x_12 = x_9; +lean_inc(x_3); +lean_inc(x_12); +x_13 = l___private_Lean_Elab_Inductive_5__mkTypeFor(x_12, x_3, x_4); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = lean_ctor_get(x_12, 0); +lean_inc(x_16); +lean_dec(x_12); +x_17 = lean_ctor_get(x_16, 2); +lean_inc(x_17); +lean_dec(x_16); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_14); +x_19 = lean_unsigned_to_nat(1u); +x_20 = lean_nat_add(x_1, x_19); +x_21 = x_18; +x_22 = lean_array_fset(x_11, x_1, x_21); +lean_dec(x_1); +x_1 = x_20; +x_2 = x_22; +x_4 = x_15; +goto _start; +} +else +{ +uint8_t x_24; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_3); +lean_dec(x_1); +x_24 = !lean_is_exclusive(x_13); +if (x_24 == 0) +{ +return x_13; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_13, 0); +x_26 = lean_ctor_get(x_13, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_13); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +lean_inc(x_1); +x_5 = x_1; +x_6 = lean_unsigned_to_nat(0u); +x_7 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___spec__1), 4, 2); +lean_closure_set(x_7, 0, x_6); +lean_closure_set(x_7, 1, x_5); +x_8 = x_7; +lean_inc(x_3); +x_9 = lean_apply_2(x_8, x_3, x_4); +if (lean_obj_tag(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_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +lean_dec(x_9); +x_12 = l_Lean_Elab_Command_ElabHeaderResult_inhabited; +x_13 = lean_array_get(x_12, x_1, x_6); +lean_dec(x_1); +x_14 = lean_ctor_get(x_13, 3); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +x_16 = lean_ctor_get(x_13, 2); +lean_inc(x_16); +x_17 = lean_ctor_get(x_13, 0); +lean_inc(x_17); +lean_dec(x_13); +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +lean_dec(x_17); +x_19 = l_Array_empty___closed__1; +x_20 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_13__withInductiveLocalDeclsAux___rarg), 8, 6); +lean_closure_set(x_20, 0, x_18); +lean_closure_set(x_20, 1, x_10); +lean_closure_set(x_20, 2, x_14); +lean_closure_set(x_20, 3, x_2); +lean_closure_set(x_20, 4, x_6); +lean_closure_set(x_20, 5, x_19); +x_21 = l_Lean_Elab_Term_withLocalContext___rarg(x_15, x_16, x_20, x_3, x_11); +return x_21; +} +else +{ +uint8_t x_22; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_22 = !lean_is_exclusive(x_9); +if (x_22 == 0) +{ +return x_9; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_9, 0); +x_24 = lean_ctor_get(x_9, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_9); +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___rarg), 4, 0); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_15__isInductiveFamily(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Elab_Term_inferType(x_1, x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +x_8 = l_Lean_Elab_Term_whnf(x_1, x_6, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_8, 0); +x_11 = l_Lean_Expr_isSort(x_10); +lean_dec(x_10); +if (x_11 == 0) +{ +uint8_t x_12; lean_object* x_13; +x_12 = 1; +x_13 = lean_box(x_12); +lean_ctor_set(x_8, 0, x_13); +return x_8; +} +else +{ +uint8_t x_14; lean_object* x_15; +x_14 = 0; +x_15 = lean_box(x_14); +lean_ctor_set(x_8, 0, x_15); +return x_8; +} +} +else +{ +lean_object* x_16; lean_object* x_17; uint8_t x_18; +x_16 = lean_ctor_get(x_8, 0); +x_17 = lean_ctor_get(x_8, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_8); +x_18 = l_Lean_Expr_isSort(x_16); +lean_dec(x_16); +if (x_18 == 0) +{ +uint8_t x_19; lean_object* x_20; lean_object* x_21; +x_19 = 1; +x_20 = lean_box(x_19); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_20); +lean_ctor_set(x_21, 1, x_17); +return x_21; +} +else +{ +uint8_t x_22; lean_object* x_23; lean_object* x_24; +x_22 = 0; +x_23 = lean_box(x_22); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_23); +lean_ctor_set(x_24, 1, x_17); +return x_24; +} +} +} +else +{ +uint8_t x_25; +x_25 = !lean_is_exclusive(x_8); +if (x_25 == 0) +{ +return x_8; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_8, 0); +x_27 = lean_ctor_get(x_8, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_8); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_dec(x_3); +x_29 = !lean_is_exclusive(x_5); +if (x_29 == 0) +{ +return x_5; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_5, 0); +x_31 = lean_ctor_get(x_5, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_5); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_15__isInductiveFamily___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_15__isInductiveFamily(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("constructor resulting type must be specified in inductive family declaration"); +return x_1; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unexpected constructor resulting type"); +return x_1; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unexpected constructor resulting type, type expected"); +return x_1; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_33; +x_8 = lean_ctor_get(x_1, 0); +lean_inc(x_8); +x_33 = lean_ctor_get(x_1, 4); +lean_inc(x_33); +if (lean_obj_tag(x_33) == 0) +{ +if (x_3 == 0) +{ +x_9 = x_4; +x_10 = x_7; +goto block_32; +} +else +{ +lean_object* x_34; lean_object* x_35; uint8_t x_36; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_34 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3; +x_35 = l_Lean_Elab_Term_throwError___rarg(x_8, x_34, x_6, x_7); +lean_dec(x_8); +x_36 = !lean_is_exclusive(x_35); +if (x_36 == 0) +{ +return x_35; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_35, 0); +x_38 = lean_ctor_get(x_35, 1); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_35); +x_39 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_39, 0, x_37); +lean_ctor_set(x_39, 1, x_38); +return x_39; +} +} +} +else +{ +lean_object* x_40; lean_object* x_41; uint8_t x_42; lean_object* x_43; +x_40 = lean_ctor_get(x_33, 0); +lean_inc(x_40); +lean_dec(x_33); +x_41 = lean_box(0); +x_42 = 1; +lean_inc(x_6); +x_43 = l_Lean_Elab_Term_elabTermAux___main(x_41, x_42, x_42, x_40, x_6, x_7); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_43, 1); +lean_inc(x_45); +lean_dec(x_43); +lean_inc(x_6); +lean_inc(x_44); +x_46 = l___private_Lean_Elab_Inductive_7__getResultingType(x_8, x_44, x_6, x_45); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; uint8_t x_50; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +x_49 = l_Lean_Expr_getAppFn___main(x_47); +x_50 = lean_expr_eqv(x_49, x_4); +lean_dec(x_4); +lean_dec(x_49); +if (x_50 == 0) +{ +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_dec(x_44); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_51 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_51, 0, x_47); +x_52 = l_Lean_indentExpr(x_51); +x_53 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6; +x_54 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_52); +x_55 = l_Lean_Elab_Term_throwError___rarg(x_8, x_54, x_6, x_48); +lean_dec(x_8); +x_56 = !lean_is_exclusive(x_55); +if (x_56 == 0) +{ +return x_55; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_55, 0); +x_58 = lean_ctor_get(x_55, 1); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_55); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +return x_59; +} +} +else +{ +lean_object* x_60; +lean_inc(x_6); +lean_inc(x_47); +x_60 = l_Lean_Elab_Term_isType(x_8, x_47, x_6, x_48); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; uint8_t x_62; +x_61 = lean_ctor_get(x_60, 0); +lean_inc(x_61); +x_62 = lean_unbox(x_61); +lean_dec(x_61); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; +lean_dec(x_44); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_63 = lean_ctor_get(x_60, 1); +lean_inc(x_63); +lean_dec(x_60); +x_64 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_64, 0, x_47); +x_65 = l_Lean_indentExpr(x_64); +x_66 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9; +x_67 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_65); +x_68 = l_Lean_Elab_Term_throwError___rarg(x_8, x_67, x_6, x_63); +lean_dec(x_8); +x_69 = !lean_is_exclusive(x_68); +if (x_69 == 0) +{ +return x_68; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_68, 0); +x_71 = lean_ctor_get(x_68, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_68); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +else +{ +lean_object* x_73; +lean_dec(x_47); +x_73 = lean_ctor_get(x_60, 1); +lean_inc(x_73); +lean_dec(x_60); +x_9 = x_44; +x_10 = x_73; +goto block_32; +} +} +else +{ +uint8_t x_74; +lean_dec(x_47); +lean_dec(x_44); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_60); +if (x_74 == 0) +{ +return x_60; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_60, 0); +x_76 = lean_ctor_get(x_60, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_60); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +} +else +{ +uint8_t x_78; +lean_dec(x_44); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_46); +if (x_78 == 0) +{ +return x_46; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_46, 0); +x_80 = lean_ctor_get(x_46, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_46); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +else +{ +uint8_t x_82; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_82 = !lean_is_exclusive(x_43); +if (x_82 == 0) +{ +return x_43; +} +else +{ +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_43, 0); +x_84 = lean_ctor_get(x_43, 1); +lean_inc(x_84); +lean_inc(x_83); +lean_dec(x_43); +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; +} +} +} +block_32: +{ +lean_object* x_11; +lean_inc(x_6); +x_11 = l_Lean_Elab_Term_mkForall(x_8, x_5, x_9, x_6, x_10); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); +x_14 = l_Lean_Elab_Term_mkForall(x_8, x_2, x_12, x_6, x_13); +lean_dec(x_8); +if (lean_obj_tag(x_14) == 0) +{ +uint8_t x_15; +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_14, 0); +x_17 = lean_ctor_get(x_1, 2); +lean_inc(x_17); +lean_dec(x_1); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_16); +lean_ctor_set(x_14, 0, x_18); +return x_14; +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_14, 0); +x_20 = lean_ctor_get(x_14, 1); +lean_inc(x_20); +lean_inc(x_19); +lean_dec(x_14); +x_21 = lean_ctor_get(x_1, 2); +lean_inc(x_21); +lean_dec(x_1); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_19); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_20); +return x_23; +} +} +else +{ +uint8_t x_24; +lean_dec(x_1); +x_24 = !lean_is_exclusive(x_14); +if (x_24 == 0) +{ +return x_14; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_14, 0); +x_26 = lean_ctor_get(x_14, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_14); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +uint8_t x_28; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_28 = !lean_is_exclusive(x_11); +if (x_28 == 0) +{ +return x_11; +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_11, 0); +x_30 = lean_ctor_get(x_11, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_11); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_6); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_4); +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; +x_10 = lean_ctor_get(x_4, 0); +x_11 = lean_ctor_get(x_4, 1); +x_12 = lean_ctor_get(x_10, 3); +lean_inc(x_12); +x_13 = l_Lean_Syntax_getArgs(x_12); +lean_dec(x_12); +x_14 = lean_box(x_3); +lean_inc(x_1); +lean_inc(x_2); +x_15 = lean_alloc_closure((void*)(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___boxed), 7, 4); +lean_closure_set(x_15, 0, x_10); +lean_closure_set(x_15, 1, x_2); +lean_closure_set(x_15, 2, x_14); +lean_closure_set(x_15, 3, x_1); +lean_inc(x_5); +x_16 = l_Lean_Elab_Term_elabBinders___rarg(x_13, x_15, x_5, x_6); +lean_dec(x_13); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +x_19 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(x_1, x_2, x_3, x_11, x_5, x_18); +if (lean_obj_tag(x_19) == 0) +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 0); +lean_ctor_set(x_4, 1, x_21); +lean_ctor_set(x_4, 0, x_17); +lean_ctor_set(x_19, 0, x_4); +return x_19; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_19, 0); +x_23 = lean_ctor_get(x_19, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_19); +lean_ctor_set(x_4, 1, x_22); +lean_ctor_set(x_4, 0, x_17); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_4); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +uint8_t x_25; +lean_dec(x_17); +lean_free_object(x_4); +x_25 = !lean_is_exclusive(x_19); +if (x_25 == 0) +{ +return x_19; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_19, 0); +x_27 = lean_ctor_get(x_19, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_19); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_free_object(x_4); +lean_dec(x_11); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_16); +if (x_29 == 0) +{ +return x_16; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_16, 0); +x_31 = lean_ctor_get(x_16, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_16); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +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; +x_33 = lean_ctor_get(x_4, 0); +x_34 = lean_ctor_get(x_4, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_4); +x_35 = lean_ctor_get(x_33, 3); +lean_inc(x_35); +x_36 = l_Lean_Syntax_getArgs(x_35); +lean_dec(x_35); +x_37 = lean_box(x_3); +lean_inc(x_1); +lean_inc(x_2); +x_38 = lean_alloc_closure((void*)(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___boxed), 7, 4); +lean_closure_set(x_38, 0, x_33); +lean_closure_set(x_38, 1, x_2); +lean_closure_set(x_38, 2, x_37); +lean_closure_set(x_38, 3, x_1); +lean_inc(x_5); +x_39 = l_Lean_Elab_Term_elabBinders___rarg(x_36, x_38, x_5, x_6); +lean_dec(x_36); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +x_42 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(x_1, x_2, x_3, x_34, x_5, x_41); +if (lean_obj_tag(x_42) == 0) +{ +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_42, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_42)) { + lean_ctor_release(x_42, 0); + lean_ctor_release(x_42, 1); + x_45 = x_42; +} else { + lean_dec_ref(x_42); + x_45 = lean_box(0); +} +x_46 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_46, 0, x_40); +lean_ctor_set(x_46, 1, x_43); +if (lean_is_scalar(x_45)) { + x_47 = lean_alloc_ctor(0, 2, 0); +} else { + x_47 = x_45; +} +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_44); +return x_47; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_40); +x_48 = lean_ctor_get(x_42, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_42, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_42)) { + lean_ctor_release(x_42, 0); + lean_ctor_release(x_42, 1); + x_50 = x_42; +} else { + lean_dec_ref(x_42); + x_50 = lean_box(0); +} +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_50; +} +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_49); +return x_51; +} +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_52 = lean_ctor_get(x_39, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_39, 1); +lean_inc(x_53); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + x_54 = x_39; +} else { + lean_dec_ref(x_39); + x_54 = lean_box(0); +} +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_54; +} +lean_ctor_set(x_55, 0, x_52); +lean_ctor_set(x_55, 1, x_53); +return x_55; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_16__elabCtors(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; +x_6 = lean_ctor_get(x_3, 0); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_4); +lean_inc(x_1); +x_8 = l___private_Lean_Elab_Inductive_15__isInductiveFamily(x_7, x_1, x_4, x_5); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = lean_ctor_get(x_6, 7); +x_12 = l_Array_toList___rarg(x_11); +x_13 = lean_unbox(x_9); +lean_dec(x_9); +x_14 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(x_1, x_2, x_13, x_12, x_4, x_10); +return x_14; +} +else +{ +uint8_t x_15; +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_15 = !lean_is_exclusive(x_8); +if (x_15 == 0) +{ +return x_8; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_8, 0); +x_17 = lean_ctor_get(x_8, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_8); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +uint8_t x_8; lean_object* x_9; +x_8 = lean_unbox(x_3); +lean_dec(x_3); +x_9 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1(x_1, x_2, x_8, x_4, x_5, x_6, x_7); +return x_9; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; lean_object* x_8; +x_7 = lean_unbox(x_3); +lean_dec(x_3); +x_8 = l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1(x_1, x_2, x_7, x_4, x_5, x_6); +return x_8; +} +} +lean_object* l___private_Lean_Elab_Inductive_16__elabCtors___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_16__elabCtors(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_4); +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); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_5); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_2); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_2, 0); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; +x_12 = lean_ctor_get(x_2, 1); +x_13 = lean_ctor_get(x_10, 1); +lean_inc(x_4); +x_14 = l_Lean_Elab_Term_instantiateMVars(x_1, x_13, x_4, x_5); +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +lean_inc(x_4); +x_17 = l_Lean_Elab_Term_levelMVarToParam_x27(x_15, x_3, x_4, x_16); +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +lean_dec(x_17); +x_20 = lean_ctor_get(x_18, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_18, 1); +lean_inc(x_21); +lean_dec(x_18); +lean_ctor_set(x_10, 1, x_20); +x_22 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_12, x_21, x_4, x_19); +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; uint8_t x_25; +x_24 = lean_ctor_get(x_22, 0); +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_24, 0); +lean_ctor_set(x_2, 1, x_26); +lean_ctor_set(x_24, 0, x_2); +return x_22; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_24, 0); +x_28 = lean_ctor_get(x_24, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_24); +lean_ctor_set(x_2, 1, x_27); +x_29 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_29, 0, x_2); +lean_ctor_set(x_29, 1, x_28); +lean_ctor_set(x_22, 0, x_29); +return x_22; +} +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_30 = lean_ctor_get(x_22, 0); +x_31 = lean_ctor_get(x_22, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_22); +x_32 = lean_ctor_get(x_30, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 1); +lean_inc(x_33); +if (lean_is_exclusive(x_30)) { + lean_ctor_release(x_30, 0); + lean_ctor_release(x_30, 1); + x_34 = x_30; +} else { + lean_dec_ref(x_30); + x_34 = lean_box(0); +} +lean_ctor_set(x_2, 1, x_32); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 2, 0); +} else { + x_35 = x_34; +} +lean_ctor_set(x_35, 0, x_2); +lean_ctor_set(x_35, 1, x_33); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_31); +return x_36; +} +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; 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_37 = lean_ctor_get(x_2, 1); +x_38 = lean_ctor_get(x_10, 0); +x_39 = lean_ctor_get(x_10, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_10); +lean_inc(x_4); +x_40 = l_Lean_Elab_Term_instantiateMVars(x_1, x_39, x_4, x_5); +x_41 = lean_ctor_get(x_40, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_40, 1); +lean_inc(x_42); +lean_dec(x_40); +lean_inc(x_4); +x_43 = l_Lean_Elab_Term_levelMVarToParam_x27(x_41, x_3, x_4, x_42); +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_43, 1); +lean_inc(x_45); +lean_dec(x_43); +x_46 = lean_ctor_get(x_44, 0); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 1); +lean_inc(x_47); +lean_dec(x_44); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_38); +lean_ctor_set(x_48, 1, x_46); +x_49 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_37, x_47, x_4, x_45); +x_50 = lean_ctor_get(x_49, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_49, 1); +lean_inc(x_51); +if (lean_is_exclusive(x_49)) { + lean_ctor_release(x_49, 0); + lean_ctor_release(x_49, 1); + x_52 = x_49; +} else { + lean_dec_ref(x_49); + x_52 = lean_box(0); +} +x_53 = lean_ctor_get(x_50, 0); +lean_inc(x_53); +x_54 = lean_ctor_get(x_50, 1); +lean_inc(x_54); +if (lean_is_exclusive(x_50)) { + lean_ctor_release(x_50, 0); + lean_ctor_release(x_50, 1); + x_55 = x_50; +} else { + lean_dec_ref(x_50); + x_55 = lean_box(0); +} +lean_ctor_set(x_2, 1, x_53); +lean_ctor_set(x_2, 0, x_48); +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 2, 0); +} else { + x_56 = x_55; +} +lean_ctor_set(x_56, 0, x_2); +lean_ctor_set(x_56, 1, x_54); +if (lean_is_scalar(x_52)) { + x_57 = lean_alloc_ctor(0, 2, 0); +} else { + x_57 = x_52; +} +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_51); +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_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; +x_58 = lean_ctor_get(x_2, 0); +x_59 = lean_ctor_get(x_2, 1); +lean_inc(x_59); +lean_inc(x_58); +lean_dec(x_2); +x_60 = lean_ctor_get(x_58, 0); +lean_inc(x_60); +x_61 = lean_ctor_get(x_58, 1); +lean_inc(x_61); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + x_62 = x_58; +} else { + lean_dec_ref(x_58); + x_62 = lean_box(0); +} +lean_inc(x_4); +x_63 = l_Lean_Elab_Term_instantiateMVars(x_1, x_61, x_4, x_5); +x_64 = lean_ctor_get(x_63, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_63, 1); +lean_inc(x_65); +lean_dec(x_63); +lean_inc(x_4); +x_66 = l_Lean_Elab_Term_levelMVarToParam_x27(x_64, x_3, x_4, x_65); +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_ctor_get(x_67, 0); +lean_inc(x_69); +x_70 = lean_ctor_get(x_67, 1); +lean_inc(x_70); +lean_dec(x_67); +if (lean_is_scalar(x_62)) { + x_71 = lean_alloc_ctor(0, 2, 0); +} else { + x_71 = x_62; +} +lean_ctor_set(x_71, 0, x_60); +lean_ctor_set(x_71, 1, x_69); +x_72 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_59, x_70, x_4, x_68); +x_73 = lean_ctor_get(x_72, 0); +lean_inc(x_73); +x_74 = lean_ctor_get(x_72, 1); +lean_inc(x_74); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + x_75 = x_72; +} else { + lean_dec_ref(x_72); + x_75 = lean_box(0); +} +x_76 = lean_ctor_get(x_73, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_73, 1); +lean_inc(x_77); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_78 = x_73; +} else { + lean_dec_ref(x_73); + x_78 = lean_box(0); +} +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_71); +lean_ctor_set(x_79, 1, x_76); +if (lean_is_scalar(x_78)) { + x_80 = lean_alloc_ctor(0, 2, 0); +} else { + x_80 = x_78; +} +lean_ctor_set(x_80, 0, x_79); +lean_ctor_set(x_80, 1, x_77); +if (lean_is_scalar(x_75)) { + x_81 = lean_alloc_ctor(0, 2, 0); +} else { + x_81 = x_75; +} +lean_ctor_set(x_81, 0, x_80); +lean_ctor_set(x_81, 1, x_74); +return x_81; +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_4); +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); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_5); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_2); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_2, 0); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +x_12 = lean_ctor_get(x_2, 1); +x_13 = lean_ctor_get(x_10, 1); +x_14 = lean_ctor_get(x_10, 2); +lean_inc(x_4); +x_15 = l_Lean_Elab_Term_instantiateMVars(x_1, x_13, x_4, x_5); +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +lean_inc(x_4); +x_18 = l_Lean_Elab_Term_levelMVarToParam_x27(x_16, x_3, x_4, x_17); +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = lean_ctor_get(x_19, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_dec(x_19); +lean_inc(x_4); +x_23 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_14, x_22, x_4, x_20); +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +x_25 = lean_ctor_get(x_23, 1); +lean_inc(x_25); +lean_dec(x_23); +x_26 = lean_ctor_get(x_24, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +lean_dec(x_24); +lean_ctor_set(x_10, 2, x_26); +lean_ctor_set(x_10, 1, x_21); +x_28 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_12, x_27, x_4, x_25); +x_29 = !lean_is_exclusive(x_28); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_28, 0); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = lean_ctor_get(x_30, 0); +lean_ctor_set(x_2, 1, x_32); +lean_ctor_set(x_30, 0, x_2); +return x_28; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_30, 0); +x_34 = lean_ctor_get(x_30, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_30); +lean_ctor_set(x_2, 1, x_33); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_2); +lean_ctor_set(x_35, 1, x_34); +lean_ctor_set(x_28, 0, x_35); +return x_28; +} +} +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; +x_36 = lean_ctor_get(x_28, 0); +x_37 = lean_ctor_get(x_28, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_28); +x_38 = lean_ctor_get(x_36, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +if (lean_is_exclusive(x_36)) { + lean_ctor_release(x_36, 0); + lean_ctor_release(x_36, 1); + x_40 = x_36; +} else { + lean_dec_ref(x_36); + x_40 = lean_box(0); +} +lean_ctor_set(x_2, 1, x_38); +if (lean_is_scalar(x_40)) { + x_41 = lean_alloc_ctor(0, 2, 0); +} else { + x_41 = x_40; +} +lean_ctor_set(x_41, 0, x_2); +lean_ctor_set(x_41, 1, x_39); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_41); +lean_ctor_set(x_42, 1, x_37); +return x_42; +} +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; 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_43 = lean_ctor_get(x_2, 1); +x_44 = lean_ctor_get(x_10, 0); +x_45 = lean_ctor_get(x_10, 1); +x_46 = lean_ctor_get(x_10, 2); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_10); +lean_inc(x_4); +x_47 = l_Lean_Elab_Term_instantiateMVars(x_1, x_45, x_4, x_5); +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +lean_inc(x_4); +x_50 = l_Lean_Elab_Term_levelMVarToParam_x27(x_48, x_3, x_4, x_49); +x_51 = lean_ctor_get(x_50, 0); +lean_inc(x_51); +x_52 = lean_ctor_get(x_50, 1); +lean_inc(x_52); +lean_dec(x_50); +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); +lean_inc(x_4); +x_55 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_46, x_54, x_4, x_52); +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = lean_ctor_get(x_56, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +lean_dec(x_56); +x_60 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_60, 0, x_44); +lean_ctor_set(x_60, 1, x_53); +lean_ctor_set(x_60, 2, x_58); +x_61 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_43, x_59, x_4, x_57); +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +x_63 = lean_ctor_get(x_61, 1); +lean_inc(x_63); +if (lean_is_exclusive(x_61)) { + lean_ctor_release(x_61, 0); + lean_ctor_release(x_61, 1); + x_64 = x_61; +} else { + lean_dec_ref(x_61); + x_64 = lean_box(0); +} +x_65 = lean_ctor_get(x_62, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_62, 1); +lean_inc(x_66); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + x_67 = x_62; +} else { + lean_dec_ref(x_62); + x_67 = lean_box(0); +} +lean_ctor_set(x_2, 1, x_65); +lean_ctor_set(x_2, 0, x_60); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 2, 0); +} else { + x_68 = x_67; +} +lean_ctor_set(x_68, 0, x_2); +lean_ctor_set(x_68, 1, x_66); +if (lean_is_scalar(x_64)) { + x_69 = lean_alloc_ctor(0, 2, 0); +} else { + x_69 = x_64; +} +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_63); +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; 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; +x_70 = lean_ctor_get(x_2, 0); +x_71 = lean_ctor_get(x_2, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_2); +x_72 = lean_ctor_get(x_70, 0); +lean_inc(x_72); +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +x_74 = lean_ctor_get(x_70, 2); +lean_inc(x_74); +if (lean_is_exclusive(x_70)) { + lean_ctor_release(x_70, 0); + lean_ctor_release(x_70, 1); + lean_ctor_release(x_70, 2); + x_75 = x_70; +} else { + lean_dec_ref(x_70); + x_75 = lean_box(0); +} +lean_inc(x_4); +x_76 = l_Lean_Elab_Term_instantiateMVars(x_1, x_73, x_4, x_5); +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); +lean_inc(x_4); +x_79 = l_Lean_Elab_Term_levelMVarToParam_x27(x_77, x_3, x_4, x_78); +x_80 = lean_ctor_get(x_79, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_79, 1); +lean_inc(x_81); +lean_dec(x_79); +x_82 = lean_ctor_get(x_80, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_80, 1); +lean_inc(x_83); +lean_dec(x_80); +lean_inc(x_4); +x_84 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_74, x_83, x_4, x_81); +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_ctor_get(x_85, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_85, 1); +lean_inc(x_88); +lean_dec(x_85); +if (lean_is_scalar(x_75)) { + x_89 = lean_alloc_ctor(0, 3, 0); +} else { + x_89 = x_75; +} +lean_ctor_set(x_89, 0, x_72); +lean_ctor_set(x_89, 1, x_82); +lean_ctor_set(x_89, 2, x_87); +x_90 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_71, x_88, x_4, x_86); +x_91 = lean_ctor_get(x_90, 0); +lean_inc(x_91); +x_92 = lean_ctor_get(x_90, 1); +lean_inc(x_92); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + x_93 = x_90; +} else { + lean_dec_ref(x_90); + x_93 = lean_box(0); +} +x_94 = lean_ctor_get(x_91, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_91, 1); +lean_inc(x_95); +if (lean_is_exclusive(x_91)) { + lean_ctor_release(x_91, 0); + lean_ctor_release(x_91, 1); + x_96 = x_91; +} else { + lean_dec_ref(x_91); + x_96 = lean_box(0); +} +x_97 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_97, 0, x_89); +lean_ctor_set(x_97, 1, x_94); +if (lean_is_scalar(x_96)) { + x_98 = lean_alloc_ctor(0, 2, 0); +} else { + x_98 = x_96; +} +lean_ctor_set(x_98, 0, x_97); +lean_ctor_set(x_98, 1, x_95); +if (lean_is_scalar(x_93)) { + x_99 = lean_alloc_ctor(0, 2, 0); +} else { + x_99 = x_93; +} +lean_ctor_set(x_99, 0, x_98); +lean_ctor_set(x_99, 1, x_92); +return x_99; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_17__levelMVarToParamAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_2, x_3, x_4, x_5); +return x_6; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_17__levelMVarToParamAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_17__levelMVarToParamAux(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_18__levelMVarToParam(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; uint8_t x_7; +x_5 = lean_unsigned_to_nat(1u); +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_17__levelMVarToParamAux___spec__2(x_1, x_2, x_5, x_3, x_4); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +x_8 = lean_ctor_get(x_6, 0); +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +lean_dec(x_8); +lean_ctor_set(x_6, 0, x_9); +return x_6; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_6, 0); +x_11 = lean_ctor_get(x_6, 1); +lean_inc(x_11); +lean_inc(x_10); +lean_dec(x_6); +x_12 = lean_ctor_get(x_10, 0); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_11); +return x_13; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_18__levelMVarToParam___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_18__levelMVarToParam(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unexpected empty inductive declaration"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("unexpected inductive type resulting type"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_5; lean_object* x_6; +x_5 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3; +x_6 = l_Lean_Elab_Term_throwError___rarg(x_1, x_5, x_3, x_4); +return x_6; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_2, 0); +lean_inc(x_7); +lean_dec(x_2); +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); +lean_dec(x_7); +lean_inc(x_3); +x_9 = l___private_Lean_Elab_Inductive_7__getResultingType(x_1, x_8, x_3, x_4); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +if (lean_obj_tag(x_10) == 3) +{ +uint8_t x_11; +lean_dec(x_3); +x_11 = !lean_is_exclusive(x_9); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_9, 0); +lean_dec(x_12); +x_13 = lean_ctor_get(x_10, 0); +lean_inc(x_13); +lean_dec(x_10); +lean_ctor_set(x_9, 0, x_13); +return x_9; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_9, 1); +lean_inc(x_14); +lean_dec(x_9); +x_15 = lean_ctor_get(x_10, 0); +lean_inc(x_15); +lean_dec(x_10); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_dec(x_10); +x_17 = lean_ctor_get(x_9, 1); +lean_inc(x_17); +lean_dec(x_9); +x_18 = l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6; +x_19 = l_Lean_Elab_Term_throwError___rarg(x_1, x_18, x_3, x_17); +return x_19; +} +} +else +{ +uint8_t x_20; +lean_dec(x_3); +x_20 = !lean_is_exclusive(x_9); +if (x_20 == 0) +{ +return x_9; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_9, 0); +x_22 = lean_ctor_get(x_9, 1); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_9); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_19__getResultingUniverse___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_19__getResultingUniverse(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("_tmp_ind_univ_param"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2; +x_2 = l_Lean_mkLevelParam(x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_20__tmpIndParam() { +_start: +{ +lean_object* x_1; +x_1 = l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3; +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("cannot infer resulting universe level of inductive datatype, given level contains metavariables "); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string(", provide universe explicitly"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l___private_Lean_Elab_Inductive_19__getResultingUniverse(x_1, x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +x_8 = l_Lean_Elab_Term_instantiateLevelMVars(x_1, x_6, x_3, x_7); +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_10 = lean_ctor_get(x_8, 0); +x_11 = lean_ctor_get(x_8, 1); +x_12 = l_Lean_Level_hasMVar(x_10); +if (x_12 == 0) +{ +uint8_t x_13; lean_object* x_14; +lean_dec(x_10); +lean_dec(x_3); +x_13 = 0; +x_14 = lean_box(x_13); +lean_ctor_set(x_8, 0, x_14); +return x_8; +} +else +{ +lean_object* x_15; +lean_free_object(x_8); +x_15 = l_Lean_Level_getLevelOffset___main(x_10); +if (lean_obj_tag(x_15) == 5) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; +lean_dec(x_10); +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +lean_dec(x_15); +x_17 = l___private_Lean_Elab_Inductive_20__tmpIndParam; +x_18 = l_Lean_Elab_Term_assignLevelMVar(x_16, x_17, x_3, x_11); +lean_dec(x_3); +x_19 = !lean_is_exclusive(x_18); +if (x_19 == 0) +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_18, 0); +lean_dec(x_20); +x_21 = 1; +x_22 = lean_box(x_21); +lean_ctor_set(x_18, 0, x_22); +return x_18; +} +else +{ +lean_object* x_23; uint8_t x_24; lean_object* x_25; lean_object* x_26; +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_dec(x_18); +x_24 = 1; +x_25 = lean_box(x_24); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_23); +return x_26; +} +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +lean_dec(x_15); +x_27 = l_Lean_mkSort(x_10); +x_28 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_28, 0, x_27); +x_29 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3; +x_30 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_28); +x_31 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6; +x_32 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +x_33 = l_Lean_Elab_Term_throwError___rarg(x_1, x_32, x_3, x_11); +return x_33; +} +} +} +else +{ +lean_object* x_34; lean_object* x_35; uint8_t x_36; +x_34 = lean_ctor_get(x_8, 0); +x_35 = lean_ctor_get(x_8, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_8); +x_36 = l_Lean_Level_hasMVar(x_34); +if (x_36 == 0) +{ +uint8_t x_37; lean_object* x_38; lean_object* x_39; +lean_dec(x_34); +lean_dec(x_3); +x_37 = 0; +x_38 = lean_box(x_37); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_35); +return x_39; +} +else +{ +lean_object* x_40; +x_40 = l_Lean_Level_getLevelOffset___main(x_34); +if (lean_obj_tag(x_40) == 5) +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; +lean_dec(x_34); +x_41 = lean_ctor_get(x_40, 0); +lean_inc(x_41); +lean_dec(x_40); +x_42 = l___private_Lean_Elab_Inductive_20__tmpIndParam; +x_43 = l_Lean_Elab_Term_assignLevelMVar(x_41, x_42, x_3, x_35); +lean_dec(x_3); +x_44 = lean_ctor_get(x_43, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_43)) { + lean_ctor_release(x_43, 0); + lean_ctor_release(x_43, 1); + x_45 = x_43; +} else { + lean_dec_ref(x_43); + x_45 = lean_box(0); +} +x_46 = 1; +x_47 = lean_box(x_46); +if (lean_is_scalar(x_45)) { + x_48 = lean_alloc_ctor(0, 2, 0); +} else { + x_48 = x_45; +} +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_44); +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_54; lean_object* x_55; +lean_dec(x_40); +x_49 = l_Lean_mkSort(x_34); +x_50 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_50, 0, x_49); +x_51 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3; +x_52 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_50); +x_53 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6; +x_54 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +x_55 = l_Lean_Elab_Term_throwError___rarg(x_1, x_54, x_3, x_35); +return x_55; +} +} +} +} +else +{ +uint8_t x_56; +lean_dec(x_3); +x_56 = !lean_is_exclusive(x_5); +if (x_56 == 0) +{ +return x_5; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_5, 0); +x_58 = lean_ctor_get(x_5, 1); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_5); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +return x_59; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_fget(x_3, x_5); +x_9 = lean_level_eq(x_2, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_5, x_10); +lean_dec(x_5); +x_5 = x_11; +goto _start; +} +else +{ +lean_dec(x_5); +return x_9; +} +} +} +} +uint8_t l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; uint8_t x_5; +x_3 = lean_array_get_size(x_1); +x_4 = lean_unsigned_to_nat(0u); +x_5 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2(x_1, x_2, x_1, x_3, x_4); +lean_dec(x_3); +return x_5; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("failed to compute resulting universe level of inductive datatype, provide universe explicitly"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 0: +{ +lean_object* x_5; +lean_dec(x_3); +lean_dec(x_1); +x_5 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_5, 0, x_4); +return x_5; +} +case 1: +{ +lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = lean_unsigned_to_nat(0u); +x_8 = lean_nat_dec_eq(x_3, x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_1); +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_sub(x_3, x_9); +lean_dec(x_3); +x_1 = x_6; +x_3 = x_10; +goto _start; +} +else +{ +uint8_t x_12; +lean_dec(x_6); +lean_dec(x_3); +x_12 = lean_level_eq(x_1, x_2); +if (x_12 == 0) +{ +uint8_t x_13; +x_13 = l_Lean_Level_occurs___main(x_2, x_1); +if (x_13 == 0) +{ +uint8_t x_14; +x_14 = l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(x_4, x_1); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_array_push(x_4, x_1); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +return x_16; +} +else +{ +lean_object* x_17; +lean_dec(x_1); +x_17 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_17, 0, x_4); +return x_17; +} +} +else +{ +lean_object* x_18; +lean_dec(x_4); +lean_dec(x_1); +x_18 = l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2; +return x_18; +} +} +else +{ +lean_object* x_19; +lean_dec(x_1); +x_19 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_19, 0, x_4); +return x_19; +} +} +} +case 2: +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_1, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_1, 1); +lean_inc(x_21); +lean_dec(x_1); +lean_inc(x_3); +x_22 = l___private_Lean_Elab_Inductive_22__addLevel___main(x_20, x_2, x_3, x_4); +if (lean_obj_tag(x_22) == 0) +{ +uint8_t x_23; +lean_dec(x_21); +lean_dec(x_3); +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +return x_22; +} +else +{ +lean_object* x_24; lean_object* x_25; +x_24 = lean_ctor_get(x_22, 0); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_25, 0, x_24); +return x_25; +} +} +else +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_22, 0); +lean_inc(x_26); +lean_dec(x_22); +x_1 = x_21; +x_4 = x_26; +goto _start; +} +} +default: +{ +lean_object* x_28; uint8_t x_29; +x_28 = lean_unsigned_to_nat(0u); +x_29 = lean_nat_dec_eq(x_3, x_28); +lean_dec(x_3); +if (x_29 == 0) +{ +uint8_t x_30; +x_30 = l_Lean_Level_occurs___main(x_2, x_1); +if (x_30 == 0) +{ +uint8_t x_31; +x_31 = l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(x_4, x_1); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; +x_32 = lean_array_push(x_4, x_1); +x_33 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_33, 0, x_32); +return x_33; +} +else +{ +lean_object* x_34; +lean_dec(x_1); +x_34 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_34, 0, x_4); +return x_34; +} +} +else +{ +lean_object* x_35; +lean_dec(x_4); +lean_dec(x_1); +x_35 = l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2; +return x_35; +} +} +else +{ +uint8_t x_36; +x_36 = lean_level_eq(x_1, x_2); +if (x_36 == 0) +{ +uint8_t x_37; +x_37 = l_Lean_Level_occurs___main(x_2, x_1); +if (x_37 == 0) +{ +uint8_t x_38; +x_38 = l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(x_4, x_1); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_array_push(x_4, x_1); +x_40 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_40, 0, x_39); +return x_40; +} +else +{ +lean_object* x_41; +lean_dec(x_1); +x_41 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_41, 0, x_4); +return x_41; +} +} +else +{ +lean_object* x_42; +lean_dec(x_4); +lean_dec(x_1); +x_42 = l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2; +return x_42; +} +} +else +{ +lean_object* x_43; +lean_dec(x_1); +x_43 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_43, 0, x_4); +return x_43; +} +} +} +} +} +} +lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; lean_object* x_4; +x_3 = l_Array_contains___at___private_Lean_Elab_Inductive_22__addLevel___main___spec__1(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +x_4 = lean_box(x_3); +return x_4; +} +} +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_22__addLevel___main(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_22__addLevel(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_22__addLevel___main(x_1, x_2, x_3, x_4); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_22__addLevel___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_22__addLevel(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_expr_instantiate1(x_1, x_7); +x_11 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_2, x_3, x_4, x_5, x_10, x_6, x_8, x_9); +return x_11; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_expr_instantiate1(x_1, x_6); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_2, x_3, x_4, x_10, x_9, x_5, x_7, x_8); +return x_11; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_nat_dec_eq(x_4, x_9); +if (x_10 == 0) +{ +if (lean_obj_tag(x_5) == 7) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; uint64_t x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_object* x_18; lean_object* x_19; +x_11 = lean_ctor_get(x_5, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_5, 1); +lean_inc(x_12); +x_13 = lean_ctor_get(x_5, 2); +lean_inc(x_13); +x_14 = lean_ctor_get_uint64(x_5, sizeof(void*)*3); +lean_dec(x_5); +x_15 = lean_unsigned_to_nat(1u); +x_16 = lean_nat_sub(x_4, x_15); +x_17 = (uint8_t)((x_14 << 24) >> 61); +lean_inc(x_1); +x_18 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1___boxed), 9, 6); +lean_closure_set(x_18, 0, x_13); +lean_closure_set(x_18, 1, x_1); +lean_closure_set(x_18, 2, x_2); +lean_closure_set(x_18, 3, x_3); +lean_closure_set(x_18, 4, x_16); +lean_closure_set(x_18, 5, x_6); +x_19 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_11, x_17, x_12, x_18, x_7, x_8); +lean_dec(x_1); +return x_19; +} +else +{ +lean_object* x_20; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_6); +lean_ctor_set(x_20, 1, x_8); +return x_20; +} +} +else +{ +if (lean_obj_tag(x_5) == 7) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; uint64_t x_24; lean_object* x_25; +x_21 = lean_ctor_get(x_5, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_5, 1); +lean_inc(x_22); +x_23 = lean_ctor_get(x_5, 2); +lean_inc(x_23); +x_24 = lean_ctor_get_uint64(x_5, sizeof(void*)*3); +lean_dec(x_5); +lean_inc(x_7); +lean_inc(x_22); +x_25 = l_Lean_Elab_Term_getLevel(x_1, x_22, x_7, x_8); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +lean_inc(x_7); +x_28 = l_Lean_Elab_Term_instantiateLevelMVars(x_1, x_26, x_7, x_27); +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +lean_inc(x_3); +x_31 = l___private_Lean_Elab_Inductive_22__addLevel___main(x_29, x_2, x_3, x_6); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +lean_dec(x_23); +lean_dec(x_22); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +lean_dec(x_31); +x_33 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_33, 0, x_32); +x_34 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_34, 0, x_33); +x_35 = l_Lean_Elab_Term_throwError___rarg(x_1, x_34, x_7, x_30); +lean_dec(x_1); +return x_35; +} +else +{ +lean_object* x_36; uint8_t x_37; lean_object* x_38; lean_object* x_39; +x_36 = lean_ctor_get(x_31, 0); +lean_inc(x_36); +lean_dec(x_31); +x_37 = (uint8_t)((x_24 << 24) >> 61); +lean_inc(x_1); +x_38 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2___boxed), 8, 5); +lean_closure_set(x_38, 0, x_23); +lean_closure_set(x_38, 1, x_1); +lean_closure_set(x_38, 2, x_2); +lean_closure_set(x_38, 3, x_3); +lean_closure_set(x_38, 4, x_36); +x_39 = l_Lean_Elab_Term_withLocalDecl___rarg(x_1, x_21, x_37, x_22, x_38, x_7, x_30); +lean_dec(x_1); +return x_39; +} +} +else +{ +uint8_t x_40; +lean_dec(x_23); +lean_dec(x_22); +lean_dec(x_21); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_40 = !lean_is_exclusive(x_25); +if (x_40 == 0) +{ +return x_25; +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_25, 0); +x_42 = lean_ctor_get(x_25, 1); +lean_inc(x_42); +lean_inc(x_41); +lean_dec(x_25); +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_41); +lean_ctor_set(x_43, 1, x_42); +return x_43; +} +} +} +else +{ +lean_object* x_44; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_6); +lean_ctor_set(x_44, 1, x_8); +return x_44; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_1); +return x_10; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_1); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_4); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_4); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_24__collectUniversesFromCtorType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_1, x_2, x_3, x_5, x_4, x_6, x_7, x_8); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_24__collectUniversesFromCtorType___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Lean_Elab_Inductive_24__collectUniversesFromCtorType(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_5); +return x_9; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_9; +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_5); +lean_ctor_set(x_9, 1, x_8); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_6, 1); +lean_inc(x_11); +lean_dec(x_6); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +lean_inc(x_7); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_1); +x_13 = l___private_Lean_Elab_Inductive_23__collectUniversesFromCtorTypeAux___main(x_1, x_2, x_3, x_4, x_12, x_5, x_7, x_8); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_5 = x_14; +x_6 = x_11; +x_8 = x_15; +goto _start; +} +else +{ +uint8_t x_17; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_17 = !lean_is_exclusive(x_13); +if (x_17 == 0) +{ +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_9; +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_5); +lean_ctor_set(x_9, 1, x_8); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_6, 1); +lean_inc(x_11); +lean_dec(x_6); +x_12 = lean_ctor_get(x_10, 2); +lean_inc(x_12); +lean_dec(x_10); +lean_inc(x_7); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_1); +x_13 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1(x_1, x_2, x_3, x_4, x_5, x_12, x_7, x_8); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_5 = x_14; +x_6 = x_11; +x_8 = x_15; +goto _start; +} +else +{ +uint8_t x_17; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_17 = !lean_is_exclusive(x_13); +if (x_17 == 0) +{ +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_25__collectUniverses(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; lean_object* x_9; +x_8 = l_Array_empty___closed__1; +x_9 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2(x_1, x_2, x_3, x_4, x_8, x_5, x_6, x_7); +return x_9; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_4); +return x_9; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_25__collectUniverses___spec__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_4); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_25__collectUniverses___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Lean_Elab_Inductive_25__collectUniverses(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +return x_8; +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = l___private_Lean_Elab_Inductive_20__tmpIndParam; +x_4 = lean_level_eq(x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +lean_dec(x_1); +x_5 = lean_box(0); +return x_5; +} +else +{ +lean_object* x_6; +x_6 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_6, 0, x_1); +return x_6; +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +lean_dec(x_1); +x_3 = lean_box(0); +return x_3; +} +else +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +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_2, 0); +x_6 = lean_ctor_get(x_2, 1); +lean_inc(x_1); +x_7 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_7, 0, x_1); +x_8 = l_Lean_Level_replace___main(x_7, x_5); +x_9 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2(x_1, x_6); +lean_ctor_set(x_2, 1, x_9); +lean_ctor_set(x_2, 0, x_8); +return x_2; +} +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; +x_10 = lean_ctor_get(x_2, 0); +x_11 = lean_ctor_get(x_2, 1); +lean_inc(x_11); +lean_inc(x_10); +lean_dec(x_2); +lean_inc(x_1); +x_12 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_12, 0, x_1); +x_13 = l_Lean_Level_replace___main(x_12, x_10); +x_14 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2(x_1, x_11); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Meta_AbstractMVars_abstractExprMVars___main___closed__3; +x_2 = l_Lean_Expr_Inhabited; +x_3 = l_monadInhabited___rarg(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; size_t x_6; size_t x_7; lean_object* x_8; lean_object* x_9; size_t x_10; uint8_t x_11; +lean_inc(x_1); +x_5 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_5, 0, x_1); +x_6 = lean_ptr_addr(x_3); +x_7 = x_2 == 0 ? 0 : x_6 % x_2; +x_8 = lean_ctor_get(x_4, 0); +lean_inc(x_8); +x_9 = lean_array_uget(x_8, x_7); +x_10 = lean_ptr_addr(x_9); +lean_dec(x_9); +x_11 = x_10 == x_6; +if (x_11 == 0) +{ +switch (lean_obj_tag(x_3)) { +case 3: +{ +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_dec(x_1); +x_12 = lean_ctor_get(x_3, 0); +lean_inc(x_12); +x_13 = l_Lean_Level_replace___main(x_5, x_12); +lean_inc(x_3); +x_14 = lean_expr_update_sort(x_3, x_13); +x_15 = lean_array_uset(x_8, x_7, x_3); +x_16 = lean_ctor_get(x_4, 1); +lean_inc(x_16); +lean_dec(x_4); +lean_inc(x_14); +x_17 = lean_array_uset(x_16, x_7, x_14); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_15); +lean_ctor_set(x_18, 1, x_17); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_14); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +case 4: +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_5); +x_20 = lean_ctor_get(x_3, 1); +lean_inc(x_20); +x_21 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2(x_1, x_20); +lean_inc(x_3); +x_22 = lean_expr_update_const(x_3, x_21); +x_23 = lean_array_uset(x_8, x_7, x_3); +x_24 = lean_ctor_get(x_4, 1); +lean_inc(x_24); +lean_dec(x_4); +lean_inc(x_22); +x_25 = lean_array_uset(x_24, x_7, x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_23); +lean_ctor_set(x_26, 1, x_25); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +case 5: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_8); +lean_dec(x_5); +x_28 = lean_ctor_get(x_3, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_3, 1); +lean_inc(x_29); +lean_inc(x_1); +x_30 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_28, x_4); +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); +lean_dec(x_30); +x_33 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_29, x_32); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_35 = lean_ctor_get(x_33, 0); +x_36 = lean_ctor_get(x_33, 1); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +lean_inc(x_3); +x_38 = lean_array_uset(x_37, x_7, x_3); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +lean_dec(x_36); +x_40 = lean_expr_update_app(x_3, x_31, x_35); +lean_inc(x_40); +x_41 = lean_array_uset(x_39, x_7, x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_38); +lean_ctor_set(x_42, 1, x_41); +lean_ctor_set(x_33, 1, x_42); +lean_ctor_set(x_33, 0, x_40); +return x_33; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_43 = lean_ctor_get(x_33, 0); +x_44 = lean_ctor_get(x_33, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_33); +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +lean_inc(x_3); +x_46 = lean_array_uset(x_45, x_7, x_3); +x_47 = lean_ctor_get(x_44, 1); +lean_inc(x_47); +lean_dec(x_44); +x_48 = lean_expr_update_app(x_3, x_31, x_43); +lean_inc(x_48); +x_49 = lean_array_uset(x_47, x_7, x_48); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_46); +lean_ctor_set(x_50, 1, x_49); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +case 6: +{ +lean_object* x_52; lean_object* x_53; uint64_t x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_59; +lean_dec(x_8); +lean_dec(x_5); +x_52 = lean_ctor_get(x_3, 1); +lean_inc(x_52); +x_53 = lean_ctor_get(x_3, 2); +lean_inc(x_53); +x_54 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_55 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_52, x_4); +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_53, x_57); +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_ctor_get(x_58, 1); +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +lean_inc(x_3); +x_63 = lean_array_uset(x_62, x_7, x_3); +x_64 = lean_ctor_get(x_61, 1); +lean_inc(x_64); +lean_dec(x_61); +x_65 = (uint8_t)((x_54 << 24) >> 61); +x_66 = lean_expr_update_lambda(x_3, x_65, x_56, x_60); +lean_inc(x_66); +x_67 = lean_array_uset(x_64, x_7, x_66); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_67); +lean_ctor_set(x_58, 1, x_68); +lean_ctor_set(x_58, 0, x_66); +return x_58; +} +else +{ +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_76; lean_object* x_77; lean_object* x_78; +x_69 = lean_ctor_get(x_58, 0); +x_70 = lean_ctor_get(x_58, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_58); +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +lean_inc(x_3); +x_72 = lean_array_uset(x_71, x_7, x_3); +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +lean_dec(x_70); +x_74 = (uint8_t)((x_54 << 24) >> 61); +x_75 = lean_expr_update_lambda(x_3, x_74, x_56, x_69); +lean_inc(x_75); +x_76 = lean_array_uset(x_73, x_7, x_75); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_72); +lean_ctor_set(x_77, 1, x_76); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_75); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +case 7: +{ +lean_object* x_79; lean_object* x_80; uint64_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; +lean_dec(x_8); +lean_dec(x_5); +x_79 = lean_ctor_get(x_3, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_3, 2); +lean_inc(x_80); +x_81 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_82 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_79, x_4); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_82, 1); +lean_inc(x_84); +lean_dec(x_82); +x_85 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_80, x_84); +x_86 = !lean_is_exclusive(x_85); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_87 = lean_ctor_get(x_85, 0); +x_88 = lean_ctor_get(x_85, 1); +x_89 = lean_ctor_get(x_88, 0); +lean_inc(x_89); +lean_inc(x_3); +x_90 = lean_array_uset(x_89, x_7, x_3); +x_91 = lean_ctor_get(x_88, 1); +lean_inc(x_91); +lean_dec(x_88); +x_92 = (uint8_t)((x_81 << 24) >> 61); +x_93 = lean_expr_update_forall(x_3, x_92, x_83, x_87); +lean_inc(x_93); +x_94 = lean_array_uset(x_91, x_7, x_93); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_94); +lean_ctor_set(x_85, 1, x_95); +lean_ctor_set(x_85, 0, x_93); +return x_85; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_96 = lean_ctor_get(x_85, 0); +x_97 = lean_ctor_get(x_85, 1); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_85); +x_98 = lean_ctor_get(x_97, 0); +lean_inc(x_98); +lean_inc(x_3); +x_99 = lean_array_uset(x_98, x_7, x_3); +x_100 = lean_ctor_get(x_97, 1); +lean_inc(x_100); +lean_dec(x_97); +x_101 = (uint8_t)((x_81 << 24) >> 61); +x_102 = lean_expr_update_forall(x_3, x_101, x_83, x_96); +lean_inc(x_102); +x_103 = lean_array_uset(x_100, x_7, x_102); +x_104 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_104, 0, x_99); +lean_ctor_set(x_104, 1, x_103); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_102); +lean_ctor_set(x_105, 1, x_104); +return x_105; +} +} +case 8: +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; uint8_t x_116; +lean_dec(x_8); +lean_dec(x_5); +x_106 = lean_ctor_get(x_3, 1); +lean_inc(x_106); +x_107 = lean_ctor_get(x_3, 2); +lean_inc(x_107); +x_108 = lean_ctor_get(x_3, 3); +lean_inc(x_108); +lean_inc(x_1); +x_109 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_106, x_4); +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); +lean_inc(x_1); +x_112 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_107, x_111); +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 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_108, x_114); +x_116 = !lean_is_exclusive(x_115); +if (x_116 == 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; +x_117 = lean_ctor_get(x_115, 0); +x_118 = lean_ctor_get(x_115, 1); +x_119 = lean_ctor_get(x_118, 0); +lean_inc(x_119); +lean_inc(x_3); +x_120 = lean_array_uset(x_119, x_7, x_3); +x_121 = lean_ctor_get(x_118, 1); +lean_inc(x_121); +lean_dec(x_118); +x_122 = lean_expr_update_let(x_3, x_110, x_113, x_117); +lean_inc(x_122); +x_123 = lean_array_uset(x_121, x_7, x_122); +x_124 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_124, 0, x_120); +lean_ctor_set(x_124, 1, x_123); +lean_ctor_set(x_115, 1, x_124); +lean_ctor_set(x_115, 0, x_122); +return x_115; +} +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_131; lean_object* x_132; lean_object* x_133; +x_125 = lean_ctor_get(x_115, 0); +x_126 = lean_ctor_get(x_115, 1); +lean_inc(x_126); +lean_inc(x_125); +lean_dec(x_115); +x_127 = lean_ctor_get(x_126, 0); +lean_inc(x_127); +lean_inc(x_3); +x_128 = lean_array_uset(x_127, x_7, x_3); +x_129 = lean_ctor_get(x_126, 1); +lean_inc(x_129); +lean_dec(x_126); +x_130 = lean_expr_update_let(x_3, x_110, x_113, x_125); +lean_inc(x_130); +x_131 = lean_array_uset(x_129, x_7, x_130); +x_132 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_132, 0, x_128); +lean_ctor_set(x_132, 1, x_131); +x_133 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_133, 0, x_130); +lean_ctor_set(x_133, 1, x_132); +return x_133; +} +} +case 10: +{ +lean_object* x_134; lean_object* x_135; uint8_t x_136; +lean_dec(x_8); +lean_dec(x_5); +x_134 = lean_ctor_get(x_3, 1); +lean_inc(x_134); +x_135 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_134, x_4); +x_136 = !lean_is_exclusive(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; lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_137 = lean_ctor_get(x_135, 0); +x_138 = lean_ctor_get(x_135, 1); +x_139 = lean_ctor_get(x_138, 0); +lean_inc(x_139); +lean_inc(x_3); +x_140 = lean_array_uset(x_139, x_7, x_3); +x_141 = lean_ctor_get(x_138, 1); +lean_inc(x_141); +lean_dec(x_138); +x_142 = lean_expr_update_mdata(x_3, x_137); +lean_inc(x_142); +x_143 = lean_array_uset(x_141, x_7, x_142); +x_144 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_144, 0, x_140); +lean_ctor_set(x_144, 1, x_143); +lean_ctor_set(x_135, 1, x_144); +lean_ctor_set(x_135, 0, x_142); +return x_135; +} +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; +x_145 = lean_ctor_get(x_135, 0); +x_146 = lean_ctor_get(x_135, 1); +lean_inc(x_146); +lean_inc(x_145); +lean_dec(x_135); +x_147 = lean_ctor_get(x_146, 0); +lean_inc(x_147); +lean_inc(x_3); +x_148 = lean_array_uset(x_147, x_7, x_3); +x_149 = lean_ctor_get(x_146, 1); +lean_inc(x_149); +lean_dec(x_146); +x_150 = lean_expr_update_mdata(x_3, x_145); +lean_inc(x_150); +x_151 = lean_array_uset(x_149, x_7, x_150); +x_152 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_152, 0, x_148); +lean_ctor_set(x_152, 1, x_151); +x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_153, 0, x_150); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +case 11: +{ +lean_object* x_154; lean_object* x_155; uint8_t x_156; +lean_dec(x_8); +lean_dec(x_5); +x_154 = lean_ctor_get(x_3, 2); +lean_inc(x_154); +x_155 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_2, x_154, x_4); +x_156 = !lean_is_exclusive(x_155); +if (x_156 == 0) +{ +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_157 = lean_ctor_get(x_155, 0); +x_158 = lean_ctor_get(x_155, 1); +x_159 = lean_ctor_get(x_158, 0); +lean_inc(x_159); +lean_inc(x_3); +x_160 = lean_array_uset(x_159, x_7, x_3); +x_161 = lean_ctor_get(x_158, 1); +lean_inc(x_161); +lean_dec(x_158); +x_162 = lean_expr_update_proj(x_3, x_157); +lean_inc(x_162); +x_163 = lean_array_uset(x_161, x_7, x_162); +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_160); +lean_ctor_set(x_164, 1, x_163); +lean_ctor_set(x_155, 1, x_164); +lean_ctor_set(x_155, 0, x_162); +return x_155; +} +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; +x_165 = lean_ctor_get(x_155, 0); +x_166 = lean_ctor_get(x_155, 1); +lean_inc(x_166); +lean_inc(x_165); +lean_dec(x_155); +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +lean_inc(x_3); +x_168 = lean_array_uset(x_167, x_7, x_3); +x_169 = lean_ctor_get(x_166, 1); +lean_inc(x_169); +lean_dec(x_166); +x_170 = lean_expr_update_proj(x_3, x_165); +lean_inc(x_170); +x_171 = lean_array_uset(x_169, x_7, x_170); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_168); +lean_ctor_set(x_172, 1, x_171); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_170); +lean_ctor_set(x_173, 1, x_172); +return x_173; +} +} +case 12: +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_174 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1; +x_175 = l_unreachable_x21___rarg(x_174); +x_176 = lean_apply_1(x_175, x_4); +return x_176; +} +default: +{ +lean_object* x_177; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_1); +x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_177, 0, x_3); +lean_ctor_set(x_177, 1, x_4); +return x_177; +} +} +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_178 = lean_ctor_get(x_4, 1); +lean_inc(x_178); +x_179 = lean_array_uget(x_178, x_7); +lean_dec(x_178); +x_180 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_180, 0, x_179); +lean_ctor_set(x_180, 1, x_4); +return x_180; +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__3(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +lean_dec(x_1); +x_3 = lean_box(0); +return x_3; +} +else +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_2, 0); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; size_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_7 = lean_ctor_get(x_2, 1); +x_8 = lean_ctor_get(x_5, 1); +x_9 = 8192; +x_10 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_11 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_9, x_8, x_10); +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +lean_dec(x_11); +lean_ctor_set(x_5, 1, x_12); +x_13 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__3(x_1, x_7); +lean_ctor_set(x_2, 1, x_13); +return x_2; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; size_t x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_14 = lean_ctor_get(x_2, 1); +x_15 = lean_ctor_get(x_5, 0); +x_16 = lean_ctor_get(x_5, 1); +x_17 = lean_ctor_get(x_5, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_5); +x_18 = 8192; +x_19 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_20 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_18, x_16, x_19); +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +lean_dec(x_20); +x_22 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_22, 0, x_15); +lean_ctor_set(x_22, 1, x_21); +lean_ctor_set(x_22, 2, x_17); +x_23 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__3(x_1, x_14); +lean_ctor_set(x_2, 1, x_23); +lean_ctor_set(x_2, 0, x_22); +return x_2; +} +} +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; size_t 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_24 = lean_ctor_get(x_2, 0); +x_25 = lean_ctor_get(x_2, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_2); +x_26 = lean_ctor_get(x_24, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +x_28 = lean_ctor_get(x_24, 2); +lean_inc(x_28); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + lean_ctor_release(x_24, 2); + x_29 = x_24; +} else { + lean_dec_ref(x_24); + x_29 = lean_box(0); +} +x_30 = 8192; +x_31 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_32 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_30, x_27, x_31); +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +lean_dec(x_32); +if (lean_is_scalar(x_29)) { + x_34 = lean_alloc_ctor(0, 3, 0); +} else { + x_34 = x_29; +} +lean_ctor_set(x_34, 0, x_26); +lean_ctor_set(x_34, 1, x_33); +lean_ctor_set(x_34, 2, x_28); +x_35 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__3(x_1, x_25); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__5(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +lean_dec(x_1); +x_3 = lean_box(0); +return x_3; +} +else +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +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_2, 0); +x_6 = lean_ctor_get(x_2, 1); +lean_inc(x_1); +x_7 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_7, 0, x_1); +x_8 = l_Lean_Level_replace___main(x_7, x_5); +x_9 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__5(x_1, x_6); +lean_ctor_set(x_2, 1, x_9); +lean_ctor_set(x_2, 0, x_8); +return x_2; +} +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; +x_10 = lean_ctor_get(x_2, 0); +x_11 = lean_ctor_get(x_2, 1); +lean_inc(x_11); +lean_inc(x_10); +lean_dec(x_2); +lean_inc(x_1); +x_12 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_12, 0, x_1); +x_13 = l_Lean_Level_replace___main(x_12, x_10); +x_14 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__5(x_1, x_11); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; size_t x_6; size_t x_7; lean_object* x_8; lean_object* x_9; size_t x_10; uint8_t x_11; +lean_inc(x_1); +x_5 = lean_alloc_closure((void*)(l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed), 2, 1); +lean_closure_set(x_5, 0, x_1); +x_6 = lean_ptr_addr(x_3); +x_7 = x_2 == 0 ? 0 : x_6 % x_2; +x_8 = lean_ctor_get(x_4, 0); +lean_inc(x_8); +x_9 = lean_array_uget(x_8, x_7); +x_10 = lean_ptr_addr(x_9); +lean_dec(x_9); +x_11 = x_10 == x_6; +if (x_11 == 0) +{ +switch (lean_obj_tag(x_3)) { +case 3: +{ +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_dec(x_1); +x_12 = lean_ctor_get(x_3, 0); +lean_inc(x_12); +x_13 = l_Lean_Level_replace___main(x_5, x_12); +lean_inc(x_3); +x_14 = lean_expr_update_sort(x_3, x_13); +x_15 = lean_array_uset(x_8, x_7, x_3); +x_16 = lean_ctor_get(x_4, 1); +lean_inc(x_16); +lean_dec(x_4); +lean_inc(x_14); +x_17 = lean_array_uset(x_16, x_7, x_14); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_15); +lean_ctor_set(x_18, 1, x_17); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_14); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +case 4: +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_5); +x_20 = lean_ctor_get(x_3, 1); +lean_inc(x_20); +x_21 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__5(x_1, x_20); +lean_inc(x_3); +x_22 = lean_expr_update_const(x_3, x_21); +x_23 = lean_array_uset(x_8, x_7, x_3); +x_24 = lean_ctor_get(x_4, 1); +lean_inc(x_24); +lean_dec(x_4); +lean_inc(x_22); +x_25 = lean_array_uset(x_24, x_7, x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_23); +lean_ctor_set(x_26, 1, x_25); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +case 5: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_8); +lean_dec(x_5); +x_28 = lean_ctor_get(x_3, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_3, 1); +lean_inc(x_29); +lean_inc(x_1); +x_30 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_28, x_4); +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); +lean_dec(x_30); +x_33 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_29, x_32); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_35 = lean_ctor_get(x_33, 0); +x_36 = lean_ctor_get(x_33, 1); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +lean_inc(x_3); +x_38 = lean_array_uset(x_37, x_7, x_3); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +lean_dec(x_36); +x_40 = lean_expr_update_app(x_3, x_31, x_35); +lean_inc(x_40); +x_41 = lean_array_uset(x_39, x_7, x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_38); +lean_ctor_set(x_42, 1, x_41); +lean_ctor_set(x_33, 1, x_42); +lean_ctor_set(x_33, 0, x_40); +return x_33; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_43 = lean_ctor_get(x_33, 0); +x_44 = lean_ctor_get(x_33, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_33); +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +lean_inc(x_3); +x_46 = lean_array_uset(x_45, x_7, x_3); +x_47 = lean_ctor_get(x_44, 1); +lean_inc(x_47); +lean_dec(x_44); +x_48 = lean_expr_update_app(x_3, x_31, x_43); +lean_inc(x_48); +x_49 = lean_array_uset(x_47, x_7, x_48); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_46); +lean_ctor_set(x_50, 1, x_49); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +case 6: +{ +lean_object* x_52; lean_object* x_53; uint64_t x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_59; +lean_dec(x_8); +lean_dec(x_5); +x_52 = lean_ctor_get(x_3, 1); +lean_inc(x_52); +x_53 = lean_ctor_get(x_3, 2); +lean_inc(x_53); +x_54 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_55 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_52, x_4); +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_53, x_57); +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_ctor_get(x_58, 1); +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +lean_inc(x_3); +x_63 = lean_array_uset(x_62, x_7, x_3); +x_64 = lean_ctor_get(x_61, 1); +lean_inc(x_64); +lean_dec(x_61); +x_65 = (uint8_t)((x_54 << 24) >> 61); +x_66 = lean_expr_update_lambda(x_3, x_65, x_56, x_60); +lean_inc(x_66); +x_67 = lean_array_uset(x_64, x_7, x_66); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_67); +lean_ctor_set(x_58, 1, x_68); +lean_ctor_set(x_58, 0, x_66); +return x_58; +} +else +{ +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_76; lean_object* x_77; lean_object* x_78; +x_69 = lean_ctor_get(x_58, 0); +x_70 = lean_ctor_get(x_58, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_58); +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +lean_inc(x_3); +x_72 = lean_array_uset(x_71, x_7, x_3); +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +lean_dec(x_70); +x_74 = (uint8_t)((x_54 << 24) >> 61); +x_75 = lean_expr_update_lambda(x_3, x_74, x_56, x_69); +lean_inc(x_75); +x_76 = lean_array_uset(x_73, x_7, x_75); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_72); +lean_ctor_set(x_77, 1, x_76); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_75); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +case 7: +{ +lean_object* x_79; lean_object* x_80; uint64_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; +lean_dec(x_8); +lean_dec(x_5); +x_79 = lean_ctor_get(x_3, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_3, 2); +lean_inc(x_80); +x_81 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_82 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_79, x_4); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_82, 1); +lean_inc(x_84); +lean_dec(x_82); +x_85 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_80, x_84); +x_86 = !lean_is_exclusive(x_85); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_87 = lean_ctor_get(x_85, 0); +x_88 = lean_ctor_get(x_85, 1); +x_89 = lean_ctor_get(x_88, 0); +lean_inc(x_89); +lean_inc(x_3); +x_90 = lean_array_uset(x_89, x_7, x_3); +x_91 = lean_ctor_get(x_88, 1); +lean_inc(x_91); +lean_dec(x_88); +x_92 = (uint8_t)((x_81 << 24) >> 61); +x_93 = lean_expr_update_forall(x_3, x_92, x_83, x_87); +lean_inc(x_93); +x_94 = lean_array_uset(x_91, x_7, x_93); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_94); +lean_ctor_set(x_85, 1, x_95); +lean_ctor_set(x_85, 0, x_93); +return x_85; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_96 = lean_ctor_get(x_85, 0); +x_97 = lean_ctor_get(x_85, 1); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_85); +x_98 = lean_ctor_get(x_97, 0); +lean_inc(x_98); +lean_inc(x_3); +x_99 = lean_array_uset(x_98, x_7, x_3); +x_100 = lean_ctor_get(x_97, 1); +lean_inc(x_100); +lean_dec(x_97); +x_101 = (uint8_t)((x_81 << 24) >> 61); +x_102 = lean_expr_update_forall(x_3, x_101, x_83, x_96); +lean_inc(x_102); +x_103 = lean_array_uset(x_100, x_7, x_102); +x_104 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_104, 0, x_99); +lean_ctor_set(x_104, 1, x_103); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_102); +lean_ctor_set(x_105, 1, x_104); +return x_105; +} +} +case 8: +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; uint8_t x_116; +lean_dec(x_8); +lean_dec(x_5); +x_106 = lean_ctor_get(x_3, 1); +lean_inc(x_106); +x_107 = lean_ctor_get(x_3, 2); +lean_inc(x_107); +x_108 = lean_ctor_get(x_3, 3); +lean_inc(x_108); +lean_inc(x_1); +x_109 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_106, x_4); +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); +lean_inc(x_1); +x_112 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_107, x_111); +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 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_108, x_114); +x_116 = !lean_is_exclusive(x_115); +if (x_116 == 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; +x_117 = lean_ctor_get(x_115, 0); +x_118 = lean_ctor_get(x_115, 1); +x_119 = lean_ctor_get(x_118, 0); +lean_inc(x_119); +lean_inc(x_3); +x_120 = lean_array_uset(x_119, x_7, x_3); +x_121 = lean_ctor_get(x_118, 1); +lean_inc(x_121); +lean_dec(x_118); +x_122 = lean_expr_update_let(x_3, x_110, x_113, x_117); +lean_inc(x_122); +x_123 = lean_array_uset(x_121, x_7, x_122); +x_124 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_124, 0, x_120); +lean_ctor_set(x_124, 1, x_123); +lean_ctor_set(x_115, 1, x_124); +lean_ctor_set(x_115, 0, x_122); +return x_115; +} +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_131; lean_object* x_132; lean_object* x_133; +x_125 = lean_ctor_get(x_115, 0); +x_126 = lean_ctor_get(x_115, 1); +lean_inc(x_126); +lean_inc(x_125); +lean_dec(x_115); +x_127 = lean_ctor_get(x_126, 0); +lean_inc(x_127); +lean_inc(x_3); +x_128 = lean_array_uset(x_127, x_7, x_3); +x_129 = lean_ctor_get(x_126, 1); +lean_inc(x_129); +lean_dec(x_126); +x_130 = lean_expr_update_let(x_3, x_110, x_113, x_125); +lean_inc(x_130); +x_131 = lean_array_uset(x_129, x_7, x_130); +x_132 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_132, 0, x_128); +lean_ctor_set(x_132, 1, x_131); +x_133 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_133, 0, x_130); +lean_ctor_set(x_133, 1, x_132); +return x_133; +} +} +case 10: +{ +lean_object* x_134; lean_object* x_135; uint8_t x_136; +lean_dec(x_8); +lean_dec(x_5); +x_134 = lean_ctor_get(x_3, 1); +lean_inc(x_134); +x_135 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_134, x_4); +x_136 = !lean_is_exclusive(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; lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_137 = lean_ctor_get(x_135, 0); +x_138 = lean_ctor_get(x_135, 1); +x_139 = lean_ctor_get(x_138, 0); +lean_inc(x_139); +lean_inc(x_3); +x_140 = lean_array_uset(x_139, x_7, x_3); +x_141 = lean_ctor_get(x_138, 1); +lean_inc(x_141); +lean_dec(x_138); +x_142 = lean_expr_update_mdata(x_3, x_137); +lean_inc(x_142); +x_143 = lean_array_uset(x_141, x_7, x_142); +x_144 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_144, 0, x_140); +lean_ctor_set(x_144, 1, x_143); +lean_ctor_set(x_135, 1, x_144); +lean_ctor_set(x_135, 0, x_142); +return x_135; +} +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; +x_145 = lean_ctor_get(x_135, 0); +x_146 = lean_ctor_get(x_135, 1); +lean_inc(x_146); +lean_inc(x_145); +lean_dec(x_135); +x_147 = lean_ctor_get(x_146, 0); +lean_inc(x_147); +lean_inc(x_3); +x_148 = lean_array_uset(x_147, x_7, x_3); +x_149 = lean_ctor_get(x_146, 1); +lean_inc(x_149); +lean_dec(x_146); +x_150 = lean_expr_update_mdata(x_3, x_145); +lean_inc(x_150); +x_151 = lean_array_uset(x_149, x_7, x_150); +x_152 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_152, 0, x_148); +lean_ctor_set(x_152, 1, x_151); +x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_153, 0, x_150); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +case 11: +{ +lean_object* x_154; lean_object* x_155; uint8_t x_156; +lean_dec(x_8); +lean_dec(x_5); +x_154 = lean_ctor_get(x_3, 2); +lean_inc(x_154); +x_155 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_2, x_154, x_4); +x_156 = !lean_is_exclusive(x_155); +if (x_156 == 0) +{ +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_157 = lean_ctor_get(x_155, 0); +x_158 = lean_ctor_get(x_155, 1); +x_159 = lean_ctor_get(x_158, 0); +lean_inc(x_159); +lean_inc(x_3); +x_160 = lean_array_uset(x_159, x_7, x_3); +x_161 = lean_ctor_get(x_158, 1); +lean_inc(x_161); +lean_dec(x_158); +x_162 = lean_expr_update_proj(x_3, x_157); +lean_inc(x_162); +x_163 = lean_array_uset(x_161, x_7, x_162); +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_160); +lean_ctor_set(x_164, 1, x_163); +lean_ctor_set(x_155, 1, x_164); +lean_ctor_set(x_155, 0, x_162); +return x_155; +} +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; +x_165 = lean_ctor_get(x_155, 0); +x_166 = lean_ctor_get(x_155, 1); +lean_inc(x_166); +lean_inc(x_165); +lean_dec(x_155); +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +lean_inc(x_3); +x_168 = lean_array_uset(x_167, x_7, x_3); +x_169 = lean_ctor_get(x_166, 1); +lean_inc(x_169); +lean_dec(x_166); +x_170 = lean_expr_update_proj(x_3, x_165); +lean_inc(x_170); +x_171 = lean_array_uset(x_169, x_7, x_170); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_168); +lean_ctor_set(x_172, 1, x_171); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_170); +lean_ctor_set(x_173, 1, x_172); +return x_173; +} +} +case 12: +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_174 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1; +x_175 = l_unreachable_x21___rarg(x_174); +x_176 = lean_apply_1(x_175, x_4); +return x_176; +} +default: +{ +lean_object* x_177; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_1); +x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_177, 0, x_3); +lean_ctor_set(x_177, 1, x_4); +return x_177; +} +} +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_178 = lean_ctor_get(x_4, 1); +lean_inc(x_178); +x_179 = lean_array_uget(x_178, x_7); +lean_dec(x_178); +x_180 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_180, 0, x_179); +lean_ctor_set(x_180, 1, x_4); +return x_180; +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +lean_dec(x_1); +x_3 = lean_box(0); +return x_3; +} +else +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_2, 0); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; size_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_7 = lean_ctor_get(x_2, 1); +x_8 = lean_ctor_get(x_5, 1); +x_9 = 8192; +x_10 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_11 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_9, x_8, x_10); +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +lean_dec(x_11); +lean_ctor_set(x_5, 1, x_12); +x_13 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(x_1, x_7); +lean_ctor_set(x_2, 1, x_13); +return x_2; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; size_t x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_14 = lean_ctor_get(x_2, 1); +x_15 = lean_ctor_get(x_5, 0); +x_16 = lean_ctor_get(x_5, 1); +x_17 = lean_ctor_get(x_5, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_5); +x_18 = 8192; +x_19 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_20 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_18, x_16, x_19); +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +lean_dec(x_20); +x_22 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_22, 0, x_15); +lean_ctor_set(x_22, 1, x_21); +lean_ctor_set(x_22, 2, x_17); +x_23 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(x_1, x_14); +lean_ctor_set(x_2, 1, x_23); +lean_ctor_set(x_2, 0, x_22); +return x_2; +} +} +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; size_t 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_24 = lean_ctor_get(x_2, 0); +x_25 = lean_ctor_get(x_2, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_2); +x_26 = lean_ctor_get(x_24, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +x_28 = lean_ctor_get(x_24, 2); +lean_inc(x_28); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + lean_ctor_release(x_24, 2); + x_29 = x_24; +} else { + lean_dec_ref(x_24); + x_29 = lean_box(0); +} +x_30 = 8192; +x_31 = l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_inc(x_1); +x_32 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_30, x_27, x_31); +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +lean_dec(x_32); +if (lean_is_scalar(x_29)) { + x_34 = lean_alloc_ctor(0, 3, 0); +} else { + x_34 = x_29; +} +lean_ctor_set(x_34, 0, x_26); +lean_ctor_set(x_34, 1, x_33); +lean_ctor_set(x_34, 2, x_28); +x_35 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(x_1, x_25); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_3); +x_6 = l___private_Lean_Elab_Inductive_19__getResultingUniverse(x_1, x_3, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = lean_unsigned_to_nat(0u); +x_10 = l_Lean_Level_getOffsetAux___main(x_7, x_9); +x_11 = l_Lean_Level_getLevelOffset___main(x_7); +lean_dec(x_7); +x_12 = l_Lean_Level_isParam(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_3); +x_13 = l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2; +x_14 = l_Lean_Elab_Term_throwError___rarg(x_1, x_13, x_4, x_8); +lean_dec(x_1); +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +return x_14; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_14, 0); +x_17 = lean_ctor_get(x_14, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_14); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +else +{ +lean_object* x_19; +lean_inc(x_3); +x_19 = l___private_Lean_Elab_Inductive_25__collectUniverses(x_1, x_11, x_10, x_2, x_3, x_4, x_8); +if (lean_obj_tag(x_19) == 0) +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_19, 0); +x_22 = l_Array_toList___rarg(x_21); +lean_dec(x_21); +x_23 = l_Lean_Level_mkNaryMax___main(x_22); +x_24 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(x_23, x_3); +lean_ctor_set(x_19, 0, x_24); +return x_19; +} +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; +x_25 = lean_ctor_get(x_19, 0); +x_26 = lean_ctor_get(x_19, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_19); +x_27 = l_Array_toList___rarg(x_25); +lean_dec(x_25); +x_28 = l_Lean_Level_mkNaryMax___main(x_27); +x_29 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__6(x_28, x_3); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_26); +return x_30; +} +} +else +{ +uint8_t x_31; +lean_dec(x_3); +x_31 = !lean_is_exclusive(x_19); +if (x_31 == 0) +{ +return x_19; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_19, 0); +x_33 = lean_ctor_get(x_19, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_19); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +} +else +{ +uint8_t x_35; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_35 = !lean_is_exclusive(x_6); +if (x_35 == 0) +{ +return x_6; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_6, 0); +x_37 = lean_ctor_get(x_6, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_6); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_List_map___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__2___lambda__1(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; lean_object* x_6; +x_5 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_6 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1(x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; lean_object* x_6; +x_5 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_6 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__4(x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_26__updateResultingUniverse___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_26__updateResultingUniverse(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* _init_l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string(" >> "); +return x_1; +} +} +lean_object* l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_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); +lean_ctor_set(x_5, 1, x_3); +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_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_1, 1); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_6, 0); +lean_inc(x_8); +x_9 = l_Lean_Name_toString___closed__1; +x_10 = l_Lean_Name_toStringWithSep___main(x_9, x_8); +x_11 = l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1; +x_12 = lean_string_append(x_11, x_10); +lean_dec(x_10); +x_13 = l_Array_iterateMAux___main___at_Lean_ppGoal___spec__6___closed__3; +x_14 = lean_string_append(x_12, x_13); +x_15 = lean_ctor_get(x_6, 1); +lean_inc(x_15); +lean_dec(x_6); +x_16 = lean_expr_dbg_to_string(x_15); +lean_dec(x_15); +x_17 = lean_string_append(x_14, x_16); +lean_dec(x_16); +x_18 = l_Lean_Meta_dbgTrace___rarg___closed__1; +x_19 = lean_dbg_trace(x_17, x_18); +lean_inc(x_2); +x_20 = lean_apply_2(x_19, x_2, x_3); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 1); +lean_inc(x_21); +lean_dec(x_20); +x_1 = x_7; +x_3 = x_21; +goto _start; +} +else +{ +uint8_t x_23; +lean_dec(x_7); +lean_dec(x_2); +x_23 = !lean_is_exclusive(x_20); +if (x_23 == 0) +{ +return x_20; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_20, 0); +x_25 = lean_ctor_get(x_20, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_20); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +} +} +lean_object* l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_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); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +else +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_1, 1); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_6, 2); +lean_inc(x_8); +lean_dec(x_6); +lean_inc(x_2); +x_9 = l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1(x_8, x_2, x_3); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; +x_10 = lean_ctor_get(x_9, 1); +lean_inc(x_10); +lean_dec(x_9); +x_1 = x_7; +x_3 = x_10; +goto _start; +} +else +{ +uint8_t x_12; +lean_dec(x_7); +lean_dec(x_2); +x_12 = !lean_is_exclusive(x_9); +if (x_12 == 0) +{ +return x_9; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_9, 0); +x_14 = lean_ctor_get(x_9, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_9); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_27__traceIndTypes(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__2(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; +lean_dec(x_4); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_2); +lean_ctor_set(x_6, 1, x_5); +return x_6; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_7 = lean_ctor_get(x_3, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_3, 1); +lean_inc(x_8); +lean_dec(x_3); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +lean_inc(x_4); +x_10 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_2, x_9, x_4, x_5); +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_2 = x_11; +x_3 = x_8; +x_5 = x_12; +goto _start; +} +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; +lean_dec(x_4); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_2); +lean_ctor_set(x_6, 1, x_5); +return x_6; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_7 = lean_ctor_get(x_3, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_3, 1); +lean_inc(x_8); +lean_dec(x_3); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_inc(x_4); +x_10 = l_Lean_Elab_Term_collectUsedFVars(x_1, x_2, x_9, x_4, x_5); +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_ctor_get(x_7, 2); +lean_inc(x_13); +lean_dec(x_7); +lean_inc(x_4); +x_14 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1(x_1, x_11, x_13, x_4, x_12); +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +x_2 = x_15; +x_3 = x_8; +x_5 = x_16; +goto _start; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_28__removeUnused(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = l___private_Lean_Elab_Definition_1__removeUnused___closed__1; +lean_inc(x_4); +x_7 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2(x_1, x_6, x_3, x_4, x_5); +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +x_10 = l_Lean_Elab_Term_removeUnused(x_1, x_2, x_8, x_4, x_9); +return x_10; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_foldlM___main___at___private_Lean_Elab_Inductive_28__removeUnused___spec__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_28__removeUnused___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_28__removeUnused(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_29__withUsed___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +lean_inc(x_5); +x_7 = l___private_Lean_Elab_Inductive_28__removeUnused(x_1, x_2, x_3, x_5, x_6); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +x_9 = lean_ctor_get(x_8, 1); +lean_inc(x_9); +x_10 = lean_ctor_get(x_5, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_7, 1); +lean_inc(x_11); +lean_dec(x_7); +x_12 = lean_ctor_get(x_8, 0); +lean_inc(x_12); +lean_dec(x_8); +x_13 = lean_ctor_get(x_9, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_9, 1); +lean_inc(x_14); +lean_dec(x_9); +x_15 = !lean_is_exclusive(x_5); +if (x_15 == 0) +{ +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_5, 0); +lean_dec(x_16); +x_17 = !lean_is_exclusive(x_10); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_10, 2); +lean_dec(x_18); +x_19 = lean_ctor_get(x_10, 1); +lean_dec(x_19); +lean_ctor_set(x_10, 2, x_13); +lean_ctor_set(x_10, 1, x_12); +x_20 = lean_apply_3(x_4, x_14, x_5, x_11); +return x_20; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_21 = lean_ctor_get(x_10, 0); +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_dec(x_10); +x_24 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_24, 0, x_21); +lean_ctor_set(x_24, 1, x_12); +lean_ctor_set(x_24, 2, x_13); +lean_ctor_set(x_24, 3, x_22); +lean_ctor_set(x_24, 4, x_23); +lean_ctor_set(x_5, 0, x_24); +x_25 = lean_apply_3(x_4, x_14, x_5, x_11); +return x_25; +} +} +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; uint8_t x_35; uint8_t x_36; uint8_t 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_26 = lean_ctor_get(x_5, 1); +x_27 = lean_ctor_get(x_5, 2); +x_28 = lean_ctor_get(x_5, 3); +x_29 = lean_ctor_get(x_5, 4); +x_30 = lean_ctor_get(x_5, 5); +x_31 = lean_ctor_get(x_5, 6); +x_32 = lean_ctor_get(x_5, 7); +x_33 = lean_ctor_get(x_5, 8); +x_34 = lean_ctor_get(x_5, 9); +x_35 = lean_ctor_get_uint8(x_5, sizeof(void*)*10); +x_36 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 1); +x_37 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 2); +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_inc(x_28); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_5); +x_38 = lean_ctor_get(x_10, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_10, 3); +lean_inc(x_39); +x_40 = lean_ctor_get(x_10, 4); +lean_inc(x_40); +if (lean_is_exclusive(x_10)) { + lean_ctor_release(x_10, 0); + lean_ctor_release(x_10, 1); + lean_ctor_release(x_10, 2); + lean_ctor_release(x_10, 3); + lean_ctor_release(x_10, 4); + x_41 = x_10; +} else { + lean_dec_ref(x_10); + x_41 = lean_box(0); +} +if (lean_is_scalar(x_41)) { + x_42 = lean_alloc_ctor(0, 5, 0); +} else { + x_42 = x_41; +} +lean_ctor_set(x_42, 0, x_38); +lean_ctor_set(x_42, 1, x_12); +lean_ctor_set(x_42, 2, x_13); +lean_ctor_set(x_42, 3, x_39); +lean_ctor_set(x_42, 4, x_40); +x_43 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_26); +lean_ctor_set(x_43, 2, x_27); +lean_ctor_set(x_43, 3, x_28); +lean_ctor_set(x_43, 4, x_29); +lean_ctor_set(x_43, 5, x_30); +lean_ctor_set(x_43, 6, x_31); +lean_ctor_set(x_43, 7, x_32); +lean_ctor_set(x_43, 8, x_33); +lean_ctor_set(x_43, 9, x_34); +lean_ctor_set_uint8(x_43, sizeof(void*)*10, x_35); +lean_ctor_set_uint8(x_43, sizeof(void*)*10 + 1, x_36); +lean_ctor_set_uint8(x_43, sizeof(void*)*10 + 2, x_37); +x_44 = lean_apply_3(x_4, x_14, x_43, x_11); +return x_44; +} +} +else +{ +uint8_t x_45; +lean_dec(x_5); +lean_dec(x_4); +x_45 = !lean_is_exclusive(x_7); +if (x_45 == 0) +{ +return x_7; +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_7, 0); +x_47 = lean_ctor_get(x_7, 1); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_7); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_46); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_29__withUsed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_29__withUsed___rarg___boxed), 6, 0); +return x_2; +} +} +lean_object* l___private_Lean_Elab_Inductive_29__withUsed___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Lean_Elab_Inductive_29__withUsed___rarg(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; lean_object* x_7; +lean_dec(x_4); +lean_dec(x_2); +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_5); +return x_7; +} +else +{ +uint8_t x_8; +x_8 = !lean_is_exclusive(x_3); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_3, 0); +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_11 = lean_ctor_get(x_3, 1); +x_12 = lean_ctor_get(x_9, 0); +x_13 = lean_ctor_get(x_9, 1); +lean_inc(x_4); +lean_inc(x_2); +x_14 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_13, x_4, x_5); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +lean_ctor_set(x_9, 1, x_15); +x_17 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_11, x_4, x_16); +if (lean_obj_tag(x_17) == 0) +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_17, 0); +lean_ctor_set(x_3, 1, x_19); +lean_ctor_set(x_17, 0, x_3); +return x_17; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_17, 0); +x_21 = lean_ctor_get(x_17, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_17); +lean_ctor_set(x_3, 1, x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_3); +lean_ctor_set(x_22, 1, x_21); +return x_22; +} +} +else +{ +uint8_t x_23; +lean_dec(x_9); +lean_free_object(x_3); +x_23 = !lean_is_exclusive(x_17); +if (x_23 == 0) +{ +return x_17; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_17, 0); +x_25 = lean_ctor_get(x_17, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_17); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +uint8_t x_27; +lean_free_object(x_9); +lean_dec(x_12); +lean_free_object(x_3); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_2); +x_27 = !lean_is_exclusive(x_14); +if (x_27 == 0) +{ +return x_14; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_14, 0); +x_29 = lean_ctor_get(x_14, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_14); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_31 = lean_ctor_get(x_3, 1); +x_32 = lean_ctor_get(x_9, 0); +x_33 = lean_ctor_get(x_9, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_9); +lean_inc(x_4); +lean_inc(x_2); +x_34 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_33, x_4, x_5); +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); +lean_dec(x_34); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_35); +x_38 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_31, x_4, x_36); +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +if (lean_is_exclusive(x_38)) { + lean_ctor_release(x_38, 0); + lean_ctor_release(x_38, 1); + x_41 = x_38; +} else { + lean_dec_ref(x_38); + x_41 = lean_box(0); +} +lean_ctor_set(x_3, 1, x_39); +lean_ctor_set(x_3, 0, x_37); +if (lean_is_scalar(x_41)) { + x_42 = lean_alloc_ctor(0, 2, 0); +} else { + x_42 = x_41; +} +lean_ctor_set(x_42, 0, x_3); +lean_ctor_set(x_42, 1, x_40); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_37); +lean_free_object(x_3); +x_43 = lean_ctor_get(x_38, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_38, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_38)) { + lean_ctor_release(x_38, 0); + lean_ctor_release(x_38, 1); + x_45 = x_38; +} else { + lean_dec_ref(x_38); + x_45 = lean_box(0); +} +if (lean_is_scalar(x_45)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_45; +} +lean_ctor_set(x_46, 0, x_43); +lean_ctor_set(x_46, 1, x_44); +return x_46; +} +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +lean_dec(x_32); +lean_free_object(x_3); +lean_dec(x_31); +lean_dec(x_4); +lean_dec(x_2); +x_47 = lean_ctor_get(x_34, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_34, 1); +lean_inc(x_48); +if (lean_is_exclusive(x_34)) { + lean_ctor_release(x_34, 0); + lean_ctor_release(x_34, 1); + x_49 = x_34; +} else { + lean_dec_ref(x_34); + x_49 = lean_box(0); +} +if (lean_is_scalar(x_49)) { + x_50 = lean_alloc_ctor(1, 2, 0); +} else { + x_50 = x_49; +} +lean_ctor_set(x_50, 0, x_47); +lean_ctor_set(x_50, 1, x_48); +return x_50; +} +} +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_51 = lean_ctor_get(x_3, 0); +x_52 = lean_ctor_get(x_3, 1); +lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_3); +x_53 = lean_ctor_get(x_51, 0); +lean_inc(x_53); +x_54 = lean_ctor_get(x_51, 1); +lean_inc(x_54); +if (lean_is_exclusive(x_51)) { + lean_ctor_release(x_51, 0); + lean_ctor_release(x_51, 1); + x_55 = x_51; +} else { + lean_dec_ref(x_51); + x_55 = lean_box(0); +} +lean_inc(x_4); +lean_inc(x_2); +x_56 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_54, x_4, x_5); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_57 = lean_ctor_get(x_56, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_56, 1); +lean_inc(x_58); +lean_dec(x_56); +if (lean_is_scalar(x_55)) { + x_59 = lean_alloc_ctor(0, 2, 0); +} else { + x_59 = x_55; +} +lean_ctor_set(x_59, 0, x_53); +lean_ctor_set(x_59, 1, x_57); +x_60 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_52, x_4, x_58); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_61 = lean_ctor_get(x_60, 0); +lean_inc(x_61); +x_62 = lean_ctor_get(x_60, 1); +lean_inc(x_62); +if (lean_is_exclusive(x_60)) { + lean_ctor_release(x_60, 0); + lean_ctor_release(x_60, 1); + x_63 = x_60; +} else { + lean_dec_ref(x_60); + x_63 = lean_box(0); +} +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_61); +if (lean_is_scalar(x_63)) { + x_65 = lean_alloc_ctor(0, 2, 0); +} else { + x_65 = x_63; +} +lean_ctor_set(x_65, 0, x_64); +lean_ctor_set(x_65, 1, x_62); +return x_65; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +lean_dec(x_59); +x_66 = lean_ctor_get(x_60, 0); +lean_inc(x_66); +x_67 = lean_ctor_get(x_60, 1); +lean_inc(x_67); +if (lean_is_exclusive(x_60)) { + lean_ctor_release(x_60, 0); + lean_ctor_release(x_60, 1); + x_68 = x_60; +} else { + lean_dec_ref(x_60); + x_68 = lean_box(0); +} +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_68; +} +lean_ctor_set(x_69, 0, x_66); +lean_ctor_set(x_69, 1, x_67); +return x_69; +} +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +lean_dec(x_55); +lean_dec(x_53); +lean_dec(x_52); +lean_dec(x_4); +lean_dec(x_2); +x_70 = lean_ctor_get(x_56, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_56, 1); +lean_inc(x_71); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_72 = x_56; +} else { + lean_dec_ref(x_56); + x_72 = lean_box(0); +} +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(1, 2, 0); +} else { + x_73 = x_72; +} +lean_ctor_set(x_73, 0, x_70); +lean_ctor_set(x_73, 1, x_71); +return x_73; +} +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; lean_object* x_7; +lean_dec(x_4); +lean_dec(x_2); +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_5); +return x_7; +} +else +{ +uint8_t x_8; +x_8 = !lean_is_exclusive(x_3); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_3, 0); +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_11 = lean_ctor_get(x_3, 1); +x_12 = lean_ctor_get(x_9, 0); +x_13 = lean_ctor_get(x_9, 1); +x_14 = lean_ctor_get(x_9, 2); +lean_inc(x_4); +lean_inc(x_2); +x_15 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_13, x_4, x_5); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +lean_inc(x_4); +lean_inc(x_2); +x_18 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_14, x_4, x_17); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +lean_ctor_set(x_9, 2, x_19); +lean_ctor_set(x_9, 1, x_16); +x_21 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_1, x_2, x_11, x_4, x_20); +if (lean_obj_tag(x_21) == 0) +{ +uint8_t x_22; +x_22 = !lean_is_exclusive(x_21); +if (x_22 == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_21, 0); +lean_ctor_set(x_3, 1, x_23); +lean_ctor_set(x_21, 0, x_3); +return x_21; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_21, 0); +x_25 = lean_ctor_get(x_21, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_21); +lean_ctor_set(x_3, 1, x_24); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_3); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +else +{ +uint8_t x_27; +lean_dec(x_9); +lean_free_object(x_3); +x_27 = !lean_is_exclusive(x_21); +if (x_27 == 0) +{ +return x_21; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_21, 0); +x_29 = lean_ctor_get(x_21, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_21); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +else +{ +uint8_t x_31; +lean_dec(x_16); +lean_free_object(x_9); +lean_dec(x_12); +lean_free_object(x_3); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_2); +x_31 = !lean_is_exclusive(x_18); +if (x_31 == 0) +{ +return x_18; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_18, 0); +x_33 = lean_ctor_get(x_18, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_18); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +else +{ +uint8_t x_35; +lean_free_object(x_9); +lean_dec(x_14); +lean_dec(x_12); +lean_free_object(x_3); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_2); +x_35 = !lean_is_exclusive(x_15); +if (x_35 == 0) +{ +return x_15; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_15, 0); +x_37 = lean_ctor_get(x_15, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_15); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_39 = lean_ctor_get(x_3, 1); +x_40 = lean_ctor_get(x_9, 0); +x_41 = lean_ctor_get(x_9, 1); +x_42 = lean_ctor_get(x_9, 2); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_9); +lean_inc(x_4); +lean_inc(x_2); +x_43 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_41, x_4, x_5); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_43, 1); +lean_inc(x_45); +lean_dec(x_43); +lean_inc(x_4); +lean_inc(x_2); +x_46 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_42, x_4, x_45); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +x_49 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_49, 0, x_40); +lean_ctor_set(x_49, 1, x_44); +lean_ctor_set(x_49, 2, x_47); +x_50 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_1, x_2, x_39, x_4, x_48); +if (lean_obj_tag(x_50) == 0) +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_51 = lean_ctor_get(x_50, 0); +lean_inc(x_51); +x_52 = lean_ctor_get(x_50, 1); +lean_inc(x_52); +if (lean_is_exclusive(x_50)) { + lean_ctor_release(x_50, 0); + lean_ctor_release(x_50, 1); + x_53 = x_50; +} else { + lean_dec_ref(x_50); + x_53 = lean_box(0); +} +lean_ctor_set(x_3, 1, x_51); +lean_ctor_set(x_3, 0, x_49); +if (lean_is_scalar(x_53)) { + x_54 = lean_alloc_ctor(0, 2, 0); +} else { + x_54 = x_53; +} +lean_ctor_set(x_54, 0, x_3); +lean_ctor_set(x_54, 1, x_52); +return x_54; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +lean_dec(x_49); +lean_free_object(x_3); +x_55 = lean_ctor_get(x_50, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_50, 1); +lean_inc(x_56); +if (lean_is_exclusive(x_50)) { + lean_ctor_release(x_50, 0); + lean_ctor_release(x_50, 1); + x_57 = x_50; +} else { + lean_dec_ref(x_50); + x_57 = lean_box(0); +} +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(1, 2, 0); +} else { + x_58 = x_57; +} +lean_ctor_set(x_58, 0, x_55); +lean_ctor_set(x_58, 1, x_56); +return x_58; +} +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +lean_dec(x_44); +lean_dec(x_40); +lean_free_object(x_3); +lean_dec(x_39); +lean_dec(x_4); +lean_dec(x_2); +x_59 = lean_ctor_get(x_46, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_46, 1); +lean_inc(x_60); +if (lean_is_exclusive(x_46)) { + lean_ctor_release(x_46, 0); + lean_ctor_release(x_46, 1); + x_61 = x_46; +} else { + lean_dec_ref(x_46); + x_61 = lean_box(0); +} +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(1, 2, 0); +} else { + x_62 = x_61; +} +lean_ctor_set(x_62, 0, x_59); +lean_ctor_set(x_62, 1, x_60); +return x_62; +} +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +lean_dec(x_42); +lean_dec(x_40); +lean_free_object(x_3); +lean_dec(x_39); +lean_dec(x_4); +lean_dec(x_2); +x_63 = lean_ctor_get(x_43, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_43, 1); +lean_inc(x_64); +if (lean_is_exclusive(x_43)) { + lean_ctor_release(x_43, 0); + lean_ctor_release(x_43, 1); + x_65 = x_43; +} else { + lean_dec_ref(x_43); + x_65 = lean_box(0); +} +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(1, 2, 0); +} else { + x_66 = x_65; +} +lean_ctor_set(x_66, 0, x_63); +lean_ctor_set(x_66, 1, x_64); +return x_66; +} +} +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_67 = lean_ctor_get(x_3, 0); +x_68 = lean_ctor_get(x_3, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_3); +x_69 = lean_ctor_get(x_67, 0); +lean_inc(x_69); +x_70 = lean_ctor_get(x_67, 1); +lean_inc(x_70); +x_71 = lean_ctor_get(x_67, 2); +lean_inc(x_71); +if (lean_is_exclusive(x_67)) { + lean_ctor_release(x_67, 0); + lean_ctor_release(x_67, 1); + lean_ctor_release(x_67, 2); + x_72 = x_67; +} else { + lean_dec_ref(x_67); + x_72 = lean_box(0); +} +lean_inc(x_4); +lean_inc(x_2); +x_73 = l_Lean_Elab_Term_mkForall(x_1, x_2, x_70, x_4, x_5); +if (lean_obj_tag(x_73) == 0) +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +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); +lean_inc(x_4); +lean_inc(x_2); +x_76 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_71, x_4, 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; +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); +if (lean_is_scalar(x_72)) { + x_79 = lean_alloc_ctor(0, 3, 0); +} else { + x_79 = x_72; +} +lean_ctor_set(x_79, 0, x_69); +lean_ctor_set(x_79, 1, x_74); +lean_ctor_set(x_79, 2, x_77); +x_80 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_1, x_2, x_68, x_4, x_78); +if (lean_obj_tag(x_80) == 0) +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_81 = lean_ctor_get(x_80, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_80, 1); +lean_inc(x_82); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + x_83 = x_80; +} else { + lean_dec_ref(x_80); + x_83 = lean_box(0); +} +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_79); +lean_ctor_set(x_84, 1, x_81); +if (lean_is_scalar(x_83)) { + x_85 = lean_alloc_ctor(0, 2, 0); +} else { + x_85 = x_83; +} +lean_ctor_set(x_85, 0, x_84); +lean_ctor_set(x_85, 1, x_82); +return x_85; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; +lean_dec(x_79); +x_86 = lean_ctor_get(x_80, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_80, 1); +lean_inc(x_87); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + x_88 = x_80; +} else { + lean_dec_ref(x_80); + x_88 = lean_box(0); +} +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(1, 2, 0); +} else { + x_89 = x_88; +} +lean_ctor_set(x_89, 0, x_86); +lean_ctor_set(x_89, 1, x_87); +return x_89; +} +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +lean_dec(x_74); +lean_dec(x_72); +lean_dec(x_69); +lean_dec(x_68); +lean_dec(x_4); +lean_dec(x_2); +x_90 = lean_ctor_get(x_76, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_76, 1); +lean_inc(x_91); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + lean_ctor_release(x_76, 1); + x_92 = x_76; +} else { + lean_dec_ref(x_76); + x_92 = lean_box(0); +} +if (lean_is_scalar(x_92)) { + x_93 = lean_alloc_ctor(1, 2, 0); +} else { + x_93 = x_92; +} +lean_ctor_set(x_93, 0, x_90); +lean_ctor_set(x_93, 1, x_91); +return x_93; +} +} +else +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; +lean_dec(x_72); +lean_dec(x_71); +lean_dec(x_69); +lean_dec(x_68); +lean_dec(x_4); +lean_dec(x_2); +x_94 = lean_ctor_get(x_73, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_73, 1); +lean_inc(x_95); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_96 = x_73; +} else { + lean_dec_ref(x_73); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(1, 2, 0); +} else { + x_97 = x_96; +} +lean_ctor_set(x_97, 0, x_94); +lean_ctor_set(x_97, 1, x_95); +return x_97; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_30__updateParams(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_1, x_2, x_3, x_4, x_5); +return x_6; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Elab_Inductive_30__updateParams___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Elab_Inductive_30__updateParams(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___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; +x_3 = lean_ctor_get(x_2, 0); +lean_inc(x_3); +x_4 = lean_ctor_get(x_2, 1); +lean_inc(x_4); +lean_dec(x_2); +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +lean_dec(x_3); +x_6 = l_Lean_CollectLevelParams_main___main(x_5, x_1); +x_1 = x_6; +x_2 = x_4; +goto _start; +} +} +} +lean_object* l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___spec__2(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; lean_object* x_8; +x_3 = lean_ctor_get(x_2, 0); +lean_inc(x_3); +x_4 = lean_ctor_get(x_2, 1); +lean_inc(x_4); +lean_dec(x_2); +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +x_6 = l_Lean_CollectLevelParams_main___main(x_5, x_1); +x_7 = lean_ctor_get(x_3, 2); +lean_inc(x_7); +lean_dec(x_3); +x_8 = l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___spec__1(x_6, x_7); +x_1 = x_8; +x_2 = x_4; +goto _start; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = l_Lean_Elab_Command_mkDef___lambda__1___closed__5; +x_3 = l_List_foldl___main___at___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive___spec__2(x_2, x_1); +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +lean_dec(x_3); +return x_4; +} +} +lean_object* l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_unsigned_to_nat(0u); +x_8 = lean_nat_dec_eq(x_5, x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_sub(x_5, x_9); +x_11 = lean_nat_sub(x_4, x_5); +lean_dec(x_5); +x_12 = l_Lean_Elab_Command_InductiveView_inhabited; +x_13 = lean_array_get(x_12, x_1, x_11); +x_14 = l_Lean_Expr_Inhabited; +x_15 = lean_array_get(x_14, x_2, x_11); +lean_dec(x_11); +x_16 = lean_ctor_get(x_13, 3); +lean_inc(x_16); +lean_dec(x_13); +lean_inc(x_3); +x_17 = l_Lean_mkConst(x_16, x_3); +x_18 = l_Std_HashMapImp_insert___at___private_Lean_MetavarContext_2__visit___spec__3(x_6, x_15, x_17); +x_5 = x_10; +x_6 = x_18; +goto _start; +} +else +{ +lean_dec(x_5); +lean_dec(x_3); +return x_6; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_32__mkIndFVar2Const(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; +x_4 = l_List_map___main___at_Lean_Meta_addGlobalInstance___spec__1(x_3); +x_5 = lean_array_get_size(x_1); +x_6 = l_Std_HashMap_inhabited___closed__1; +lean_inc(x_5); +x_7 = l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1(x_1, x_2, x_4, x_5, x_5, x_6); +lean_dec(x_5); +return x_7; +} +} +lean_object* l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Nat_foldAux___main___at___private_Lean_Elab_Inductive_32__mkIndFVar2Const___spec__1(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_32__mkIndFVar2Const___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_32__mkIndFVar2Const(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(lean_object* x_1, lean_object* x_2, size_t x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +size_t x_6; size_t x_7; lean_object* x_8; lean_object* x_160; lean_object* x_161; size_t x_162; uint8_t x_163; +x_6 = lean_ptr_addr(x_4); +x_7 = x_3 == 0 ? 0 : x_6 % x_3; +x_160 = lean_ctor_get(x_5, 0); +lean_inc(x_160); +x_161 = lean_array_uget(x_160, x_7); +x_162 = lean_ptr_addr(x_161); +lean_dec(x_161); +x_163 = x_162 == x_6; +if (x_163 == 0) +{ +uint8_t x_164; +x_164 = l_Lean_Expr_isFVar(x_4); +if (x_164 == 0) +{ +lean_object* x_165; +lean_dec(x_160); +x_165 = lean_box(0); +x_8 = x_165; +goto block_159; +} +else +{ +lean_object* x_166; +x_166 = l_Std_HashMapImp_find_x3f___at___private_Lean_MetavarContext_2__visit___spec__1(x_1, x_4); +if (lean_obj_tag(x_166) == 0) +{ +lean_object* x_167; +lean_dec(x_160); +x_167 = lean_box(0); +x_8 = x_167; +goto block_159; +} +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; +x_168 = lean_ctor_get(x_166, 0); +lean_inc(x_168); +lean_dec(x_166); +x_169 = lean_unsigned_to_nat(0u); +x_170 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_2, x_2, x_169, x_168); +x_171 = lean_array_uset(x_160, x_7, x_4); +x_172 = lean_ctor_get(x_5, 1); +lean_inc(x_172); +lean_dec(x_5); +lean_inc(x_170); +x_173 = lean_array_uset(x_172, x_7, x_170); +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_171); +lean_ctor_set(x_174, 1, x_173); +x_175 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_175, 0, x_170); +lean_ctor_set(x_175, 1, x_174); +return x_175; +} +} +} +else +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; +lean_dec(x_160); +lean_dec(x_4); +x_176 = lean_ctor_get(x_5, 1); +lean_inc(x_176); +x_177 = lean_array_uget(x_176, x_7); +lean_dec(x_176); +x_178 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_178, 0, x_177); +lean_ctor_set(x_178, 1, x_5); +return x_178; +} +block_159: +{ +lean_dec(x_8); +switch (lean_obj_tag(x_4)) { +case 5: +{ +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; +x_9 = lean_ctor_get(x_4, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_4, 1); +lean_inc(x_10); +x_11 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_9, x_5); +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); +x_14 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_10, x_13); +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_16 = lean_ctor_get(x_14, 0); +x_17 = lean_ctor_get(x_14, 1); +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +lean_inc(x_4); +x_19 = lean_array_uset(x_18, x_7, x_4); +x_20 = lean_ctor_get(x_17, 1); +lean_inc(x_20); +lean_dec(x_17); +x_21 = lean_expr_update_app(x_4, x_12, x_16); +lean_inc(x_21); +x_22 = lean_array_uset(x_20, x_7, x_21); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_19); +lean_ctor_set(x_23, 1, x_22); +lean_ctor_set(x_14, 1, x_23); +lean_ctor_set(x_14, 0, x_21); +return x_14; +} +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; +x_24 = lean_ctor_get(x_14, 0); +x_25 = lean_ctor_get(x_14, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_14); +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +lean_inc(x_4); +x_27 = lean_array_uset(x_26, x_7, x_4); +x_28 = lean_ctor_get(x_25, 1); +lean_inc(x_28); +lean_dec(x_25); +x_29 = lean_expr_update_app(x_4, x_12, x_24); +lean_inc(x_29); +x_30 = lean_array_uset(x_28, x_7, x_29); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_27); +lean_ctor_set(x_31, 1, x_30); +x_32 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_32, 0, x_29); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +case 6: +{ +lean_object* x_33; lean_object* x_34; uint64_t x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_33 = lean_ctor_get(x_4, 1); +lean_inc(x_33); +x_34 = lean_ctor_get(x_4, 2); +lean_inc(x_34); +x_35 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); +x_36 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_33, x_5); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_36, 1); +lean_inc(x_38); +lean_dec(x_36); +x_39 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_34, x_38); +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_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_41 = lean_ctor_get(x_39, 0); +x_42 = lean_ctor_get(x_39, 1); +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +lean_inc(x_4); +x_44 = lean_array_uset(x_43, x_7, x_4); +x_45 = lean_ctor_get(x_42, 1); +lean_inc(x_45); +lean_dec(x_42); +x_46 = (uint8_t)((x_35 << 24) >> 61); +x_47 = lean_expr_update_lambda(x_4, x_46, x_37, x_41); +lean_inc(x_47); +x_48 = lean_array_uset(x_45, x_7, x_47); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_44); +lean_ctor_set(x_49, 1, x_48); +lean_ctor_set(x_39, 1, x_49); +lean_ctor_set(x_39, 0, x_47); +return x_39; +} +else +{ +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; lean_object* x_58; lean_object* x_59; +x_50 = lean_ctor_get(x_39, 0); +x_51 = lean_ctor_get(x_39, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_39); +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +lean_inc(x_4); +x_53 = lean_array_uset(x_52, x_7, x_4); +x_54 = lean_ctor_get(x_51, 1); +lean_inc(x_54); +lean_dec(x_51); +x_55 = (uint8_t)((x_35 << 24) >> 61); +x_56 = lean_expr_update_lambda(x_4, x_55, x_37, x_50); +lean_inc(x_56); +x_57 = lean_array_uset(x_54, x_7, x_56); +x_58 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_57); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_56); +lean_ctor_set(x_59, 1, x_58); +return x_59; +} +} +case 7: +{ +lean_object* x_60; lean_object* x_61; uint64_t x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; uint8_t x_67; +x_60 = lean_ctor_get(x_4, 1); +lean_inc(x_60); +x_61 = lean_ctor_get(x_4, 2); +lean_inc(x_61); +x_62 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); +x_63 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_60, x_5); +x_64 = lean_ctor_get(x_63, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_63, 1); +lean_inc(x_65); +lean_dec(x_63); +x_66 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_61, x_65); +x_67 = !lean_is_exclusive(x_66); +if (x_67 == 0) +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; uint8_t x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_68 = lean_ctor_get(x_66, 0); +x_69 = lean_ctor_get(x_66, 1); +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +lean_inc(x_4); +x_71 = lean_array_uset(x_70, x_7, x_4); +x_72 = lean_ctor_get(x_69, 1); +lean_inc(x_72); +lean_dec(x_69); +x_73 = (uint8_t)((x_62 << 24) >> 61); +x_74 = lean_expr_update_forall(x_4, x_73, x_64, x_68); +lean_inc(x_74); +x_75 = lean_array_uset(x_72, x_7, x_74); +x_76 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_75); +lean_ctor_set(x_66, 1, x_76); +lean_ctor_set(x_66, 0, x_74); +return x_66; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; uint8_t x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_77 = lean_ctor_get(x_66, 0); +x_78 = lean_ctor_get(x_66, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_66); +x_79 = lean_ctor_get(x_78, 0); +lean_inc(x_79); +lean_inc(x_4); +x_80 = lean_array_uset(x_79, x_7, x_4); +x_81 = lean_ctor_get(x_78, 1); +lean_inc(x_81); +lean_dec(x_78); +x_82 = (uint8_t)((x_62 << 24) >> 61); +x_83 = lean_expr_update_forall(x_4, x_82, x_64, x_77); +lean_inc(x_83); +x_84 = lean_array_uset(x_81, x_7, x_83); +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_84); +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_83); +lean_ctor_set(x_86, 1, x_85); +return x_86; +} +} +case 8: +{ +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; uint8_t x_97; +x_87 = lean_ctor_get(x_4, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_4, 2); +lean_inc(x_88); +x_89 = lean_ctor_get(x_4, 3); +lean_inc(x_89); +x_90 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_87, x_5); +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_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_88, x_92); +x_94 = lean_ctor_get(x_93, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_93, 1); +lean_inc(x_95); +lean_dec(x_93); +x_96 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_89, x_95); +x_97 = !lean_is_exclusive(x_96); +if (x_97 == 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; +x_98 = lean_ctor_get(x_96, 0); +x_99 = lean_ctor_get(x_96, 1); +x_100 = lean_ctor_get(x_99, 0); +lean_inc(x_100); +lean_inc(x_4); +x_101 = lean_array_uset(x_100, x_7, x_4); +x_102 = lean_ctor_get(x_99, 1); +lean_inc(x_102); +lean_dec(x_99); +x_103 = lean_expr_update_let(x_4, x_91, x_94, x_98); +lean_inc(x_103); +x_104 = lean_array_uset(x_102, x_7, x_103); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_101); +lean_ctor_set(x_105, 1, x_104); +lean_ctor_set(x_96, 1, x_105); +lean_ctor_set(x_96, 0, x_103); +return x_96; +} +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; +x_106 = lean_ctor_get(x_96, 0); +x_107 = lean_ctor_get(x_96, 1); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_96); +x_108 = lean_ctor_get(x_107, 0); +lean_inc(x_108); +lean_inc(x_4); +x_109 = lean_array_uset(x_108, x_7, x_4); +x_110 = lean_ctor_get(x_107, 1); +lean_inc(x_110); +lean_dec(x_107); +x_111 = lean_expr_update_let(x_4, x_91, x_94, x_106); +lean_inc(x_111); +x_112 = lean_array_uset(x_110, x_7, x_111); +x_113 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_113, 0, x_109); +lean_ctor_set(x_113, 1, x_112); +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_111); +lean_ctor_set(x_114, 1, x_113); +return x_114; +} +} +case 10: +{ +lean_object* x_115; lean_object* x_116; uint8_t x_117; +x_115 = lean_ctor_get(x_4, 1); +lean_inc(x_115); +x_116 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_115, x_5); +x_117 = !lean_is_exclusive(x_116); +if (x_117 == 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; +x_118 = lean_ctor_get(x_116, 0); +x_119 = lean_ctor_get(x_116, 1); +x_120 = lean_ctor_get(x_119, 0); +lean_inc(x_120); +lean_inc(x_4); +x_121 = lean_array_uset(x_120, x_7, x_4); +x_122 = lean_ctor_get(x_119, 1); +lean_inc(x_122); +lean_dec(x_119); +x_123 = lean_expr_update_mdata(x_4, x_118); +lean_inc(x_123); +x_124 = lean_array_uset(x_122, x_7, x_123); +x_125 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_125, 0, x_121); +lean_ctor_set(x_125, 1, x_124); +lean_ctor_set(x_116, 1, x_125); +lean_ctor_set(x_116, 0, x_123); +return x_116; +} +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; +x_126 = lean_ctor_get(x_116, 0); +x_127 = lean_ctor_get(x_116, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_116); +x_128 = lean_ctor_get(x_127, 0); +lean_inc(x_128); +lean_inc(x_4); +x_129 = lean_array_uset(x_128, x_7, x_4); +x_130 = lean_ctor_get(x_127, 1); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_expr_update_mdata(x_4, x_126); +lean_inc(x_131); +x_132 = lean_array_uset(x_130, x_7, x_131); +x_133 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_133, 0, x_129); +lean_ctor_set(x_133, 1, x_132); +x_134 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_134, 0, x_131); +lean_ctor_set(x_134, 1, x_133); +return x_134; +} +} +case 11: +{ +lean_object* x_135; lean_object* x_136; uint8_t x_137; +x_135 = lean_ctor_get(x_4, 2); +lean_inc(x_135); +x_136 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_3, x_135, x_5); +x_137 = !lean_is_exclusive(x_136); +if (x_137 == 0) +{ +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_138 = lean_ctor_get(x_136, 0); +x_139 = lean_ctor_get(x_136, 1); +x_140 = lean_ctor_get(x_139, 0); +lean_inc(x_140); +lean_inc(x_4); +x_141 = lean_array_uset(x_140, x_7, x_4); +x_142 = lean_ctor_get(x_139, 1); +lean_inc(x_142); +lean_dec(x_139); +x_143 = lean_expr_update_proj(x_4, x_138); +lean_inc(x_143); +x_144 = lean_array_uset(x_142, x_7, x_143); +x_145 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_145, 0, x_141); +lean_ctor_set(x_145, 1, x_144); +lean_ctor_set(x_136, 1, x_145); +lean_ctor_set(x_136, 0, x_143); +return x_136; +} +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; +x_146 = lean_ctor_get(x_136, 0); +x_147 = lean_ctor_get(x_136, 1); +lean_inc(x_147); +lean_inc(x_146); +lean_dec(x_136); +x_148 = lean_ctor_get(x_147, 0); +lean_inc(x_148); +lean_inc(x_4); +x_149 = lean_array_uset(x_148, x_7, x_4); +x_150 = lean_ctor_get(x_147, 1); +lean_inc(x_150); +lean_dec(x_147); +x_151 = lean_expr_update_proj(x_4, x_146); +lean_inc(x_151); +x_152 = lean_array_uset(x_150, x_7, x_151); +x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_152); +x_154 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_154, 0, x_151); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +case 12: +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; +lean_dec(x_4); +x_155 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1; +x_156 = l_unreachable_x21___rarg(x_155); +x_157 = lean_apply_1(x_156, x_5); +return x_157; +} +default: +{ +lean_object* x_158; +x_158 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_158, 0, x_4); +lean_ctor_set(x_158, 1, x_5); +return x_158; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +size_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_dec(x_5); +x_10 = 8192; +x_11 = l_Lean_Expr_ReplaceImpl_initCache; +x_12 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_10, x_3, x_11); +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +lean_dec(x_12); +x_14 = l_Lean_Meta_mkForall(x_2, x_13, x_6, x_7); +return x_14; +} +else +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_16 = l_Lean_Meta_getFVarLocalDecl(x_15, x_6, x_7); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +x_19 = l_Lean_LocalDecl_type(x_17); +lean_dec(x_17); +lean_inc(x_6); +lean_inc(x_19); +x_20 = l_Lean_Meta_isClassQuick___main(x_19, x_6, x_18); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +switch (lean_obj_tag(x_21)) { +case 0: +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_dec(x_19); +lean_dec(x_15); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = lean_unsigned_to_nat(1u); +x_24 = lean_nat_add(x_5, x_23); +lean_dec(x_5); +x_5 = x_24; +x_7 = x_22; +goto _start; +} +case 1: +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; +lean_dec(x_19); +x_26 = lean_ctor_get(x_20, 1); +lean_inc(x_26); +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + x_27 = x_20; +} else { + lean_dec_ref(x_20); + x_27 = lean_box(0); +} +x_28 = lean_ctor_get(x_21, 0); +lean_inc(x_28); +lean_dec(x_21); +x_29 = lean_unsigned_to_nat(1u); +x_30 = lean_nat_add(x_5, x_29); +lean_dec(x_5); +x_31 = !lean_is_exclusive(x_26); +if (x_31 == 0) +{ +lean_object* x_32; uint8_t x_33; +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; +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) +{ +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_33__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; +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_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; +} +} +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_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_33__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; +} +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_35 = x_112; +x_36 = x_111; +goto block_85; +} +} +block_85: +{ +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_37 = lean_ctor_get(x_36, 2); +lean_inc(x_37); +x_38 = lean_ctor_get(x_35, 0); +lean_inc(x_38); +lean_dec(x_35); +x_39 = !lean_is_exclusive(x_36); +if (x_39 == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_36, 2); +lean_dec(x_40); +x_41 = !lean_is_exclusive(x_37); +if (x_41 == 0) +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_37, 2); +lean_dec(x_42); +lean_ctor_set(x_37, 2, x_34); +if (lean_is_scalar(x_27)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_27; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_36); +return x_43; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_44 = lean_ctor_get(x_37, 0); +x_45 = lean_ctor_get(x_37, 1); +x_46 = lean_ctor_get(x_37, 3); +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); +if (lean_is_scalar(x_27)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_27; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_38); +lean_ctor_set(x_48, 1, x_36); +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_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_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); +lean_inc(x_55); +x_56 = lean_ctor_get(x_37, 3); +lean_inc(x_56); +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; +} else { + lean_dec_ref(x_37); + x_57 = lean_box(0); +} +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(0, 4, 0); +} else { + x_58 = x_57; +} +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); +if (lean_is_scalar(x_27)) { + x_60 = lean_alloc_ctor(1, 2, 0); +} else { + x_60 = x_27; + lean_ctor_set_tag(x_60, 1); +} +lean_ctor_set(x_60, 0, x_38); +lean_ctor_set(x_60, 1, x_59); +return x_60; +} +} +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_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); +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_34); +if (lean_is_scalar(x_27)) { + x_67 = lean_alloc_ctor(0, 2, 0); +} else { + x_67 = x_27; +} +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_36); +return x_67; +} +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_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); +if (lean_is_scalar(x_27)) { + x_72 = lean_alloc_ctor(0, 2, 0); +} else { + x_72 = x_27; +} +lean_ctor_set(x_72, 0, x_62); +lean_ctor_set(x_72, 1, x_36); +return x_72; +} +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +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_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; +} else { + lean_dec_ref(x_61); + x_81 = lean_box(0); +} +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(0, 4, 0); +} else { + x_82 = x_81; +} +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); +if (lean_is_scalar(x_27)) { + x_84 = lean_alloc_ctor(0, 2, 0); +} else { + x_84 = x_27; +} +lean_ctor_set(x_84, 0, x_62); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +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_33__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_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); +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; +} else { + lean_dec_ref(x_6); + x_220 = 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_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_220; +} +lean_ctor_set(x_223, 0, x_215); +lean_ctor_set(x_223, 1, x_216); +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_33__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_inc(x_225); +x_226 = lean_ctor_get(x_224, 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); +lean_inc(x_228); +x_229 = lean_ctor_get(x_224, 1); +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; +} +block_211: +{ +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; +} +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_inc(x_197); +lean_dec(x_179); +x_198 = lean_ctor_get(x_180, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_180, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_180, 3); +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; +} else { + lean_dec_ref(x_180); + x_203 = 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; +} else { + lean_dec_ref(x_196); + x_207 = lean_box(0); +} +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 4, 0); +} else { + x_208 = x_207; +} +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); +if (lean_is_scalar(x_27)) { + x_210 = lean_alloc_ctor(0, 2, 0); +} else { + x_210 = x_27; +} +lean_ctor_set(x_210, 0, x_197); +lean_ctor_set(x_210, 1, x_209); +return x_210; +} +} +} +} +default: +{ +lean_object* x_231; lean_object* x_232; +x_231 = lean_ctor_get(x_20, 1); +lean_inc(x_231); +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) +{ +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_234; lean_object* x_235; lean_object* x_236; +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); +lean_dec(x_5); +x_5 = x_236; +x_7 = x_234; +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; +} else { + lean_dec_ref(x_232); + x_239 = 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_33__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_33__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); +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); +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; +} +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; +} +} +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_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_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, 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); +} else { + x_272 = x_239; + lean_ctor_set_tag(x_272, 1); +} +lean_ctor_set(x_272, 0, x_250); +lean_ctor_set(x_272, 1, x_271); +return x_272; +} +} +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_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_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); +} else { + x_284 = x_239; +} +lean_ctor_set(x_284, 0, x_274); +lean_ctor_set(x_284, 1, x_248); +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_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); +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; +} else { + lean_dec_ref(x_273); + x_293 = lean_box(0); +} +if (lean_is_scalar(x_293)) { + x_294 = lean_alloc_ctor(0, 4, 0); +} else { + x_294 = x_293; +} +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); +} else { + x_296 = x_239; +} +lean_ctor_set(x_296, 0, x_274); +lean_ctor_set(x_296, 1, x_295); +return x_296; +} +} +} +} +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); +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; +} else { + lean_dec_ref(x_6); + x_369 = 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); +} else { + x_372 = x_369; +} +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_33__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_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; +} +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; +} +block_361: +{ +if (lean_obj_tag(x_329) == 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_inc(x_346); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +lean_dec(x_329); +x_348 = lean_ctor_get(x_330, 0); +lean_inc(x_348); +x_349 = lean_ctor_get(x_330, 1); +lean_inc(x_349); +x_350 = lean_ctor_get(x_330, 3); +lean_inc(x_350); +x_351 = lean_ctor_get(x_330, 4); +lean_inc(x_351); +x_352 = lean_ctor_get(x_330, 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; +} else { + lean_dec_ref(x_330); + x_353 = lean_box(0); +} +x_354 = lean_ctor_get(x_346, 0); +lean_inc(x_354); +x_355 = lean_ctor_get(x_346, 1); +lean_inc(x_355); +x_356 = lean_ctor_get(x_346, 3); +lean_inc(x_356); +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; +} else { + lean_dec_ref(x_346); + x_357 = lean_box(0); +} +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 4, 0); +} else { + x_358 = x_357; +} +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); +if (lean_is_scalar(x_353)) { + x_359 = lean_alloc_ctor(0, 6, 0); +} else { + x_359 = 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); +} else { + x_360 = x_239; +} +lean_ctor_set(x_360, 0, x_347); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +} +} +} +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; +} else { + lean_dec_ref(x_380); + x_390 = 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); +} else { + x_425 = x_390; +} +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); +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; +} else { + lean_dec_ref(x_6); + x_432 = 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); +} else { + x_435 = x_432; +} +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_33__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_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; +} +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; +} +block_423: +{ +if (lean_obj_tag(x_391) == 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_inc(x_411); +x_412 = lean_ctor_get(x_392, 3); +lean_inc(x_412); +x_413 = lean_ctor_get(x_392, 4); +lean_inc(x_413); +x_414 = lean_ctor_get(x_392, 5); +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); +lean_inc(x_416); +x_417 = lean_ctor_get(x_408, 1); +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; +} else { + lean_dec_ref(x_408); + x_419 = lean_box(0); +} +if (lean_is_scalar(x_419)) { + x_420 = lean_alloc_ctor(0, 4, 0); +} else { + x_420 = x_419; +} +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); +} else { + x_421 = x_415; +} +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); +} else { + x_422 = x_239; +} +lean_ctor_set(x_422, 0, x_409); +lean_ctor_set(x_422, 1, x_421); +return x_422; +} +} +} +} +} +else +{ +uint8_t x_443; +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) +{ +return x_232; +} +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; +} +} +} +} +} +else +{ +uint8_t x_447; +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) +{ +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_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; +} +} +} +else +{ +uint8_t x_451; +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) +{ +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_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; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; +x_11 = l_Lean_Expr_isForall(x_8); +if (x_11 == 0) +{ +size_t x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_12 = 8192; +x_13 = l_Lean_Expr_ReplaceImpl_initCache; +x_14 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_12, x_3, x_13); +lean_dec(x_1); +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +lean_dec(x_14); +x_16 = l_Lean_Meta_mkForall(x_2, x_15, x_9, x_10); +return x_16; +} +else +{ +lean_object* x_17; +lean_dec(x_3); +x_17 = l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3(x_1, x_4, x_5, x_6, x_2, x_7, x_8, x_9, x_10); +return x_17; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_inc(x_9); +x_14 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_14, 0, x_9); +x_15 = lean_box(x_2); +lean_inc(x_8); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_5); +lean_inc(x_1); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1___boxed), 10, 7); +lean_closure_set(x_16, 0, x_1); +lean_closure_set(x_16, 1, x_5); +lean_closure_set(x_16, 2, x_9); +lean_closure_set(x_16, 3, x_15); +lean_closure_set(x_16, 4, x_3); +lean_closure_set(x_16, 5, x_4); +lean_closure_set(x_16, 6, x_8); +x_17 = lean_array_get_size(x_10); +x_18 = lean_nat_dec_lt(x_11, x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_19 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_14, x_16, x_12, x_13); +return x_19; +} +else +{ +lean_object* x_20; lean_object* x_21; +lean_dec(x_16); +lean_dec(x_14); +x_20 = lean_array_fget(x_10, x_11); +lean_inc(x_12); +x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +x_24 = l_Lean_LocalDecl_type(x_22); +lean_dec(x_22); +lean_inc(x_12); +lean_inc(x_24); +x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +switch (lean_obj_tag(x_26)) { +case 0: +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_24); +lean_dec(x_20); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_11, x_28); +lean_dec(x_11); +x_11 = x_29; +x_13 = x_27; +goto _start; +} +case 1: +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_32 = x_25; +} else { + lean_dec_ref(x_25); + x_32 = lean_box(0); +} +x_33 = lean_ctor_get(x_26, 0); +lean_inc(x_33); +lean_dec(x_26); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_11, x_34); +lean_dec(x_11); +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) +{ +lean_object* x_37; uint8_t x_38; +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; +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) +{ +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_33__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; +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_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; +} +} +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_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_33__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; +} +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_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; +} +} +block_90: +{ +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 2); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 0); +lean_inc(x_43); +lean_dec(x_40); +x_44 = !lean_is_exclusive(x_41); +if (x_44 == 0) +{ +lean_object* x_45; uint8_t x_46; +x_45 = lean_ctor_get(x_41, 2); +lean_dec(x_45); +x_46 = !lean_is_exclusive(x_42); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_42, 2); +lean_dec(x_47); +lean_ctor_set(x_42, 2, x_39); +if (lean_is_scalar(x_32)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_32; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_41); +return x_48; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_49 = lean_ctor_get(x_42, 0); +x_50 = lean_ctor_get(x_42, 1); +x_51 = lean_ctor_get(x_42, 3); +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); +if (lean_is_scalar(x_32)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_32; + lean_ctor_set_tag(x_53, 1); +} +lean_ctor_set(x_53, 0, x_43); +lean_ctor_set(x_53, 1, x_41); +return x_53; +} +} +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_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); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 3); +lean_inc(x_61); +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; +} else { + lean_dec_ref(x_42); + x_62 = lean_box(0); +} +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); +} else { + x_63 = x_62; +} +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); +if (lean_is_scalar(x_32)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_32; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_43); +lean_ctor_set(x_65, 1, x_64); +return x_65; +} +} +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_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); +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_39); +if (lean_is_scalar(x_32)) { + x_72 = lean_alloc_ctor(0, 2, 0); +} else { + x_72 = x_32; +} +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_41); +return x_72; +} +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_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); +if (lean_is_scalar(x_32)) { + x_77 = lean_alloc_ctor(0, 2, 0); +} else { + x_77 = x_32; +} +lean_ctor_set(x_77, 0, x_67); +lean_ctor_set(x_77, 1, x_41); +return x_77; +} +} +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_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; +} else { + lean_dec_ref(x_66); + x_86 = lean_box(0); +} +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); +} else { + x_87 = x_86; +} +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); +if (lean_is_scalar(x_32)) { + x_89 = lean_alloc_ctor(0, 2, 0); +} else { + x_89 = x_32; +} +lean_ctor_set(x_89, 0, x_67); +lean_ctor_set(x_89, 1, x_88); +return x_89; +} +} +} +} +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_33__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_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); +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; +} else { + lean_dec_ref(x_12); + x_225 = 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_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___at___private_Lean_Elab_Inductive_33__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_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_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); +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_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; +} 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; +} +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_inc(x_202); +lean_dec(x_184); +x_203 = lean_ctor_get(x_185, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_185, 3); +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; +} else { + lean_dec_ref(x_185); + x_208 = 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; +} else { + lean_dec_ref(x_201); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); +} else { + x_213 = x_212; +} +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); +if (lean_is_scalar(x_32)) { + x_215 = lean_alloc_ctor(0, 2, 0); +} else { + x_215 = x_32; +} +lean_ctor_set(x_215, 0, x_202); +lean_ctor_set(x_215, 1, x_214); +return x_215; +} +} +} +} +default: +{ +lean_object* x_236; lean_object* x_237; +x_236 = lean_ctor_get(x_25, 1); +lean_inc(x_236); +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) +{ +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_239; lean_object* x_240; lean_object* x_241; +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); +lean_dec(x_11); +x_11 = x_241; +x_13 = x_239; +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; +} else { + lean_dec_ref(x_237); + x_244 = 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_33__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_33__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); +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; +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; +} +} +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_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_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, 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); +} else { + x_277 = x_244; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_255); +lean_ctor_set(x_277, 1, x_276); +return x_277; +} +} +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_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_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); +} else { + x_289 = x_244; +} +lean_ctor_set(x_289, 0, x_279); +lean_ctor_set(x_289, 1, x_253); +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_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); +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; +} else { + lean_dec_ref(x_278); + x_298 = lean_box(0); +} +if (lean_is_scalar(x_298)) { + x_299 = lean_alloc_ctor(0, 4, 0); +} else { + x_299 = x_298; +} +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); +} else { + x_301 = x_244; +} +lean_ctor_set(x_301, 0, x_279); +lean_ctor_set(x_301, 1, x_300); +return x_301; +} +} +} +} +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); +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; +} else { + lean_dec_ref(x_12); + x_374 = 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); +} else { + x_377 = x_374; +} +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_33__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_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; +} +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; +} +block_366: +{ +if (lean_obj_tag(x_334) == 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_inc(x_351); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +lean_dec(x_334); +x_353 = lean_ctor_get(x_335, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_335, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_335, 3); +lean_inc(x_355); +x_356 = lean_ctor_get(x_335, 4); +lean_inc(x_356); +x_357 = lean_ctor_get(x_335, 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; +} else { + lean_dec_ref(x_335); + x_358 = lean_box(0); +} +x_359 = lean_ctor_get(x_351, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_351, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_351, 3); +lean_inc(x_361); +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; +} else { + lean_dec_ref(x_351); + x_362 = lean_box(0); +} +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 4, 0); +} else { + x_363 = x_362; +} +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); +if (lean_is_scalar(x_358)) { + x_364 = lean_alloc_ctor(0, 6, 0); +} else { + x_364 = 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); +} else { + x_365 = x_244; +} +lean_ctor_set(x_365, 0, x_352); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +} +} +} +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; +} else { + lean_dec_ref(x_385); + x_395 = 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); +} else { + x_430 = x_395; +} +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); +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; +} else { + lean_dec_ref(x_12); + x_437 = 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); +} else { + x_440 = x_437; +} +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_33__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_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; +} +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; +} +block_428: +{ +if (lean_obj_tag(x_396) == 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_inc(x_416); +x_417 = lean_ctor_get(x_397, 3); +lean_inc(x_417); +x_418 = lean_ctor_get(x_397, 4); +lean_inc(x_418); +x_419 = lean_ctor_get(x_397, 5); +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); +lean_inc(x_421); +x_422 = lean_ctor_get(x_413, 1); +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; +} else { + lean_dec_ref(x_413); + x_424 = lean_box(0); +} +if (lean_is_scalar(x_424)) { + x_425 = lean_alloc_ctor(0, 4, 0); +} else { + x_425 = x_424; +} +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); +} else { + x_426 = x_420; +} +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); +} else { + x_427 = x_244; +} +lean_ctor_set(x_427, 0, x_414); +lean_ctor_set(x_427, 1, x_426); +return x_427; +} +} +} +} +} +else +{ +uint8_t x_448; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_448 = !lean_is_exclusive(x_237); +if (x_448 == 0) +{ +return x_237; +} +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; +} +} +} +} +} +else +{ +uint8_t x_452; +lean_dec(x_24); +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_452 = !lean_is_exclusive(x_25); +if (x_452 == 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_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; +} +} +} +else +{ +uint8_t x_456; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_456 = !lean_is_exclusive(x_21); +if (x_456 == 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_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; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +size_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_dec(x_5); +x_10 = 8192; +x_11 = l_Lean_Expr_ReplaceImpl_initCache; +x_12 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_10, x_3, x_11); +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +lean_dec(x_12); +x_14 = l_Lean_Meta_mkForall(x_2, x_13, x_6, x_7); +return x_14; +} +else +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_16 = l_Lean_Meta_getFVarLocalDecl(x_15, x_6, x_7); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +x_19 = l_Lean_LocalDecl_type(x_17); +lean_dec(x_17); +lean_inc(x_6); +lean_inc(x_19); +x_20 = l_Lean_Meta_isClassQuick___main(x_19, x_6, x_18); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +switch (lean_obj_tag(x_21)) { +case 0: +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_dec(x_19); +lean_dec(x_15); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = lean_unsigned_to_nat(1u); +x_24 = lean_nat_add(x_5, x_23); +lean_dec(x_5); +x_5 = x_24; +x_7 = x_22; +goto _start; +} +case 1: +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; +lean_dec(x_19); +x_26 = lean_ctor_get(x_20, 1); +lean_inc(x_26); +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + x_27 = x_20; +} else { + lean_dec_ref(x_20); + x_27 = lean_box(0); +} +x_28 = lean_ctor_get(x_21, 0); +lean_inc(x_28); +lean_dec(x_21); +x_29 = lean_unsigned_to_nat(1u); +x_30 = lean_nat_add(x_5, x_29); +lean_dec(x_5); +x_31 = !lean_is_exclusive(x_26); +if (x_31 == 0) +{ +lean_object* x_32; uint8_t x_33; +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; +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) +{ +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_33__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; +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_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; +} +} +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_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_33__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; +} +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_35 = x_112; +x_36 = x_111; +goto block_85; +} +} +block_85: +{ +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_37 = lean_ctor_get(x_36, 2); +lean_inc(x_37); +x_38 = lean_ctor_get(x_35, 0); +lean_inc(x_38); +lean_dec(x_35); +x_39 = !lean_is_exclusive(x_36); +if (x_39 == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_36, 2); +lean_dec(x_40); +x_41 = !lean_is_exclusive(x_37); +if (x_41 == 0) +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_37, 2); +lean_dec(x_42); +lean_ctor_set(x_37, 2, x_34); +if (lean_is_scalar(x_27)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_27; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_36); +return x_43; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_44 = lean_ctor_get(x_37, 0); +x_45 = lean_ctor_get(x_37, 1); +x_46 = lean_ctor_get(x_37, 3); +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); +if (lean_is_scalar(x_27)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_27; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_38); +lean_ctor_set(x_48, 1, x_36); +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_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_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); +lean_inc(x_55); +x_56 = lean_ctor_get(x_37, 3); +lean_inc(x_56); +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; +} else { + lean_dec_ref(x_37); + x_57 = lean_box(0); +} +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(0, 4, 0); +} else { + x_58 = x_57; +} +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); +if (lean_is_scalar(x_27)) { + x_60 = lean_alloc_ctor(1, 2, 0); +} else { + x_60 = x_27; + lean_ctor_set_tag(x_60, 1); +} +lean_ctor_set(x_60, 0, x_38); +lean_ctor_set(x_60, 1, x_59); +return x_60; +} +} +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_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); +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_34); +if (lean_is_scalar(x_27)) { + x_67 = lean_alloc_ctor(0, 2, 0); +} else { + x_67 = x_27; +} +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_36); +return x_67; +} +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_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); +if (lean_is_scalar(x_27)) { + x_72 = lean_alloc_ctor(0, 2, 0); +} else { + x_72 = x_27; +} +lean_ctor_set(x_72, 0, x_62); +lean_ctor_set(x_72, 1, x_36); +return x_72; +} +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +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_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; +} else { + lean_dec_ref(x_61); + x_81 = lean_box(0); +} +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(0, 4, 0); +} else { + x_82 = x_81; +} +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); +if (lean_is_scalar(x_27)) { + x_84 = lean_alloc_ctor(0, 2, 0); +} else { + x_84 = x_27; +} +lean_ctor_set(x_84, 0, x_62); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +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_33__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_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); +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; +} else { + lean_dec_ref(x_6); + x_220 = 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_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_220; +} +lean_ctor_set(x_223, 0, x_215); +lean_ctor_set(x_223, 1, x_216); +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_33__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_inc(x_225); +x_226 = lean_ctor_get(x_224, 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); +lean_inc(x_228); +x_229 = lean_ctor_get(x_224, 1); +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; +} +block_211: +{ +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; +} +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_inc(x_197); +lean_dec(x_179); +x_198 = lean_ctor_get(x_180, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_180, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_180, 3); +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; +} else { + lean_dec_ref(x_180); + x_203 = 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; +} else { + lean_dec_ref(x_196); + x_207 = lean_box(0); +} +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 4, 0); +} else { + x_208 = x_207; +} +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); +if (lean_is_scalar(x_27)) { + x_210 = lean_alloc_ctor(0, 2, 0); +} else { + x_210 = x_27; +} +lean_ctor_set(x_210, 0, x_197); +lean_ctor_set(x_210, 1, x_209); +return x_210; +} +} +} +} +default: +{ +lean_object* x_231; lean_object* x_232; +x_231 = lean_ctor_get(x_20, 1); +lean_inc(x_231); +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) +{ +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_234; lean_object* x_235; lean_object* x_236; +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); +lean_dec(x_5); +x_5 = x_236; +x_7 = x_234; +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; +} else { + lean_dec_ref(x_232); + x_239 = 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_33__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_33__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); +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); +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; +} +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; +} +} +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_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_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, 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); +} else { + x_272 = x_239; + lean_ctor_set_tag(x_272, 1); +} +lean_ctor_set(x_272, 0, x_250); +lean_ctor_set(x_272, 1, x_271); +return x_272; +} +} +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_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_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); +} else { + x_284 = x_239; +} +lean_ctor_set(x_284, 0, x_274); +lean_ctor_set(x_284, 1, x_248); +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_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); +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; +} else { + lean_dec_ref(x_273); + x_293 = lean_box(0); +} +if (lean_is_scalar(x_293)) { + x_294 = lean_alloc_ctor(0, 4, 0); +} else { + x_294 = x_293; +} +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); +} else { + x_296 = x_239; +} +lean_ctor_set(x_296, 0, x_274); +lean_ctor_set(x_296, 1, x_295); +return x_296; +} +} +} +} +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); +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; +} else { + lean_dec_ref(x_6); + x_369 = 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); +} else { + x_372 = x_369; +} +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_33__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_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; +} +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; +} +block_361: +{ +if (lean_obj_tag(x_329) == 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_inc(x_346); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +lean_dec(x_329); +x_348 = lean_ctor_get(x_330, 0); +lean_inc(x_348); +x_349 = lean_ctor_get(x_330, 1); +lean_inc(x_349); +x_350 = lean_ctor_get(x_330, 3); +lean_inc(x_350); +x_351 = lean_ctor_get(x_330, 4); +lean_inc(x_351); +x_352 = lean_ctor_get(x_330, 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; +} else { + lean_dec_ref(x_330); + x_353 = lean_box(0); +} +x_354 = lean_ctor_get(x_346, 0); +lean_inc(x_354); +x_355 = lean_ctor_get(x_346, 1); +lean_inc(x_355); +x_356 = lean_ctor_get(x_346, 3); +lean_inc(x_356); +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; +} else { + lean_dec_ref(x_346); + x_357 = lean_box(0); +} +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 4, 0); +} else { + x_358 = x_357; +} +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); +if (lean_is_scalar(x_353)) { + x_359 = lean_alloc_ctor(0, 6, 0); +} else { + x_359 = 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); +} else { + x_360 = x_239; +} +lean_ctor_set(x_360, 0, x_347); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +} +} +} +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; +} else { + lean_dec_ref(x_380); + x_390 = 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); +} else { + x_425 = x_390; +} +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); +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; +} else { + lean_dec_ref(x_6); + x_432 = 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); +} else { + x_435 = x_432; +} +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_33__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_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; +} +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; +} +block_423: +{ +if (lean_obj_tag(x_391) == 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_inc(x_411); +x_412 = lean_ctor_get(x_392, 3); +lean_inc(x_412); +x_413 = lean_ctor_get(x_392, 4); +lean_inc(x_413); +x_414 = lean_ctor_get(x_392, 5); +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); +lean_inc(x_416); +x_417 = lean_ctor_get(x_408, 1); +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; +} else { + lean_dec_ref(x_408); + x_419 = lean_box(0); +} +if (lean_is_scalar(x_419)) { + x_420 = lean_alloc_ctor(0, 4, 0); +} else { + x_420 = x_419; +} +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); +} else { + x_421 = x_415; +} +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); +} else { + x_422 = x_239; +} +lean_ctor_set(x_422, 0, x_409); +lean_ctor_set(x_422, 1, x_421); +return x_422; +} +} +} +} +} +else +{ +uint8_t x_443; +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) +{ +return x_232; +} +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; +} +} +} +} +} +else +{ +uint8_t x_447; +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) +{ +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_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; +} +} +} +else +{ +uint8_t x_451; +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) +{ +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_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; +} +} +} +} +} +lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +if (lean_obj_tag(x_7) == 7) +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; uint64_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_25 = lean_ctor_get(x_7, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_7, 1); +lean_inc(x_26); +x_27 = lean_ctor_get(x_7, 2); +lean_inc(x_27); +x_28 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); +lean_dec(x_7); +x_29 = lean_array_get_size(x_5); +x_30 = lean_expr_instantiate_rev_range(x_26, x_6, x_29, x_5); +lean_dec(x_29); +lean_dec(x_26); +x_31 = l_Lean_Meta_mkFreshId___rarg(x_9); +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_31, 1); +lean_inc(x_33); +lean_dec(x_31); +x_34 = (uint8_t)((x_28 << 24) >> 61); +lean_inc(x_32); +x_35 = lean_local_ctx_mk_local_decl(x_4, x_32, x_25, x_30, x_34); +x_36 = l_Lean_mkFVar(x_32); +x_37 = lean_array_push(x_5, x_36); +x_4 = x_35; +x_5 = x_37; +x_7 = x_27; +x_9 = x_33; +goto _start; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; uint64_t x_42; lean_object* x_43; lean_object* x_44; uint8_t x_45; +x_39 = lean_ctor_get(x_7, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_7, 1); +lean_inc(x_40); +x_41 = lean_ctor_get(x_7, 2); +lean_inc(x_41); +x_42 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); +x_43 = lean_ctor_get(x_3, 0); +lean_inc(x_43); +x_44 = lean_array_get_size(x_5); +x_45 = lean_nat_dec_lt(x_44, x_43); +lean_dec(x_43); +if (x_45 == 0) +{ +lean_object* x_46; uint8_t x_47; +lean_dec(x_41); +lean_dec(x_40); +lean_dec(x_39); +lean_dec(x_3); +x_46 = lean_expr_instantiate_rev_range(x_7, x_6, x_44, x_5); +lean_dec(x_44); +lean_dec(x_7); +x_47 = !lean_is_exclusive(x_8); +if (x_47 == 0) +{ +lean_object* x_48; lean_object* x_49; +x_48 = lean_ctor_get(x_8, 1); +lean_dec(x_48); +lean_ctor_set(x_8, 1, x_4); +lean_inc(x_5); +x_49 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6(x_1, x_5, x_46, x_5, x_6, x_8, x_9); +lean_dec(x_5); +lean_dec(x_1); +return x_49; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_50 = lean_ctor_get(x_8, 0); +x_51 = lean_ctor_get(x_8, 2); +x_52 = lean_ctor_get(x_8, 3); +x_53 = lean_ctor_get(x_8, 4); +lean_inc(x_53); +lean_inc(x_52); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_8); +x_54 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_54, 0, x_50); +lean_ctor_set(x_54, 1, x_4); +lean_ctor_set(x_54, 2, x_51); +lean_ctor_set(x_54, 3, x_52); +lean_ctor_set(x_54, 4, x_53); +lean_inc(x_5); +x_55 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6(x_1, x_5, x_46, x_5, x_6, x_54, x_9); +lean_dec(x_5); +lean_dec(x_1); +return x_55; +} +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +lean_dec(x_7); +x_56 = lean_expr_instantiate_rev_range(x_40, x_6, x_44, x_5); +lean_dec(x_44); +lean_dec(x_40); +x_57 = l_Lean_Meta_mkFreshId___rarg(x_9); +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); +x_60 = (uint8_t)((x_42 << 24) >> 61); +lean_inc(x_58); +x_61 = lean_local_ctx_mk_local_decl(x_4, x_58, x_39, x_56, x_60); +x_62 = l_Lean_mkFVar(x_58); +x_63 = lean_array_push(x_5, x_62); +x_4 = x_61; +x_5 = x_63; +x_7 = x_41; +x_9 = x_59; +goto _start; +} +} +} +else +{ +lean_object* x_65; +x_65 = lean_box(0); +x_10 = x_65; +goto block_24; +} +block_24: +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +lean_dec(x_10); +x_11 = lean_array_get_size(x_5); +x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); +x_13 = !lean_is_exclusive(x_8); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_8, 1); +lean_dec(x_14); +lean_inc(x_4); +lean_ctor_set(x_8, 1, x_4); +if (x_2 == 0) +{ +lean_object* x_15; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_5); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4(x_1, x_5, x_12, x_5, x_6, x_8, x_9); +lean_dec(x_5); +lean_dec(x_1); +return x_15; +} +else +{ +lean_object* x_16; +lean_inc(x_6); +lean_inc(x_5); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_17 = lean_ctor_get(x_8, 0); +x_18 = lean_ctor_get(x_8, 2); +x_19 = lean_ctor_get(x_8, 3); +x_20 = lean_ctor_get(x_8, 4); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_8); +lean_inc(x_4); +x_21 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_21, 0, x_17); +lean_ctor_set(x_21, 1, x_4); +lean_ctor_set(x_21, 2, x_18); +lean_ctor_set(x_21, 3, x_19); +lean_ctor_set(x_21, 4, x_20); +if (x_2 == 0) +{ +lean_object* x_22; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_5); +x_22 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4(x_1, x_5, x_12, x_5, x_6, x_21, x_9); +lean_dec(x_5); +lean_dec(x_1); +return x_22; +} +else +{ +lean_object* x_23; +lean_inc(x_6); +lean_inc(x_5); +x_23 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_21, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_23; +} +} +} +} +} +lean_object* l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_2); +x_6 = l_Lean_Meta_whnf(x_2, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_Expr_isForall(x_7); +if (x_9 == 0) +{ +size_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_3); +x_10 = 8192; +x_11 = l_Array_empty___closed__1; +x_12 = l_Lean_Expr_ReplaceImpl_initCache; +x_13 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_11, x_10, x_2, x_12); +lean_dec(x_1); +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +lean_dec(x_13); +x_15 = l_Lean_Meta_mkForall(x_11, x_14, x_4, x_8); +return x_15; +} +else +{ +lean_object* x_16; uint8_t x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +lean_dec(x_2); +x_16 = lean_ctor_get(x_4, 1); +lean_inc(x_16); +x_17 = 1; +x_18 = l_Array_empty___closed__1; +x_19 = lean_unsigned_to_nat(0u); +x_20 = l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3(x_1, x_17, x_3, x_16, x_18, x_19, x_7, x_4, x_8); +return x_20; +} +} +else +{ +uint8_t x_21; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_21 = !lean_is_exclusive(x_6); +if (x_21 == 0) +{ +return x_6; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_6, 0); +x_23 = lean_ctor_get(x_6, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_6); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_6); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_4); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_4, 0); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +x_12 = lean_ctor_get(x_4, 1); +x_13 = lean_ctor_get(x_10, 0); +x_14 = lean_ctor_get(x_10, 1); +lean_inc(x_1); +x_15 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_15, 0, x_1); +x_16 = lean_ctor_get(x_6, 0); +lean_inc(x_16); +x_17 = !lean_is_exclusive(x_16); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_18 = lean_ctor_get(x_16, 4); +x_19 = lean_ctor_get(x_5, 0); +lean_inc(x_19); +x_20 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_16, 4, x_20); +lean_inc(x_3); +x_21 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(x_3, x_14, x_15, x_19, x_16); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +lean_inc(x_5); +x_24 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_23, x_18); +lean_ctor_set(x_10, 1, x_22); +x_25 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_12, x_5, x_24); +if (lean_obj_tag(x_25) == 0) +{ +uint8_t x_26; +x_26 = !lean_is_exclusive(x_25); +if (x_26 == 0) +{ +lean_object* x_27; +x_27 = lean_ctor_get(x_25, 0); +lean_ctor_set(x_4, 1, x_27); +lean_ctor_set(x_25, 0, x_4); +return x_25; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_25, 0); +x_29 = lean_ctor_get(x_25, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_25); +lean_ctor_set(x_4, 1, x_28); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_4); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +else +{ +uint8_t x_31; +lean_dec(x_10); +lean_free_object(x_4); +x_31 = !lean_is_exclusive(x_25); +if (x_31 == 0) +{ +return x_25; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_25, 0); +x_33 = lean_ctor_get(x_25, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_25); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +else +{ +uint8_t x_35; +lean_free_object(x_10); +lean_dec(x_13); +lean_free_object(x_4); +lean_dec(x_12); +lean_dec(x_3); +lean_dec(x_1); +x_35 = !lean_is_exclusive(x_21); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_36 = lean_ctor_get(x_21, 0); +x_37 = lean_ctor_get(x_21, 1); +lean_inc(x_5); +x_38 = l___private_Lean_Elab_Term_2__fromMetaException(x_5, x_2, x_36); +x_39 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_37, x_18); +lean_ctor_set(x_21, 1, x_39); +lean_ctor_set(x_21, 0, x_38); +return x_21; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_40 = lean_ctor_get(x_21, 0); +x_41 = lean_ctor_get(x_21, 1); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_21); +lean_inc(x_5); +x_42 = l___private_Lean_Elab_Term_2__fromMetaException(x_5, x_2, x_40); +x_43 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_41, x_18); +x_44 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_44, 0, x_42); +lean_ctor_set(x_44, 1, x_43); +return x_44; +} +} +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_45 = lean_ctor_get(x_16, 0); +x_46 = lean_ctor_get(x_16, 1); +x_47 = lean_ctor_get(x_16, 2); +x_48 = lean_ctor_get(x_16, 3); +x_49 = lean_ctor_get(x_16, 4); +x_50 = lean_ctor_get(x_16, 5); +lean_inc(x_50); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_16); +x_51 = lean_ctor_get(x_5, 0); +lean_inc(x_51); +x_52 = l_Lean_TraceState_Inhabited___closed__1; +x_53 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_53, 0, x_45); +lean_ctor_set(x_53, 1, x_46); +lean_ctor_set(x_53, 2, x_47); +lean_ctor_set(x_53, 3, x_48); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_53, 5, x_50); +lean_inc(x_3); +x_54 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(x_3, x_14, x_15, x_51, x_53); +if (lean_obj_tag(x_54) == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_55 = lean_ctor_get(x_54, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_54, 1); +lean_inc(x_56); +lean_dec(x_54); +lean_inc(x_5); +x_57 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_56, x_49); +lean_ctor_set(x_10, 1, x_55); +x_58 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_12, x_5, x_57); +if (lean_obj_tag(x_58) == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_59 = lean_ctor_get(x_58, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_58, 1); +lean_inc(x_60); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + x_61 = x_58; +} else { + lean_dec_ref(x_58); + x_61 = lean_box(0); +} +lean_ctor_set(x_4, 1, x_59); +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 2, 0); +} else { + x_62 = x_61; +} +lean_ctor_set(x_62, 0, x_4); +lean_ctor_set(x_62, 1, x_60); +return x_62; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +lean_dec(x_10); +lean_free_object(x_4); +x_63 = lean_ctor_get(x_58, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_58, 1); +lean_inc(x_64); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + x_65 = x_58; +} else { + lean_dec_ref(x_58); + x_65 = lean_box(0); +} +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(1, 2, 0); +} else { + x_66 = x_65; +} +lean_ctor_set(x_66, 0, x_63); +lean_ctor_set(x_66, 1, x_64); +return x_66; +} +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +lean_free_object(x_10); +lean_dec(x_13); +lean_free_object(x_4); +lean_dec(x_12); +lean_dec(x_3); +lean_dec(x_1); +x_67 = lean_ctor_get(x_54, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_54, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_54)) { + lean_ctor_release(x_54, 0); + lean_ctor_release(x_54, 1); + x_69 = x_54; +} else { + lean_dec_ref(x_54); + x_69 = lean_box(0); +} +lean_inc(x_5); +x_70 = l___private_Lean_Elab_Term_2__fromMetaException(x_5, x_2, x_67); +x_71 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_68, x_49); +if (lean_is_scalar(x_69)) { + x_72 = lean_alloc_ctor(1, 2, 0); +} else { + x_72 = x_69; +} +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_73 = lean_ctor_get(x_4, 1); +x_74 = lean_ctor_get(x_10, 0); +x_75 = lean_ctor_get(x_10, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_10); +lean_inc(x_1); +x_76 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_76, 0, x_1); +x_77 = lean_ctor_get(x_6, 0); +lean_inc(x_77); +x_78 = lean_ctor_get(x_77, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_77, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_77, 2); +lean_inc(x_80); +x_81 = lean_ctor_get(x_77, 3); +lean_inc(x_81); +x_82 = lean_ctor_get(x_77, 4); +lean_inc(x_82); +x_83 = lean_ctor_get(x_77, 5); +lean_inc(x_83); +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_84 = x_77; +} else { + lean_dec_ref(x_77); + x_84 = lean_box(0); +} +x_85 = lean_ctor_get(x_5, 0); +lean_inc(x_85); +x_86 = l_Lean_TraceState_Inhabited___closed__1; +if (lean_is_scalar(x_84)) { + x_87 = lean_alloc_ctor(0, 6, 0); +} else { + x_87 = x_84; +} +lean_ctor_set(x_87, 0, x_78); +lean_ctor_set(x_87, 1, x_79); +lean_ctor_set(x_87, 2, x_80); +lean_ctor_set(x_87, 3, x_81); +lean_ctor_set(x_87, 4, x_86); +lean_ctor_set(x_87, 5, x_83); +lean_inc(x_3); +x_88 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(x_3, x_75, x_76, x_85, x_87); +if (lean_obj_tag(x_88) == 0) +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_89 = lean_ctor_get(x_88, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_88, 1); +lean_inc(x_90); +lean_dec(x_88); +lean_inc(x_5); +x_91 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_90, x_82); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_74); +lean_ctor_set(x_92, 1, x_89); +x_93 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_73, x_5, x_91); +if (lean_obj_tag(x_93) == 0) +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_94 = lean_ctor_get(x_93, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_93, 1); +lean_inc(x_95); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + x_96 = x_93; +} else { + lean_dec_ref(x_93); + x_96 = lean_box(0); +} +lean_ctor_set(x_4, 1, x_94); +lean_ctor_set(x_4, 0, x_92); +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 2, 0); +} else { + x_97 = x_96; +} +lean_ctor_set(x_97, 0, x_4); +lean_ctor_set(x_97, 1, x_95); +return x_97; +} +else +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; +lean_dec(x_92); +lean_free_object(x_4); +x_98 = lean_ctor_get(x_93, 0); +lean_inc(x_98); +x_99 = lean_ctor_get(x_93, 1); +lean_inc(x_99); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + x_100 = x_93; +} else { + lean_dec_ref(x_93); + x_100 = lean_box(0); +} +if (lean_is_scalar(x_100)) { + x_101 = lean_alloc_ctor(1, 2, 0); +} else { + x_101 = x_100; +} +lean_ctor_set(x_101, 0, x_98); +lean_ctor_set(x_101, 1, x_99); +return x_101; +} +} +else +{ +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_dec(x_74); +lean_free_object(x_4); +lean_dec(x_73); +lean_dec(x_3); +lean_dec(x_1); +x_102 = lean_ctor_get(x_88, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_88, 1); +lean_inc(x_103); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + x_104 = x_88; +} else { + lean_dec_ref(x_88); + x_104 = lean_box(0); +} +lean_inc(x_5); +x_105 = l___private_Lean_Elab_Term_2__fromMetaException(x_5, x_2, x_102); +x_106 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_103, x_82); +if (lean_is_scalar(x_104)) { + x_107 = lean_alloc_ctor(1, 2, 0); +} else { + x_107 = x_104; +} +lean_ctor_set(x_107, 0, x_105); +lean_ctor_set(x_107, 1, x_106); +return x_107; +} +} +} +else +{ +lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_108 = lean_ctor_get(x_4, 0); +x_109 = lean_ctor_get(x_4, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_4); +x_110 = lean_ctor_get(x_108, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_108, 1); +lean_inc(x_111); +if (lean_is_exclusive(x_108)) { + lean_ctor_release(x_108, 0); + lean_ctor_release(x_108, 1); + x_112 = x_108; +} else { + lean_dec_ref(x_108); + x_112 = lean_box(0); +} +lean_inc(x_1); +x_113 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_113, 0, x_1); +x_114 = lean_ctor_get(x_6, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_114, 0); +lean_inc(x_115); +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +x_117 = lean_ctor_get(x_114, 2); +lean_inc(x_117); +x_118 = lean_ctor_get(x_114, 3); +lean_inc(x_118); +x_119 = lean_ctor_get(x_114, 4); +lean_inc(x_119); +x_120 = lean_ctor_get(x_114, 5); +lean_inc(x_120); +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); + lean_ctor_release(x_114, 4); + lean_ctor_release(x_114, 5); + x_121 = x_114; +} else { + lean_dec_ref(x_114); + x_121 = lean_box(0); +} +x_122 = lean_ctor_get(x_5, 0); +lean_inc(x_122); +x_123 = l_Lean_TraceState_Inhabited___closed__1; +if (lean_is_scalar(x_121)) { + x_124 = lean_alloc_ctor(0, 6, 0); +} else { + x_124 = x_121; +} +lean_ctor_set(x_124, 0, x_115); +lean_ctor_set(x_124, 1, x_116); +lean_ctor_set(x_124, 2, x_117); +lean_ctor_set(x_124, 3, x_118); +lean_ctor_set(x_124, 4, x_123); +lean_ctor_set(x_124, 5, x_120); +lean_inc(x_3); +x_125 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__2(x_3, x_111, x_113, x_122, x_124); +if (lean_obj_tag(x_125) == 0) +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; +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); +lean_inc(x_5); +x_128 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_127, x_119); +if (lean_is_scalar(x_112)) { + x_129 = lean_alloc_ctor(0, 2, 0); +} else { + x_129 = x_112; +} +lean_ctor_set(x_129, 0, x_110); +lean_ctor_set(x_129, 1, x_126); +x_130 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_109, x_5, x_128); +if (lean_obj_tag(x_130) == 0) +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_131 = lean_ctor_get(x_130, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_130, 1); +lean_inc(x_132); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + x_133 = x_130; +} else { + lean_dec_ref(x_130); + x_133 = lean_box(0); +} +x_134 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_134, 0, x_129); +lean_ctor_set(x_134, 1, x_131); +if (lean_is_scalar(x_133)) { + x_135 = lean_alloc_ctor(0, 2, 0); +} else { + x_135 = x_133; +} +lean_ctor_set(x_135, 0, x_134); +lean_ctor_set(x_135, 1, x_132); +return x_135; +} +else +{ +lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +lean_dec(x_129); +x_136 = lean_ctor_get(x_130, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_130, 1); +lean_inc(x_137); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + x_138 = x_130; +} else { + lean_dec_ref(x_130); + x_138 = lean_box(0); +} +if (lean_is_scalar(x_138)) { + x_139 = lean_alloc_ctor(1, 2, 0); +} else { + x_139 = x_138; +} +lean_ctor_set(x_139, 0, x_136); +lean_ctor_set(x_139, 1, x_137); +return x_139; +} +} +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_dec(x_112); +lean_dec(x_110); +lean_dec(x_109); +lean_dec(x_3); +lean_dec(x_1); +x_140 = lean_ctor_get(x_125, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_125, 1); +lean_inc(x_141); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_142 = x_125; +} else { + lean_dec_ref(x_125); + x_142 = lean_box(0); +} +lean_inc(x_5); +x_143 = l___private_Lean_Elab_Term_2__fromMetaException(x_5, x_2, x_140); +x_144 = l___private_Lean_Elab_Term_3__fromMetaState(x_2, x_5, x_6, x_141, x_119); +if (lean_is_scalar(x_142)) { + x_145 = lean_alloc_ctor(1, 2, 0); +} else { + x_145 = x_142; +} +lean_ctor_set(x_145, 0, x_143); +lean_ctor_set(x_145, 1, x_144); +return x_145; +} +} +} +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_6); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_4); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_4, 0); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_12 = lean_ctor_get(x_4, 1); +x_13 = lean_ctor_get(x_10, 0); +x_14 = lean_ctor_get(x_10, 1); +x_15 = lean_ctor_get(x_10, 2); +lean_inc(x_5); +lean_inc(x_3); +lean_inc(x_1); +x_16 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_15, x_5, x_6); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +lean_ctor_set(x_10, 2, x_17); +x_19 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(x_1, x_2, x_3, x_12, x_5, x_18); +if (lean_obj_tag(x_19) == 0) +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 0); +lean_ctor_set(x_4, 1, x_21); +lean_ctor_set(x_19, 0, x_4); +return x_19; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_19, 0); +x_23 = lean_ctor_get(x_19, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_19); +lean_ctor_set(x_4, 1, x_22); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_4); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +uint8_t x_25; +lean_dec(x_10); +lean_free_object(x_4); +x_25 = !lean_is_exclusive(x_19); +if (x_25 == 0) +{ +return x_19; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_19, 0); +x_27 = lean_ctor_get(x_19, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_19); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_free_object(x_10); +lean_dec(x_14); +lean_dec(x_13); +lean_free_object(x_4); +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_16); +if (x_29 == 0) +{ +return x_16; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_16, 0); +x_31 = lean_ctor_get(x_16, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_16); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_33 = lean_ctor_get(x_4, 1); +x_34 = lean_ctor_get(x_10, 0); +x_35 = lean_ctor_get(x_10, 1); +x_36 = lean_ctor_get(x_10, 2); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_10); +lean_inc(x_5); +lean_inc(x_3); +lean_inc(x_1); +x_37 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_36, x_5, x_6); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_37, 1); +lean_inc(x_39); +lean_dec(x_37); +x_40 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_40, 0, x_34); +lean_ctor_set(x_40, 1, x_35); +lean_ctor_set(x_40, 2, x_38); +x_41 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(x_1, x_2, x_3, x_33, x_5, x_39); +if (lean_obj_tag(x_41) == 0) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_41, 1); +lean_inc(x_43); +if (lean_is_exclusive(x_41)) { + lean_ctor_release(x_41, 0); + lean_ctor_release(x_41, 1); + x_44 = x_41; +} else { + lean_dec_ref(x_41); + x_44 = lean_box(0); +} +lean_ctor_set(x_4, 1, x_42); +lean_ctor_set(x_4, 0, x_40); +if (lean_is_scalar(x_44)) { + x_45 = lean_alloc_ctor(0, 2, 0); +} else { + x_45 = x_44; +} +lean_ctor_set(x_45, 0, x_4); +lean_ctor_set(x_45, 1, x_43); +return x_45; +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_40); +lean_free_object(x_4); +x_46 = lean_ctor_get(x_41, 0); +lean_inc(x_46); +x_47 = lean_ctor_get(x_41, 1); +lean_inc(x_47); +if (lean_is_exclusive(x_41)) { + lean_ctor_release(x_41, 0); + lean_ctor_release(x_41, 1); + x_48 = x_41; +} else { + lean_dec_ref(x_41); + x_48 = lean_box(0); +} +if (lean_is_scalar(x_48)) { + x_49 = lean_alloc_ctor(1, 2, 0); +} else { + x_49 = x_48; +} +lean_ctor_set(x_49, 0, x_46); +lean_ctor_set(x_49, 1, x_47); +return x_49; +} +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_dec(x_35); +lean_dec(x_34); +lean_free_object(x_4); +lean_dec(x_33); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_50 = lean_ctor_get(x_37, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_37, 1); +lean_inc(x_51); +if (lean_is_exclusive(x_37)) { + lean_ctor_release(x_37, 0); + lean_ctor_release(x_37, 1); + x_52 = x_37; +} else { + lean_dec_ref(x_37); + x_52 = lean_box(0); +} +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_52; +} +lean_ctor_set(x_53, 0, x_50); +lean_ctor_set(x_53, 1, x_51); +return x_53; +} +} +} +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; +x_54 = lean_ctor_get(x_4, 0); +x_55 = lean_ctor_get(x_4, 1); +lean_inc(x_55); +lean_inc(x_54); +lean_dec(x_4); +x_56 = lean_ctor_get(x_54, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_54, 1); +lean_inc(x_57); +x_58 = lean_ctor_get(x_54, 2); +lean_inc(x_58); +if (lean_is_exclusive(x_54)) { + lean_ctor_release(x_54, 0); + lean_ctor_release(x_54, 1); + lean_ctor_release(x_54, 2); + x_59 = x_54; +} else { + lean_dec_ref(x_54); + x_59 = lean_box(0); +} +lean_inc(x_5); +lean_inc(x_3); +lean_inc(x_1); +x_60 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_58, x_5, x_6); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +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); +if (lean_is_scalar(x_59)) { + x_63 = lean_alloc_ctor(0, 3, 0); +} else { + x_63 = x_59; +} +lean_ctor_set(x_63, 0, x_56); +lean_ctor_set(x_63, 1, x_57); +lean_ctor_set(x_63, 2, x_61); +x_64 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(x_1, x_2, x_3, x_55, x_5, x_62); +if (lean_obj_tag(x_64) == 0) +{ +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_64, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_64, 1); +lean_inc(x_66); +if (lean_is_exclusive(x_64)) { + lean_ctor_release(x_64, 0); + lean_ctor_release(x_64, 1); + x_67 = x_64; +} else { + lean_dec_ref(x_64); + x_67 = lean_box(0); +} +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_65); +if (lean_is_scalar(x_67)) { + x_69 = lean_alloc_ctor(0, 2, 0); +} else { + x_69 = x_67; +} +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_66); +return x_69; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +lean_dec(x_63); +x_70 = lean_ctor_get(x_64, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_64, 1); +lean_inc(x_71); +if (lean_is_exclusive(x_64)) { + lean_ctor_release(x_64, 0); + lean_ctor_release(x_64, 1); + x_72 = x_64; +} else { + lean_dec_ref(x_64); + x_72 = lean_box(0); +} +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(1, 2, 0); +} else { + x_73 = x_72; +} +lean_ctor_set(x_73, 0, x_70); +lean_ctor_set(x_73, 1, x_71); +return x_73; +} +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; +lean_dec(x_59); +lean_dec(x_57); +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_74 = lean_ctor_get(x_60, 0); +lean_inc(x_74); +x_75 = lean_ctor_get(x_60, 1); +lean_inc(x_75); +if (lean_is_exclusive(x_60)) { + lean_ctor_release(x_60, 0); + lean_ctor_release(x_60, 1); + x_76 = x_60; +} else { + lean_dec_ref(x_60); + x_76 = lean_box(0); +} +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(1, 2, 0); +} else { + x_77 = x_76; +} +lean_ctor_set(x_77, 0, x_74); +lean_ctor_set(x_77, 1, x_75); +return x_77; +} +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_8 = l_Lean_Elab_Command_InductiveView_inhabited; +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_array_get(x_8, x_1, x_9); +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +lean_dec(x_10); +x_12 = l___private_Lean_Elab_Inductive_32__mkIndFVar2Const(x_1, x_2, x_3); +x_13 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(x_4, x_11, x_12, x_5, x_6, x_7); +lean_dec(x_11); +return x_13; +} +} +lean_object* l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +size_t x_6; lean_object* x_7; +x_6 = lean_unbox_usize(x_3); +lean_dec(x_3); +x_7 = l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__1(x_1, x_2, x_6, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +lean_dec(x_1); +return x_8; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_4); +lean_dec(x_4); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___lambda__1(x_1, x_2, x_3, x_11, x_5, x_6, x_7, x_8, x_9, x_10); +return x_12; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +uint8_t x_14; lean_object* x_15; +x_14 = lean_unbox(x_2); +lean_dec(x_2); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__5(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_6); +return x_15; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +lean_dec(x_1); +return x_8; +} +} +lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__3(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__7(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +return x_7; +} +} +lean_object* l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_List_mapM___main___at___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___spec__8(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +return x_7; +} +} +lean_object* l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +lean_dec(x_1); +return x_8; +} +} +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_array_get_size(x_2); +x_6 = lean_nat_dec_lt(x_3, x_5); +lean_dec(x_5); +if (x_6 == 0) +{ +lean_dec(x_3); +return x_4; +} +else +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_7 = lean_array_fget(x_2, x_3); +x_8 = lean_ctor_get(x_7, 2); +lean_inc(x_8); +x_9 = lean_ctor_get_uint8(x_7, sizeof(void*)*5); +lean_dec(x_7); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_3, x_10); +lean_dec(x_3); +x_12 = l_Std_HashMapImp_insert___at_Lean_ClassState_addEntry___spec__6(x_4, x_8, x_9); +x_3 = x_11; +x_4 = x_12; +goto _start; +} +} +} +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_array_get_size(x_2); +x_6 = lean_nat_dec_lt(x_3, x_5); +lean_dec(x_5); +if (x_6 == 0) +{ +lean_dec(x_3); +return x_4; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_7 = lean_array_fget(x_2, x_3); +x_8 = lean_ctor_get(x_7, 7); +lean_inc(x_8); +x_9 = lean_unsigned_to_nat(0u); +x_10 = l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1(x_7, x_8, x_9, x_4); +lean_dec(x_8); +lean_dec(x_7); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +x_3 = x_12; +x_4 = x_10; +goto _start; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_34__mkCtor2InferMod(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = lean_unsigned_to_nat(0u); +x_3 = l_Std_HashMap_inhabited___closed__1; +x_4 = l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2(x_1, x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__1(x_1, x_2, x_3, x_4); +lean_dec(x_2); +lean_dec(x_1); +return x_5; +} +} +lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Array_iterateMAux___main___at___private_Lean_Elab_Inductive_34__mkCtor2InferMod___spec__2(x_1, x_2, x_3, x_4); +lean_dec(x_2); +lean_dec(x_1); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Inductive_34__mkCtor2InferMod___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l___private_Lean_Elab_Inductive_34__mkCtor2InferMod(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_1 = l_Std_HashMap_find_x21___rarg___closed__1; +x_2 = lean_unsigned_to_nat(162u); +x_3 = lean_unsigned_to_nat(12u); +x_4 = l_Std_PersistentHashMap_find_x21___rarg___closed__2; +x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); +return x_5; +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_4; +x_4 = lean_box(0); +return x_4; +} +else +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_3); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_3, 0); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_8 = lean_ctor_get(x_3, 1); +x_9 = lean_ctor_get(x_6, 0); +x_10 = lean_ctor_get(x_6, 1); +x_11 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_8); +x_12 = l_Std_HashMapImp_find_x3f___at_Lean_hasOutParams___spec__5(x_2, x_9); +if (lean_obj_tag(x_12) == 0) +{ +uint8_t x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +x_13 = l_Bool_Inhabited; +x_14 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1; +x_15 = lean_box(x_13); +x_16 = lean_panic_fn(x_15, x_14); +x_17 = lean_unbox(x_16); +lean_dec(x_16); +if (x_17 == 0) +{ +uint8_t x_18; lean_object* x_19; +x_18 = 1; +x_19 = l_Lean_Expr_inferImplicit___main(x_10, x_1, x_18); +lean_ctor_set(x_6, 1, x_19); +lean_ctor_set(x_3, 1, x_11); +return x_3; +} +else +{ +uint8_t x_20; lean_object* x_21; +x_20 = 0; +x_21 = l_Lean_Expr_inferImplicit___main(x_10, x_1, x_20); +lean_ctor_set(x_6, 1, x_21); +lean_ctor_set(x_3, 1, x_11); +return x_3; +} +} +else +{ +lean_object* x_22; uint8_t x_23; +x_22 = lean_ctor_get(x_12, 0); +lean_inc(x_22); +lean_dec(x_12); +x_23 = lean_unbox(x_22); +lean_dec(x_22); +if (x_23 == 0) +{ +uint8_t x_24; lean_object* x_25; +x_24 = 1; +x_25 = l_Lean_Expr_inferImplicit___main(x_10, x_1, x_24); +lean_ctor_set(x_6, 1, x_25); +lean_ctor_set(x_3, 1, x_11); +return x_3; +} +else +{ +uint8_t x_26; lean_object* x_27; +x_26 = 0; +x_27 = l_Lean_Expr_inferImplicit___main(x_10, x_1, x_26); +lean_ctor_set(x_6, 1, x_27); +lean_ctor_set(x_3, 1, x_11); +return x_3; +} +} +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_28 = lean_ctor_get(x_3, 1); +x_29 = lean_ctor_get(x_6, 0); +x_30 = lean_ctor_get(x_6, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_6); +x_31 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_28); +x_32 = l_Std_HashMapImp_find_x3f___at_Lean_hasOutParams___spec__5(x_2, x_29); +if (lean_obj_tag(x_32) == 0) +{ +uint8_t x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; +x_33 = l_Bool_Inhabited; +x_34 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1; +x_35 = lean_box(x_33); +x_36 = lean_panic_fn(x_35, x_34); +x_37 = lean_unbox(x_36); +lean_dec(x_36); +if (x_37 == 0) +{ +uint8_t x_38; lean_object* x_39; lean_object* x_40; +x_38 = 1; +x_39 = l_Lean_Expr_inferImplicit___main(x_30, x_1, x_38); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_39); +lean_ctor_set(x_3, 1, x_31); +lean_ctor_set(x_3, 0, x_40); +return x_3; +} +else +{ +uint8_t x_41; lean_object* x_42; lean_object* x_43; +x_41 = 0; +x_42 = l_Lean_Expr_inferImplicit___main(x_30, x_1, x_41); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_29); +lean_ctor_set(x_43, 1, x_42); +lean_ctor_set(x_3, 1, x_31); +lean_ctor_set(x_3, 0, x_43); +return x_3; +} +} +else +{ +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_32, 0); +lean_inc(x_44); +lean_dec(x_32); +x_45 = lean_unbox(x_44); +lean_dec(x_44); +if (x_45 == 0) +{ +uint8_t x_46; lean_object* x_47; lean_object* x_48; +x_46 = 1; +x_47 = l_Lean_Expr_inferImplicit___main(x_30, x_1, x_46); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_29); +lean_ctor_set(x_48, 1, x_47); +lean_ctor_set(x_3, 1, x_31); +lean_ctor_set(x_3, 0, x_48); +return x_3; +} +else +{ +uint8_t x_49; lean_object* x_50; lean_object* x_51; +x_49 = 0; +x_50 = l_Lean_Expr_inferImplicit___main(x_30, x_1, x_49); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_29); +lean_ctor_set(x_51, 1, x_50); +lean_ctor_set(x_3, 1, x_31); +lean_ctor_set(x_3, 0, x_51); +return x_3; +} +} +} +} +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; +x_52 = lean_ctor_get(x_3, 0); +x_53 = lean_ctor_get(x_3, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_3); +x_54 = lean_ctor_get(x_52, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_52, 1); +lean_inc(x_55); +if (lean_is_exclusive(x_52)) { + lean_ctor_release(x_52, 0); + lean_ctor_release(x_52, 1); + x_56 = x_52; +} else { + lean_dec_ref(x_52); + x_56 = lean_box(0); +} +x_57 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_53); +x_58 = l_Std_HashMapImp_find_x3f___at_Lean_hasOutParams___spec__5(x_2, x_54); +if (lean_obj_tag(x_58) == 0) +{ +uint8_t x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_59 = l_Bool_Inhabited; +x_60 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1; +x_61 = lean_box(x_59); +x_62 = lean_panic_fn(x_61, x_60); +x_63 = lean_unbox(x_62); +lean_dec(x_62); +if (x_63 == 0) +{ +uint8_t x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_64 = 1; +x_65 = l_Lean_Expr_inferImplicit___main(x_55, x_1, x_64); +if (lean_is_scalar(x_56)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_56; +} +lean_ctor_set(x_66, 0, x_54); +lean_ctor_set(x_66, 1, x_65); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_57); +return x_67; +} +else +{ +uint8_t x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_68 = 0; +x_69 = l_Lean_Expr_inferImplicit___main(x_55, x_1, x_68); +if (lean_is_scalar(x_56)) { + x_70 = lean_alloc_ctor(0, 2, 0); +} else { + x_70 = x_56; +} +lean_ctor_set(x_70, 0, x_54); +lean_ctor_set(x_70, 1, x_69); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_57); +return x_71; +} +} +else +{ +lean_object* x_72; uint8_t x_73; +x_72 = lean_ctor_get(x_58, 0); +lean_inc(x_72); +lean_dec(x_58); +x_73 = lean_unbox(x_72); +lean_dec(x_72); +if (x_73 == 0) +{ +uint8_t x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_74 = 1; +x_75 = l_Lean_Expr_inferImplicit___main(x_55, x_1, x_74); +if (lean_is_scalar(x_56)) { + x_76 = lean_alloc_ctor(0, 2, 0); +} else { + x_76 = x_56; +} +lean_ctor_set(x_76, 0, x_54); +lean_ctor_set(x_76, 1, x_75); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_76); +lean_ctor_set(x_77, 1, x_57); +return x_77; +} +else +{ +uint8_t x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_78 = 0; +x_79 = l_Lean_Expr_inferImplicit___main(x_55, x_1, x_78); +if (lean_is_scalar(x_56)) { + x_80 = lean_alloc_ctor(0, 2, 0); +} else { + x_80 = x_56; +} +lean_ctor_set(x_80, 0, x_54); +lean_ctor_set(x_80, 1, x_79); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_80); +lean_ctor_set(x_81, 1, x_57); +return x_81; +} +} +} +} +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_4; +x_4 = lean_box(0); +return x_4; +} +else +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_3); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_3, 0); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_8 = lean_ctor_get(x_3, 1); +x_9 = lean_ctor_get(x_6, 2); +x_10 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_9); +lean_ctor_set(x_6, 2, x_10); +x_11 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(x_1, x_2, x_8); +lean_ctor_set(x_3, 1, x_11); +return x_3; +} +else +{ +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; +x_12 = lean_ctor_get(x_3, 1); +x_13 = lean_ctor_get(x_6, 0); +x_14 = lean_ctor_get(x_6, 1); +x_15 = lean_ctor_get(x_6, 2); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_6); +x_16 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_15); +x_17 = lean_alloc_ctor(0, 3, 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); +x_18 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(x_1, x_2, x_12); +lean_ctor_set(x_3, 1, x_18); +lean_ctor_set(x_3, 0, x_17); +return x_3; +} +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_19 = lean_ctor_get(x_3, 0); +x_20 = lean_ctor_get(x_3, 1); +lean_inc(x_20); +lean_inc(x_19); +lean_dec(x_3); +x_21 = lean_ctor_get(x_19, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +x_23 = lean_ctor_get(x_19, 2); +lean_inc(x_23); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + lean_ctor_release(x_19, 2); + x_24 = x_19; +} else { + lean_dec_ref(x_19); + x_24 = lean_box(0); +} +x_25 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_23); +if (lean_is_scalar(x_24)) { + x_26 = lean_alloc_ctor(0, 3, 0); +} else { + x_26 = x_24; +} +lean_ctor_set(x_26, 0, x_21); +lean_ctor_set(x_26, 1, x_22); +lean_ctor_set(x_26, 2, x_25); +x_27 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(x_1, x_2, x_20); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_35__applyInferMod(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l___private_Lean_Elab_Inductive_34__mkCtor2InferMod(x_1); +x_5 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(x_2, x_4, x_3); +lean_dec(x_4); +return x_5; +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__2(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l___private_Lean_Elab_Inductive_35__applyInferMod___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_35__applyInferMod(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_unsigned_to_nat(0u); +x_11 = lean_nat_dec_eq(x_6, x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_12 = lean_unsigned_to_nat(1u); +x_13 = lean_nat_sub(x_6, x_12); +lean_dec(x_6); +x_14 = lean_nat_sub(x_5, x_13); +x_15 = lean_nat_sub(x_14, x_12); +lean_dec(x_14); +x_16 = l_Lean_Expr_Inhabited; +x_17 = lean_array_get(x_16, x_4, x_15); +x_18 = l_Lean_Elab_Command_ElabHeaderResult_inhabited; +x_19 = lean_array_get(x_18, x_2, x_15); +lean_dec(x_15); +x_20 = lean_ctor_get(x_19, 4); +lean_inc(x_20); +lean_inc(x_8); +lean_inc(x_3); +x_21 = l_Lean_Elab_Term_mkForall(x_1, x_3, x_20, x_8, x_9); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +lean_inc(x_8); +lean_inc(x_3); +x_24 = l___private_Lean_Elab_Inductive_16__elabCtors(x_17, x_3, x_19, x_8, x_23); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = lean_ctor_get(x_19, 0); +lean_inc(x_27); +lean_dec(x_19); +x_28 = lean_ctor_get(x_27, 3); +lean_inc(x_28); +lean_dec(x_27); +x_29 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_29, 0, x_28); +lean_ctor_set(x_29, 1, x_22); +lean_ctor_set(x_29, 2, x_25); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_7); +x_6 = x_13; +x_7 = x_30; +x_9 = x_26; +goto _start; +} +else +{ +uint8_t x_32; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_13); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_3); +x_32 = !lean_is_exclusive(x_24); +if (x_32 == 0) +{ +return x_24; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_24, 0); +x_34 = lean_ctor_get(x_24, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_24); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_33); +lean_ctor_set(x_35, 1, x_34); +return x_35; +} +} +} +else +{ +uint8_t x_36; +lean_dec(x_19); +lean_dec(x_17); +lean_dec(x_13); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_3); +x_36 = !lean_is_exclusive(x_21); +if (x_36 == 0) +{ +return x_21; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_21, 0); +x_38 = lean_ctor_get(x_21, 1); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_21); +x_39 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_39, 0, x_37); +lean_ctor_set(x_39, 1, x_38); +return x_39; +} +} +} +else +{ +lean_object* x_40; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_3); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_7); +lean_ctor_set(x_40, 1, x_9); +return x_40; +} +} +} +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, uint8_t x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_array_get_size(x_10); +x_14 = lean_nat_add(x_13, x_1); +lean_dec(x_13); +lean_inc(x_11); +x_15 = l_List_mapM___main___at___private_Lean_Elab_Inductive_30__updateParams___spec__2(x_2, x_10, x_3, x_11, x_12); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +lean_inc(x_11); +x_18 = l___private_Lean_Elab_Inductive_18__levelMVarToParam(x_2, x_16, x_11, x_17); +if (x_4 == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +lean_inc(x_19); +x_21 = l___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive(x_19); +x_22 = l_Lean_Elab_Command_sortDeclLevelParams(x_5, x_6, x_21); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_19); +lean_dec(x_14); +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +lean_dec(x_22); +x_24 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_24, 0, x_23); +x_25 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_25, 0, x_24); +x_26 = l_Lean_Elab_Term_throwError___rarg(x_2, x_25, x_11, x_20); +lean_dec(x_2); +return x_26; +} +else +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_2); +x_27 = lean_ctor_get(x_22, 0); +lean_inc(x_27); +lean_dec(x_22); +lean_inc(x_14); +lean_inc(x_27); +x_28 = l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts(x_7, x_8, x_27, x_14, x_19, x_11, x_20); +if (lean_obj_tag(x_28) == 0) +{ +uint8_t x_29; +x_29 = !lean_is_exclusive(x_28); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_28, 0); +x_31 = l___private_Lean_Elab_Inductive_35__applyInferMod(x_7, x_14, x_30); +x_32 = lean_alloc_ctor(6, 3, 1); +lean_ctor_set(x_32, 0, x_27); +lean_ctor_set(x_32, 1, x_14); +lean_ctor_set(x_32, 2, x_31); +lean_ctor_set_uint8(x_32, sizeof(void*)*3, x_9); +lean_ctor_set(x_28, 0, x_32); +return x_28; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_33 = lean_ctor_get(x_28, 0); +x_34 = lean_ctor_get(x_28, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_28); +x_35 = l___private_Lean_Elab_Inductive_35__applyInferMod(x_7, x_14, x_33); +x_36 = lean_alloc_ctor(6, 3, 1); +lean_ctor_set(x_36, 0, x_27); +lean_ctor_set(x_36, 1, x_14); +lean_ctor_set(x_36, 2, x_35); +lean_ctor_set_uint8(x_36, sizeof(void*)*3, x_9); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_34); +return x_37; +} +} +else +{ +uint8_t x_38; +lean_dec(x_27); +lean_dec(x_14); +x_38 = !lean_is_exclusive(x_28); +if (x_38 == 0) +{ +return x_28; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_28, 0); +x_40 = lean_ctor_get(x_28, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_28); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_18, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_18, 1); +lean_inc(x_43); +lean_dec(x_18); +lean_inc(x_11); +lean_inc(x_2); +x_44 = l___private_Lean_Elab_Inductive_26__updateResultingUniverse(x_2, x_14, x_42, x_11, x_43); +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_44, 1); +lean_inc(x_46); +lean_dec(x_44); +lean_inc(x_45); +x_47 = l___private_Lean_Elab_Inductive_31__collectLevelParamsInInductive(x_45); +x_48 = l_Lean_Elab_Command_sortDeclLevelParams(x_5, x_6, x_47); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_45); +lean_dec(x_14); +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +lean_dec(x_48); +x_50 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_50, 0, x_49); +x_51 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_51, 0, x_50); +x_52 = l_Lean_Elab_Term_throwError___rarg(x_2, x_51, x_11, x_46); +lean_dec(x_2); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; +lean_dec(x_2); +x_53 = lean_ctor_get(x_48, 0); +lean_inc(x_53); +lean_dec(x_48); +lean_inc(x_14); +lean_inc(x_53); +x_54 = l___private_Lean_Elab_Inductive_33__replaceIndFVarsWithConsts(x_7, x_8, x_53, x_14, x_45, x_11, x_46); +if (lean_obj_tag(x_54) == 0) +{ +uint8_t x_55; +x_55 = !lean_is_exclusive(x_54); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_54, 0); +x_57 = l___private_Lean_Elab_Inductive_35__applyInferMod(x_7, x_14, x_56); +x_58 = lean_alloc_ctor(6, 3, 1); +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_14); +lean_ctor_set(x_58, 2, x_57); +lean_ctor_set_uint8(x_58, sizeof(void*)*3, x_9); +lean_ctor_set(x_54, 0, x_58); +return x_54; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_59 = lean_ctor_get(x_54, 0); +x_60 = lean_ctor_get(x_54, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_54); +x_61 = l___private_Lean_Elab_Inductive_35__applyInferMod(x_7, x_14, x_59); +x_62 = lean_alloc_ctor(6, 3, 1); +lean_ctor_set(x_62, 0, x_53); +lean_ctor_set(x_62, 1, x_14); +lean_ctor_set(x_62, 2, x_61); +lean_ctor_set_uint8(x_62, sizeof(void*)*3, x_9); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_60); +return x_63; +} +} +else +{ +uint8_t x_64; +lean_dec(x_53); +lean_dec(x_14); +x_64 = !lean_is_exclusive(x_54); +if (x_64 == 0) +{ +return x_54; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_54, 0); +x_66 = lean_ctor_get(x_54, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_54); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_68 = !lean_is_exclusive(x_44); +if (x_68 == 0) +{ +return x_44; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_44, 0); +x_70 = lean_ctor_get(x_44, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_44); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_72 = !lean_is_exclusive(x_15); +if (x_72 == 0) +{ +return x_15; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_15, 0); +x_74 = lean_ctor_get(x_15, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_15); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, uint8_t x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +_start: +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_12 = lean_array_get_size(x_8); +x_13 = lean_box(0); +x_14 = lean_array_get_size(x_1); +lean_inc(x_10); +lean_inc(x_14); +x_15 = l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1(x_2, x_3, x_8, x_9, x_14, x_14, x_13, x_10, x_11); +lean_dec(x_14); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x_20; lean_object* x_21; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_List_reverse___rarg(x_16); +x_19 = 0; +x_20 = lean_box(0); +lean_inc(x_10); +x_21 = l___private_Lean_Elab_SyntheticMVars_11__synthesizeSyntheticMVarsAux___main(x_19, x_20, x_10, x_17); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_21, 1); +lean_inc(x_22); +lean_dec(x_21); +lean_inc(x_10); +lean_inc(x_18); +x_23 = l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse(x_2, x_18, x_10, x_22); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +x_25 = lean_ctor_get(x_23, 1); +lean_inc(x_25); +lean_dec(x_23); +x_26 = lean_box(x_6); +lean_inc(x_18); +lean_inc(x_2); +x_27 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1___boxed), 12, 9); +lean_closure_set(x_27, 0, x_12); +lean_closure_set(x_27, 1, x_2); +lean_closure_set(x_27, 2, x_18); +lean_closure_set(x_27, 3, x_24); +lean_closure_set(x_27, 4, x_4); +lean_closure_set(x_27, 5, x_5); +lean_closure_set(x_27, 6, x_1); +lean_closure_set(x_27, 7, x_9); +lean_closure_set(x_27, 8, x_26); +x_28 = l___private_Lean_Elab_Inductive_29__withUsed___rarg(x_2, x_7, x_18, x_27, x_10, x_25); +lean_dec(x_2); +return x_28; +} +else +{ +uint8_t x_29; +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_23); +if (x_29 == 0) +{ +return x_23; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_23, 0); +x_31 = lean_ctor_get(x_23, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_23); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +else +{ +uint8_t x_33; +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_33 = !lean_is_exclusive(x_21); +if (x_33 == 0) +{ +return x_21; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_21, 0); +x_35 = lean_ctor_get(x_21, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_21); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +else +{ +uint8_t x_37; +lean_dec(x_12); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_37 = !lean_is_exclusive(x_15); +if (x_37 == 0) +{ +return x_15; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_15, 0); +x_39 = lean_ctor_get(x_15, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_15); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_38); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +} +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; +x_5 = l_Lean_Elab_Command_InductiveView_inhabited; +x_6 = lean_unsigned_to_nat(0u); +x_7 = lean_array_get(x_5, x_2, x_6); +x_8 = l_Lean_Elab_Term_getLevelNames(x_3, x_4); +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = lean_ctor_get(x_7, 4); +lean_inc(x_11); +x_12 = lean_ctor_get(x_7, 1); +lean_inc(x_12); +x_13 = lean_ctor_get_uint8(x_12, sizeof(void*)*2 + 3); +lean_dec(x_12); +x_14 = lean_ctor_get(x_7, 0); +lean_inc(x_14); +lean_dec(x_7); +lean_inc(x_3); +x_15 = l___private_Lean_Elab_Inductive_4__checkLevelNames(x_2, x_3, x_10); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_15, 1); +lean_inc(x_16); +lean_dec(x_15); +x_17 = !lean_is_exclusive(x_3); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; +x_18 = lean_ctor_get(x_3, 6); +lean_dec(x_18); +lean_inc(x_11); +lean_ctor_set(x_3, 6, x_11); +lean_inc(x_3); +lean_inc(x_2); +x_19 = l___private_Lean_Elab_Inductive_12__elabHeader(x_2, x_3, x_16); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = lean_box(x_13); +lean_inc(x_20); +x_23 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2___boxed), 11, 7); +lean_closure_set(x_23, 0, x_2); +lean_closure_set(x_23, 1, x_14); +lean_closure_set(x_23, 2, x_20); +lean_closure_set(x_23, 3, x_9); +lean_closure_set(x_23, 4, x_11); +lean_closure_set(x_23, 5, x_22); +lean_closure_set(x_23, 6, x_1); +x_24 = l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___rarg(x_20, x_23, x_3, x_21); +return x_24; +} +else +{ +uint8_t x_25; +lean_dec(x_3); +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_2); +lean_dec(x_1); +x_25 = !lean_is_exclusive(x_19); +if (x_25 == 0) +{ +return x_19; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_19, 0); +x_27 = lean_ctor_get(x_19, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_19); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; uint8_t x_39; uint8_t x_40; lean_object* x_41; lean_object* x_42; +x_29 = lean_ctor_get(x_3, 0); +x_30 = lean_ctor_get(x_3, 1); +x_31 = lean_ctor_get(x_3, 2); +x_32 = lean_ctor_get(x_3, 3); +x_33 = lean_ctor_get(x_3, 4); +x_34 = lean_ctor_get(x_3, 5); +x_35 = lean_ctor_get(x_3, 7); +x_36 = lean_ctor_get(x_3, 8); +x_37 = lean_ctor_get(x_3, 9); +x_38 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); +x_39 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); +x_40 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +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_inc(x_31); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_3); +lean_inc(x_11); +x_41 = lean_alloc_ctor(0, 10, 3); +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_32); +lean_ctor_set(x_41, 4, x_33); +lean_ctor_set(x_41, 5, x_34); +lean_ctor_set(x_41, 6, x_11); +lean_ctor_set(x_41, 7, x_35); +lean_ctor_set(x_41, 8, x_36); +lean_ctor_set(x_41, 9, x_37); +lean_ctor_set_uint8(x_41, sizeof(void*)*10, x_38); +lean_ctor_set_uint8(x_41, sizeof(void*)*10 + 1, x_39); +lean_ctor_set_uint8(x_41, sizeof(void*)*10 + 2, x_40); +lean_inc(x_41); +lean_inc(x_2); +x_42 = l___private_Lean_Elab_Inductive_12__elabHeader(x_2, x_41, x_16); +if (lean_obj_tag(x_42) == 0) +{ +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_42, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = lean_box(x_13); +lean_inc(x_43); +x_46 = lean_alloc_closure((void*)(l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2___boxed), 11, 7); +lean_closure_set(x_46, 0, x_2); +lean_closure_set(x_46, 1, x_14); +lean_closure_set(x_46, 2, x_43); +lean_closure_set(x_46, 3, x_9); +lean_closure_set(x_46, 4, x_11); +lean_closure_set(x_46, 5, x_45); +lean_closure_set(x_46, 6, x_1); +x_47 = l___private_Lean_Elab_Inductive_14__withInductiveLocalDecls___rarg(x_43, x_46, x_41, x_44); +return x_47; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_41); +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_2); +lean_dec(x_1); +x_48 = lean_ctor_get(x_42, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_42, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_42)) { + lean_ctor_release(x_42, 0); + lean_ctor_release(x_42, 1); + x_50 = x_42; +} else { + lean_dec_ref(x_42); + x_50 = lean_box(0); +} +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_50; +} +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_49); +return x_51; +} +} +} +else +{ +uint8_t x_52; +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_52 = !lean_is_exclusive(x_15); +if (x_52 == 0) +{ +return x_15; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_15, 0); +x_54 = lean_ctor_get(x_15, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_15); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; +} +} +} +} +lean_object* l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l_Nat_foldMAux___main___at___private_Lean_Elab_Inductive_36__mkInductiveDecl___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +return x_10; +} +} +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +uint8_t x_13; uint8_t x_14; lean_object* x_15; +x_13 = lean_unbox(x_4); +lean_dec(x_4); +x_14 = lean_unbox(x_9); +lean_dec(x_9); +x_15 = l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__1(x_1, x_2, x_3, x_13, x_5, x_6, x_7, x_8, x_14, x_10, x_11, x_12); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_1); +return x_15; +} +} +lean_object* l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +_start: +{ +uint8_t x_12; lean_object* x_13; +x_12 = lean_unbox(x_6); +lean_dec(x_6); +x_13 = l___private_Lean_Elab_Inductive_36__mkInductiveDecl___lambda__2(x_1, x_2, x_3, x_4, x_5, x_12, x_7, x_8, x_9, x_10, x_11); +lean_dec(x_7); +lean_dec(x_3); +return x_13; +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1(uint8_t x_1, uint8_t x_2, uint8_t x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_array_get_size(x_5); +x_10 = lean_nat_dec_lt(x_6, x_9); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +lean_dec(x_7); +lean_dec(x_6); +x_11 = lean_box(0); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_8); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +x_13 = lean_array_fget(x_5, x_6); +x_14 = lean_unsigned_to_nat(1u); +x_15 = lean_nat_add(x_6, x_14); +lean_dec(x_6); +x_16 = lean_ctor_get(x_13, 3); +lean_inc(x_16); +lean_dec(x_13); +lean_inc(x_7); +x_17 = l___private_Lean_Elab_Command_2__getState(x_7, x_8); +if (x_3 == 0) +{ +uint8_t x_211; +x_211 = 0; +x_18 = x_211; +goto block_210; +} +else +{ +uint8_t x_212; +x_212 = 1; +x_18 = x_212; +goto block_210; +} +block_210: +{ +uint8_t x_19; +if (x_3 == 0) +{ +uint8_t x_208; +x_208 = 0; +x_19 = x_208; +goto block_207; +} +else +{ +if (x_1 == 0) +{ +uint8_t x_209; +x_209 = 0; +x_19 = x_209; +goto block_207; +} +else +{ +x_19 = x_2; +goto block_207; +} +} +block_207: +{ +uint8_t x_20; +if (x_19 == 0) +{ +uint8_t x_205; +x_205 = 0; +x_20 = x_205; +goto block_204; +} +else +{ +uint8_t x_206; +x_206 = 1; +x_20 = x_206; +goto block_204; +} +block_204: +{ +uint8_t x_21; +if (x_3 == 0) +{ +uint8_t x_203; +x_203 = 0; +x_21 = x_203; +goto block_202; +} +else +{ +x_21 = x_4; +goto block_202; +} +block_202: +{ +uint8_t x_22; +if (x_21 == 0) +{ +uint8_t x_200; +x_200 = 0; +x_22 = x_200; +goto block_199; +} +else +{ +uint8_t x_201; +x_201 = 1; +x_22 = x_201; +goto block_199; +} +block_199: +{ +lean_object* x_23; lean_object* x_57; lean_object* x_88; +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_119; lean_object* x_120; uint8_t x_121; +x_119 = lean_ctor_get(x_17, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_17, 1); +lean_inc(x_120); +lean_dec(x_17); +x_121 = !lean_is_exclusive(x_119); +if (x_121 == 0) +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_119, 0); +x_123 = lean_mk_rec_on(x_122, x_16); +lean_ctor_set(x_119, 0, x_123); +lean_inc(x_7); +x_124 = l___private_Lean_Elab_Command_3__setState(x_119, x_7, x_120); +if (lean_obj_tag(x_124) == 0) +{ +if (x_18 == 0) +{ +lean_object* x_125; +x_125 = lean_ctor_get(x_124, 1); +lean_inc(x_125); +lean_dec(x_124); +x_88 = x_125; +goto block_118; +} +else +{ +lean_object* x_126; lean_object* x_127; +x_126 = lean_ctor_get(x_124, 1); +lean_inc(x_126); +lean_dec(x_124); +lean_inc(x_7); +x_127 = l___private_Lean_Elab_Command_2__getState(x_7, x_126); +if (lean_obj_tag(x_127) == 0) +{ +lean_object* x_128; lean_object* x_129; uint8_t x_130; +x_128 = lean_ctor_get(x_127, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_127, 1); +lean_inc(x_129); +lean_dec(x_127); +x_130 = !lean_is_exclusive(x_128); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; +x_131 = lean_ctor_get(x_128, 0); +x_132 = lean_mk_cases_on(x_131, x_16); +lean_ctor_set(x_128, 0, x_132); +lean_inc(x_7); +x_133 = l___private_Lean_Elab_Command_3__setState(x_128, x_7, x_129); +if (lean_obj_tag(x_133) == 0) +{ +lean_object* x_134; +x_134 = lean_ctor_get(x_133, 1); +lean_inc(x_134); +lean_dec(x_133); +x_88 = x_134; +goto block_118; +} +else +{ +uint8_t x_135; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_135 = !lean_is_exclusive(x_133); +if (x_135 == 0) +{ +return x_133; +} +else +{ +lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_136 = lean_ctor_get(x_133, 0); +x_137 = lean_ctor_get(x_133, 1); +lean_inc(x_137); +lean_inc(x_136); +lean_dec(x_133); +x_138 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_138, 0, x_136); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +} +} +else +{ +lean_object* x_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_139 = lean_ctor_get(x_128, 0); +x_140 = lean_ctor_get(x_128, 1); +x_141 = lean_ctor_get(x_128, 2); +x_142 = lean_ctor_get(x_128, 3); +x_143 = lean_ctor_get(x_128, 4); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); +lean_inc(x_140); +lean_inc(x_139); +lean_dec(x_128); +x_144 = lean_mk_cases_on(x_139, x_16); +x_145 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_145, 0, x_144); +lean_ctor_set(x_145, 1, x_140); +lean_ctor_set(x_145, 2, x_141); +lean_ctor_set(x_145, 3, x_142); +lean_ctor_set(x_145, 4, x_143); +lean_inc(x_7); +x_146 = l___private_Lean_Elab_Command_3__setState(x_145, x_7, x_129); +if (lean_obj_tag(x_146) == 0) +{ +lean_object* x_147; +x_147 = lean_ctor_get(x_146, 1); +lean_inc(x_147); +lean_dec(x_146); +x_88 = x_147; +goto block_118; +} +else +{ +lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_148 = lean_ctor_get(x_146, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_146, 1); +lean_inc(x_149); +if (lean_is_exclusive(x_146)) { + lean_ctor_release(x_146, 0); + lean_ctor_release(x_146, 1); + x_150 = x_146; +} else { + lean_dec_ref(x_146); + x_150 = lean_box(0); +} +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(1, 2, 0); +} else { + x_151 = x_150; +} +lean_ctor_set(x_151, 0, x_148); +lean_ctor_set(x_151, 1, x_149); +return x_151; +} +} +} +else +{ +uint8_t x_152; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_152 = !lean_is_exclusive(x_127); +if (x_152 == 0) +{ +return x_127; +} +else +{ +lean_object* x_153; lean_object* x_154; lean_object* x_155; +x_153 = lean_ctor_get(x_127, 0); +x_154 = lean_ctor_get(x_127, 1); +lean_inc(x_154); +lean_inc(x_153); +lean_dec(x_127); +x_155 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_155, 0, x_153); +lean_ctor_set(x_155, 1, x_154); +return x_155; +} +} +} +} +else +{ +uint8_t x_156; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_156 = !lean_is_exclusive(x_124); +if (x_156 == 0) +{ +return x_124; +} +else +{ +lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_157 = lean_ctor_get(x_124, 0); +x_158 = lean_ctor_get(x_124, 1); +lean_inc(x_158); +lean_inc(x_157); +lean_dec(x_124); +x_159 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_159, 0, x_157); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +} +else +{ +lean_object* x_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_160 = lean_ctor_get(x_119, 0); +x_161 = lean_ctor_get(x_119, 1); +x_162 = lean_ctor_get(x_119, 2); +x_163 = lean_ctor_get(x_119, 3); +x_164 = lean_ctor_get(x_119, 4); +lean_inc(x_164); +lean_inc(x_163); +lean_inc(x_162); +lean_inc(x_161); +lean_inc(x_160); +lean_dec(x_119); +x_165 = lean_mk_rec_on(x_160, x_16); +x_166 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_166, 0, x_165); +lean_ctor_set(x_166, 1, x_161); +lean_ctor_set(x_166, 2, x_162); +lean_ctor_set(x_166, 3, x_163); +lean_ctor_set(x_166, 4, x_164); +lean_inc(x_7); +x_167 = l___private_Lean_Elab_Command_3__setState(x_166, x_7, x_120); +if (lean_obj_tag(x_167) == 0) +{ +if (x_18 == 0) +{ +lean_object* x_168; +x_168 = lean_ctor_get(x_167, 1); +lean_inc(x_168); +lean_dec(x_167); +x_88 = x_168; +goto block_118; +} +else +{ +lean_object* x_169; lean_object* x_170; +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +lean_inc(x_7); +x_170 = l___private_Lean_Elab_Command_2__getState(x_7, x_169); +if (lean_obj_tag(x_170) == 0) +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; 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; +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_ctor_get(x_171, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_171, 1); +lean_inc(x_174); +x_175 = lean_ctor_get(x_171, 2); +lean_inc(x_175); +x_176 = lean_ctor_get(x_171, 3); +lean_inc(x_176); +x_177 = lean_ctor_get(x_171, 4); +lean_inc(x_177); +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_178 = x_171; +} else { + lean_dec_ref(x_171); + x_178 = lean_box(0); +} +x_179 = lean_mk_cases_on(x_173, x_16); +if (lean_is_scalar(x_178)) { + x_180 = lean_alloc_ctor(0, 5, 0); +} else { + x_180 = x_178; +} +lean_ctor_set(x_180, 0, x_179); +lean_ctor_set(x_180, 1, x_174); +lean_ctor_set(x_180, 2, x_175); +lean_ctor_set(x_180, 3, x_176); +lean_ctor_set(x_180, 4, x_177); +lean_inc(x_7); +x_181 = l___private_Lean_Elab_Command_3__setState(x_180, x_7, x_172); +if (lean_obj_tag(x_181) == 0) +{ +lean_object* x_182; +x_182 = lean_ctor_get(x_181, 1); +lean_inc(x_182); +lean_dec(x_181); +x_88 = x_182; +goto block_118; +} +else +{ +lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_183 = lean_ctor_get(x_181, 0); +lean_inc(x_183); +x_184 = lean_ctor_get(x_181, 1); +lean_inc(x_184); +if (lean_is_exclusive(x_181)) { + lean_ctor_release(x_181, 0); + lean_ctor_release(x_181, 1); + x_185 = x_181; +} else { + lean_dec_ref(x_181); + x_185 = lean_box(0); +} +if (lean_is_scalar(x_185)) { + x_186 = lean_alloc_ctor(1, 2, 0); +} else { + x_186 = x_185; +} +lean_ctor_set(x_186, 0, x_183); +lean_ctor_set(x_186, 1, x_184); +return x_186; +} +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_187 = lean_ctor_get(x_170, 0); +lean_inc(x_187); +x_188 = lean_ctor_get(x_170, 1); +lean_inc(x_188); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + x_189 = x_170; +} else { + lean_dec_ref(x_170); + x_189 = lean_box(0); +} +if (lean_is_scalar(x_189)) { + x_190 = lean_alloc_ctor(1, 2, 0); +} else { + x_190 = x_189; +} +lean_ctor_set(x_190, 0, x_187); +lean_ctor_set(x_190, 1, x_188); +return x_190; +} +} +} +else +{ +lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_191 = lean_ctor_get(x_167, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_167, 1); +lean_inc(x_192); +if (lean_is_exclusive(x_167)) { + lean_ctor_release(x_167, 0); + lean_ctor_release(x_167, 1); + x_193 = x_167; +} else { + lean_dec_ref(x_167); + x_193 = lean_box(0); +} +if (lean_is_scalar(x_193)) { + x_194 = lean_alloc_ctor(1, 2, 0); +} else { + x_194 = x_193; +} +lean_ctor_set(x_194, 0, x_191); +lean_ctor_set(x_194, 1, x_192); +return x_194; +} +} +} +else +{ +uint8_t x_195; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_195 = !lean_is_exclusive(x_17); +if (x_195 == 0) +{ +return x_17; +} +else +{ +lean_object* x_196; lean_object* x_197; lean_object* x_198; +x_196 = lean_ctor_get(x_17, 0); +x_197 = lean_ctor_get(x_17, 1); +lean_inc(x_197); +lean_inc(x_196); +lean_dec(x_17); +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; +} +} +block_56: +{ +if (x_22 == 0) +{ +lean_dec(x_16); +x_6 = x_15; +x_8 = x_23; +goto _start; +} +else +{ +lean_object* x_25; +lean_inc(x_7); +x_25 = l___private_Lean_Elab_Command_2__getState(x_7, x_23); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; lean_object* x_27; uint8_t x_28; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = !lean_is_exclusive(x_26); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_26, 0); +x_30 = lean_mk_ibelow(x_29, x_16); +lean_dec(x_16); +lean_ctor_set(x_26, 0, x_30); +lean_inc(x_7); +x_31 = l___private_Lean_Elab_Command_3__setState(x_26, x_7, x_27); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; +x_32 = lean_ctor_get(x_31, 1); +lean_inc(x_32); +lean_dec(x_31); +x_6 = x_15; +x_8 = x_32; +goto _start; +} +else +{ +uint8_t x_34; +lean_dec(x_15); +lean_dec(x_7); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +return x_31; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_31, 0); +x_36 = lean_ctor_get(x_31, 1); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_31); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_38 = lean_ctor_get(x_26, 0); +x_39 = lean_ctor_get(x_26, 1); +x_40 = lean_ctor_get(x_26, 2); +x_41 = lean_ctor_get(x_26, 3); +x_42 = lean_ctor_get(x_26, 4); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_26); +x_43 = lean_mk_ibelow(x_38, x_16); +lean_dec(x_16); +x_44 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_39); +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_inc(x_7); +x_45 = l___private_Lean_Elab_Command_3__setState(x_44, x_7, x_27); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 1); +lean_inc(x_46); +lean_dec(x_45); +x_6 = x_15; +x_8 = x_46; +goto _start; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_15); +lean_dec(x_7); +x_48 = lean_ctor_get(x_45, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_45, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_45)) { + lean_ctor_release(x_45, 0); + lean_ctor_release(x_45, 1); + x_50 = x_45; +} else { + lean_dec_ref(x_45); + x_50 = lean_box(0); +} +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_50; +} +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_49); +return x_51; +} +} +} +else +{ +uint8_t x_52; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_52 = !lean_is_exclusive(x_25); +if (x_52 == 0) +{ +return x_25; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_25, 0); +x_54 = lean_ctor_get(x_25, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_25); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; +} +} +} +} +block_87: +{ +if (x_22 == 0) +{ +x_23 = x_57; +goto block_56; +} +else +{ +lean_object* x_58; +lean_inc(x_7); +x_58 = l___private_Lean_Elab_Command_2__getState(x_7, x_57); +if (lean_obj_tag(x_58) == 0) +{ +lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_59 = lean_ctor_get(x_58, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_58, 1); +lean_inc(x_60); +lean_dec(x_58); +x_61 = !lean_is_exclusive(x_59); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_59, 0); +x_63 = lean_mk_below(x_62, x_16); +lean_ctor_set(x_59, 0, x_63); +lean_inc(x_7); +x_64 = l___private_Lean_Elab_Command_3__setState(x_59, x_7, x_60); +if (lean_obj_tag(x_64) == 0) +{ +lean_object* x_65; +x_65 = lean_ctor_get(x_64, 1); +lean_inc(x_65); +lean_dec(x_64); +x_23 = x_65; +goto block_56; +} +else +{ +uint8_t x_66; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_66 = !lean_is_exclusive(x_64); +if (x_66 == 0) +{ +return x_64; +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_67 = lean_ctor_get(x_64, 0); +x_68 = lean_ctor_get(x_64, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_64); +x_69 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_69, 0, x_67); +lean_ctor_set(x_69, 1, x_68); +return x_69; +} +} +} +else +{ +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_70 = lean_ctor_get(x_59, 0); +x_71 = lean_ctor_get(x_59, 1); +x_72 = lean_ctor_get(x_59, 2); +x_73 = lean_ctor_get(x_59, 3); +x_74 = lean_ctor_get(x_59, 4); +lean_inc(x_74); +lean_inc(x_73); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_59); +x_75 = lean_mk_below(x_70, x_16); +x_76 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_76, 0, x_75); +lean_ctor_set(x_76, 1, x_71); +lean_ctor_set(x_76, 2, x_72); +lean_ctor_set(x_76, 3, x_73); +lean_ctor_set(x_76, 4, x_74); +lean_inc(x_7); +x_77 = l___private_Lean_Elab_Command_3__setState(x_76, x_7, x_60); +if (lean_obj_tag(x_77) == 0) +{ +lean_object* x_78; +x_78 = lean_ctor_get(x_77, 1); +lean_inc(x_78); +lean_dec(x_77); +x_23 = x_78; +goto block_56; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_79 = lean_ctor_get(x_77, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_77, 1); +lean_inc(x_80); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + x_81 = x_77; +} else { + lean_dec_ref(x_77); + 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); +return x_82; +} +} +} +else +{ +uint8_t x_83; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_83 = !lean_is_exclusive(x_58); +if (x_83 == 0) +{ +return x_58; +} +else +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_84 = lean_ctor_get(x_58, 0); +x_85 = lean_ctor_get(x_58, 1); +lean_inc(x_85); +lean_inc(x_84); +lean_dec(x_58); +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; +} +} +} +} +block_118: +{ +if (x_20 == 0) +{ +x_57 = x_88; +goto block_87; +} +else +{ +lean_object* x_89; +lean_inc(x_7); +x_89 = l___private_Lean_Elab_Command_2__getState(x_7, x_88); +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_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_is_exclusive(x_90); +if (x_92 == 0) +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_90, 0); +x_94 = lean_mk_no_confusion(x_93, x_16); +lean_ctor_set(x_90, 0, x_94); +lean_inc(x_7); +x_95 = l___private_Lean_Elab_Command_3__setState(x_90, x_7, x_91); +if (lean_obj_tag(x_95) == 0) +{ +lean_object* x_96; +x_96 = lean_ctor_get(x_95, 1); +lean_inc(x_96); +lean_dec(x_95); +x_57 = x_96; +goto block_87; +} +else +{ +uint8_t x_97; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_97 = !lean_is_exclusive(x_95); +if (x_97 == 0) +{ +return x_95; +} +else +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_95, 0); +x_99 = lean_ctor_get(x_95, 1); +lean_inc(x_99); +lean_inc(x_98); +lean_dec(x_95); +x_100 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_100, 0, x_98); +lean_ctor_set(x_100, 1, x_99); +return x_100; +} +} +} +else +{ +lean_object* x_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_101 = lean_ctor_get(x_90, 0); +x_102 = lean_ctor_get(x_90, 1); +x_103 = lean_ctor_get(x_90, 2); +x_104 = lean_ctor_get(x_90, 3); +x_105 = lean_ctor_get(x_90, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_90); +x_106 = lean_mk_no_confusion(x_101, x_16); +x_107 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_107, 0, x_106); +lean_ctor_set(x_107, 1, x_102); +lean_ctor_set(x_107, 2, x_103); +lean_ctor_set(x_107, 3, x_104); +lean_ctor_set(x_107, 4, x_105); +lean_inc(x_7); +x_108 = l___private_Lean_Elab_Command_3__setState(x_107, x_7, x_91); +if (lean_obj_tag(x_108) == 0) +{ +lean_object* x_109; +x_109 = lean_ctor_get(x_108, 1); +lean_inc(x_109); +lean_dec(x_108); +x_57 = x_109; +goto block_87; +} +else +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_110 = lean_ctor_get(x_108, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_108, 1); +lean_inc(x_111); +if (lean_is_exclusive(x_108)) { + lean_ctor_release(x_108, 0); + lean_ctor_release(x_108, 1); + x_112 = x_108; +} else { + lean_dec_ref(x_108); + x_112 = lean_box(0); +} +if (lean_is_scalar(x_112)) { + x_113 = lean_alloc_ctor(1, 2, 0); +} else { + x_113 = x_112; +} +lean_ctor_set(x_113, 0, x_110); +lean_ctor_set(x_113, 1, x_111); +return x_113; +} +} +} +else +{ +uint8_t x_114; +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_7); +x_114 = !lean_is_exclusive(x_89); +if (x_114 == 0) +{ +return x_89; +} +else +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_115 = lean_ctor_get(x_89, 0); +x_116 = lean_ctor_get(x_89, 1); +lean_inc(x_116); +lean_inc(x_115); +lean_dec(x_89); +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* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2(uint8_t x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_5); +lean_dec(x_4); +x_9 = lean_box(0); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_6); +return x_10; +} +else +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +x_11 = lean_array_fget(x_3, x_4); +x_12 = lean_unsigned_to_nat(1u); +x_13 = lean_nat_add(x_4, x_12); +lean_dec(x_4); +x_14 = lean_ctor_get(x_11, 3); +lean_inc(x_14); +lean_dec(x_11); +if (x_1 == 0) +{ +uint8_t x_84; +x_84 = 0; +x_15 = x_84; +goto block_83; +} +else +{ +x_15 = x_2; +goto block_83; +} +block_83: +{ +uint8_t x_16; +if (x_15 == 0) +{ +uint8_t x_81; +x_81 = 0; +x_16 = x_81; +goto block_80; +} +else +{ +uint8_t x_82; +x_82 = 1; +x_16 = x_82; +goto block_80; +} +block_80: +{ +lean_object* x_17; +if (x_16 == 0) +{ +x_17 = x_6; +goto block_50; +} +else +{ +lean_object* x_51; +lean_inc(x_5); +x_51 = l___private_Lean_Elab_Command_2__getState(x_5, x_6); +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; lean_object* x_53; uint8_t x_54; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +x_54 = !lean_is_exclusive(x_52); +if (x_54 == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_52, 0); +x_56 = lean_mk_brec_on(x_55, x_14); +lean_ctor_set(x_52, 0, x_56); +lean_inc(x_5); +x_57 = l___private_Lean_Elab_Command_3__setState(x_52, x_5, x_53); +if (lean_obj_tag(x_57) == 0) +{ +lean_object* x_58; +x_58 = lean_ctor_get(x_57, 1); +lean_inc(x_58); +lean_dec(x_57); +x_17 = x_58; +goto block_50; +} +else +{ +uint8_t x_59; +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +x_59 = !lean_is_exclusive(x_57); +if (x_59 == 0) +{ +return x_57; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_60 = lean_ctor_get(x_57, 0); +x_61 = lean_ctor_get(x_57, 1); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_57); +x_62 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_62, 0, x_60); +lean_ctor_set(x_62, 1, x_61); +return x_62; +} +} +} +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; +x_63 = lean_ctor_get(x_52, 0); +x_64 = lean_ctor_get(x_52, 1); +x_65 = lean_ctor_get(x_52, 2); +x_66 = lean_ctor_get(x_52, 3); +x_67 = lean_ctor_get(x_52, 4); +lean_inc(x_67); +lean_inc(x_66); +lean_inc(x_65); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_52); +x_68 = lean_mk_brec_on(x_63, x_14); +x_69 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_64); +lean_ctor_set(x_69, 2, x_65); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +lean_inc(x_5); +x_70 = l___private_Lean_Elab_Command_3__setState(x_69, x_5, x_53); +if (lean_obj_tag(x_70) == 0) +{ +lean_object* x_71; +x_71 = lean_ctor_get(x_70, 1); +lean_inc(x_71); +lean_dec(x_70); +x_17 = x_71; +goto block_50; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +x_72 = lean_ctor_get(x_70, 0); +lean_inc(x_72); +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +if (lean_is_exclusive(x_70)) { + lean_ctor_release(x_70, 0); + lean_ctor_release(x_70, 1); + x_74 = x_70; +} else { + lean_dec_ref(x_70); + x_74 = lean_box(0); +} +if (lean_is_scalar(x_74)) { + x_75 = lean_alloc_ctor(1, 2, 0); +} else { + x_75 = x_74; +} +lean_ctor_set(x_75, 0, x_72); +lean_ctor_set(x_75, 1, x_73); +return x_75; +} +} +} +else +{ +uint8_t x_76; +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +x_76 = !lean_is_exclusive(x_51); +if (x_76 == 0) +{ +return x_51; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_51, 0); +x_78 = lean_ctor_get(x_51, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_51); +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; +} +} +} +block_50: +{ +if (x_16 == 0) +{ +lean_dec(x_14); +x_4 = x_13; +x_6 = x_17; +goto _start; +} +else +{ +lean_object* x_19; +lean_inc(x_5); +x_19 = l___private_Lean_Elab_Command_2__getState(x_5, x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = !lean_is_exclusive(x_20); +if (x_22 == 0) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_20, 0); +x_24 = lean_mk_binduction_on(x_23, x_14); +lean_dec(x_14); +lean_ctor_set(x_20, 0, x_24); +lean_inc(x_5); +x_25 = l___private_Lean_Elab_Command_3__setState(x_20, x_5, x_21); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 1); +lean_inc(x_26); +lean_dec(x_25); +x_4 = x_13; +x_6 = x_26; +goto _start; +} +else +{ +uint8_t x_28; +lean_dec(x_13); +lean_dec(x_5); +x_28 = !lean_is_exclusive(x_25); +if (x_28 == 0) +{ +return x_25; +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_25, 0); +x_30 = lean_ctor_get(x_25, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_25); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +else +{ +lean_object* x_32; lean_object* x_33; 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_32 = lean_ctor_get(x_20, 0); +x_33 = lean_ctor_get(x_20, 1); +x_34 = lean_ctor_get(x_20, 2); +x_35 = lean_ctor_get(x_20, 3); +x_36 = lean_ctor_get(x_20, 4); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_20); +x_37 = lean_mk_binduction_on(x_32, x_14); +lean_dec(x_14); +x_38 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_38, 0, x_37); +lean_ctor_set(x_38, 1, x_33); +lean_ctor_set(x_38, 2, x_34); +lean_ctor_set(x_38, 3, x_35); +lean_ctor_set(x_38, 4, x_36); +lean_inc(x_5); +x_39 = l___private_Lean_Elab_Command_3__setState(x_38, x_5, x_21); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; +x_40 = lean_ctor_get(x_39, 1); +lean_inc(x_40); +lean_dec(x_39); +x_4 = x_13; +x_6 = x_40; +goto _start; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +lean_dec(x_13); +lean_dec(x_5); +x_42 = lean_ctor_get(x_39, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_39, 1); +lean_inc(x_43); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + x_44 = x_39; +} else { + lean_dec_ref(x_39); + x_44 = lean_box(0); +} +if (lean_is_scalar(x_44)) { + x_45 = lean_alloc_ctor(1, 2, 0); +} else { + x_45 = x_44; +} +lean_ctor_set(x_45, 0, x_42); +lean_ctor_set(x_45, 1, x_43); +return x_45; +} +} +} +else +{ +uint8_t x_46; +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +x_46 = !lean_is_exclusive(x_19); +if (x_46 == 0) +{ +return x_19; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_47 = lean_ctor_get(x_19, 0); +x_48 = lean_ctor_get(x_19, 1); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_19); +x_49 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_49, 0, x_47); +lean_ctor_set(x_49, 1, x_48); +return x_49; +} +} +} +} +} +} +} +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("PUnit"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +lean_inc(x_2); +x_4 = l_Lean_Elab_Command_getEnv(x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +lean_dec(x_4); +x_7 = l_Lean_Expr_eq_x3f___closed__2; +lean_inc(x_5); +x_8 = l_Lean_Environment_contains(x_5, x_7); +x_9 = l_Lean_Expr_heq_x3f___closed__2; +lean_inc(x_5); +x_10 = l_Lean_Environment_contains(x_5, x_9); +x_11 = l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2; +lean_inc(x_5); +x_12 = l_Lean_Environment_contains(x_5, x_11); +x_13 = l_Lean_Expr_prod_x3f___closed__2; +x_14 = l_Lean_Environment_contains(x_5, x_13); +x_15 = lean_unsigned_to_nat(0u); +lean_inc(x_2); +x_16 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1(x_8, x_10, x_12, x_14, x_1, x_15, x_2, x_6); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +x_18 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2(x_12, x_14, x_1, x_15, x_2, x_17); +return x_18; +} +else +{ +uint8_t x_19; +lean_dec(x_2); +x_19 = !lean_is_exclusive(x_16); +if (x_19 == 0) +{ +return x_16; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_16, 0); +x_21 = lean_ctor_get(x_16, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_16); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_20); +lean_ctor_set(x_22, 1, x_21); +return x_22; +} +} +} +else +{ +uint8_t x_23; +lean_dec(x_2); +x_23 = !lean_is_exclusive(x_4); +if (x_23 == 0) +{ +return x_4; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_4, 0); +x_25 = lean_ctor_get(x_4, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_4); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; lean_object* x_13; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = lean_unbox(x_3); +lean_dec(x_3); +x_12 = lean_unbox(x_4); +lean_dec(x_4); +x_13 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__1(x_9, x_10, x_11, x_12, x_5, x_6, x_7, x_8); +lean_dec(x_5); +return x_13; +} +} +lean_object* l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; uint8_t x_8; lean_object* x_9; +x_7 = lean_unbox(x_1); +lean_dec(x_1); +x_8 = lean_unbox(x_2); +lean_dec(x_2); +x_9 = l_Array_forMAux___main___at___private_Lean_Elab_Inductive_37__mkAuxConstructions___spec__2(x_7, x_8, x_3, x_4, x_5, x_6); +lean_dec(x_3); +return x_9; +} +} +lean_object* l___private_Lean_Elab_Inductive_37__mkAuxConstructions___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Lean_Elab_Inductive_37__mkAuxConstructions(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_4); +lean_dec(x_3); +x_8 = lean_box(0); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_5); +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; uint8_t x_16; lean_object* x_17; lean_object* x_18; +x_10 = lean_array_fget(x_2, x_3); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +x_13 = lean_ctor_get(x_10, 3); +lean_inc(x_13); +x_14 = lean_ctor_get(x_10, 1); +lean_inc(x_14); +lean_dec(x_10); +x_15 = lean_ctor_get(x_14, 1); +lean_inc(x_15); +lean_dec(x_14); +x_16 = 0; +x_17 = lean_unsigned_to_nat(0u); +lean_inc(x_4); +x_18 = l_Array_forMAux___main___at_Lean_Elab_Command_applyAttributes___spec__1(x_1, x_13, x_16, x_15, x_17, x_4, x_5); +lean_dec(x_15); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_18, 1); +lean_inc(x_19); +lean_dec(x_18); +x_3 = x_12; +x_5 = x_19; +goto _start; +} +else +{ +uint8_t x_21; +lean_dec(x_12); +lean_dec(x_4); +x_21 = !lean_is_exclusive(x_18); +if (x_21 == 0) +{ +return x_18; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_18, 0); +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_18); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +} +} +lean_object* l_Lean_Elab_Command_elabInductiveCore___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Lean_Elab_Inductive_36__mkInductiveDecl(x_2, x_1, x_3, x_4); +return x_5; +} +} +lean_object* l_Lean_Elab_Command_elabInductiveCore(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_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_4 = l_Lean_Elab_Command_InductiveView_inhabited; +x_5 = lean_unsigned_to_nat(0u); +x_6 = lean_array_get(x_4, x_1, x_5); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_34 = lean_ctor_get(x_6, 3); +lean_inc(x_34); +lean_dec(x_6); +x_35 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_35, 0, x_34); +lean_inc(x_1); +x_36 = lean_alloc_closure((void*)(l_Lean_Elab_Command_elabInductiveCore___lambda__1), 4, 1); +lean_closure_set(x_36, 0, x_1); +lean_inc(x_2); +x_37 = l___private_Lean_Elab_Command_2__getState(x_2, x_3); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_37, 1); +lean_inc(x_39); +lean_dec(x_37); +x_40 = l___private_Lean_Elab_Command_9__getVarDecls(x_38); +lean_dec(x_38); +lean_inc(x_2); +x_41 = l___private_Lean_Elab_Command_2__getState(x_2, x_39); +if (lean_obj_tag(x_41) == 0) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_41, 1); +lean_inc(x_43); +lean_dec(x_41); +x_44 = l___private_Lean_Elab_Command_6__mkTermContext(x_2, x_42, x_35); +x_45 = l___private_Lean_Elab_Command_7__mkTermState(x_42); +lean_dec(x_42); +x_46 = l_Lean_Elab_Term_elabBinders___rarg(x_40, x_36, x_44, x_45); +lean_dec(x_40); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +lean_inc(x_2); +x_49 = l___private_Lean_Elab_Command_2__getState(x_2, x_43); +if (lean_obj_tag(x_49) == 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; +x_50 = lean_ctor_get(x_48, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_49, 0); +lean_inc(x_51); +x_52 = lean_ctor_get(x_49, 1); +lean_inc(x_52); +lean_dec(x_49); +x_53 = lean_ctor_get(x_50, 0); +lean_inc(x_53); +lean_dec(x_50); +x_54 = lean_ctor_get(x_48, 2); +lean_inc(x_54); +lean_dec(x_48); +x_55 = !lean_is_exclusive(x_51); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_51, 1); +lean_dec(x_56); +x_57 = lean_ctor_get(x_51, 0); +lean_dec(x_57); +lean_ctor_set(x_51, 1, x_54); +lean_ctor_set(x_51, 0, x_53); +lean_inc(x_2); +x_58 = l___private_Lean_Elab_Command_3__setState(x_51, x_2, x_52); +if (lean_obj_tag(x_58) == 0) +{ +lean_object* x_59; +x_59 = lean_ctor_get(x_58, 1); +lean_inc(x_59); +lean_dec(x_58); +x_8 = x_47; +x_9 = x_59; +goto block_33; +} +else +{ +uint8_t x_60; +lean_dec(x_47); +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_60 = !lean_is_exclusive(x_58); +if (x_60 == 0) +{ +return x_58; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_61 = lean_ctor_get(x_58, 0); +x_62 = lean_ctor_get(x_58, 1); +lean_inc(x_62); +lean_inc(x_61); +lean_dec(x_58); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_61); +lean_ctor_set(x_63, 1, x_62); +return x_63; +} +} +} +else +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_64 = lean_ctor_get(x_51, 2); +x_65 = lean_ctor_get(x_51, 3); +x_66 = lean_ctor_get(x_51, 4); +lean_inc(x_66); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_51); +x_67 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_67, 0, x_53); +lean_ctor_set(x_67, 1, x_54); +lean_ctor_set(x_67, 2, x_64); +lean_ctor_set(x_67, 3, x_65); +lean_ctor_set(x_67, 4, x_66); +lean_inc(x_2); +x_68 = l___private_Lean_Elab_Command_3__setState(x_67, x_2, x_52); +if (lean_obj_tag(x_68) == 0) +{ +lean_object* x_69; +x_69 = lean_ctor_get(x_68, 1); +lean_inc(x_69); +lean_dec(x_68); +x_8 = x_47; +x_9 = x_69; +goto block_33; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +lean_dec(x_47); +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_70 = lean_ctor_get(x_68, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_68, 1); +lean_inc(x_71); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + x_72 = x_68; +} else { + lean_dec_ref(x_68); + x_72 = lean_box(0); +} +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(1, 2, 0); +} else { + x_73 = x_72; +} +lean_ctor_set(x_73, 0, x_70); +lean_ctor_set(x_73, 1, x_71); +return x_73; +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_48); +lean_dec(x_47); +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_49); +if (x_74 == 0) +{ +return x_49; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_49, 0); +x_76 = lean_ctor_get(x_49, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_49); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +else +{ +lean_object* x_78; +x_78 = lean_ctor_get(x_46, 0); +lean_inc(x_78); +if (lean_obj_tag(x_78) == 0) +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +lean_dec(x_7); +lean_dec(x_1); +x_79 = lean_ctor_get(x_46, 1); +lean_inc(x_79); +lean_dec(x_46); +x_80 = lean_ctor_get(x_78, 0); +lean_inc(x_80); +lean_dec(x_78); +lean_inc(x_2); +x_81 = l___private_Lean_Elab_Command_2__getState(x_2, x_43); +if (lean_obj_tag(x_81) == 0) +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; uint8_t x_87; +x_82 = lean_ctor_get(x_79, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_81, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_81, 1); +lean_inc(x_84); +lean_dec(x_81); +x_85 = lean_ctor_get(x_82, 0); +lean_inc(x_85); +lean_dec(x_82); +x_86 = lean_ctor_get(x_79, 2); +lean_inc(x_86); +lean_dec(x_79); +x_87 = !lean_is_exclusive(x_83); +if (x_87 == 0) +{ +lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_88 = lean_ctor_get(x_83, 1); +lean_dec(x_88); +x_89 = lean_ctor_get(x_83, 0); +lean_dec(x_89); +lean_ctor_set(x_83, 1, x_86); +lean_ctor_set(x_83, 0, x_85); +x_90 = l___private_Lean_Elab_Command_3__setState(x_83, x_2, x_84); +if (lean_obj_tag(x_90) == 0) +{ +uint8_t x_91; +x_91 = !lean_is_exclusive(x_90); +if (x_91 == 0) +{ +lean_object* x_92; +x_92 = lean_ctor_get(x_90, 0); +lean_dec(x_92); +lean_ctor_set_tag(x_90, 1); +lean_ctor_set(x_90, 0, x_80); +return x_90; +} +else +{ +lean_object* x_93; lean_object* x_94; +x_93 = lean_ctor_get(x_90, 1); +lean_inc(x_93); +lean_dec(x_90); +x_94 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_94, 0, x_80); +lean_ctor_set(x_94, 1, x_93); +return x_94; +} +} +else +{ +uint8_t x_95; +lean_dec(x_80); +x_95 = !lean_is_exclusive(x_90); +if (x_95 == 0) +{ +return x_90; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_96 = lean_ctor_get(x_90, 0); +x_97 = lean_ctor_get(x_90, 1); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_90); +x_98 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_98, 0, x_96); +lean_ctor_set(x_98, 1, x_97); +return x_98; +} +} +} +else +{ +lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_99 = lean_ctor_get(x_83, 2); +x_100 = lean_ctor_get(x_83, 3); +x_101 = lean_ctor_get(x_83, 4); +lean_inc(x_101); +lean_inc(x_100); +lean_inc(x_99); +lean_dec(x_83); +x_102 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_102, 0, x_85); +lean_ctor_set(x_102, 1, x_86); +lean_ctor_set(x_102, 2, x_99); +lean_ctor_set(x_102, 3, x_100); +lean_ctor_set(x_102, 4, x_101); +x_103 = l___private_Lean_Elab_Command_3__setState(x_102, x_2, x_84); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_103, 1); +lean_inc(x_104); +if (lean_is_exclusive(x_103)) { + lean_ctor_release(x_103, 0); + lean_ctor_release(x_103, 1); + x_105 = x_103; +} else { + lean_dec_ref(x_103); + x_105 = lean_box(0); +} +if (lean_is_scalar(x_105)) { + x_106 = lean_alloc_ctor(1, 2, 0); +} else { + x_106 = x_105; + lean_ctor_set_tag(x_106, 1); +} +lean_ctor_set(x_106, 0, x_80); +lean_ctor_set(x_106, 1, x_104); +return x_106; +} +else +{ +lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; +lean_dec(x_80); +x_107 = lean_ctor_get(x_103, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_103, 1); +lean_inc(x_108); +if (lean_is_exclusive(x_103)) { + lean_ctor_release(x_103, 0); + lean_ctor_release(x_103, 1); + x_109 = x_103; +} else { + lean_dec_ref(x_103); + x_109 = lean_box(0); +} +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(1, 2, 0); +} else { + x_110 = x_109; +} +lean_ctor_set(x_110, 0, x_107); +lean_ctor_set(x_110, 1, x_108); +return x_110; +} +} +} +else +{ +uint8_t x_111; +lean_dec(x_80); +lean_dec(x_79); +lean_dec(x_2); +x_111 = !lean_is_exclusive(x_81); +if (x_111 == 0) +{ +return x_81; +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; +x_112 = lean_ctor_get(x_81, 0); +x_113 = lean_ctor_get(x_81, 1); +lean_inc(x_113); +lean_inc(x_112); +lean_dec(x_81); +x_114 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_114, 0, x_112); +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_dec(x_46); +x_115 = l_Lean_Elab_Command_liftTermElabM___rarg___closed__1; +x_116 = l_unreachable_x21___rarg(x_115); +lean_inc(x_2); +x_117 = lean_apply_2(x_116, x_2, x_43); +if (lean_obj_tag(x_117) == 0) +{ +lean_object* x_118; lean_object* x_119; +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_8 = x_118; +x_9 = x_119; +goto block_33; +} +else +{ +uint8_t x_120; +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_120 = !lean_is_exclusive(x_117); +if (x_120 == 0) +{ +return x_117; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_117, 0); +x_122 = lean_ctor_get(x_117, 1); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_117); +x_123 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_123, 0, x_121); +lean_ctor_set(x_123, 1, x_122); +return x_123; +} +} +} +} +} +else +{ +uint8_t x_124; +lean_dec(x_40); +lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_124 = !lean_is_exclusive(x_41); +if (x_124 == 0) +{ +return x_41; +} +else +{ +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_41, 0); +x_126 = lean_ctor_get(x_41, 1); +lean_inc(x_126); +lean_inc(x_125); +lean_dec(x_41); +x_127 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_127, 0, x_125); +lean_ctor_set(x_127, 1, x_126); +return x_127; +} +} +} +else +{ +uint8_t x_128; +lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_128 = !lean_is_exclusive(x_37); +if (x_128 == 0) +{ +return x_37; +} +else +{ +lean_object* x_129; lean_object* x_130; lean_object* x_131; +x_129 = lean_ctor_get(x_37, 0); +x_130 = lean_ctor_get(x_37, 1); +lean_inc(x_130); +lean_inc(x_129); +lean_dec(x_37); +x_131 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_131, 0, x_129); +lean_ctor_set(x_131, 1, x_130); +return x_131; +} +} +block_33: +{ +lean_object* x_10; +lean_inc(x_2); +x_10 = l_Lean_Elab_Command_addDecl(x_7, x_8, x_2, x_9); +lean_dec(x_8); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +lean_inc(x_2); +x_12 = l___private_Lean_Elab_Inductive_37__mkAuxConstructions(x_1, x_2, x_11); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +x_14 = l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(x_7, x_1, x_5, x_2, x_13); +lean_dec(x_1); +lean_dec(x_7); +if (lean_obj_tag(x_14) == 0) +{ +uint8_t x_15; +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_14, 0); +lean_dec(x_16); +x_17 = lean_box(0); +lean_ctor_set(x_14, 0, x_17); +return x_14; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_14, 1); +lean_inc(x_18); +lean_dec(x_14); +x_19 = lean_box(0); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_18); +return x_20; +} +} +else +{ +uint8_t x_21; +x_21 = !lean_is_exclusive(x_14); +if (x_21 == 0) +{ +return x_14; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_14, 0); +x_23 = lean_ctor_get(x_14, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_14); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +else +{ +uint8_t x_25; +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_25 = !lean_is_exclusive(x_12); +if (x_25 == 0) +{ +return x_12; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_12, 0); +x_27 = lean_ctor_get(x_12, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_12); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_10); +if (x_29 == 0) +{ +return x_10; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_10, 0); +x_31 = lean_ctor_get(x_10, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_10); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +} +} +lean_object* l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Array_forMAux___main___at_Lean_Elab_Command_elabInductiveCore___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} lean_object* initialize_Init(lean_object*); +lean_object* initialize_Lean_Util_ReplaceLevel(lean_object*); +lean_object* initialize_Lean_Util_ReplaceExpr(lean_object*); +lean_object* initialize_Lean_Util_CollectLevelParams(lean_object*); +lean_object* initialize_Lean_Util_Constructions(lean_object*); lean_object* initialize_Lean_Elab_Command(lean_object*); +lean_object* initialize_Lean_Elab_CollectFVars(lean_object*); lean_object* initialize_Lean_Elab_Definition(lean_object*); static bool _G_initialized = false; lean_object* initialize_Lean_Elab_Inductive(lean_object* w) { @@ -320,24 +20602,177 @@ _G_initialized = true; res = initialize_Init(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Lean_Util_ReplaceLevel(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); +res = initialize_Lean_Util_CollectLevelParams(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +res = initialize_Lean_Util_Constructions(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Lean_Elab_Command(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Lean_Elab_CollectFVars(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Lean_Elab_Definition(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +l_Lean_Elab_Command_CtorView_inhabited___closed__1 = _init_l_Lean_Elab_Command_CtorView_inhabited___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_CtorView_inhabited___closed__1); +l_Lean_Elab_Command_CtorView_inhabited___closed__2 = _init_l_Lean_Elab_Command_CtorView_inhabited___closed__2(); +lean_mark_persistent(l_Lean_Elab_Command_CtorView_inhabited___closed__2); +l_Lean_Elab_Command_CtorView_inhabited = _init_l_Lean_Elab_Command_CtorView_inhabited(); +lean_mark_persistent(l_Lean_Elab_Command_CtorView_inhabited); l_Lean_Elab_Command_InductiveView_inhabited___closed__1 = _init_l_Lean_Elab_Command_InductiveView_inhabited___closed__1(); lean_mark_persistent(l_Lean_Elab_Command_InductiveView_inhabited___closed__1); -l_Lean_Elab_Command_InductiveView_inhabited___closed__2 = _init_l_Lean_Elab_Command_InductiveView_inhabited___closed__2(); -lean_mark_persistent(l_Lean_Elab_Command_InductiveView_inhabited___closed__2); l_Lean_Elab_Command_InductiveView_inhabited = _init_l_Lean_Elab_Command_InductiveView_inhabited(); lean_mark_persistent(l_Lean_Elab_Command_InductiveView_inhabited); -l_Lean_Elab_Command_elabInductiveCore___closed__1 = _init_l_Lean_Elab_Command_elabInductiveCore___closed__1(); -lean_mark_persistent(l_Lean_Elab_Command_elabInductiveCore___closed__1); -l_Lean_Elab_Command_elabInductiveCore___closed__2 = _init_l_Lean_Elab_Command_elabInductiveCore___closed__2(); -lean_mark_persistent(l_Lean_Elab_Command_elabInductiveCore___closed__2); -l_Lean_Elab_Command_elabInductiveCore___closed__3 = _init_l_Lean_Elab_Command_elabInductiveCore___closed__3(); -lean_mark_persistent(l_Lean_Elab_Command_elabInductiveCore___closed__3); +l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1 = _init_l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1(); +lean_mark_persistent(l_Lean_Elab_Command_ElabHeaderResult_inhabited___closed__1); +l_Lean_Elab_Command_ElabHeaderResult_inhabited = _init_l_Lean_Elab_Command_ElabHeaderResult_inhabited(); +lean_mark_persistent(l_Lean_Elab_Command_ElabHeaderResult_inhabited); +l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1 = _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__1); +l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2 = _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__2); +l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3 = _init_l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_1__elabHeaderAux___main___lambda__1___closed__3); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__1); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__2); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_2__checkNumParams___spec__1___closed__3); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__1); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__2); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_3__checkUnsafe___spec__1___closed__3); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__1); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__2); +l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3 = _init_l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3(); +lean_mark_persistent(l_Array_forMAux___main___at___private_Lean_Elab_Inductive_4__checkLevelNames___spec__1___closed__3); +l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1 = _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__1); +l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2 = _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__2); +l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3 = _init_l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_6__throwUnexpectedInductiveType___rarg___closed__3); +l___private_Lean_Elab_Inductive_7__getResultingType___closed__1 = _init_l___private_Lean_Elab_Inductive_7__getResultingType___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_7__getResultingType___closed__1); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__1); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__2); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__3); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__4); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__5); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__6); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__7); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__8); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__9); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__10); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__11); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__12); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__13); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__14); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__15); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__16); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__17); +l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18 = _init_l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_9__checkParamsAndResultType___main___closed__18); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__1); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__2); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__3); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__4); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__5); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__6); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__7); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__8); +l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9 = _init_l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9(); +lean_mark_persistent(l_List_mapM___main___at___private_Lean_Elab_Inductive_16__elabCtors___spec__1___lambda__1___closed__9); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__1); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__2); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__3); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__4); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__5); +l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6 = _init_l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_19__getResultingUniverse___closed__6); +l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1 = _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__1); +l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2 = _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__2); +l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3 = _init_l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_20__tmpIndParam___closed__3); +l___private_Lean_Elab_Inductive_20__tmpIndParam = _init_l___private_Lean_Elab_Inductive_20__tmpIndParam(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_20__tmpIndParam); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__1); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__2); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__3); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__4); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__5); +l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6 = _init_l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_21__shouldInferResultUniverse___closed__6); +l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1 = _init_l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_22__addLevel___main___closed__1); +l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2 = _init_l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_22__addLevel___main___closed__2); +l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1 = _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___at___private_Lean_Elab_Inductive_26__updateResultingUniverse___spec__1___closed__1); +l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1 = _init_l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__1); +l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2 = _init_l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_26__updateResultingUniverse___closed__2); +l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1 = _init_l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1(); +lean_mark_persistent(l_List_forM___main___at___private_Lean_Elab_Inductive_27__traceIndTypes___spec__1___closed__1); +l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1 = _init_l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1(); +lean_mark_persistent(l_List_map___main___at___private_Lean_Elab_Inductive_35__applyInferMod___spec__1___closed__1); +l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1 = _init_l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__1); +l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2 = _init_l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Inductive_37__mkAuxConstructions___closed__2); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/stdlib/Lean/Elab/Tactic/Basic.c b/stage0/stdlib/Lean/Elab/Tactic/Basic.c index 001e122596..86b2d37538 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_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; x_4 = lean_ctor_get(x_3, 0); lean_inc(x_4); x_5 = lean_ctor_get(x_4, 0); @@ -6557,859 +6557,693 @@ lean_dec(x_5); x_7 = lean_ctor_get(x_6, 2); lean_inc(x_7); lean_dec(x_6); -x_8 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +x_153 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; lean_inc(x_2); -x_9 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_8, x_2, x_3); -if (lean_obj_tag(x_9) == 0) +x_154 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_153, x_2, x_3); +if (lean_obj_tag(x_154) == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_9, 1); -lean_inc(x_10); -lean_dec(x_9); -x_11 = l_Lean_Elab_Tactic_save(x_10); -lean_inc(x_10); -x_12 = lean_apply_2(x_1, x_2, x_10); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; -lean_dec(x_11); -lean_dec(x_10); -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_15, 2); -lean_inc(x_16); -x_17 = !lean_is_exclusive(x_12); -if (x_17 == 0) -{ -lean_object* x_18; uint8_t x_19; -x_18 = lean_ctor_get(x_12, 1); -lean_dec(x_18); -x_19 = !lean_is_exclusive(x_13); -if (x_19 == 0) -{ -lean_object* x_20; uint8_t x_21; -x_20 = lean_ctor_get(x_13, 0); -lean_dec(x_20); -x_21 = !lean_is_exclusive(x_14); -if (x_21 == 0) -{ -lean_object* x_22; uint8_t x_23; -x_22 = lean_ctor_get(x_14, 0); -lean_dec(x_22); -x_23 = !lean_is_exclusive(x_15); -if (x_23 == 0) -{ -lean_object* x_24; uint8_t x_25; -x_24 = lean_ctor_get(x_15, 2); -lean_dec(x_24); -x_25 = !lean_is_exclusive(x_16); -if (x_25 == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_16, 2); -lean_dec(x_26); -lean_ctor_set(x_16, 2, x_7); -return x_12; -} -else -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_27 = lean_ctor_get(x_16, 0); -x_28 = lean_ctor_get(x_16, 1); -x_29 = lean_ctor_get(x_16, 3); -lean_inc(x_29); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_16); -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_7); -lean_ctor_set(x_30, 3, x_29); -lean_ctor_set(x_15, 2, x_30); -return x_12; -} -} -else -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_31 = lean_ctor_get(x_15, 0); -x_32 = lean_ctor_get(x_15, 1); -x_33 = lean_ctor_get(x_15, 3); -x_34 = lean_ctor_get(x_15, 4); -x_35 = lean_ctor_get(x_15, 5); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_inc(x_32); -lean_inc(x_31); -lean_dec(x_15); -x_36 = lean_ctor_get(x_16, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_16, 1); -lean_inc(x_37); -x_38 = lean_ctor_get(x_16, 3); -lean_inc(x_38); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - x_39 = x_16; -} else { - lean_dec_ref(x_16); - x_39 = lean_box(0); -} -if (lean_is_scalar(x_39)) { - x_40 = lean_alloc_ctor(0, 4, 0); -} else { - x_40 = x_39; -} -lean_ctor_set(x_40, 0, x_36); -lean_ctor_set(x_40, 1, x_37); -lean_ctor_set(x_40, 2, x_7); -lean_ctor_set(x_40, 3, x_38); -x_41 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_41, 0, x_31); -lean_ctor_set(x_41, 1, x_32); -lean_ctor_set(x_41, 2, x_40); -lean_ctor_set(x_41, 3, x_33); -lean_ctor_set(x_41, 4, x_34); -lean_ctor_set(x_41, 5, x_35); -lean_ctor_set(x_14, 0, x_41); -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; lean_object* x_58; lean_object* x_59; -x_42 = lean_ctor_get(x_14, 1); -x_43 = lean_ctor_get(x_14, 2); -x_44 = lean_ctor_get(x_14, 3); -x_45 = lean_ctor_get(x_14, 4); -x_46 = lean_ctor_get(x_14, 5); -lean_inc(x_46); -lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); -lean_inc(x_42); -lean_dec(x_14); -x_47 = lean_ctor_get(x_15, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_15, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_15, 3); -lean_inc(x_49); -x_50 = lean_ctor_get(x_15, 4); -lean_inc(x_50); -x_51 = lean_ctor_get(x_15, 5); -lean_inc(x_51); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - lean_ctor_release(x_15, 2); - lean_ctor_release(x_15, 3); - lean_ctor_release(x_15, 4); - lean_ctor_release(x_15, 5); - x_52 = x_15; -} else { - lean_dec_ref(x_15); - x_52 = lean_box(0); -} -x_53 = lean_ctor_get(x_16, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_16, 1); -lean_inc(x_54); -x_55 = lean_ctor_get(x_16, 3); -lean_inc(x_55); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - x_56 = x_16; -} else { - lean_dec_ref(x_16); - x_56 = lean_box(0); -} -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); -} else { - x_57 = x_56; -} -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_7); -lean_ctor_set(x_57, 3, x_55); -if (lean_is_scalar(x_52)) { - x_58 = lean_alloc_ctor(0, 6, 0); -} else { - x_58 = x_52; -} -lean_ctor_set(x_58, 0, x_47); -lean_ctor_set(x_58, 1, x_48); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_49); -lean_ctor_set(x_58, 4, x_50); -lean_ctor_set(x_58, 5, x_51); -x_59 = lean_alloc_ctor(0, 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_13, 0, x_59); -return x_12; -} -} -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; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_60 = lean_ctor_get(x_13, 1); -lean_inc(x_60); -lean_dec(x_13); -x_61 = lean_ctor_get(x_14, 1); -lean_inc(x_61); -x_62 = lean_ctor_get(x_14, 2); -lean_inc(x_62); -x_63 = lean_ctor_get(x_14, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_14, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_14, 5); -lean_inc(x_65); -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); - lean_ctor_release(x_14, 4); - lean_ctor_release(x_14, 5); - x_66 = x_14; -} else { - lean_dec_ref(x_14); - x_66 = lean_box(0); -} -x_67 = lean_ctor_get(x_15, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_15, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_15, 3); -lean_inc(x_69); -x_70 = lean_ctor_get(x_15, 4); -lean_inc(x_70); -x_71 = lean_ctor_get(x_15, 5); -lean_inc(x_71); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - lean_ctor_release(x_15, 2); - lean_ctor_release(x_15, 3); - lean_ctor_release(x_15, 4); - lean_ctor_release(x_15, 5); - x_72 = x_15; -} else { - lean_dec_ref(x_15); - x_72 = lean_box(0); -} -x_73 = lean_ctor_get(x_16, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_16, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_16, 3); -lean_inc(x_75); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - x_76 = x_16; -} else { - lean_dec_ref(x_16); - x_76 = lean_box(0); -} -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); -} else { - x_77 = x_76; -} -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_7); -lean_ctor_set(x_77, 3, x_75); -if (lean_is_scalar(x_72)) { - x_78 = lean_alloc_ctor(0, 6, 0); -} else { - x_78 = x_72; -} -lean_ctor_set(x_78, 0, x_67); -lean_ctor_set(x_78, 1, x_68); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_69); -lean_ctor_set(x_78, 4, x_70); -lean_ctor_set(x_78, 5, x_71); -if (lean_is_scalar(x_66)) { - x_79 = lean_alloc_ctor(0, 6, 0); -} else { - x_79 = x_66; -} -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_61); -lean_ctor_set(x_79, 2, x_62); -lean_ctor_set(x_79, 3, x_63); -lean_ctor_set(x_79, 4, x_64); -lean_ctor_set(x_79, 5, x_65); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_79); -lean_ctor_set(x_80, 1, x_60); -lean_ctor_set(x_12, 1, x_80); -return x_12; -} -} -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; 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_81 = lean_ctor_get(x_12, 0); -lean_inc(x_81); -lean_dec(x_12); -x_82 = lean_ctor_get(x_13, 1); -lean_inc(x_82); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - x_83 = x_13; -} else { - lean_dec_ref(x_13); - x_83 = lean_box(0); -} -x_84 = lean_ctor_get(x_14, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_14, 2); -lean_inc(x_85); -x_86 = lean_ctor_get(x_14, 3); -lean_inc(x_86); -x_87 = lean_ctor_get(x_14, 4); -lean_inc(x_87); -x_88 = lean_ctor_get(x_14, 5); -lean_inc(x_88); -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); - lean_ctor_release(x_14, 4); - lean_ctor_release(x_14, 5); - x_89 = x_14; -} else { - lean_dec_ref(x_14); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_15, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_15, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_15, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_15, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_15, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - lean_ctor_release(x_15, 2); - lean_ctor_release(x_15, 3); - lean_ctor_release(x_15, 4); - lean_ctor_release(x_15, 5); - x_95 = x_15; -} else { - lean_dec_ref(x_15); - x_95 = lean_box(0); -} -x_96 = lean_ctor_get(x_16, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_16, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_16, 3); -lean_inc(x_98); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - x_99 = x_16; -} else { - lean_dec_ref(x_16); - 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_7); -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); -if (lean_is_scalar(x_89)) { - x_102 = lean_alloc_ctor(0, 6, 0); -} else { - x_102 = x_89; -} -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); -if (lean_is_scalar(x_83)) { - x_103 = lean_alloc_ctor(0, 2, 0); -} else { - x_103 = x_83; -} -lean_ctor_set(x_103, 0, x_102); -lean_ctor_set(x_103, 1, x_82); -x_104 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_104, 0, x_81); -lean_ctor_set(x_104, 1, x_103); -return x_104; -} -} -else -{ -uint8_t x_105; -x_105 = !lean_is_exclusive(x_12); -if (x_105 == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; uint8_t x_111; -x_106 = lean_ctor_get(x_12, 1); -x_107 = l_Lean_Elab_Tactic_restore(x_106, x_11); -lean_dec(x_11); -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -lean_dec(x_107); -x_109 = lean_ctor_get(x_108, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_109, 2); -lean_inc(x_110); -x_111 = !lean_is_exclusive(x_108); -if (x_111 == 0) -{ -lean_object* x_112; uint8_t x_113; -x_112 = lean_ctor_get(x_108, 0); -lean_dec(x_112); -x_113 = !lean_is_exclusive(x_109); -if (x_113 == 0) -{ -lean_object* x_114; uint8_t x_115; -x_114 = lean_ctor_get(x_109, 2); -lean_dec(x_114); -x_115 = !lean_is_exclusive(x_110); -if (x_115 == 0) -{ -lean_object* x_116; uint8_t x_117; -x_116 = lean_ctor_get(x_110, 2); -lean_dec(x_116); -lean_ctor_set(x_110, 2, x_7); -x_117 = !lean_is_exclusive(x_10); -if (x_117 == 0) -{ -lean_object* x_118; -x_118 = lean_ctor_get(x_10, 0); -lean_dec(x_118); -lean_ctor_set(x_10, 0, x_108); -lean_ctor_set(x_12, 1, x_10); -return x_12; -} -else -{ -lean_object* x_119; lean_object* x_120; -x_119 = lean_ctor_get(x_10, 1); -lean_inc(x_119); -lean_dec(x_10); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_108); -lean_ctor_set(x_120, 1, x_119); -lean_ctor_set(x_12, 1, x_120); -return x_12; -} -} -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; -x_121 = lean_ctor_get(x_110, 0); -x_122 = lean_ctor_get(x_110, 1); -x_123 = lean_ctor_get(x_110, 3); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_dec(x_110); -x_124 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_122); -lean_ctor_set(x_124, 2, x_7); -lean_ctor_set(x_124, 3, x_123); -lean_ctor_set(x_109, 2, x_124); -x_125 = lean_ctor_get(x_10, 1); -lean_inc(x_125); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_126 = x_10; -} else { - lean_dec_ref(x_10); - x_126 = lean_box(0); -} -if (lean_is_scalar(x_126)) { - x_127 = lean_alloc_ctor(0, 2, 0); -} else { - x_127 = x_126; -} -lean_ctor_set(x_127, 0, x_108); -lean_ctor_set(x_127, 1, x_125); -lean_ctor_set(x_12, 1, x_127); -return x_12; -} -} -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; lean_object* x_141; -x_128 = lean_ctor_get(x_109, 0); -x_129 = lean_ctor_get(x_109, 1); -x_130 = lean_ctor_get(x_109, 3); -x_131 = lean_ctor_get(x_109, 4); -x_132 = lean_ctor_get(x_109, 5); -lean_inc(x_132); -lean_inc(x_131); -lean_inc(x_130); -lean_inc(x_129); -lean_inc(x_128); -lean_dec(x_109); -x_133 = lean_ctor_get(x_110, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_110, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_110, 3); -lean_inc(x_135); -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_136 = x_110; -} else { - lean_dec_ref(x_110); - 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_7); -lean_ctor_set(x_137, 3, x_135); -x_138 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_138, 0, x_128); -lean_ctor_set(x_138, 1, x_129); -lean_ctor_set(x_138, 2, x_137); -lean_ctor_set(x_138, 3, x_130); -lean_ctor_set(x_138, 4, x_131); -lean_ctor_set(x_138, 5, x_132); -lean_ctor_set(x_108, 0, x_138); -x_139 = lean_ctor_get(x_10, 1); -lean_inc(x_139); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_140 = x_10; -} else { - lean_dec_ref(x_10); - x_140 = lean_box(0); -} -if (lean_is_scalar(x_140)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_140; -} -lean_ctor_set(x_141, 0, x_108); -lean_ctor_set(x_141, 1, x_139); -lean_ctor_set(x_12, 1, x_141); -return x_12; -} -} -else -{ -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; -x_142 = lean_ctor_get(x_108, 1); -x_143 = lean_ctor_get(x_108, 2); -x_144 = lean_ctor_get(x_108, 3); -x_145 = lean_ctor_get(x_108, 4); -x_146 = lean_ctor_get(x_108, 5); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); -lean_inc(x_142); -lean_dec(x_108); -x_147 = lean_ctor_get(x_109, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_109, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_109, 3); -lean_inc(x_149); -x_150 = lean_ctor_get(x_109, 4); -lean_inc(x_150); -x_151 = lean_ctor_get(x_109, 5); -lean_inc(x_151); -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_152 = x_109; -} else { - lean_dec_ref(x_109); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_110, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_110, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_110, 3); +lean_object* x_155; lean_object* x_156; lean_object* x_157; +x_155 = lean_ctor_get(x_154, 1); lean_inc(x_155); -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_156 = x_110; -} else { - lean_dec_ref(x_110); - x_156 = lean_box(0); +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_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; } -if (lean_is_scalar(x_156)) { - x_157 = lean_alloc_ctor(0, 4, 0); -} else { - x_157 = x_156; -} -lean_ctor_set(x_157, 0, x_153); -lean_ctor_set(x_157, 1, x_154); -lean_ctor_set(x_157, 2, x_7); -lean_ctor_set(x_157, 3, x_155); -if (lean_is_scalar(x_152)) { - x_158 = lean_alloc_ctor(0, 6, 0); -} else { - x_158 = x_152; -} -lean_ctor_set(x_158, 0, x_147); -lean_ctor_set(x_158, 1, x_148); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_149); -lean_ctor_set(x_158, 4, x_150); -lean_ctor_set(x_158, 5, x_151); -x_159 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_159, 0, x_158); -lean_ctor_set(x_159, 1, x_142); -lean_ctor_set(x_159, 2, x_143); -lean_ctor_set(x_159, 3, x_144); -lean_ctor_set(x_159, 4, x_145); -lean_ctor_set(x_159, 5, x_146); -x_160 = lean_ctor_get(x_10, 1); -lean_inc(x_160); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_161 = x_10; -} else { - lean_dec_ref(x_10); - x_161 = lean_box(0); -} -if (lean_is_scalar(x_161)) { - x_162 = lean_alloc_ctor(0, 2, 0); -} else { - x_162 = x_161; -} -lean_ctor_set(x_162, 0, x_159); -lean_ctor_set(x_162, 1, x_160); -lean_ctor_set(x_12, 1, x_162); -return x_12; +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; } } 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_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; -x_163 = lean_ctor_get(x_12, 0); -x_164 = lean_ctor_get(x_12, 1); -lean_inc(x_164); -lean_inc(x_163); -lean_dec(x_12); -x_165 = l_Lean_Elab_Tactic_restore(x_164, x_11); -lean_dec(x_11); -x_166 = lean_ctor_get(x_165, 0); -lean_inc(x_166); -lean_dec(x_165); -x_167 = lean_ctor_get(x_166, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_167, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_166, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_166, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_166, 4); -lean_inc(x_172); -x_173 = lean_ctor_get(x_166, 5); -lean_inc(x_173); -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); - lean_ctor_release(x_166, 4); - lean_ctor_release(x_166, 5); - x_174 = x_166; -} else { - lean_dec_ref(x_166); - 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); -x_179 = lean_ctor_get(x_167, 5); -lean_inc(x_179); -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); - lean_ctor_release(x_167, 5); - x_180 = x_167; -} else { - lean_dec_ref(x_167); - x_180 = lean_box(0); -} -x_181 = lean_ctor_get(x_168, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_168, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_168, 3); -lean_inc(x_183); -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_184 = x_168; -} else { - lean_dec_ref(x_168); - x_184 = lean_box(0); -} -if (lean_is_scalar(x_184)) { - x_185 = lean_alloc_ctor(0, 4, 0); -} else { - x_185 = x_184; -} -lean_ctor_set(x_185, 0, x_181); -lean_ctor_set(x_185, 1, x_182); -lean_ctor_set(x_185, 2, x_7); -lean_ctor_set(x_185, 3, x_183); -if (lean_is_scalar(x_180)) { - x_186 = lean_alloc_ctor(0, 6, 0); -} else { - x_186 = x_180; -} -lean_ctor_set(x_186, 0, x_175); -lean_ctor_set(x_186, 1, x_176); -lean_ctor_set(x_186, 2, x_185); -lean_ctor_set(x_186, 3, x_177); -lean_ctor_set(x_186, 4, x_178); -lean_ctor_set(x_186, 5, x_179); -if (lean_is_scalar(x_174)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_174; -} -lean_ctor_set(x_187, 0, x_186); -lean_ctor_set(x_187, 1, x_169); -lean_ctor_set(x_187, 2, x_170); -lean_ctor_set(x_187, 3, x_171); -lean_ctor_set(x_187, 4, x_172); -lean_ctor_set(x_187, 5, x_173); -x_188 = lean_ctor_get(x_10, 1); -lean_inc(x_188); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_189 = x_10; -} else { - lean_dec_ref(x_10); - x_189 = lean_box(0); -} -if (lean_is_scalar(x_189)) { - x_190 = lean_alloc_ctor(0, 2, 0); -} else { - x_190 = x_189; -} -lean_ctor_set(x_190, 0, x_187); -lean_ctor_set(x_190, 1, x_188); -x_191 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_191, 0, x_163); -lean_ctor_set(x_191, 1, x_190); -return x_191; -} -} -} -else -{ -uint8_t x_192; +uint8_t x_165; lean_dec(x_7); lean_dec(x_2); lean_dec(x_1); -x_192 = !lean_is_exclusive(x_9); -if (x_192 == 0) +x_165 = !lean_is_exclusive(x_154); +if (x_165 == 0) { -return x_9; +return x_154; } else { -lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_193 = lean_ctor_get(x_9, 0); -x_194 = lean_ctor_get(x_9, 1); -lean_inc(x_194); -lean_inc(x_193); +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; +} +} +block_152: +{ +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_11, 2); +lean_inc(x_12); +x_13 = lean_ctor_get(x_8, 0); +lean_inc(x_13); +lean_dec(x_8); +x_14 = !lean_is_exclusive(x_9); +if (x_14 == 0) +{ +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_9, 0); +lean_dec(x_15); +x_16 = !lean_is_exclusive(x_10); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; +x_17 = lean_ctor_get(x_10, 0); +lean_dec(x_17); +x_18 = !lean_is_exclusive(x_11); +if (x_18 == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_11, 2); +lean_dec(x_19); +x_20 = !lean_is_exclusive(x_12); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; +x_21 = lean_ctor_get(x_12, 2); +lean_dec(x_21); +lean_ctor_set(x_12, 2, x_7); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_13); +lean_ctor_set(x_22, 1, x_9); +return x_22; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_23 = lean_ctor_get(x_12, 0); +x_24 = lean_ctor_get(x_12, 1); +x_25 = lean_ctor_get(x_12, 3); +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; +} +} +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_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); +lean_inc(x_34); +x_35 = lean_ctor_get(x_12, 3); +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_36 = x_12; +} else { + lean_dec_ref(x_12); + x_36 = lean_box(0); +} +if (lean_is_scalar(x_36)) { + x_37 = lean_alloc_ctor(0, 4, 0); +} else { + x_37 = x_36; +} +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; +} +} +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_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); +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); + lean_ctor_release(x_11, 2); + lean_ctor_release(x_11, 3); + lean_ctor_release(x_11, 4); + lean_ctor_release(x_11, 5); + x_50 = x_11; +} else { + lean_dec_ref(x_11); + x_50 = 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); +lean_inc(x_53); +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; +} else { + lean_dec_ref(x_12); + x_54 = lean_box(0); +} +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 4, 0); +} else { + x_55 = x_54; +} +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); +} else { + x_56 = x_50; +} +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; +} +} +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_195 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_195, 0, x_193); -lean_ctor_set(x_195, 1, x_194); -return x_195; +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_inc(x_62); +x_63 = lean_ctor_get(x_10, 4); +lean_inc(x_63); +x_64 = lean_ctor_get(x_10, 5); +lean_inc(x_64); +if (lean_is_exclusive(x_10)) { + lean_ctor_release(x_10, 0); + lean_ctor_release(x_10, 1); + lean_ctor_release(x_10, 2); + lean_ctor_release(x_10, 3); + lean_ctor_release(x_10, 4); + lean_ctor_release(x_10, 5); + x_65 = x_10; +} else { + lean_dec_ref(x_10); + x_65 = 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); +lean_inc(x_69); +x_70 = lean_ctor_get(x_11, 5); +lean_inc(x_70); +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); + lean_ctor_release(x_11, 5); + x_71 = x_11; +} else { + lean_dec_ref(x_11); + x_71 = 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); +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; +} else { + lean_dec_ref(x_12); + x_75 = lean_box(0); +} +if (lean_is_scalar(x_75)) { + x_76 = lean_alloc_ctor(0, 4, 0); +} else { + x_76 = x_75; +} +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); +} else { + x_77 = x_71; +} +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); +} else { + x_78 = x_65; +} +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; +} +} +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_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); +if (x_89 == 0) +{ +lean_object* x_90; uint8_t x_91; +x_90 = lean_ctor_get(x_82, 2); +lean_dec(x_90); +x_91 = !lean_is_exclusive(x_83); +if (x_91 == 0) +{ +lean_object* x_92; lean_object* x_93; +x_92 = lean_ctor_get(x_83, 2); +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; +} +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_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_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_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; +} else { + lean_dec_ref(x_82); + x_121 = 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; +} else { + lean_dec_ref(x_83); + 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_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; +} +} +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_inc(x_130); +lean_dec(x_9); +x_131 = lean_ctor_get(x_81, 1); +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; +} else { + lean_dec_ref(x_81); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_82, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_82, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_82, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_82, 4); +lean_inc(x_140); +x_141 = lean_ctor_get(x_82, 5); +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; +} else { + lean_dec_ref(x_82); + x_142 = lean_box(0); +} +x_143 = lean_ctor_get(x_83, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_83, 1); +lean_inc(x_144); +x_145 = lean_ctor_get(x_83, 3); +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; +} else { + lean_dec_ref(x_83); + x_146 = lean_box(0); +} +if (lean_is_scalar(x_146)) { + x_147 = lean_alloc_ctor(0, 4, 0); +} else { + x_147 = x_146; +} +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); +} else { + x_148 = x_142; +} +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); +} else { + x_149 = x_136; +} +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; +} } } } @@ -7433,7 +7267,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_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; x_6 = lean_ctor_get(x_4, 0); lean_inc(x_6); x_7 = lean_ctor_get(x_6, 0); @@ -7445,859 +7279,693 @@ lean_dec(x_7); x_9 = lean_ctor_get(x_8, 2); lean_inc(x_9); lean_dec(x_8); -x_10 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +x_155 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; lean_inc(x_3); -x_11 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_10, x_3, x_4); -if (lean_obj_tag(x_11) == 0) +x_156 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_155, x_3, x_4); +if (lean_obj_tag(x_156) == 0) { -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 1); -lean_inc(x_12); -lean_dec(x_11); -x_13 = l_Lean_Elab_Tactic_save(x_12); -lean_inc(x_12); -x_14 = lean_apply_2(x_2, x_3, x_12); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; -lean_dec(x_13); -lean_dec(x_12); -x_15 = lean_ctor_get(x_14, 1); -lean_inc(x_15); -x_16 = lean_ctor_get(x_15, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_17, 2); -lean_inc(x_18); -x_19 = !lean_is_exclusive(x_14); -if (x_19 == 0) -{ -lean_object* x_20; uint8_t x_21; -x_20 = lean_ctor_get(x_14, 1); -lean_dec(x_20); -x_21 = !lean_is_exclusive(x_15); -if (x_21 == 0) -{ -lean_object* x_22; uint8_t x_23; -x_22 = lean_ctor_get(x_15, 0); -lean_dec(x_22); -x_23 = !lean_is_exclusive(x_16); -if (x_23 == 0) -{ -lean_object* x_24; uint8_t x_25; -x_24 = lean_ctor_get(x_16, 0); -lean_dec(x_24); -x_25 = !lean_is_exclusive(x_17); -if (x_25 == 0) -{ -lean_object* x_26; uint8_t x_27; -x_26 = lean_ctor_get(x_17, 2); -lean_dec(x_26); -x_27 = !lean_is_exclusive(x_18); -if (x_27 == 0) -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_18, 2); -lean_dec(x_28); -lean_ctor_set(x_18, 2, x_9); -return x_14; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_18, 0); -x_30 = lean_ctor_get(x_18, 1); -x_31 = lean_ctor_get(x_18, 3); -lean_inc(x_31); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_18); -x_32 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_32, 0, x_29); -lean_ctor_set(x_32, 1, x_30); -lean_ctor_set(x_32, 2, x_9); -lean_ctor_set(x_32, 3, x_31); -lean_ctor_set(x_17, 2, x_32); -return x_14; -} -} -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; -x_33 = lean_ctor_get(x_17, 0); -x_34 = lean_ctor_get(x_17, 1); -x_35 = lean_ctor_get(x_17, 3); -x_36 = lean_ctor_get(x_17, 4); -x_37 = lean_ctor_get(x_17, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_17); -x_38 = lean_ctor_get(x_18, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_18, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_18, 3); -lean_inc(x_40); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - lean_ctor_release(x_18, 1); - lean_ctor_release(x_18, 2); - lean_ctor_release(x_18, 3); - x_41 = x_18; -} else { - lean_dec_ref(x_18); - x_41 = lean_box(0); -} -if (lean_is_scalar(x_41)) { - x_42 = lean_alloc_ctor(0, 4, 0); -} else { - x_42 = x_41; -} -lean_ctor_set(x_42, 0, x_38); -lean_ctor_set(x_42, 1, x_39); -lean_ctor_set(x_42, 2, x_9); -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); -lean_ctor_set(x_16, 0, x_43); -return x_14; -} -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_44 = lean_ctor_get(x_16, 1); -x_45 = lean_ctor_get(x_16, 2); -x_46 = lean_ctor_get(x_16, 3); -x_47 = lean_ctor_get(x_16, 4); -x_48 = lean_ctor_get(x_16, 5); -lean_inc(x_48); -lean_inc(x_47); -lean_inc(x_46); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_16); -x_49 = lean_ctor_get(x_17, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_17, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_17, 3); -lean_inc(x_51); -x_52 = lean_ctor_get(x_17, 4); -lean_inc(x_52); -x_53 = lean_ctor_get(x_17, 5); -lean_inc(x_53); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - lean_ctor_release(x_17, 4); - lean_ctor_release(x_17, 5); - x_54 = x_17; -} else { - lean_dec_ref(x_17); - x_54 = lean_box(0); -} -x_55 = lean_ctor_get(x_18, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_18, 1); -lean_inc(x_56); -x_57 = lean_ctor_get(x_18, 3); -lean_inc(x_57); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - lean_ctor_release(x_18, 1); - lean_ctor_release(x_18, 2); - lean_ctor_release(x_18, 3); - x_58 = x_18; -} else { - lean_dec_ref(x_18); - x_58 = lean_box(0); -} -if (lean_is_scalar(x_58)) { - x_59 = lean_alloc_ctor(0, 4, 0); -} else { - x_59 = x_58; -} -lean_ctor_set(x_59, 0, x_55); -lean_ctor_set(x_59, 1, x_56); -lean_ctor_set(x_59, 2, x_9); -lean_ctor_set(x_59, 3, x_57); -if (lean_is_scalar(x_54)) { - x_60 = lean_alloc_ctor(0, 6, 0); -} else { - x_60 = x_54; -} -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, 6, 0); -lean_ctor_set(x_61, 0, x_60); -lean_ctor_set(x_61, 1, x_44); -lean_ctor_set(x_61, 2, x_45); -lean_ctor_set(x_61, 3, x_46); -lean_ctor_set(x_61, 4, x_47); -lean_ctor_set(x_61, 5, x_48); -lean_ctor_set(x_15, 0, x_61); -return x_14; -} -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_15, 1); -lean_inc(x_62); -lean_dec(x_15); -x_63 = lean_ctor_get(x_16, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_16, 2); -lean_inc(x_64); -x_65 = lean_ctor_get(x_16, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_16, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_16, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - lean_ctor_release(x_16, 4); - lean_ctor_release(x_16, 5); - x_68 = x_16; -} else { - lean_dec_ref(x_16); - x_68 = lean_box(0); -} -x_69 = lean_ctor_get(x_17, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_17, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_17, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_17, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_17, 5); -lean_inc(x_73); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - lean_ctor_release(x_17, 4); - lean_ctor_release(x_17, 5); - x_74 = x_17; -} else { - lean_dec_ref(x_17); - x_74 = lean_box(0); -} -x_75 = lean_ctor_get(x_18, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_18, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_18, 3); -lean_inc(x_77); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - lean_ctor_release(x_18, 1); - lean_ctor_release(x_18, 2); - lean_ctor_release(x_18, 3); - x_78 = x_18; -} else { - lean_dec_ref(x_18); - 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_9); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); -} else { - x_80 = x_74; -} -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); -if (lean_is_scalar(x_68)) { - x_81 = lean_alloc_ctor(0, 6, 0); -} else { - x_81 = x_68; -} -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_63); -lean_ctor_set(x_81, 2, x_64); -lean_ctor_set(x_81, 3, x_65); -lean_ctor_set(x_81, 4, x_66); -lean_ctor_set(x_81, 5, x_67); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_81); -lean_ctor_set(x_82, 1, x_62); -lean_ctor_set(x_14, 1, x_82); -return x_14; -} -} -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; lean_object* x_105; lean_object* x_106; -x_83 = lean_ctor_get(x_14, 0); -lean_inc(x_83); -lean_dec(x_14); -x_84 = lean_ctor_get(x_15, 1); -lean_inc(x_84); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - x_85 = x_15; -} else { - lean_dec_ref(x_15); - x_85 = lean_box(0); -} -x_86 = lean_ctor_get(x_16, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_16, 2); -lean_inc(x_87); -x_88 = lean_ctor_get(x_16, 3); -lean_inc(x_88); -x_89 = lean_ctor_get(x_16, 4); -lean_inc(x_89); -x_90 = lean_ctor_get(x_16, 5); -lean_inc(x_90); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - lean_ctor_release(x_16, 4); - lean_ctor_release(x_16, 5); - x_91 = x_16; -} else { - lean_dec_ref(x_16); - x_91 = lean_box(0); -} -x_92 = lean_ctor_get(x_17, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_17, 1); -lean_inc(x_93); -x_94 = lean_ctor_get(x_17, 3); -lean_inc(x_94); -x_95 = lean_ctor_get(x_17, 4); -lean_inc(x_95); -x_96 = lean_ctor_get(x_17, 5); -lean_inc(x_96); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - lean_ctor_release(x_17, 4); - lean_ctor_release(x_17, 5); - x_97 = x_17; -} else { - lean_dec_ref(x_17); - x_97 = lean_box(0); -} -x_98 = lean_ctor_get(x_18, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_18, 1); -lean_inc(x_99); -x_100 = lean_ctor_get(x_18, 3); -lean_inc(x_100); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - lean_ctor_release(x_18, 1); - lean_ctor_release(x_18, 2); - lean_ctor_release(x_18, 3); - x_101 = x_18; -} else { - lean_dec_ref(x_18); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 4, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_98); -lean_ctor_set(x_102, 1, x_99); -lean_ctor_set(x_102, 2, x_9); -lean_ctor_set(x_102, 3, x_100); -if (lean_is_scalar(x_97)) { - x_103 = lean_alloc_ctor(0, 6, 0); -} else { - x_103 = x_97; -} -lean_ctor_set(x_103, 0, x_92); -lean_ctor_set(x_103, 1, x_93); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_94); -lean_ctor_set(x_103, 4, x_95); -lean_ctor_set(x_103, 5, x_96); -if (lean_is_scalar(x_91)) { - x_104 = lean_alloc_ctor(0, 6, 0); -} else { - x_104 = x_91; -} -lean_ctor_set(x_104, 0, x_103); -lean_ctor_set(x_104, 1, x_86); -lean_ctor_set(x_104, 2, x_87); -lean_ctor_set(x_104, 3, x_88); -lean_ctor_set(x_104, 4, x_89); -lean_ctor_set(x_104, 5, x_90); -if (lean_is_scalar(x_85)) { - x_105 = lean_alloc_ctor(0, 2, 0); -} else { - x_105 = x_85; -} -lean_ctor_set(x_105, 0, x_104); -lean_ctor_set(x_105, 1, x_84); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_83); -lean_ctor_set(x_106, 1, x_105); -return x_106; -} -} -else -{ -uint8_t x_107; -x_107 = !lean_is_exclusive(x_14); -if (x_107 == 0) -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; uint8_t x_113; -x_108 = lean_ctor_get(x_14, 1); -x_109 = l_Lean_Elab_Tactic_restore(x_108, x_13); -lean_dec(x_13); -x_110 = lean_ctor_get(x_109, 0); -lean_inc(x_110); -lean_dec(x_109); -x_111 = lean_ctor_get(x_110, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_111, 2); -lean_inc(x_112); -x_113 = !lean_is_exclusive(x_110); -if (x_113 == 0) -{ -lean_object* x_114; uint8_t x_115; -x_114 = lean_ctor_get(x_110, 0); -lean_dec(x_114); -x_115 = !lean_is_exclusive(x_111); -if (x_115 == 0) -{ -lean_object* x_116; uint8_t x_117; -x_116 = lean_ctor_get(x_111, 2); -lean_dec(x_116); -x_117 = !lean_is_exclusive(x_112); -if (x_117 == 0) -{ -lean_object* x_118; uint8_t x_119; -x_118 = lean_ctor_get(x_112, 2); -lean_dec(x_118); -lean_ctor_set(x_112, 2, x_9); -x_119 = !lean_is_exclusive(x_12); -if (x_119 == 0) -{ -lean_object* x_120; -x_120 = lean_ctor_get(x_12, 0); -lean_dec(x_120); -lean_ctor_set(x_12, 0, x_110); -lean_ctor_set(x_14, 1, x_12); -return x_14; -} -else -{ -lean_object* x_121; lean_object* x_122; -x_121 = lean_ctor_get(x_12, 1); -lean_inc(x_121); -lean_dec(x_12); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_110); -lean_ctor_set(x_122, 1, x_121); -lean_ctor_set(x_14, 1, x_122); -return x_14; -} -} -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; -x_123 = lean_ctor_get(x_112, 0); -x_124 = lean_ctor_get(x_112, 1); -x_125 = lean_ctor_get(x_112, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_dec(x_112); -x_126 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_126, 0, x_123); -lean_ctor_set(x_126, 1, x_124); -lean_ctor_set(x_126, 2, x_9); -lean_ctor_set(x_126, 3, x_125); -lean_ctor_set(x_111, 2, x_126); -x_127 = lean_ctor_get(x_12, 1); -lean_inc(x_127); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_128 = x_12; -} else { - lean_dec_ref(x_12); - x_128 = lean_box(0); -} -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 2, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_110); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_14, 1, x_129); -return x_14; -} -} -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; -x_130 = lean_ctor_get(x_111, 0); -x_131 = lean_ctor_get(x_111, 1); -x_132 = lean_ctor_get(x_111, 3); -x_133 = lean_ctor_get(x_111, 4); -x_134 = lean_ctor_get(x_111, 5); -lean_inc(x_134); -lean_inc(x_133); -lean_inc(x_132); -lean_inc(x_131); -lean_inc(x_130); -lean_dec(x_111); -x_135 = lean_ctor_get(x_112, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_112, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_112, 3); -lean_inc(x_137); -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); - x_138 = x_112; -} else { - lean_dec_ref(x_112); - x_138 = lean_box(0); -} -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 4, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_135); -lean_ctor_set(x_139, 1, x_136); -lean_ctor_set(x_139, 2, x_9); -lean_ctor_set(x_139, 3, x_137); -x_140 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_140, 0, x_130); -lean_ctor_set(x_140, 1, x_131); -lean_ctor_set(x_140, 2, x_139); -lean_ctor_set(x_140, 3, x_132); -lean_ctor_set(x_140, 4, x_133); -lean_ctor_set(x_140, 5, x_134); -lean_ctor_set(x_110, 0, x_140); -x_141 = lean_ctor_get(x_12, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_142 = x_12; -} else { - lean_dec_ref(x_12); - x_142 = lean_box(0); -} -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(0, 2, 0); -} else { - x_143 = x_142; -} -lean_ctor_set(x_143, 0, x_110); -lean_ctor_set(x_143, 1, x_141); -lean_ctor_set(x_14, 1, x_143); -return x_14; -} -} -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; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_144 = lean_ctor_get(x_110, 1); -x_145 = lean_ctor_get(x_110, 2); -x_146 = lean_ctor_get(x_110, 3); -x_147 = lean_ctor_get(x_110, 4); -x_148 = lean_ctor_get(x_110, 5); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_dec(x_110); -x_149 = lean_ctor_get(x_111, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_111, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_111, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_111, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_111, 5); -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); - lean_ctor_release(x_111, 5); - x_154 = x_111; -} else { - lean_dec_ref(x_111); - x_154 = lean_box(0); -} -x_155 = lean_ctor_get(x_112, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_112, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_112, 3); +lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_157 = lean_ctor_get(x_156, 1); lean_inc(x_157); -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); - x_158 = x_112; -} else { - lean_dec_ref(x_112); - x_158 = lean_box(0); +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_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; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 4, 0); -} else { - x_159 = x_158; -} -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_9); -lean_ctor_set(x_159, 3, x_157); -if (lean_is_scalar(x_154)) { - x_160 = lean_alloc_ctor(0, 6, 0); -} else { - x_160 = x_154; -} -lean_ctor_set(x_160, 0, x_149); -lean_ctor_set(x_160, 1, x_150); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_151); -lean_ctor_set(x_160, 4, x_152); -lean_ctor_set(x_160, 5, x_153); -x_161 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_161, 0, x_160); -lean_ctor_set(x_161, 1, x_144); -lean_ctor_set(x_161, 2, x_145); -lean_ctor_set(x_161, 3, x_146); -lean_ctor_set(x_161, 4, x_147); -lean_ctor_set(x_161, 5, x_148); -x_162 = lean_ctor_get(x_12, 1); -lean_inc(x_162); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_163 = x_12; -} else { - lean_dec_ref(x_12); - x_163 = lean_box(0); -} -if (lean_is_scalar(x_163)) { - x_164 = lean_alloc_ctor(0, 2, 0); -} else { - x_164 = x_163; -} -lean_ctor_set(x_164, 0, x_161); -lean_ctor_set(x_164, 1, x_162); -lean_ctor_set(x_14, 1, x_164); -return x_14; +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; } } 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; 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_165 = lean_ctor_get(x_14, 0); -x_166 = lean_ctor_get(x_14, 1); -lean_inc(x_166); -lean_inc(x_165); -lean_dec(x_14); -x_167 = l_Lean_Elab_Tactic_restore(x_166, x_13); -lean_dec(x_13); -x_168 = lean_ctor_get(x_167, 0); -lean_inc(x_168); -lean_dec(x_167); -x_169 = lean_ctor_get(x_168, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_169, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_168, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_168, 2); -lean_inc(x_172); -x_173 = lean_ctor_get(x_168, 3); -lean_inc(x_173); -x_174 = lean_ctor_get(x_168, 4); -lean_inc(x_174); -x_175 = lean_ctor_get(x_168, 5); -lean_inc(x_175); -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); - lean_ctor_release(x_168, 4); - lean_ctor_release(x_168, 5); - x_176 = x_168; -} else { - lean_dec_ref(x_168); - x_176 = lean_box(0); -} -x_177 = lean_ctor_get(x_169, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_169, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_169, 3); -lean_inc(x_179); -x_180 = lean_ctor_get(x_169, 4); -lean_inc(x_180); -x_181 = lean_ctor_get(x_169, 5); -lean_inc(x_181); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - lean_ctor_release(x_169, 4); - lean_ctor_release(x_169, 5); - x_182 = x_169; -} else { - lean_dec_ref(x_169); - x_182 = lean_box(0); -} -x_183 = lean_ctor_get(x_170, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_170, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_170, 3); -lean_inc(x_185); -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); - x_186 = x_170; -} else { - lean_dec_ref(x_170); - x_186 = lean_box(0); -} -if (lean_is_scalar(x_186)) { - x_187 = lean_alloc_ctor(0, 4, 0); -} else { - x_187 = x_186; -} -lean_ctor_set(x_187, 0, x_183); -lean_ctor_set(x_187, 1, x_184); -lean_ctor_set(x_187, 2, x_9); -lean_ctor_set(x_187, 3, x_185); -if (lean_is_scalar(x_182)) { - x_188 = lean_alloc_ctor(0, 6, 0); -} else { - x_188 = x_182; -} -lean_ctor_set(x_188, 0, x_177); -lean_ctor_set(x_188, 1, x_178); -lean_ctor_set(x_188, 2, x_187); -lean_ctor_set(x_188, 3, x_179); -lean_ctor_set(x_188, 4, x_180); -lean_ctor_set(x_188, 5, x_181); -if (lean_is_scalar(x_176)) { - x_189 = lean_alloc_ctor(0, 6, 0); -} else { - x_189 = x_176; -} -lean_ctor_set(x_189, 0, x_188); -lean_ctor_set(x_189, 1, x_171); -lean_ctor_set(x_189, 2, x_172); -lean_ctor_set(x_189, 3, x_173); -lean_ctor_set(x_189, 4, x_174); -lean_ctor_set(x_189, 5, x_175); -x_190 = lean_ctor_get(x_12, 1); -lean_inc(x_190); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_191 = x_12; -} else { - lean_dec_ref(x_12); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 2, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -x_193 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_193, 0, x_165); -lean_ctor_set(x_193, 1, x_192); -return x_193; -} -} -} -else -{ -uint8_t x_194; +uint8_t x_167; lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_194 = !lean_is_exclusive(x_11); -if (x_194 == 0) +x_167 = !lean_is_exclusive(x_156); +if (x_167 == 0) { -return x_11; +return x_156; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; -x_195 = lean_ctor_get(x_11, 0); -x_196 = lean_ctor_get(x_11, 1); -lean_inc(x_196); -lean_inc(x_195); +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; +} +} +block_154: +{ +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_13, 2); +lean_inc(x_14); +x_15 = lean_ctor_get(x_10, 0); +lean_inc(x_15); +lean_dec(x_10); +x_16 = !lean_is_exclusive(x_11); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; +x_17 = lean_ctor_get(x_11, 0); +lean_dec(x_17); +x_18 = !lean_is_exclusive(x_12); +if (x_18 == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_12, 0); +lean_dec(x_19); +x_20 = !lean_is_exclusive(x_13); +if (x_20 == 0) +{ +lean_object* x_21; uint8_t x_22; +x_21 = lean_ctor_get(x_13, 2); +lean_dec(x_21); +x_22 = !lean_is_exclusive(x_14); +if (x_22 == 0) +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_14, 2); +lean_dec(x_23); +lean_ctor_set(x_14, 2, x_9); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_15); +lean_ctor_set(x_24, 1, x_11); +return x_24; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_25 = lean_ctor_get(x_14, 0); +x_26 = lean_ctor_get(x_14, 1); +x_27 = lean_ctor_get(x_14, 3); +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; +} +} +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_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); +lean_inc(x_36); +x_37 = lean_ctor_get(x_14, 3); +lean_inc(x_37); +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; +} else { + lean_dec_ref(x_14); + x_38 = lean_box(0); +} +if (lean_is_scalar(x_38)) { + x_39 = lean_alloc_ctor(0, 4, 0); +} else { + x_39 = x_38; +} +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; +} +} +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_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); +lean_inc(x_49); +x_50 = lean_ctor_get(x_13, 4); +lean_inc(x_50); +x_51 = lean_ctor_get(x_13, 5); +lean_inc(x_51); +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + lean_ctor_release(x_13, 2); + lean_ctor_release(x_13, 3); + lean_ctor_release(x_13, 4); + lean_ctor_release(x_13, 5); + x_52 = x_13; +} else { + lean_dec_ref(x_13); + x_52 = 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); +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_56 = x_14; +} else { + lean_dec_ref(x_14); + x_56 = lean_box(0); +} +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); +} else { + x_57 = x_56; +} +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); +} else { + x_58 = x_52; +} +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_48); +lean_ctor_set(x_58, 2, x_57); +lean_ctor_set(x_58, 3, x_49); +lean_ctor_set(x_58, 4, x_50); +lean_ctor_set(x_58, 5, x_51); +x_59 = lean_alloc_ctor(0, 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; +} +} +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_197 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_197, 0, x_195); -lean_ctor_set(x_197, 1, x_196); -return x_197; +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_inc(x_64); +x_65 = lean_ctor_get(x_12, 4); +lean_inc(x_65); +x_66 = lean_ctor_get(x_12, 5); +lean_inc(x_66); +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); + lean_ctor_release(x_12, 5); + x_67 = x_12; +} else { + lean_dec_ref(x_12); + x_67 = 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); +lean_inc(x_71); +x_72 = lean_ctor_get(x_13, 5); +lean_inc(x_72); +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + lean_ctor_release(x_13, 2); + lean_ctor_release(x_13, 3); + lean_ctor_release(x_13, 4); + lean_ctor_release(x_13, 5); + x_73 = x_13; +} else { + lean_dec_ref(x_13); + x_73 = 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); +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; +} else { + lean_dec_ref(x_14); + x_77 = lean_box(0); +} +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(0, 4, 0); +} else { + x_78 = x_77; +} +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); +} else { + x_79 = x_73; +} +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); +} else { + x_80 = x_67; +} +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; +} +} +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_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); +if (x_91 == 0) +{ +lean_object* x_92; uint8_t x_93; +x_92 = lean_ctor_get(x_84, 2); +lean_dec(x_92); +x_93 = !lean_is_exclusive(x_85); +if (x_93 == 0) +{ +lean_object* x_94; lean_object* x_95; +x_94 = lean_ctor_get(x_85, 2); +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; +} +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_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_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_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; +} else { + lean_dec_ref(x_84); + x_123 = 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; +} else { + lean_dec_ref(x_85); + x_127 = lean_box(0); +} +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; +} +} +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_inc(x_132); +lean_dec(x_11); +x_133 = lean_ctor_get(x_83, 1); +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; +} else { + lean_dec_ref(x_83); + x_138 = lean_box(0); +} +x_139 = lean_ctor_get(x_84, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_84, 1); +lean_inc(x_140); +x_141 = lean_ctor_get(x_84, 3); +lean_inc(x_141); +x_142 = lean_ctor_get(x_84, 4); +lean_inc(x_142); +x_143 = lean_ctor_get(x_84, 5); +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; +} else { + lean_dec_ref(x_84); + x_144 = lean_box(0); +} +x_145 = lean_ctor_get(x_85, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_85, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_85, 3); +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; +} else { + lean_dec_ref(x_85); + 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_9); +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_138)) { + x_151 = lean_alloc_ctor(0, 6, 0); +} else { + x_151 = x_138; +} +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; +} } } } @@ -8366,7 +8034,7 @@ goto _start; lean_object* l_Lean_Elab_Tactic_withMVarContext___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +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; uint8_t x_13; x_5 = l_Lean_Elab_Tactic_getMVarDecl(x_1, x_3, x_4); x_6 = lean_ctor_get(x_3, 0); lean_inc(x_6); @@ -8376,353 +8044,446 @@ x_8 = lean_ctor_get(x_5, 0); lean_inc(x_8); x_9 = lean_ctor_get(x_5, 1); lean_inc(x_9); -lean_dec(x_5); -x_10 = lean_ctor_get(x_3, 1); -lean_inc(x_10); -x_11 = lean_ctor_get(x_3, 2); +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + x_10 = x_5; +} else { + lean_dec_ref(x_5); + x_10 = lean_box(0); +} +x_11 = lean_ctor_get(x_3, 1); lean_inc(x_11); -x_12 = !lean_is_exclusive(x_6); -if (x_12 == 0) +x_12 = lean_ctor_get(x_3, 2); +lean_inc(x_12); +x_13 = !lean_is_exclusive(x_6); +if (x_13 == 0) { -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_6, 0); -lean_dec(x_13); -x_14 = !lean_is_exclusive(x_7); -if (x_14 == 0) +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_6, 0); +lean_dec(x_14); +x_15 = !lean_is_exclusive(x_7); +if (x_15 == 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; uint8_t x_21; lean_object* x_22; -x_15 = lean_ctor_get(x_7, 2); -x_16 = lean_ctor_get(x_7, 1); -lean_dec(x_16); -x_17 = lean_ctor_get(x_8, 1); -lean_inc(x_17); -x_18 = lean_ctor_get(x_8, 4); +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; lean_object* x_23; +x_16 = lean_ctor_get(x_7, 2); +x_17 = lean_ctor_get(x_7, 1); +lean_dec(x_17); +x_18 = lean_ctor_get(x_8, 1); lean_inc(x_18); -x_19 = lean_array_get_size(x_15); -x_20 = lean_array_get_size(x_18); -x_21 = lean_nat_dec_eq(x_19, x_20); +x_19 = lean_ctor_get(x_8, 4); +lean_inc(x_19); +x_20 = lean_array_get_size(x_16); +x_21 = lean_array_get_size(x_19); +x_22 = lean_nat_dec_eq(x_20, x_21); +lean_dec(x_21); lean_dec(x_20); +lean_inc(x_19); +lean_ctor_set(x_7, 2, x_19); +lean_ctor_set(x_7, 1, x_18); +x_23 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_23, 0, x_6); +lean_ctor_set(x_23, 1, x_11); +lean_ctor_set(x_23, 2, x_12); +if (x_22 == 0) +{ +lean_object* x_24; lean_dec(x_19); -lean_inc(x_18); -lean_ctor_set(x_7, 2, x_18); -lean_ctor_set(x_7, 1, x_17); -x_22 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_22, 0, x_6); -lean_ctor_set(x_22, 1, x_10); -lean_ctor_set(x_22, 2, x_11); -if (x_21 == 0) -{ -lean_object* x_23; -lean_dec(x_18); -lean_dec(x_15); +lean_dec(x_16); +lean_dec(x_10); lean_dec(x_8); lean_dec(x_3); -x_23 = lean_apply_2(x_2, x_22, x_9); -return x_23; +x_24 = lean_apply_2(x_2, x_23, x_9); +return x_24; } else { -lean_object* x_24; uint8_t x_25; -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_15, x_18, x_24); -lean_dec(x_18); -lean_dec(x_15); +lean_object* x_25; uint8_t x_26; +x_25 = lean_unsigned_to_nat(0u); +x_26 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_16, x_19, x_25); +lean_dec(x_19); +lean_dec(x_16); lean_dec(x_8); lean_dec(x_3); -if (x_25 == 0) +if (x_26 == 0) { -lean_object* x_26; -x_26 = lean_apply_2(x_2, x_22, x_9); -return x_26; +lean_object* x_27; +lean_dec(x_10); +x_27 = lean_apply_2(x_2, x_23, x_9); +return x_27; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_27 = lean_ctor_get(x_9, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_27, 0); +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; +x_28 = lean_ctor_get(x_9, 0); lean_inc(x_28); -lean_dec(x_27); -x_29 = lean_ctor_get(x_28, 2); +x_29 = lean_ctor_get(x_28, 0); lean_inc(x_29); lean_dec(x_28); x_30 = lean_ctor_get(x_29, 2); lean_inc(x_30); lean_dec(x_29); -x_31 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; -lean_inc(x_22); -x_32 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_31, x_22, x_9); +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; +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) +{ +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_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; +} +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; +} +} +else +{ +uint8_t x_189; +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) +{ +return x_178; +} +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; +} +} +block_176: +{ if (lean_obj_tag(x_32) == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_32, 1); -lean_inc(x_33); -lean_dec(x_32); -x_34 = l_Lean_Elab_Tactic_save(x_33); -lean_inc(x_33); -x_35 = lean_apply_2(x_2, x_22, x_33); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; -lean_dec(x_34); -lean_dec(x_33); -x_36 = lean_ctor_get(x_35, 1); +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_35, 2); lean_inc(x_36); -x_37 = lean_ctor_get(x_36, 0); +x_37 = lean_ctor_get(x_32, 0); lean_inc(x_37); -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_38, 2); -lean_inc(x_39); -x_40 = !lean_is_exclusive(x_35); +lean_dec(x_32); +x_38 = !lean_is_exclusive(x_33); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_33, 0); +lean_dec(x_39); +x_40 = !lean_is_exclusive(x_34); if (x_40 == 0) { lean_object* x_41; uint8_t x_42; -x_41 = lean_ctor_get(x_35, 1); +x_41 = lean_ctor_get(x_34, 0); lean_dec(x_41); -x_42 = !lean_is_exclusive(x_36); +x_42 = !lean_is_exclusive(x_35); if (x_42 == 0) { lean_object* x_43; uint8_t x_44; -x_43 = lean_ctor_get(x_36, 0); +x_43 = lean_ctor_get(x_35, 2); lean_dec(x_43); -x_44 = !lean_is_exclusive(x_37); +x_44 = !lean_is_exclusive(x_36); if (x_44 == 0) { -lean_object* x_45; uint8_t x_46; -x_45 = lean_ctor_get(x_37, 0); +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_36, 2); lean_dec(x_45); -x_46 = !lean_is_exclusive(x_38); -if (x_46 == 0) -{ -lean_object* x_47; uint8_t x_48; -x_47 = lean_ctor_get(x_38, 2); -lean_dec(x_47); -x_48 = !lean_is_exclusive(x_39); -if (x_48 == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_39, 2); -lean_dec(x_49); -lean_ctor_set(x_39, 2, x_30); -return x_35; +lean_ctor_set(x_36, 2, x_31); +if (lean_is_scalar(x_10)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_10; + lean_ctor_set_tag(x_46, 1); +} +lean_ctor_set(x_46, 0, x_37); +lean_ctor_set(x_46, 1, x_33); +return x_46; } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -lean_inc(x_52); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_39); -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_30); -lean_ctor_set(x_53, 3, x_52); -lean_ctor_set(x_38, 2, x_53); -return x_35; +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_47 = lean_ctor_get(x_36, 0); +x_48 = lean_ctor_get(x_36, 1); +x_49 = lean_ctor_get(x_36, 3); +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); +if (lean_is_scalar(x_10)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_10; + lean_ctor_set_tag(x_51, 1); +} +lean_ctor_set(x_51, 0, x_37); +lean_ctor_set(x_51, 1, x_33); +return x_51; } } 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; -x_54 = lean_ctor_get(x_38, 0); -x_55 = lean_ctor_get(x_38, 1); -x_56 = lean_ctor_get(x_38, 3); -x_57 = lean_ctor_get(x_38, 4); -x_58 = lean_ctor_get(x_38, 5); -lean_inc(x_58); -lean_inc(x_57); +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_inc(x_56); lean_inc(x_55); lean_inc(x_54); -lean_dec(x_38); -x_59 = lean_ctor_get(x_39, 0); +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); +lean_inc(x_58); +x_59 = lean_ctor_get(x_36, 3); lean_inc(x_59); -x_60 = lean_ctor_get(x_39, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_39, 3); -lean_inc(x_61); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_62 = x_39; +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; } else { - lean_dec_ref(x_39); - x_62 = lean_box(0); + lean_dec_ref(x_36); + x_60 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_60)) { + x_61 = lean_alloc_ctor(0, 4, 0); } else { - x_63 = x_62; + x_61 = x_60; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_30); -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_37, 0, x_64); -return x_35; +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); +if (lean_is_scalar(x_10)) { + x_63 = lean_alloc_ctor(1, 2, 0); +} else { + x_63 = x_10; + lean_ctor_set_tag(x_63, 1); +} +lean_ctor_set(x_63, 0, x_37); +lean_ctor_set(x_63, 1, x_33); +return x_63; } } else { -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_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_65 = lean_ctor_get(x_37, 1); -x_66 = lean_ctor_get(x_37, 2); -x_67 = lean_ctor_get(x_37, 3); -x_68 = lean_ctor_get(x_37, 4); -x_69 = lean_ctor_get(x_37, 5); -lean_inc(x_69); +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_inc(x_68); lean_inc(x_67); lean_inc(x_66); lean_inc(x_65); -lean_dec(x_37); -x_70 = lean_ctor_get(x_38, 0); +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_38, 1); +x_71 = lean_ctor_get(x_35, 3); lean_inc(x_71); -x_72 = lean_ctor_get(x_38, 3); +x_72 = lean_ctor_get(x_35, 4); lean_inc(x_72); -x_73 = lean_ctor_get(x_38, 4); +x_73 = lean_ctor_get(x_35, 5); lean_inc(x_73); -x_74 = lean_ctor_get(x_38, 5); -lean_inc(x_74); -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); - lean_ctor_release(x_38, 5); - x_75 = x_38; +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); + lean_ctor_release(x_35, 4); + lean_ctor_release(x_35, 5); + x_74 = x_35; } else { - lean_dec_ref(x_38); - x_75 = lean_box(0); + lean_dec_ref(x_35); + x_74 = lean_box(0); } -x_76 = lean_ctor_get(x_39, 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_39, 1); +x_77 = lean_ctor_get(x_36, 3); lean_inc(x_77); -x_78 = lean_ctor_get(x_39, 3); -lean_inc(x_78); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_79 = x_39; +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; } else { - lean_dec_ref(x_39); - x_79 = lean_box(0); + lean_dec_ref(x_36); + x_78 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_79 = x_78; } -lean_ctor_set(x_80, 0, x_76); -lean_ctor_set(x_80, 1, x_77); -lean_ctor_set(x_80, 2, x_30); -lean_ctor_set(x_80, 3, x_78); -if (lean_is_scalar(x_75)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_81 = x_75; + x_80 = x_74; } -lean_ctor_set(x_81, 0, x_70); -lean_ctor_set(x_81, 1, x_71); -lean_ctor_set(x_81, 2, x_80); -lean_ctor_set(x_81, 3, x_72); -lean_ctor_set(x_81, 4, x_73); -lean_ctor_set(x_81, 5, x_74); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_81); -lean_ctor_set(x_82, 1, x_65); -lean_ctor_set(x_82, 2, x_66); -lean_ctor_set(x_82, 3, x_67); -lean_ctor_set(x_82, 4, x_68); -lean_ctor_set(x_82, 5, x_69); -lean_ctor_set(x_36, 0, x_82); -return x_35; +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); +if (lean_is_scalar(x_10)) { + x_82 = lean_alloc_ctor(1, 2, 0); +} else { + x_82 = x_10; + lean_ctor_set_tag(x_82, 1); +} +lean_ctor_set(x_82, 0, x_37); +lean_ctor_set(x_82, 1, x_33); +return x_82; } } 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; -x_83 = lean_ctor_get(x_36, 1); +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_36); -x_84 = lean_ctor_get(x_37, 1); +lean_dec(x_33); +x_84 = lean_ctor_get(x_34, 1); lean_inc(x_84); -x_85 = lean_ctor_get(x_37, 2); +x_85 = lean_ctor_get(x_34, 2); lean_inc(x_85); -x_86 = lean_ctor_get(x_37, 3); +x_86 = lean_ctor_get(x_34, 3); lean_inc(x_86); -x_87 = lean_ctor_get(x_37, 4); +x_87 = lean_ctor_get(x_34, 4); lean_inc(x_87); -x_88 = lean_ctor_get(x_37, 5); +x_88 = lean_ctor_get(x_34, 5); lean_inc(x_88); -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); - lean_ctor_release(x_37, 4); - lean_ctor_release(x_37, 5); - x_89 = x_37; +if (lean_is_exclusive(x_34)) { + lean_ctor_release(x_34, 0); + lean_ctor_release(x_34, 1); + lean_ctor_release(x_34, 2); + lean_ctor_release(x_34, 3); + lean_ctor_release(x_34, 4); + lean_ctor_release(x_34, 5); + x_89 = x_34; } else { - lean_dec_ref(x_37); + lean_dec_ref(x_34); x_89 = lean_box(0); } -x_90 = lean_ctor_get(x_38, 0); +x_90 = lean_ctor_get(x_35, 0); lean_inc(x_90); -x_91 = lean_ctor_get(x_38, 1); +x_91 = lean_ctor_get(x_35, 1); lean_inc(x_91); -x_92 = lean_ctor_get(x_38, 3); +x_92 = lean_ctor_get(x_35, 3); lean_inc(x_92); -x_93 = lean_ctor_get(x_38, 4); +x_93 = lean_ctor_get(x_35, 4); lean_inc(x_93); -x_94 = lean_ctor_get(x_38, 5); +x_94 = lean_ctor_get(x_35, 5); lean_inc(x_94); -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); - lean_ctor_release(x_38, 5); - x_95 = x_38; +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); + lean_ctor_release(x_35, 4); + lean_ctor_release(x_35, 5); + x_95 = x_35; } else { - lean_dec_ref(x_38); + lean_dec_ref(x_35); x_95 = lean_box(0); } -x_96 = lean_ctor_get(x_39, 0); +x_96 = lean_ctor_get(x_36, 0); lean_inc(x_96); -x_97 = lean_ctor_get(x_39, 1); +x_97 = lean_ctor_get(x_36, 1); lean_inc(x_97); -x_98 = lean_ctor_get(x_39, 3); +x_98 = lean_ctor_get(x_36, 3); lean_inc(x_98); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_99 = x_39; +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; } else { - lean_dec_ref(x_39); + lean_dec_ref(x_36); x_99 = lean_box(0); } if (lean_is_scalar(x_99)) { @@ -8732,7 +8493,7 @@ if (lean_is_scalar(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_30); +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); @@ -8759,1392 +8520,1216 @@ 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_35, 1, x_103); -return x_35; +if (lean_is_scalar(x_10)) { + x_104 = lean_alloc_ctor(1, 2, 0); +} else { + x_104 = x_10; + lean_ctor_set_tag(x_104, 1); +} +lean_ctor_set(x_104, 0, x_37); +lean_ctor_set(x_104, 1, x_103); +return x_104; } } 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; 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_104 = lean_ctor_get(x_35, 0); -lean_inc(x_104); -lean_dec(x_35); -x_105 = lean_ctor_get(x_36, 1); +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); -if (lean_is_exclusive(x_36)) { - lean_ctor_release(x_36, 0); - lean_ctor_release(x_36, 1); - x_106 = x_36; -} else { - lean_dec_ref(x_36); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_37, 1); +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_37, 2); +x_108 = lean_ctor_get(x_32, 0); lean_inc(x_108); -x_109 = lean_ctor_get(x_37, 3); -lean_inc(x_109); -x_110 = lean_ctor_get(x_37, 4); -lean_inc(x_110); -x_111 = lean_ctor_get(x_37, 5); -lean_inc(x_111); -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); - lean_ctor_release(x_37, 4); - lean_ctor_release(x_37, 5); - x_112 = x_37; +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); +if (x_113 == 0) +{ +lean_object* x_114; uint8_t x_115; +x_114 = lean_ctor_get(x_106, 2); +lean_dec(x_114); +x_115 = !lean_is_exclusive(x_107); +if (x_115 == 0) +{ +lean_object* x_116; lean_object* x_117; +x_116 = lean_ctor_get(x_107, 2); +lean_dec(x_116); +lean_ctor_set(x_107, 2, x_31); +if (lean_is_scalar(x_10)) { + x_117 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_37); - x_112 = lean_box(0); + x_117 = x_10; } -x_113 = lean_ctor_get(x_38, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_38, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_38, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_38, 4); -lean_inc(x_116); -x_117 = lean_ctor_get(x_38, 5); -lean_inc(x_117); -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); - lean_ctor_release(x_38, 5); - x_118 = x_38; -} else { - lean_dec_ref(x_38); - x_118 = lean_box(0); +lean_ctor_set(x_117, 0, x_108); +lean_ctor_set(x_117, 1, x_33); +return x_117; } -x_119 = lean_ctor_get(x_39, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_39, 1); +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); -x_121 = lean_ctor_get(x_39, 3); -lean_inc(x_121); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_122 = x_39; +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 { - lean_dec_ref(x_39); - x_122 = lean_box(0); + x_122 = x_10; } -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(0, 4, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_119); -lean_ctor_set(x_123, 1, x_120); -lean_ctor_set(x_123, 2, x_30); -lean_ctor_set(x_123, 3, x_121); -if (lean_is_scalar(x_118)) { - x_124 = lean_alloc_ctor(0, 6, 0); -} else { - x_124 = x_118; -} -lean_ctor_set(x_124, 0, x_113); -lean_ctor_set(x_124, 1, x_114); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_115); -lean_ctor_set(x_124, 4, x_116); -lean_ctor_set(x_124, 5, x_117); -if (lean_is_scalar(x_112)) { - x_125 = lean_alloc_ctor(0, 6, 0); -} else { - x_125 = x_112; -} -lean_ctor_set(x_125, 0, x_124); -lean_ctor_set(x_125, 1, x_107); -lean_ctor_set(x_125, 2, x_108); -lean_ctor_set(x_125, 3, x_109); -lean_ctor_set(x_125, 4, x_110); -lean_ctor_set(x_125, 5, x_111); -if (lean_is_scalar(x_106)) { - x_126 = lean_alloc_ctor(0, 2, 0); -} else { - x_126 = x_106; -} -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_105); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_104); -lean_ctor_set(x_127, 1, x_126); -return x_127; +lean_ctor_set(x_122, 0, x_108); +lean_ctor_set(x_122, 1, x_33); +return x_122; } } else { -uint8_t x_128; -x_128 = !lean_is_exclusive(x_35); -if (x_128 == 0) -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; uint8_t x_134; -x_129 = lean_ctor_get(x_35, 1); -x_130 = l_Lean_Elab_Tactic_restore(x_129, x_34); -lean_dec(x_34); -x_131 = lean_ctor_get(x_130, 0); -lean_inc(x_131); -lean_dec(x_130); -x_132 = lean_ctor_get(x_131, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = !lean_is_exclusive(x_131); -if (x_134 == 0) -{ -lean_object* x_135; uint8_t x_136; -x_135 = lean_ctor_get(x_131, 0); -lean_dec(x_135); -x_136 = !lean_is_exclusive(x_132); -if (x_136 == 0) -{ -lean_object* x_137; uint8_t x_138; -x_137 = lean_ctor_get(x_132, 2); -lean_dec(x_137); -x_138 = !lean_is_exclusive(x_133); -if (x_138 == 0) -{ -lean_object* x_139; uint8_t x_140; -x_139 = lean_ctor_get(x_133, 2); -lean_dec(x_139); -lean_ctor_set(x_133, 2, x_30); -x_140 = !lean_is_exclusive(x_33); -if (x_140 == 0) -{ -lean_object* x_141; -x_141 = lean_ctor_get(x_33, 0); -lean_dec(x_141); -lean_ctor_set(x_33, 0, x_131); -lean_ctor_set(x_35, 1, x_33); -return x_35; +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_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_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_142; lean_object* x_143; -x_142 = lean_ctor_get(x_33, 1); +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_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); -lean_dec(x_33); -x_143 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_143, 0, x_131); -lean_ctor_set(x_143, 1, x_142); -lean_ctor_set(x_35, 1, x_143); -return x_35; -} -} -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; -x_144 = lean_ctor_get(x_133, 0); -x_145 = lean_ctor_get(x_133, 1); -x_146 = lean_ctor_get(x_133, 3); -lean_inc(x_146); -lean_inc(x_145); +x_143 = lean_ctor_get(x_106, 4); +lean_inc(x_143); +x_144 = lean_ctor_get(x_106, 5); lean_inc(x_144); -lean_dec(x_133); -x_147 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_147, 0, x_144); -lean_ctor_set(x_147, 1, x_145); -lean_ctor_set(x_147, 2, x_30); -lean_ctor_set(x_147, 3, x_146); -lean_ctor_set(x_132, 2, x_147); -x_148 = lean_ctor_get(x_33, 1); -lean_inc(x_148); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_149 = x_33; +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_33); + lean_dec_ref(x_106); + x_145 = lean_box(0); +} +x_146 = lean_ctor_get(x_107, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_107, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_107, 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; +} else { + lean_dec_ref(x_107); x_149 = lean_box(0); } if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 2, 0); + x_150 = lean_alloc_ctor(0, 4, 0); } else { x_150 = x_149; } -lean_ctor_set(x_150, 0, x_131); -lean_ctor_set(x_150, 1, x_148); -lean_ctor_set(x_35, 1, x_150); -return x_35; +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_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_151 = lean_ctor_get(x_132, 0); -x_152 = lean_ctor_get(x_132, 1); -x_153 = lean_ctor_get(x_132, 3); -x_154 = lean_ctor_get(x_132, 4); -x_155 = lean_ctor_get(x_132, 5); -lean_inc(x_155); +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); lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); -lean_inc(x_151); -lean_dec(x_132); -x_156 = lean_ctor_get(x_133, 0); +lean_dec(x_33); +x_155 = lean_ctor_get(x_105, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_105, 2); lean_inc(x_156); -x_157 = lean_ctor_get(x_133, 1); +x_157 = lean_ctor_get(x_105, 3); lean_inc(x_157); -x_158 = lean_ctor_get(x_133, 3); +x_158 = lean_ctor_get(x_105, 4); lean_inc(x_158); -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_159 = x_133; +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; } else { - lean_dec_ref(x_133); - x_159 = lean_box(0); + lean_dec_ref(x_105); + x_160 = lean_box(0); } -if (lean_is_scalar(x_159)) { - x_160 = lean_alloc_ctor(0, 4, 0); -} else { - x_160 = x_159; -} -lean_ctor_set(x_160, 0, x_156); -lean_ctor_set(x_160, 1, x_157); -lean_ctor_set(x_160, 2, x_30); -lean_ctor_set(x_160, 3, x_158); -x_161 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_161, 0, x_151); -lean_ctor_set(x_161, 1, x_152); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_153); -lean_ctor_set(x_161, 4, x_154); -lean_ctor_set(x_161, 5, x_155); -lean_ctor_set(x_131, 0, x_161); -x_162 = lean_ctor_get(x_33, 1); +x_161 = lean_ctor_get(x_106, 0); +lean_inc(x_161); +x_162 = lean_ctor_get(x_106, 1); lean_inc(x_162); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_163 = x_33; -} else { - lean_dec_ref(x_33); - x_163 = lean_box(0); -} -if (lean_is_scalar(x_163)) { - x_164 = lean_alloc_ctor(0, 2, 0); -} else { - x_164 = x_163; -} -lean_ctor_set(x_164, 0, x_131); -lean_ctor_set(x_164, 1, x_162); -lean_ctor_set(x_35, 1, x_164); -return x_35; -} -} -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; -x_165 = lean_ctor_get(x_131, 1); -x_166 = lean_ctor_get(x_131, 2); -x_167 = lean_ctor_get(x_131, 3); -x_168 = lean_ctor_get(x_131, 4); -x_169 = lean_ctor_get(x_131, 5); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); +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); -lean_dec(x_131); -x_170 = lean_ctor_get(x_132, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_132, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_132, 3); -lean_inc(x_172); -x_173 = lean_ctor_get(x_132, 4); -lean_inc(x_173); -x_174 = lean_ctor_get(x_132, 5); -lean_inc(x_174); -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_175 = x_132; +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; } else { - lean_dec_ref(x_132); - x_175 = lean_box(0); + lean_dec_ref(x_106); + x_166 = lean_box(0); } -x_176 = lean_ctor_get(x_133, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_133, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_133, 3); -lean_inc(x_178); -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_179 = x_133; +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; } else { - lean_dec_ref(x_133); - x_179 = lean_box(0); + lean_dec_ref(x_107); + x_170 = lean_box(0); } -if (lean_is_scalar(x_179)) { - x_180 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_170)) { + x_171 = lean_alloc_ctor(0, 4, 0); } else { - x_180 = x_179; + x_171 = x_170; } -lean_ctor_set(x_180, 0, x_176); -lean_ctor_set(x_180, 1, x_177); -lean_ctor_set(x_180, 2, x_30); -lean_ctor_set(x_180, 3, x_178); -if (lean_is_scalar(x_175)) { - x_181 = lean_alloc_ctor(0, 6, 0); +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_181 = x_175; + x_172 = x_166; } -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); -x_182 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_182, 0, x_181); -lean_ctor_set(x_182, 1, x_165); -lean_ctor_set(x_182, 2, x_166); -lean_ctor_set(x_182, 3, x_167); -lean_ctor_set(x_182, 4, x_168); -lean_ctor_set(x_182, 5, x_169); -x_183 = lean_ctor_get(x_33, 1); -lean_inc(x_183); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_184 = x_33; +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 { - lean_dec_ref(x_33); - x_184 = lean_box(0); + x_173 = x_160; } -if (lean_is_scalar(x_184)) { - x_185 = lean_alloc_ctor(0, 2, 0); +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); +if (lean_is_scalar(x_10)) { + x_175 = lean_alloc_ctor(0, 2, 0); } else { - x_185 = x_184; + x_175 = 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_185, 0, x_182); -lean_ctor_set(x_185, 1, x_183); -lean_ctor_set(x_35, 1, x_185); -return x_35; } } else { -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; 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_186 = lean_ctor_get(x_35, 0); -x_187 = lean_ctor_get(x_35, 1); -lean_inc(x_187); -lean_inc(x_186); -lean_dec(x_35); -x_188 = l_Lean_Elab_Tactic_restore(x_187, x_34); -lean_dec(x_34); -x_189 = lean_ctor_get(x_188, 0); -lean_inc(x_189); -lean_dec(x_188); -x_190 = lean_ctor_get(x_189, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_190, 2); -lean_inc(x_191); -x_192 = lean_ctor_get(x_189, 1); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 2); -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_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); -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); -x_201 = lean_ctor_get(x_190, 4); -lean_inc(x_201); -x_202 = lean_ctor_get(x_190, 5); -lean_inc(x_202); -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); - lean_ctor_release(x_190, 4); - lean_ctor_release(x_190, 5); - x_203 = x_190; -} else { - lean_dec_ref(x_190); - x_203 = lean_box(0); -} -x_204 = lean_ctor_get(x_191, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_191, 1); -lean_inc(x_205); -x_206 = lean_ctor_get(x_191, 3); -lean_inc(x_206); -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_207 = x_191; -} else { - lean_dec_ref(x_191); - x_207 = lean_box(0); -} -if (lean_is_scalar(x_207)) { - x_208 = lean_alloc_ctor(0, 4, 0); -} else { - x_208 = x_207; -} -lean_ctor_set(x_208, 0, x_204); -lean_ctor_set(x_208, 1, x_205); -lean_ctor_set(x_208, 2, x_30); -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); -if (lean_is_scalar(x_197)) { - x_210 = lean_alloc_ctor(0, 6, 0); -} else { - x_210 = x_197; -} -lean_ctor_set(x_210, 0, x_209); -lean_ctor_set(x_210, 1, x_192); -lean_ctor_set(x_210, 2, x_193); -lean_ctor_set(x_210, 3, x_194); -lean_ctor_set(x_210, 4, x_195); -lean_ctor_set(x_210, 5, x_196); -x_211 = lean_ctor_get(x_33, 1); -lean_inc(x_211); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_212 = x_33; -} else { - lean_dec_ref(x_33); - x_212 = lean_box(0); -} -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 2, 0); -} else { - x_213 = x_212; -} -lean_ctor_set(x_213, 0, x_210); -lean_ctor_set(x_213, 1, x_211); -x_214 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_214, 0, x_186); -lean_ctor_set(x_214, 1, x_213); -return x_214; -} -} -} -else -{ -uint8_t x_215; -lean_dec(x_30); -lean_dec(x_22); -lean_dec(x_2); -x_215 = !lean_is_exclusive(x_32); -if (x_215 == 0) -{ -return x_32; -} -else -{ -lean_object* x_216; lean_object* x_217; lean_object* x_218; -x_216 = lean_ctor_get(x_32, 0); -x_217 = lean_ctor_get(x_32, 1); -lean_inc(x_217); -lean_inc(x_216); -lean_dec(x_32); -x_218 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_218, 0, x_216); -lean_ctor_set(x_218, 1, x_217); -return x_218; -} -} -} -} -} -else -{ -lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; uint8_t x_227; lean_object* x_228; lean_object* x_229; -x_219 = lean_ctor_get(x_7, 0); -x_220 = lean_ctor_get(x_7, 2); -x_221 = lean_ctor_get(x_7, 3); -x_222 = lean_ctor_get(x_7, 4); -lean_inc(x_222); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); +lean_inc(x_195); +lean_inc(x_194); +lean_inc(x_193); lean_dec(x_7); -x_223 = lean_ctor_get(x_8, 1); +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_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_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; +} +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; +} +} +else +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; +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_8, 4); +x_224 = lean_ctor_get(x_214, 5); lean_inc(x_224); -x_225 = lean_array_get_size(x_220); -x_226 = lean_array_get_size(x_224); -x_227 = lean_nat_dec_eq(x_225, x_226); -lean_dec(x_226); -lean_dec(x_225); -lean_inc(x_224); -x_228 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_228, 0, x_219); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_224); -lean_ctor_set(x_228, 3, x_221); -lean_ctor_set(x_228, 4, x_222); -lean_ctor_set(x_6, 0, x_228); -x_229 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_229, 0, x_6); -lean_ctor_set(x_229, 1, x_10); -lean_ctor_set(x_229, 2, x_11); -if (x_227 == 0) -{ -lean_object* x_230; -lean_dec(x_224); -lean_dec(x_220); -lean_dec(x_8); -lean_dec(x_3); -x_230 = lean_apply_2(x_2, x_229, x_9); -return x_230; +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); } -else -{ -lean_object* x_231; uint8_t x_232; -x_231 = lean_unsigned_to_nat(0u); -x_232 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_220, x_224, x_231); -lean_dec(x_224); -lean_dec(x_220); -lean_dec(x_8); -lean_dec(x_3); -if (x_232 == 0) -{ -lean_object* x_233; -x_233 = lean_apply_2(x_2, x_229, x_9); -return x_233; -} -else -{ -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_234 = lean_ctor_get(x_9, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 0); -lean_inc(x_235); -lean_dec(x_234); -x_236 = lean_ctor_get(x_235, 2); -lean_inc(x_236); -lean_dec(x_235); -x_237 = lean_ctor_get(x_236, 2); -lean_inc(x_237); -lean_dec(x_236); -x_238 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +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_239 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_238, x_229, x_9); -if (lean_obj_tag(x_239) == 0) +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_240; lean_object* x_241; lean_object* x_242; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -lean_dec(x_239); -x_241 = l_Lean_Elab_Tactic_save(x_240); -lean_inc(x_240); -x_242 = lean_apply_2(x_2, x_229, x_240); -if (lean_obj_tag(x_242) == 0) -{ -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; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; -lean_dec(x_241); -lean_dec(x_240); -x_243 = lean_ctor_get(x_242, 1); +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_243, 0); +x_244 = lean_ctor_get(x_212, 0); lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 0); +lean_dec(x_212); +x_245 = lean_ctor_get(x_213, 1); lean_inc(x_245); -x_246 = lean_ctor_get(x_245, 2); -lean_inc(x_246); -x_247 = lean_ctor_get(x_242, 0); +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); - x_248 = x_242; + 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_248 = lean_box(0); + x_258 = lean_box(0); } -x_249 = lean_ctor_get(x_243, 1); -lean_inc(x_249); +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); - x_250 = x_243; + lean_ctor_release(x_243, 2); + lean_ctor_release(x_243, 3); + x_262 = x_243; } else { lean_dec_ref(x_243); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_244, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_244, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_244, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_244, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_244, 4); - lean_ctor_release(x_244, 5); - x_256 = x_244; -} else { - lean_dec_ref(x_244); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_245, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_245, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_245, 3); -lean_inc(x_259); -x_260 = lean_ctor_get(x_245, 4); -lean_inc(x_260); -x_261 = lean_ctor_get(x_245, 5); -lean_inc(x_261); -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); - lean_ctor_release(x_245, 5); - x_262 = x_245; -} else { - lean_dec_ref(x_245); x_262 = lean_box(0); } -x_263 = lean_ctor_get(x_246, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_246, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_246, 3); -lean_inc(x_265); -if (lean_is_exclusive(x_246)) { - lean_ctor_release(x_246, 0); - lean_ctor_release(x_246, 1); - lean_ctor_release(x_246, 2); - lean_ctor_release(x_246, 3); - x_266 = x_246; -} else { - lean_dec_ref(x_246); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(0, 4, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_263); -lean_ctor_set(x_267, 1, x_264); -lean_ctor_set(x_267, 2, x_237); -lean_ctor_set(x_267, 3, x_265); if (lean_is_scalar(x_262)) { - x_268 = lean_alloc_ctor(0, 6, 0); + x_263 = lean_alloc_ctor(0, 4, 0); } else { - x_268 = x_262; + x_263 = x_262; } -lean_ctor_set(x_268, 0, x_257); -lean_ctor_set(x_268, 1, x_258); -lean_ctor_set(x_268, 2, x_267); -lean_ctor_set(x_268, 3, x_259); -lean_ctor_set(x_268, 4, x_260); -lean_ctor_set(x_268, 5, x_261); -if (lean_is_scalar(x_256)) { - x_269 = lean_alloc_ctor(0, 6, 0); +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_269 = x_256; + x_264 = x_258; } -lean_ctor_set(x_269, 0, x_268); -lean_ctor_set(x_269, 1, x_251); -lean_ctor_set(x_269, 2, x_252); -lean_ctor_set(x_269, 3, x_253); -lean_ctor_set(x_269, 4, x_254); -lean_ctor_set(x_269, 5, x_255); -if (lean_is_scalar(x_250)) { - x_270 = lean_alloc_ctor(0, 2, 0); +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_270 = x_250; + x_265 = x_252; } -lean_ctor_set(x_270, 0, x_269); -lean_ctor_set(x_270, 1, x_249); -if (lean_is_scalar(x_248)) { - x_271 = lean_alloc_ctor(0, 2, 0); +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_271 = x_248; + 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; +} +} +} +} } -lean_ctor_set(x_271, 0, x_247); -lean_ctor_set(x_271, 1, x_270); -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; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; 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_272 = lean_ctor_get(x_242, 0); -lean_inc(x_272); -x_273 = lean_ctor_get(x_242, 1); -lean_inc(x_273); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - x_274 = x_242; -} else { - lean_dec_ref(x_242); - x_274 = lean_box(0); -} -x_275 = l_Lean_Elab_Tactic_restore(x_273, x_241); -lean_dec(x_241); -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -lean_dec(x_275); -x_277 = lean_ctor_get(x_276, 0); -lean_inc(x_277); -x_278 = lean_ctor_get(x_277, 2); -lean_inc(x_278); -x_279 = lean_ctor_get(x_276, 1); -lean_inc(x_279); -x_280 = lean_ctor_get(x_276, 2); -lean_inc(x_280); -x_281 = lean_ctor_get(x_276, 3); -lean_inc(x_281); -x_282 = lean_ctor_get(x_276, 4); -lean_inc(x_282); -x_283 = lean_ctor_get(x_276, 5); -lean_inc(x_283); -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); - lean_ctor_release(x_276, 4); - lean_ctor_release(x_276, 5); - x_284 = x_276; -} else { - lean_dec_ref(x_276); - x_284 = lean_box(0); -} -x_285 = lean_ctor_get(x_277, 0); -lean_inc(x_285); -x_286 = lean_ctor_get(x_277, 1); -lean_inc(x_286); -x_287 = lean_ctor_get(x_277, 3); -lean_inc(x_287); -x_288 = lean_ctor_get(x_277, 4); -lean_inc(x_288); -x_289 = lean_ctor_get(x_277, 5); -lean_inc(x_289); -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); - lean_ctor_release(x_277, 4); - lean_ctor_release(x_277, 5); - x_290 = x_277; -} else { - lean_dec_ref(x_277); - x_290 = lean_box(0); -} -x_291 = lean_ctor_get(x_278, 0); -lean_inc(x_291); -x_292 = lean_ctor_get(x_278, 1); -lean_inc(x_292); -x_293 = lean_ctor_get(x_278, 3); +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); -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_294 = x_278; -} else { - lean_dec_ref(x_278); - x_294 = lean_box(0); -} -if (lean_is_scalar(x_294)) { - x_295 = lean_alloc_ctor(0, 4, 0); -} else { - x_295 = x_294; -} -lean_ctor_set(x_295, 0, x_291); -lean_ctor_set(x_295, 1, x_292); -lean_ctor_set(x_295, 2, x_237); -lean_ctor_set(x_295, 3, x_293); -if (lean_is_scalar(x_290)) { - x_296 = lean_alloc_ctor(0, 6, 0); -} else { - x_296 = x_290; -} -lean_ctor_set(x_296, 0, x_285); -lean_ctor_set(x_296, 1, x_286); -lean_ctor_set(x_296, 2, x_295); -lean_ctor_set(x_296, 3, x_287); -lean_ctor_set(x_296, 4, x_288); -lean_ctor_set(x_296, 5, x_289); -if (lean_is_scalar(x_284)) { - x_297 = lean_alloc_ctor(0, 6, 0); -} else { - x_297 = x_284; -} -lean_ctor_set(x_297, 0, x_296); -lean_ctor_set(x_297, 1, x_279); -lean_ctor_set(x_297, 2, x_280); -lean_ctor_set(x_297, 3, x_281); -lean_ctor_set(x_297, 4, x_282); -lean_ctor_set(x_297, 5, x_283); -x_298 = lean_ctor_get(x_240, 1); -lean_inc(x_298); -if (lean_is_exclusive(x_240)) { - lean_ctor_release(x_240, 0); - lean_ctor_release(x_240, 1); - x_299 = x_240; -} else { - lean_dec_ref(x_240); - x_299 = lean_box(0); -} -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 2, 0); -} else { - x_300 = x_299; -} -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -if (lean_is_scalar(x_274)) { - x_301 = lean_alloc_ctor(1, 2, 0); -} else { - x_301 = x_274; -} -lean_ctor_set(x_301, 0, x_272); -lean_ctor_set(x_301, 1, x_300); -return x_301; -} -} -else -{ -lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; -lean_dec(x_237); -lean_dec(x_229); -lean_dec(x_2); -x_302 = lean_ctor_get(x_239, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_239, 1); -lean_inc(x_303); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_304 = x_239; -} else { - lean_dec_ref(x_239); - x_304 = lean_box(0); -} -if (lean_is_scalar(x_304)) { - x_305 = lean_alloc_ctor(1, 2, 0); -} else { - x_305 = x_304; -} -lean_ctor_set(x_305, 0, x_302); -lean_ctor_set(x_305, 1, x_303); -return x_305; -} -} -} -} -} -else -{ -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; uint8_t x_315; uint8_t x_316; uint8_t x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; uint8_t x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_306 = lean_ctor_get(x_6, 1); -x_307 = lean_ctor_get(x_6, 2); -x_308 = lean_ctor_get(x_6, 3); -x_309 = lean_ctor_get(x_6, 4); -x_310 = lean_ctor_get(x_6, 5); -x_311 = lean_ctor_get(x_6, 6); -x_312 = lean_ctor_get(x_6, 7); -x_313 = lean_ctor_get(x_6, 8); -x_314 = lean_ctor_get(x_6, 9); -x_315 = lean_ctor_get_uint8(x_6, sizeof(void*)*10); -x_316 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 1); -x_317 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 2); -lean_inc(x_314); -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_inc(x_306); +lean_inc(x_292); +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_318 = lean_ctor_get(x_7, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_7, 2); -lean_inc(x_319); -x_320 = lean_ctor_get(x_7, 3); -lean_inc(x_320); -x_321 = lean_ctor_get(x_7, 4); -lean_inc(x_321); +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); +lean_inc(x_300); 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_322 = x_7; + x_301 = x_7; } else { lean_dec_ref(x_7); - x_322 = lean_box(0); + x_301 = lean_box(0); } -x_323 = lean_ctor_get(x_8, 1); +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); +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_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; +} +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; +} +} +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_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; +} else { + lean_dec_ref(x_376); + x_389 = lean_box(0); +} +if (lean_is_scalar(x_389)) { + x_390 = lean_alloc_ctor(1, 2, 0); +} else { + x_390 = x_389; +} +lean_ctor_set(x_390, 0, x_387); +lean_ctor_set(x_390, 1, x_388); +return x_390; +} +block_374: +{ +if (lean_obj_tag(x_318) == 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); -x_324 = lean_ctor_get(x_8, 4); +lean_dec(x_318); +x_324 = lean_ctor_get(x_319, 1); lean_inc(x_324); -x_325 = lean_array_get_size(x_319); -x_326 = lean_array_get_size(x_324); -x_327 = lean_nat_dec_eq(x_325, x_326); -lean_dec(x_326); -lean_dec(x_325); -lean_inc(x_324); -if (lean_is_scalar(x_322)) { - x_328 = lean_alloc_ctor(0, 5, 0); +if (lean_is_exclusive(x_319)) { + lean_ctor_release(x_319, 0); + lean_ctor_release(x_319, 1); + x_325 = x_319; } else { - x_328 = x_322; + lean_dec_ref(x_319); + x_325 = lean_box(0); } -lean_ctor_set(x_328, 0, x_318); -lean_ctor_set(x_328, 1, x_323); -lean_ctor_set(x_328, 2, x_324); -lean_ctor_set(x_328, 3, x_320); -lean_ctor_set(x_328, 4, x_321); -x_329 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_329, 0, x_328); -lean_ctor_set(x_329, 1, x_306); -lean_ctor_set(x_329, 2, x_307); -lean_ctor_set(x_329, 3, x_308); -lean_ctor_set(x_329, 4, x_309); -lean_ctor_set(x_329, 5, x_310); -lean_ctor_set(x_329, 6, x_311); -lean_ctor_set(x_329, 7, x_312); -lean_ctor_set(x_329, 8, x_313); -lean_ctor_set(x_329, 9, x_314); -lean_ctor_set_uint8(x_329, sizeof(void*)*10, x_315); -lean_ctor_set_uint8(x_329, sizeof(void*)*10 + 1, x_316); -lean_ctor_set_uint8(x_329, sizeof(void*)*10 + 2, x_317); -x_330 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_330, 0, x_329); -lean_ctor_set(x_330, 1, x_10); -lean_ctor_set(x_330, 2, x_11); -if (x_327 == 0) -{ -lean_object* x_331; -lean_dec(x_324); -lean_dec(x_319); -lean_dec(x_8); -lean_dec(x_3); -x_331 = lean_apply_2(x_2, x_330, x_9); -return x_331; -} -else -{ -lean_object* x_332; uint8_t x_333; -x_332 = lean_unsigned_to_nat(0u); -x_333 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_319, x_324, x_332); -lean_dec(x_324); -lean_dec(x_319); -lean_dec(x_8); -lean_dec(x_3); -if (x_333 == 0) -{ -lean_object* x_334; -x_334 = lean_apply_2(x_2, x_330, x_9); -return x_334; -} -else -{ -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_335 = lean_ctor_get(x_9, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_335, 0); -lean_inc(x_336); -lean_dec(x_335); -x_337 = lean_ctor_get(x_336, 2); -lean_inc(x_337); -lean_dec(x_336); -x_338 = lean_ctor_get(x_337, 2); -lean_inc(x_338); -lean_dec(x_337); -x_339 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +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_inc(x_330); -x_340 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_339, x_330, x_9); -if (lean_obj_tag(x_340) == 0) +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); +lean_inc(x_332); +x_333 = lean_ctor_get(x_321, 1); +lean_inc(x_333); +x_334 = lean_ctor_get(x_321, 3); +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; +} else { + lean_dec_ref(x_321); + x_337 = lean_box(0); +} +x_338 = lean_ctor_get(x_322, 0); +lean_inc(x_338); +x_339 = lean_ctor_get(x_322, 1); +lean_inc(x_339); +x_340 = lean_ctor_get(x_322, 3); +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; +} else { + lean_dec_ref(x_322); + 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_317); +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_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); +if (lean_is_scalar(x_10)) { + x_346 = lean_alloc_ctor(1, 2, 0); +} else { + x_346 = x_10; + lean_ctor_set_tag(x_346, 1); +} +lean_ctor_set(x_346, 0, x_323); +lean_ctor_set(x_346, 1, x_345); +return x_346; +} +else { -lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_341 = lean_ctor_get(x_340, 1); -lean_inc(x_341); -lean_dec(x_340); -x_342 = l_Lean_Elab_Tactic_save(x_341); -lean_inc(x_341); -x_343 = lean_apply_2(x_2, x_330, x_341); -if (lean_obj_tag(x_343) == 0) -{ -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; 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_dec(x_342); -lean_dec(x_341); -x_344 = lean_ctor_get(x_343, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_344, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_345, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_346, 2); +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_343, 0); +x_348 = lean_ctor_get(x_347, 0); lean_inc(x_348); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - x_349 = x_343; -} else { - lean_dec_ref(x_343); - x_349 = lean_box(0); -} -x_350 = lean_ctor_get(x_344, 1); +x_349 = lean_ctor_get(x_348, 2); +lean_inc(x_349); +x_350 = lean_ctor_get(x_318, 0); lean_inc(x_350); -if (lean_is_exclusive(x_344)) { - lean_ctor_release(x_344, 0); - lean_ctor_release(x_344, 1); - x_351 = x_344; +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_344); - x_351 = lean_box(0); + lean_dec_ref(x_319); + x_352 = lean_box(0); } -x_352 = lean_ctor_get(x_345, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_345, 2); +x_353 = lean_ctor_get(x_347, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_345, 3); +x_354 = lean_ctor_get(x_347, 2); lean_inc(x_354); -x_355 = lean_ctor_get(x_345, 4); +x_355 = lean_ctor_get(x_347, 3); lean_inc(x_355); -x_356 = lean_ctor_get(x_345, 5); +x_356 = lean_ctor_get(x_347, 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); - lean_ctor_release(x_345, 4); - lean_ctor_release(x_345, 5); - x_357 = x_345; -} else { - lean_dec_ref(x_345); - x_357 = lean_box(0); -} -x_358 = lean_ctor_get(x_346, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_346, 1); -lean_inc(x_359); -x_360 = lean_ctor_get(x_346, 3); -lean_inc(x_360); -x_361 = lean_ctor_get(x_346, 4); -lean_inc(x_361); -x_362 = lean_ctor_get(x_346, 5); -lean_inc(x_362); -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); - x_363 = x_346; -} else { - lean_dec_ref(x_346); - x_363 = lean_box(0); -} -x_364 = lean_ctor_get(x_347, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_347, 1); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 3); -lean_inc(x_366); +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); - x_367 = x_347; + lean_ctor_release(x_347, 4); + lean_ctor_release(x_347, 5); + x_358 = x_347; } else { lean_dec_ref(x_347); - x_367 = lean_box(0); + x_358 = lean_box(0); } -if (lean_is_scalar(x_367)) { - x_368 = lean_alloc_ctor(0, 4, 0); +x_359 = lean_ctor_get(x_348, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_348, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_348, 3); +lean_inc(x_361); +x_362 = lean_ctor_get(x_348, 4); +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; } else { - x_368 = x_367; + lean_dec_ref(x_348); + x_364 = lean_box(0); } -lean_ctor_set(x_368, 0, x_364); -lean_ctor_set(x_368, 1, x_365); -lean_ctor_set(x_368, 2, x_338); -lean_ctor_set(x_368, 3, x_366); -if (lean_is_scalar(x_363)) { - x_369 = lean_alloc_ctor(0, 6, 0); +x_365 = lean_ctor_get(x_349, 0); +lean_inc(x_365); +x_366 = lean_ctor_get(x_349, 1); +lean_inc(x_366); +x_367 = lean_ctor_get(x_349, 3); +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; } else { - x_369 = x_363; + lean_dec_ref(x_349); + x_368 = lean_box(0); } -lean_ctor_set(x_369, 0, x_358); -lean_ctor_set(x_369, 1, x_359); -lean_ctor_set(x_369, 2, x_368); -lean_ctor_set(x_369, 3, x_360); -lean_ctor_set(x_369, 4, x_361); -lean_ctor_set(x_369, 5, x_362); -if (lean_is_scalar(x_357)) { +if (lean_is_scalar(x_368)) { + x_369 = lean_alloc_ctor(0, 4, 0); +} else { + x_369 = x_368; +} +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); } else { - x_370 = x_357; + x_370 = x_364; } -lean_ctor_set(x_370, 0, x_369); -lean_ctor_set(x_370, 1, x_352); -lean_ctor_set(x_370, 2, x_353); -lean_ctor_set(x_370, 3, x_354); -lean_ctor_set(x_370, 4, x_355); -lean_ctor_set(x_370, 5, x_356); -if (lean_is_scalar(x_351)) { - x_371 = lean_alloc_ctor(0, 2, 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); } else { - x_371 = x_351; + x_371 = x_358; } lean_ctor_set(x_371, 0, x_370); -lean_ctor_set(x_371, 1, x_350); -if (lean_is_scalar(x_349)) { +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); } else { - x_372 = x_349; + x_372 = x_352; } -lean_ctor_set(x_372, 0, x_348); -lean_ctor_set(x_372, 1, x_371); -return x_372; -} -else -{ -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; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; -x_373 = lean_ctor_get(x_343, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_343, 1); -lean_inc(x_374); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - x_375 = x_343; +lean_ctor_set(x_372, 0, x_371); +lean_ctor_set(x_372, 1, x_351); +if (lean_is_scalar(x_10)) { + x_373 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_343); - x_375 = lean_box(0); + x_373 = x_10; } -x_376 = l_Lean_Elab_Tactic_restore(x_374, x_342); -lean_dec(x_342); -x_377 = lean_ctor_get(x_376, 0); -lean_inc(x_377); -lean_dec(x_376); -x_378 = lean_ctor_get(x_377, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_378, 2); -lean_inc(x_379); -x_380 = lean_ctor_get(x_377, 1); -lean_inc(x_380); -x_381 = lean_ctor_get(x_377, 2); -lean_inc(x_381); -x_382 = lean_ctor_get(x_377, 3); -lean_inc(x_382); -x_383 = lean_ctor_get(x_377, 4); -lean_inc(x_383); -x_384 = lean_ctor_get(x_377, 5); -lean_inc(x_384); -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_385 = x_377; -} else { - lean_dec_ref(x_377); - x_385 = lean_box(0); +lean_ctor_set(x_373, 0, x_350); +lean_ctor_set(x_373, 1, x_372); +return x_373; } -x_386 = lean_ctor_get(x_378, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_378, 1); -lean_inc(x_387); -x_388 = lean_ctor_get(x_378, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_378, 4); -lean_inc(x_389); -x_390 = lean_ctor_get(x_378, 5); -lean_inc(x_390); -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); - lean_ctor_release(x_378, 4); - lean_ctor_release(x_378, 5); - x_391 = x_378; -} else { - lean_dec_ref(x_378); - x_391 = lean_box(0); -} -x_392 = lean_ctor_get(x_379, 0); -lean_inc(x_392); -x_393 = lean_ctor_get(x_379, 1); -lean_inc(x_393); -x_394 = lean_ctor_get(x_379, 3); -lean_inc(x_394); -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_395 = x_379; -} else { - lean_dec_ref(x_379); - x_395 = lean_box(0); -} -if (lean_is_scalar(x_395)) { - x_396 = lean_alloc_ctor(0, 4, 0); -} else { - x_396 = x_395; -} -lean_ctor_set(x_396, 0, x_392); -lean_ctor_set(x_396, 1, x_393); -lean_ctor_set(x_396, 2, x_338); -lean_ctor_set(x_396, 3, x_394); -if (lean_is_scalar(x_391)) { - x_397 = lean_alloc_ctor(0, 6, 0); -} else { - x_397 = x_391; -} -lean_ctor_set(x_397, 0, x_386); -lean_ctor_set(x_397, 1, x_387); -lean_ctor_set(x_397, 2, x_396); -lean_ctor_set(x_397, 3, x_388); -lean_ctor_set(x_397, 4, x_389); -lean_ctor_set(x_397, 5, x_390); -if (lean_is_scalar(x_385)) { - x_398 = lean_alloc_ctor(0, 6, 0); -} else { - x_398 = x_385; -} -lean_ctor_set(x_398, 0, x_397); -lean_ctor_set(x_398, 1, x_380); -lean_ctor_set(x_398, 2, x_381); -lean_ctor_set(x_398, 3, x_382); -lean_ctor_set(x_398, 4, x_383); -lean_ctor_set(x_398, 5, x_384); -x_399 = lean_ctor_get(x_341, 1); -lean_inc(x_399); -if (lean_is_exclusive(x_341)) { - lean_ctor_release(x_341, 0); - lean_ctor_release(x_341, 1); - x_400 = x_341; -} else { - lean_dec_ref(x_341); - x_400 = lean_box(0); -} -if (lean_is_scalar(x_400)) { - x_401 = lean_alloc_ctor(0, 2, 0); -} else { - x_401 = x_400; -} -lean_ctor_set(x_401, 0, x_398); -lean_ctor_set(x_401, 1, x_399); -if (lean_is_scalar(x_375)) { - x_402 = lean_alloc_ctor(1, 2, 0); -} else { - x_402 = x_375; -} -lean_ctor_set(x_402, 0, x_373); -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_dec(x_338); -lean_dec(x_330); -lean_dec(x_2); -x_403 = lean_ctor_get(x_340, 0); -lean_inc(x_403); -x_404 = lean_ctor_get(x_340, 1); -lean_inc(x_404); -if (lean_is_exclusive(x_340)) { - lean_ctor_release(x_340, 0); - lean_ctor_release(x_340, 1); - x_405 = x_340; -} else { - lean_dec_ref(x_340); - x_405 = lean_box(0); -} -if (lean_is_scalar(x_405)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_405; -} -lean_ctor_set(x_406, 0, x_403); -lean_ctor_set(x_406, 1, x_404); -return x_406; } } } diff --git a/stage0/stdlib/Lean/Elab/Term.c b/stage0/stdlib/Lean/Elab/Term.c index 8fc3829334..b26345f8f8 100644 --- a/stage0/stdlib/Lean/Elab/Term.c +++ b/stage0/stdlib/Lean/Elab/Term.c @@ -14,6 +14,7 @@ extern "C" { #endif lean_object* l_Lean_Elab_mkMessage___at_Lean_Elab_Term_throwError___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_getLevelNames(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__4; lean_object* l_Lean_Elab_Term_elabChar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkAppM(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -33,6 +34,7 @@ extern lean_object* l_Lean_Closure_mkNewLevelParam___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabTypeStx___closed__1; lean_object* l_Lean_extractMacroScopes(lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__8; +lean_object* l_Lean_Elab_Term_instantiateLevelMVars___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_MessageData_hasSyntheticSorry___main(lean_object*); lean_object* l_Lean_Elab_Term_elabArrayLit___closed__1; lean_object* l_Lean_Elab_Term_elabImplicitLambdaAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -133,6 +135,7 @@ extern lean_object* l_Lean_Parser_declareBuiltinParser___closed__5; lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__6; lean_object* l_Lean_Elab_Term_getDecLevel(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_monadQuotation___closed__2; +lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkIdentFrom(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withoutPostponing(lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__13; @@ -185,6 +188,7 @@ extern lean_object* l_List_repr___rarg___closed__3; extern lean_object* l_Lean_unitToExpr___lambda__1___closed__3; lean_object* l___private_Lean_Elab_Term_18__mkPairsAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_typeAscription___elambda__1___closed__2; +lean_object* l_Lean_Elab_Term_withLocalContext___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwError(lean_object*); lean_object* l_Lean_Elab_Term_elabSort___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getMCtx(lean_object*); @@ -263,6 +267,7 @@ lean_object* l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__ lean_object* l_Lean_Elab_Term_liftMetaM(lean_object*); extern lean_object* l_Lean_PersistentEnvExtension_inhabited___rarg___closed__1; lean_object* l___private_Lean_Elab_Term_7__isMonad_x3f___closed__2; +lean_object* l_Lean_Elab_Term_isTypeFormerType(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_metavar_ctx_is_expr_assigned(lean_object*, lean_object*); extern lean_object* l_Lean_LocalContext_Inhabited___closed__2; lean_object* l_Lean_Meta_isClass(lean_object*, lean_object*, lean_object*); @@ -306,7 +311,7 @@ uint8_t lean_nat_dec_eq(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withMVarContext(lean_object*); lean_object* l_Lean_Elab_Term_termElabAttribute___closed__4; lean_object* l_Lean_Elab_Term_addContext___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Term_14__isLambdaWithImplicit___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabByTactic(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Lean_Elab_Term_3__fromMetaState___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -345,6 +350,7 @@ lean_object* l___private_Lean_Elab_Term_23__mkConsts(lean_object*, lean_object*, lean_object* l_Lean_Elab_Term_termElabAttribute___closed__1; lean_object* l___private_Lean_Elab_Term_5__expandCDot___main___closed__3; lean_object* l_Lean_Elab_Term_mkFreshInstanceName(lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3; lean_object* l_Lean_Elab_Term_elabChar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_11__elabUsingElabFnsAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Name_append___main(lean_object*, lean_object*); @@ -397,6 +403,7 @@ lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Elab_Term_4__hasCDo lean_object* l___private_Lean_Elab_Term_5__expandCDot___main___closed__2; uint8_t l_Lean_Elab_Term_blockImplicitLambda(lean_object*); lean_object* l_Lean_Elab_Term_elabTypeStx(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_assignLevelMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_findAux___main___at_Lean_Elab_Term_elabUsingElabFns___spec__3(lean_object*, size_t, lean_object*); lean_object* l_Lean_Elab_Term_throwTypeMismatchError___rarg___closed__3; lean_object* l_Lean_Elab_Term_monadLog___closed__6; @@ -451,9 +458,11 @@ lean_object* l_Lean_Elab_Term_resolveName(lean_object*, lean_object*, lean_objec lean_object* l___regBuiltin_Lean_Elab_Term_elabRawNumLit(lean_object*); extern size_t l_Std_PersistentHashMap_insertAux___main___rarg___closed__2; lean_object* l_Lean_Elab_Term_elabProp___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getCurrMacroScope(lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_assignExpr(lean_object*, lean_object*, lean_object*); lean_object* l_Nat_foldMAux___main___at___private_Lean_Elab_Term_22__mkFreshLevelMVars___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_withLocalContext(lean_object*); uint8_t l_Lean_Environment_contains(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_applyResult___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_monadQuotation___closed__4; @@ -471,6 +480,7 @@ lean_object* l_Lean_Elab_Term_monadLog___lambda__1(lean_object*, lean_object*, l lean_object* l_Lean_Elab_Term_mkAppM___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getCurrMacroScope___boxed(lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__6; +lean_object* l_Lean_Meta_isTypeFormerType___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Options_empty; lean_object* l_Lean_Elab_Term_mkConst___closed__7; lean_object* l_Lean_Elab_Term_useImplicitLambda_x3f(lean_object*, lean_object*, lean_object*, lean_object*); @@ -491,6 +501,7 @@ lean_object* l_Lean_Elab_addMacroStack(lean_object*, lean_object*); lean_object* l_Lean_LocalDecl_toExpr(lean_object*); extern lean_object* l_Lean_firstFrontendMacroScope; lean_object* l_Lean_Elab_Term_elabTermAux(lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_isLevelDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_termElabAttribute___closed__5; lean_object* l_Lean_Elab_mkElabAttribute___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabRawNumLit___closed__1; @@ -503,6 +514,7 @@ lean_object* l___private_Lean_Elab_Term_1__mkMessageAux(lean_object*, lean_objec lean_object* l_Lean_Elab_Term_getLocalInsts(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkFreshInstanceName___rarg(lean_object*); lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_isTypeFormerType___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isClass(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_ReaderT_bind___at_Lean_Elab_Term_monadLog___spec__2___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*); @@ -537,7 +549,6 @@ lean_object* l_Lean_Elab_Term_mkConst___closed__3; lean_object* l_Lean_Elab_Term_resolveName___closed__4; extern lean_object* l_Lean_nullKind___closed__2; uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Elab_Term_14__isLambdaWithImplicit___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3; lean_object* l_Lean_Elab_Term_throwTypeMismatchError___rarg___closed__2; lean_object* l_Lean_Elab_Term_elabNamedHole___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInst___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -560,6 +571,7 @@ lean_object* l_Lean_ConstantInfo_lparams(lean_object*); lean_object* l_Lean_Elab_Term_mkTermElabAttribute___closed__9; lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); lean_object* l_Lean_Elab_Term_mkFreshAnonymousName(lean_object*); +lean_object* l_Lean_Elab_Term_levelMVarToParam_x27(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withLCtx(lean_object*); extern lean_object* l_Option_HasRepr___rarg___closed__3; lean_object* l_Lean_Elab_Term_withoutPostponing___rarg(lean_object*, lean_object*, lean_object*); @@ -578,6 +590,7 @@ extern lean_object* l_Lean_mkAppStx___closed__5; lean_object* l___private_Lean_Elab_Term_10__postponeElabTerm___closed__2; extern lean_object* l_Lean_Expr_listLitAux___main___closed__6; lean_object* l_Lean_Elab_Term_MetaHasEval___rarg(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*); +lean_object* l_Lean_Elab_Term_isLevelDefEq(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isTypeFormer___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_16__mkAuxNameAux___main(lean_object*, lean_object*, lean_object*); @@ -621,8 +634,11 @@ lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore(lean_object*, lean_object*, lean_object* l_Lean_Elab_Term_decLevel___closed__3; lean_object* l_Lean_Elab_Term_withTransparency___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_paren___elambda__1___closed__1; +lean_object* l_Lean_Meta_isLevelDefEq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_assignLevelMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l___private_Lean_Elab_Term_12__isExplicit(lean_object*); extern lean_object* l_Lean_Meta_evalNat___main___closed__9; +lean_object* lean_metavar_ctx_assign_level(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_11__elabUsingElabFnsAux(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_tryLiftAndCoe___closed__6; lean_object* l_Lean_Elab_Term_savingMCtx___rarg(lean_object*, lean_object*, lean_object*); @@ -742,6 +758,7 @@ lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lea lean_object* l_Lean_Elab_Term_withLocalDecl___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkPairs___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__11; +lean_object* l_Lean_Elab_Term_getLevelNames___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_decLevel___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getLCtx___boxed(lean_object*, lean_object*); @@ -822,6 +839,7 @@ lean_object* l_Lean_indentExpr(lean_object*); lean_object* l___private_Lean_Elab_Term_18__mkPairsAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_Lean_Elab_MonadMacroAdapter___closed__8; lean_object* l_Lean_Elab_Term_trace(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabRawCharLit___closed__2; lean_object* l_Lean_Elab_Term_mkFreshInstanceName___boxed(lean_object*); lean_object* l___private_Lean_Elab_Term_11__elabUsingElabFnsAux___main___closed__2; @@ -838,6 +856,7 @@ lean_object* l_Lean_mkConst(lean_object*, lean_object*); extern lean_object* l_Lean_MessageData_Inhabited___closed__1; lean_object* l_Lean_Elab_Term_registerSyntheticMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withReducible___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_instantiateLevelMVars(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_ensureHasTypeAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_tryLiftAndCoe___closed__5; lean_object* l_Lean_Elab_Term_tryPostponeIfNoneOrMVar___boxed(lean_object*, lean_object*, lean_object*); @@ -1359,6 +1378,27 @@ lean_dec(x_1); return x_3; } } +lean_object* l_Lean_Elab_Term_getLevelNames(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; +x_3 = lean_ctor_get(x_1, 6); +lean_inc(x_3); +x_4 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_4, 0, x_3); +lean_ctor_set(x_4, 1, x_2); +return x_4; +} +} +lean_object* l_Lean_Elab_Term_getLevelNames___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Elab_Term_getLevelNames(x_1, x_2); +lean_dec(x_1); +return x_3; +} +} lean_object* l_Lean_Elab_Term_setEnv(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -3453,6 +3493,136 @@ lean_dec(x_3); return x_5; } } +lean_object* l_Lean_Elab_Term_assignLevelMVar(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_4, 0); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_8 = lean_ctor_get(x_6, 1); +x_9 = lean_metavar_ctx_assign_level(x_8, x_1, x_2); +lean_ctor_set(x_6, 1, x_9); +x_10 = lean_box(0); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_4); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_12 = lean_ctor_get(x_6, 0); +x_13 = lean_ctor_get(x_6, 1); +x_14 = lean_ctor_get(x_6, 2); +x_15 = lean_ctor_get(x_6, 3); +x_16 = lean_ctor_get(x_6, 4); +x_17 = lean_ctor_get(x_6, 5); +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_dec(x_6); +x_18 = lean_metavar_ctx_assign_level(x_13, x_1, x_2); +x_19 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_19, 0, x_12); +lean_ctor_set(x_19, 1, x_18); +lean_ctor_set(x_19, 2, x_14); +lean_ctor_set(x_19, 3, x_15); +lean_ctor_set(x_19, 4, x_16); +lean_ctor_set(x_19, 5, x_17); +lean_ctor_set(x_4, 0, x_19); +x_20 = lean_box(0); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_20); +lean_ctor_set(x_21, 1, x_4); +return x_21; +} +} +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; 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_22 = lean_ctor_get(x_4, 0); +x_23 = lean_ctor_get(x_4, 1); +x_24 = lean_ctor_get(x_4, 2); +x_25 = lean_ctor_get(x_4, 3); +x_26 = lean_ctor_get(x_4, 4); +x_27 = lean_ctor_get(x_4, 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_4); +x_28 = lean_ctor_get(x_22, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_22, 1); +lean_inc(x_29); +x_30 = lean_ctor_get(x_22, 2); +lean_inc(x_30); +x_31 = lean_ctor_get(x_22, 3); +lean_inc(x_31); +x_32 = lean_ctor_get(x_22, 4); +lean_inc(x_32); +x_33 = lean_ctor_get(x_22, 5); +lean_inc(x_33); +if (lean_is_exclusive(x_22)) { + lean_ctor_release(x_22, 0); + lean_ctor_release(x_22, 1); + lean_ctor_release(x_22, 2); + lean_ctor_release(x_22, 3); + lean_ctor_release(x_22, 4); + lean_ctor_release(x_22, 5); + x_34 = x_22; +} else { + lean_dec_ref(x_22); + x_34 = lean_box(0); +} +x_35 = lean_metavar_ctx_assign_level(x_29, x_1, x_2); +if (lean_is_scalar(x_34)) { + x_36 = lean_alloc_ctor(0, 6, 0); +} else { + x_36 = x_34; +} +lean_ctor_set(x_36, 0, x_28); +lean_ctor_set(x_36, 1, x_35); +lean_ctor_set(x_36, 2, x_30); +lean_ctor_set(x_36, 3, x_31); +lean_ctor_set(x_36, 4, x_32); +lean_ctor_set(x_36, 5, x_33); +x_37 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_23); +lean_ctor_set(x_37, 2, x_24); +lean_ctor_set(x_37, 3, x_25); +lean_ctor_set(x_37, 4, x_26); +lean_ctor_set(x_37, 5, x_27); +x_38 = lean_box(0); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_37); +return x_39; +} +} +} +lean_object* l_Lean_Elab_Term_assignLevelMVar___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Elab_Term_assignLevelMVar(x_1, x_2, x_3, x_4); +lean_dec(x_3); +return x_5; +} +} lean_object* l_Lean_Elab_logAt___at_Lean_Elab_Term_logTrace___spec__2(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { @@ -3723,7 +3893,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l___private_Lean_Elab_Util_4__regTraceClasses___closed__1; -x_2 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3; +x_2 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } @@ -4918,6 +5088,174 @@ lean_dec(x_1); return x_5; } } +lean_object* l_Lean_Elab_Term_isTypeFormerType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_7 = lean_ctor_get(x_5, 4); +x_8 = lean_ctor_get(x_3, 0); +lean_inc(x_8); +x_9 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_5, 4, x_9); +x_10 = l_Lean_Meta_isTypeFormerType___main(x_2, x_8, x_5); +if (lean_obj_tag(x_10) == 0) +{ +uint8_t x_11; +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_10, 1); +x_13 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_12, x_7); +lean_ctor_set(x_10, 1, x_13); +return x_10; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_14 = lean_ctor_get(x_10, 0); +x_15 = lean_ctor_get(x_10, 1); +lean_inc(x_15); +lean_inc(x_14); +lean_dec(x_10); +x_16 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_15, x_7); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_14); +lean_ctor_set(x_17, 1, x_16); +return x_17; +} +} +else +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_10); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_10, 0); +x_20 = lean_ctor_get(x_10, 1); +lean_inc(x_3); +x_21 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_19); +x_22 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_20, x_7); +lean_ctor_set(x_10, 1, x_22); +lean_ctor_set(x_10, 0, x_21); +return x_10; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_23 = lean_ctor_get(x_10, 0); +x_24 = lean_ctor_get(x_10, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_10); +lean_inc(x_3); +x_25 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_23); +x_26 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_24, x_7); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_28 = lean_ctor_get(x_5, 0); +x_29 = lean_ctor_get(x_5, 1); +x_30 = lean_ctor_get(x_5, 2); +x_31 = lean_ctor_get(x_5, 3); +x_32 = lean_ctor_get(x_5, 4); +x_33 = lean_ctor_get(x_5, 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_5); +x_34 = lean_ctor_get(x_3, 0); +lean_inc(x_34); +x_35 = l_Lean_TraceState_Inhabited___closed__1; +x_36 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_36, 0, x_28); +lean_ctor_set(x_36, 1, x_29); +lean_ctor_set(x_36, 2, x_30); +lean_ctor_set(x_36, 3, x_31); +lean_ctor_set(x_36, 4, x_35); +lean_ctor_set(x_36, 5, x_33); +x_37 = l_Lean_Meta_isTypeFormerType___main(x_2, x_34, x_36); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_37, 1); +lean_inc(x_39); +if (lean_is_exclusive(x_37)) { + lean_ctor_release(x_37, 0); + lean_ctor_release(x_37, 1); + x_40 = x_37; +} else { + lean_dec_ref(x_37); + x_40 = lean_box(0); +} +x_41 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_39, x_32); +if (lean_is_scalar(x_40)) { + x_42 = lean_alloc_ctor(0, 2, 0); +} else { + x_42 = x_40; +} +lean_ctor_set(x_42, 0, x_38); +lean_ctor_set(x_42, 1, x_41); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_37, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_37, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_37)) { + lean_ctor_release(x_37, 0); + lean_ctor_release(x_37, 1); + x_45 = x_37; +} else { + lean_dec_ref(x_37); + x_45 = lean_box(0); +} +lean_inc(x_3); +x_46 = l___private_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_43); +x_47 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_44, x_32); +if (lean_is_scalar(x_45)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_45; +} +lean_ctor_set(x_48, 0, x_46); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +} +} +lean_object* l_Lean_Elab_Term_isTypeFormerType___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Elab_Term_isTypeFormerType(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} lean_object* l_Lean_Elab_Term_isDefEqNoConstantApprox(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { @@ -5750,6 +6088,176 @@ lean_dec(x_1); return x_6; } } +lean_object* l_Lean_Elab_Term_isLevelDefEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_8 = lean_ctor_get(x_6, 4); +x_9 = lean_ctor_get(x_4, 0); +lean_inc(x_9); +x_10 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_6, 4, x_10); +x_11 = l_Lean_Meta_isLevelDefEq(x_2, x_3, x_9, x_6); +lean_dec(x_9); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_11, 1); +x_14 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_13, x_8); +lean_ctor_set(x_11, 1, x_14); +return x_11; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_15 = lean_ctor_get(x_11, 0); +x_16 = lean_ctor_get(x_11, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_11); +x_17 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_16, x_8); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_15); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +else +{ +uint8_t x_19; +x_19 = !lean_is_exclusive(x_11); +if (x_19 == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_11, 0); +x_21 = lean_ctor_get(x_11, 1); +lean_inc(x_4); +x_22 = l___private_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_20); +x_23 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_21, x_8); +lean_ctor_set(x_11, 1, x_23); +lean_ctor_set(x_11, 0, x_22); +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +lean_inc(x_4); +x_26 = l___private_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_24); +x_27 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_25, x_8); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_29 = lean_ctor_get(x_6, 0); +x_30 = lean_ctor_get(x_6, 1); +x_31 = lean_ctor_get(x_6, 2); +x_32 = lean_ctor_get(x_6, 3); +x_33 = lean_ctor_get(x_6, 4); +x_34 = lean_ctor_get(x_6, 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_6); +x_35 = lean_ctor_get(x_4, 0); +lean_inc(x_35); +x_36 = l_Lean_TraceState_Inhabited___closed__1; +x_37 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_37, 0, x_29); +lean_ctor_set(x_37, 1, x_30); +lean_ctor_set(x_37, 2, x_31); +lean_ctor_set(x_37, 3, x_32); +lean_ctor_set(x_37, 4, x_36); +lean_ctor_set(x_37, 5, x_34); +x_38 = l_Lean_Meta_isLevelDefEq(x_2, x_3, x_35, x_37); +lean_dec(x_35); +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +if (lean_is_exclusive(x_38)) { + lean_ctor_release(x_38, 0); + lean_ctor_release(x_38, 1); + x_41 = x_38; +} else { + lean_dec_ref(x_38); + x_41 = lean_box(0); +} +x_42 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_40, x_33); +if (lean_is_scalar(x_41)) { + x_43 = lean_alloc_ctor(0, 2, 0); +} else { + x_43 = x_41; +} +lean_ctor_set(x_43, 0, x_39); +lean_ctor_set(x_43, 1, x_42); +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_49; +x_44 = lean_ctor_get(x_38, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_38, 1); +lean_inc(x_45); +if (lean_is_exclusive(x_38)) { + lean_ctor_release(x_38, 0); + lean_ctor_release(x_38, 1); + x_46 = x_38; +} else { + lean_dec_ref(x_38); + x_46 = lean_box(0); +} +lean_inc(x_4); +x_47 = l___private_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_44); +x_48 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_4, x_5, x_45, x_33); +if (lean_is_scalar(x_46)) { + x_49 = lean_alloc_ctor(1, 2, 0); +} else { + x_49 = x_46; +} +lean_ctor_set(x_49, 0, x_47); +lean_ctor_set(x_49, 1, x_48); +return x_49; +} +} +} +} +lean_object* l_Lean_Elab_Term_isLevelDefEq___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Elab_Term_isLevelDefEq(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} lean_object* l_Lean_Elab_Term_inferType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -6692,6 +7200,108 @@ lean_dec(x_1); return x_5; } } +lean_object* l_Lean_Elab_Term_instantiateLevelMVars(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = lean_ctor_get(x_5, 4); +x_8 = lean_ctor_get(x_3, 0); +lean_inc(x_8); +x_9 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_5, 4, x_9); +x_10 = l_Lean_Meta_instantiateLevelMVars(x_2, x_8, x_5); +lean_dec(x_8); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_10, 1); +x_13 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_12, x_7); +lean_ctor_set(x_10, 1, x_13); +return x_10; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_14 = lean_ctor_get(x_10, 0); +x_15 = lean_ctor_get(x_10, 1); +lean_inc(x_15); +lean_inc(x_14); +lean_dec(x_10); +x_16 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_15, x_7); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_14); +lean_ctor_set(x_17, 1, x_16); +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; +x_18 = lean_ctor_get(x_5, 0); +x_19 = lean_ctor_get(x_5, 1); +x_20 = lean_ctor_get(x_5, 2); +x_21 = lean_ctor_get(x_5, 3); +x_22 = lean_ctor_get(x_5, 4); +x_23 = lean_ctor_get(x_5, 5); +lean_inc(x_23); +lean_inc(x_22); +lean_inc(x_21); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_5); +x_24 = lean_ctor_get(x_3, 0); +lean_inc(x_24); +x_25 = l_Lean_TraceState_Inhabited___closed__1; +x_26 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_26, 0, x_18); +lean_ctor_set(x_26, 1, x_19); +lean_ctor_set(x_26, 2, x_20); +lean_ctor_set(x_26, 3, x_21); +lean_ctor_set(x_26, 4, x_25); +lean_ctor_set(x_26, 5, x_23); +x_27 = l_Lean_Meta_instantiateLevelMVars(x_2, x_24, x_26); +lean_dec(x_24); +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +if (lean_is_exclusive(x_27)) { + lean_ctor_release(x_27, 0); + lean_ctor_release(x_27, 1); + x_30 = x_27; +} else { + lean_dec_ref(x_27); + x_30 = lean_box(0); +} +x_31 = l___private_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_4, x_29, x_22); +if (lean_is_scalar(x_30)) { + x_32 = lean_alloc_ctor(0, 2, 0); +} else { + x_32 = x_30; +} +lean_ctor_set(x_32, 0, x_28); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +lean_object* l_Lean_Elab_Term_instantiateLevelMVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Elab_Term_instantiateLevelMVars(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} lean_object* l_Lean_Elab_Term_isClass(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -8876,390 +9486,305 @@ return x_5; lean_object* l_Lean_Elab_Term_savingMCtx___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_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_67; x_4 = l_Lean_Elab_Term_getMCtx___rarg(x_3); x_5 = lean_ctor_get(x_4, 0); lean_inc(x_5); x_6 = lean_ctor_get(x_4, 1); lean_inc(x_6); -lean_dec(x_4); -x_7 = lean_apply_2(x_1, x_2, x_6); -if (lean_obj_tag(x_7) == 0) +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_67 = lean_apply_2(x_1, x_2, x_6); +if (lean_obj_tag(x_67) == 0) { -lean_object* x_8; lean_object* x_9; uint8_t x_10; -x_8 = lean_ctor_get(x_7, 1); -lean_inc(x_8); -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -x_10 = !lean_is_exclusive(x_7); -if (x_10 == 0) -{ -lean_object* x_11; uint8_t x_12; -x_11 = lean_ctor_get(x_7, 1); -lean_dec(x_11); -x_12 = !lean_is_exclusive(x_8); -if (x_12 == 0) -{ -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_8, 0); -lean_dec(x_13); -x_14 = !lean_is_exclusive(x_9); -if (x_14 == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_9, 1); -lean_dec(x_15); -lean_ctor_set(x_9, 1, x_5); -return x_7; +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_67, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_67, 1); +lean_inc(x_69); +lean_dec(x_67); +x_70 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_70, 0, x_68); +x_8 = x_70; +x_9 = x_69; +goto block_66; } else { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_16 = lean_ctor_get(x_9, 0); -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); +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_67, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_67, 1); +lean_inc(x_72); +lean_dec(x_67); +x_73 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_73, 0, x_71); +x_8 = x_73; +x_9 = x_72; +goto block_66; +} +block_66: +{ +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_8, 0); +lean_inc(x_11); +lean_dec(x_8); +x_12 = !lean_is_exclusive(x_9); +if (x_12 == 0) +{ +lean_object* x_13; uint8_t x_14; +x_13 = lean_ctor_get(x_9, 0); +lean_dec(x_13); +x_14 = !lean_is_exclusive(x_10); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_10, 1); +lean_dec(x_15); +lean_ctor_set(x_10, 1, x_5); +if (lean_is_scalar(x_7)) { + x_16 = lean_alloc_ctor(1, 2, 0); +} else { + x_16 = x_7; + lean_ctor_set_tag(x_16, 1); +} +lean_ctor_set(x_16, 0, x_11); +lean_ctor_set(x_16, 1, x_9); +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_22; lean_object* x_23; +x_17 = lean_ctor_get(x_10, 0); +x_18 = lean_ctor_get(x_10, 2); +x_19 = lean_ctor_get(x_10, 3); +x_20 = lean_ctor_get(x_10, 4); +x_21 = lean_ctor_get(x_10, 5); +lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_inc(x_18); lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_9); -x_21 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_21, 0, x_16); -lean_ctor_set(x_21, 1, x_5); -lean_ctor_set(x_21, 2, x_17); -lean_ctor_set(x_21, 3, x_18); -lean_ctor_set(x_21, 4, x_19); -lean_ctor_set(x_21, 5, x_20); -lean_ctor_set(x_8, 0, x_21); -return x_7; +lean_dec(x_10); +x_22 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_22, 0, x_17); +lean_ctor_set(x_22, 1, x_5); +lean_ctor_set(x_22, 2, x_18); +lean_ctor_set(x_22, 3, x_19); +lean_ctor_set(x_22, 4, x_20); +lean_ctor_set(x_22, 5, x_21); +lean_ctor_set(x_9, 0, x_22); +if (lean_is_scalar(x_7)) { + x_23 = lean_alloc_ctor(1, 2, 0); +} else { + x_23 = x_7; + lean_ctor_set_tag(x_23, 1); +} +lean_ctor_set(x_23, 0, x_11); +lean_ctor_set(x_23, 1, x_9); +return x_23; } } 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; lean_object* x_34; -x_22 = lean_ctor_get(x_8, 1); -x_23 = lean_ctor_get(x_8, 2); -x_24 = lean_ctor_get(x_8, 3); -x_25 = lean_ctor_get(x_8, 4); -x_26 = lean_ctor_get(x_8, 5); +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; +x_24 = lean_ctor_get(x_9, 1); +x_25 = lean_ctor_get(x_9, 2); +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_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_dec(x_8); -x_27 = lean_ctor_get(x_9, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_9, 2); -lean_inc(x_28); -x_29 = lean_ctor_get(x_9, 3); +lean_dec(x_9); +x_29 = lean_ctor_get(x_10, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_9, 4); +x_30 = lean_ctor_get(x_10, 2); lean_inc(x_30); -x_31 = lean_ctor_get(x_9, 5); +x_31 = lean_ctor_get(x_10, 3); lean_inc(x_31); -if (lean_is_exclusive(x_9)) { - lean_ctor_release(x_9, 0); - lean_ctor_release(x_9, 1); - lean_ctor_release(x_9, 2); - lean_ctor_release(x_9, 3); - lean_ctor_release(x_9, 4); - lean_ctor_release(x_9, 5); - x_32 = x_9; +x_32 = lean_ctor_get(x_10, 4); +lean_inc(x_32); +x_33 = lean_ctor_get(x_10, 5); +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); + lean_ctor_release(x_10, 4); + lean_ctor_release(x_10, 5); + x_34 = x_10; } else { - lean_dec_ref(x_9); - x_32 = lean_box(0); + lean_dec_ref(x_10); + x_34 = lean_box(0); } -if (lean_is_scalar(x_32)) { - x_33 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 6, 0); } else { - x_33 = x_32; + x_35 = x_34; } -lean_ctor_set(x_33, 0, x_27); -lean_ctor_set(x_33, 1, x_5); -lean_ctor_set(x_33, 2, x_28); -lean_ctor_set(x_33, 3, x_29); -lean_ctor_set(x_33, 4, x_30); -lean_ctor_set(x_33, 5, x_31); -x_34 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_22); -lean_ctor_set(x_34, 2, x_23); -lean_ctor_set(x_34, 3, x_24); -lean_ctor_set(x_34, 4, x_25); -lean_ctor_set(x_34, 5, x_26); -lean_ctor_set(x_7, 1, x_34); -return x_7; +lean_ctor_set(x_35, 0, x_29); +lean_ctor_set(x_35, 1, x_5); +lean_ctor_set(x_35, 2, x_30); +lean_ctor_set(x_35, 3, x_31); +lean_ctor_set(x_35, 4, x_32); +lean_ctor_set(x_35, 5, x_33); +x_36 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_24); +lean_ctor_set(x_36, 2, x_25); +lean_ctor_set(x_36, 3, x_26); +lean_ctor_set(x_36, 4, x_27); +lean_ctor_set(x_36, 5, x_28); +if (lean_is_scalar(x_7)) { + x_37 = lean_alloc_ctor(1, 2, 0); +} else { + x_37 = x_7; + lean_ctor_set_tag(x_37, 1); +} +lean_ctor_set(x_37, 0, x_11); +lean_ctor_set(x_37, 1, x_36); +return x_37; } } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_35 = lean_ctor_get(x_7, 0); -lean_inc(x_35); -lean_dec(x_7); -x_36 = lean_ctor_get(x_8, 1); -lean_inc(x_36); -x_37 = lean_ctor_get(x_8, 2); -lean_inc(x_37); -x_38 = lean_ctor_get(x_8, 3); +lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_38 = lean_ctor_get(x_9, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_8, 4); +x_39 = lean_ctor_get(x_8, 0); lean_inc(x_39); -x_40 = lean_ctor_get(x_8, 5); -lean_inc(x_40); -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); - lean_ctor_release(x_8, 5); - x_41 = x_8; +lean_dec(x_8); +x_40 = !lean_is_exclusive(x_9); +if (x_40 == 0) +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_9, 0); +lean_dec(x_41); +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, 1); +lean_dec(x_43); +lean_ctor_set(x_38, 1, x_5); +if (lean_is_scalar(x_7)) { + x_44 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_8); - x_41 = lean_box(0); + x_44 = x_7; } -x_42 = lean_ctor_get(x_9, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_9, 2); -lean_inc(x_43); -x_44 = lean_ctor_get(x_9, 3); -lean_inc(x_44); -x_45 = lean_ctor_get(x_9, 4); -lean_inc(x_45); -x_46 = lean_ctor_get(x_9, 5); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_9); +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; +x_45 = lean_ctor_get(x_38, 0); +x_46 = lean_ctor_get(x_38, 2); +x_47 = lean_ctor_get(x_38, 3); +x_48 = lean_ctor_get(x_38, 4); +x_49 = lean_ctor_get(x_38, 5); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); lean_inc(x_46); -if (lean_is_exclusive(x_9)) { - lean_ctor_release(x_9, 0); - lean_ctor_release(x_9, 1); - lean_ctor_release(x_9, 2); - lean_ctor_release(x_9, 3); - lean_ctor_release(x_9, 4); - lean_ctor_release(x_9, 5); - x_47 = x_9; +lean_inc(x_45); +lean_dec(x_38); +x_50 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_5); +lean_ctor_set(x_50, 2, x_46); +lean_ctor_set(x_50, 3, x_47); +lean_ctor_set(x_50, 4, x_48); +lean_ctor_set(x_50, 5, x_49); +lean_ctor_set(x_9, 0, x_50); +if (lean_is_scalar(x_7)) { + x_51 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_9); - x_47 = lean_box(0); + x_51 = x_7; } -if (lean_is_scalar(x_47)) { - x_48 = lean_alloc_ctor(0, 6, 0); -} else { - x_48 = x_47; -} -lean_ctor_set(x_48, 0, x_42); -lean_ctor_set(x_48, 1, x_5); -lean_ctor_set(x_48, 2, x_43); -lean_ctor_set(x_48, 3, x_44); -lean_ctor_set(x_48, 4, x_45); -lean_ctor_set(x_48, 5, x_46); -if (lean_is_scalar(x_41)) { - x_49 = lean_alloc_ctor(0, 6, 0); -} else { - x_49 = x_41; -} -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_36); -lean_ctor_set(x_49, 2, x_37); -lean_ctor_set(x_49, 3, x_38); -lean_ctor_set(x_49, 4, x_39); -lean_ctor_set(x_49, 5, x_40); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_35); -lean_ctor_set(x_50, 1, x_49); -return x_50; +lean_ctor_set(x_51, 0, x_39); +lean_ctor_set(x_51, 1, x_9); +return x_51; } } else { -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_7, 1); -lean_inc(x_51); -x_52 = lean_ctor_get(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; lean_object* x_65; +x_52 = lean_ctor_get(x_9, 1); +x_53 = lean_ctor_get(x_9, 2); +x_54 = lean_ctor_get(x_9, 3); +x_55 = lean_ctor_get(x_9, 4); +x_56 = lean_ctor_get(x_9, 5); +lean_inc(x_56); +lean_inc(x_55); +lean_inc(x_54); +lean_inc(x_53); lean_inc(x_52); -x_53 = !lean_is_exclusive(x_7); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_7, 1); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_51); -if (x_55 == 0) -{ -lean_object* x_56; uint8_t x_57; -x_56 = lean_ctor_get(x_51, 0); -lean_dec(x_56); -x_57 = !lean_is_exclusive(x_52); -if (x_57 == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_52, 1); -lean_dec(x_58); -lean_ctor_set(x_52, 1, x_5); -return x_7; -} -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; -x_59 = lean_ctor_get(x_52, 0); -x_60 = lean_ctor_get(x_52, 2); -x_61 = lean_ctor_get(x_52, 3); -x_62 = lean_ctor_get(x_52, 4); -x_63 = lean_ctor_get(x_52, 5); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); +lean_dec(x_9); +x_57 = lean_ctor_get(x_38, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_38, 2); +lean_inc(x_58); +x_59 = lean_ctor_get(x_38, 3); lean_inc(x_59); -lean_dec(x_52); +x_60 = lean_ctor_get(x_38, 4); +lean_inc(x_60); +x_61 = lean_ctor_get(x_38, 5); +lean_inc(x_61); +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); + lean_ctor_release(x_38, 5); + x_62 = x_38; +} else { + lean_dec_ref(x_38); + x_62 = lean_box(0); +} +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 6, 0); +} else { + x_63 = x_62; +} +lean_ctor_set(x_63, 0, x_57); +lean_ctor_set(x_63, 1, x_5); +lean_ctor_set(x_63, 2, x_58); +lean_ctor_set(x_63, 3, x_59); +lean_ctor_set(x_63, 4, x_60); +lean_ctor_set(x_63, 5, x_61); x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_59); -lean_ctor_set(x_64, 1, x_5); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_63); -lean_ctor_set(x_51, 0, x_64); -return x_7; -} -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_65 = lean_ctor_get(x_51, 1); -x_66 = lean_ctor_get(x_51, 2); -x_67 = lean_ctor_get(x_51, 3); -x_68 = lean_ctor_get(x_51, 4); -x_69 = lean_ctor_get(x_51, 5); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_51); -x_70 = lean_ctor_get(x_52, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_52, 2); -lean_inc(x_71); -x_72 = lean_ctor_get(x_52, 3); -lean_inc(x_72); -x_73 = lean_ctor_get(x_52, 4); -lean_inc(x_73); -x_74 = lean_ctor_get(x_52, 5); -lean_inc(x_74); -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); - x_75 = x_52; +lean_ctor_set(x_64, 0, x_63); +lean_ctor_set(x_64, 1, x_52); +lean_ctor_set(x_64, 2, x_53); +lean_ctor_set(x_64, 3, x_54); +lean_ctor_set(x_64, 4, x_55); +lean_ctor_set(x_64, 5, x_56); +if (lean_is_scalar(x_7)) { + x_65 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_52); - x_75 = lean_box(0); + x_65 = x_7; } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 6, 0); -} else { - x_76 = x_75; +lean_ctor_set(x_65, 0, x_39); +lean_ctor_set(x_65, 1, x_64); +return x_65; } -lean_ctor_set(x_76, 0, x_70); -lean_ctor_set(x_76, 1, x_5); -lean_ctor_set(x_76, 2, x_71); -lean_ctor_set(x_76, 3, x_72); -lean_ctor_set(x_76, 4, x_73); -lean_ctor_set(x_76, 5, x_74); -x_77 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_65); -lean_ctor_set(x_77, 2, x_66); -lean_ctor_set(x_77, 3, x_67); -lean_ctor_set(x_77, 4, x_68); -lean_ctor_set(x_77, 5, x_69); -lean_ctor_set(x_7, 1, x_77); -return x_7; -} -} -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; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_78 = lean_ctor_get(x_7, 0); -lean_inc(x_78); -lean_dec(x_7); -x_79 = lean_ctor_get(x_51, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_51, 2); -lean_inc(x_80); -x_81 = lean_ctor_get(x_51, 3); -lean_inc(x_81); -x_82 = lean_ctor_get(x_51, 4); -lean_inc(x_82); -x_83 = lean_ctor_get(x_51, 5); -lean_inc(x_83); -if (lean_is_exclusive(x_51)) { - lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - lean_ctor_release(x_51, 2); - lean_ctor_release(x_51, 3); - lean_ctor_release(x_51, 4); - lean_ctor_release(x_51, 5); - x_84 = x_51; -} else { - lean_dec_ref(x_51); - x_84 = lean_box(0); -} -x_85 = lean_ctor_get(x_52, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_52, 2); -lean_inc(x_86); -x_87 = lean_ctor_get(x_52, 3); -lean_inc(x_87); -x_88 = lean_ctor_get(x_52, 4); -lean_inc(x_88); -x_89 = lean_ctor_get(x_52, 5); -lean_inc(x_89); -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); - x_90 = x_52; -} else { - lean_dec_ref(x_52); - x_90 = lean_box(0); -} -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 6, 0); -} else { - x_91 = x_90; -} -lean_ctor_set(x_91, 0, x_85); -lean_ctor_set(x_91, 1, x_5); -lean_ctor_set(x_91, 2, x_86); -lean_ctor_set(x_91, 3, x_87); -lean_ctor_set(x_91, 4, x_88); -lean_ctor_set(x_91, 5, x_89); -if (lean_is_scalar(x_84)) { - x_92 = lean_alloc_ctor(0, 6, 0); -} else { - x_92 = x_84; -} -lean_ctor_set(x_92, 0, x_91); -lean_ctor_set(x_92, 1, x_79); -lean_ctor_set(x_92, 2, x_80); -lean_ctor_set(x_92, 3, x_81); -lean_ctor_set(x_92, 4, x_82); -lean_ctor_set(x_92, 5, x_83); -x_93 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_93, 0, x_78); -lean_ctor_set(x_93, 1, x_92); -return x_93; } } } @@ -10485,226 +11010,233 @@ x_4 = l_List_elem___main___at_Lean_NameHashSet_insert___spec__2(x_2, x_3); return x_4; } } -lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Elab_Term_levelMVarToParam(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_4; uint8_t x_5; -x_4 = l_Lean_Elab_Term_getMCtx___rarg(x_3); -x_5 = !lean_is_exclusive(x_4); -if (x_5 == 0) +lean_object* x_5; uint8_t x_6; +x_5 = l_Lean_Elab_Term_getMCtx___rarg(x_4); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_6 = lean_ctor_get(x_4, 0); -x_7 = lean_ctor_get(x_4, 1); -x_8 = lean_alloc_closure((void*)(l_Lean_Elab_Term_levelMVarToParam___lambda__1___boxed), 2, 1); -lean_closure_set(x_8, 0, x_2); -x_9 = l_Lean_Closure_mkNewLevelParam___closed__2; -x_10 = lean_unsigned_to_nat(1u); -x_11 = l_Lean_MetavarContext_levelMVarToParam(x_6, x_8, x_1, x_9, x_10); -x_12 = lean_ctor_get(x_7, 0); +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +x_7 = lean_ctor_get(x_5, 0); +x_8 = lean_ctor_get(x_5, 1); +x_9 = lean_alloc_closure((void*)(l_Lean_Elab_Term_levelMVarToParam___lambda__1___boxed), 2, 1); +lean_closure_set(x_9, 0, x_3); +x_10 = l_Lean_Closure_mkNewLevelParam___closed__2; +x_11 = l_Lean_MetavarContext_levelMVarToParam(x_7, x_9, x_1, x_10, x_2); +x_12 = lean_ctor_get(x_11, 3); lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 3); +x_13 = lean_ctor_get(x_11, 2); lean_inc(x_13); -x_14 = !lean_is_exclusive(x_7); -if (x_14 == 0) +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_12); +lean_ctor_set(x_14, 1, x_13); +x_15 = !lean_is_exclusive(x_8); +if (x_15 == 0) { -lean_object* x_15; uint8_t x_16; -x_15 = lean_ctor_get(x_7, 0); -lean_dec(x_15); -x_16 = !lean_is_exclusive(x_12); -if (x_16 == 0) +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_8, 0); +x_17 = !lean_is_exclusive(x_16); +if (x_17 == 0) { -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_12, 1); -lean_dec(x_17); -x_18 = lean_ctor_get(x_11, 0); -lean_inc(x_18); +lean_object* x_18; lean_object* x_19; +x_18 = lean_ctor_get(x_16, 1); +lean_dec(x_18); +x_19 = lean_ctor_get(x_11, 0); +lean_inc(x_19); lean_dec(x_11); -lean_ctor_set(x_12, 1, x_18); -lean_ctor_set(x_4, 0, x_13); -return x_4; +lean_ctor_set(x_16, 1, x_19); +lean_ctor_set(x_5, 0, x_14); +return x_5; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_19 = lean_ctor_get(x_12, 0); -x_20 = lean_ctor_get(x_12, 2); -x_21 = lean_ctor_get(x_12, 3); -x_22 = lean_ctor_get(x_12, 4); -x_23 = lean_ctor_get(x_12, 5); +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_20 = lean_ctor_get(x_16, 0); +x_21 = lean_ctor_get(x_16, 2); +x_22 = lean_ctor_get(x_16, 3); +x_23 = lean_ctor_get(x_16, 4); +x_24 = lean_ctor_get(x_16, 5); +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_12); -x_24 = lean_ctor_get(x_11, 0); -lean_inc(x_24); +lean_dec(x_16); +x_25 = lean_ctor_get(x_11, 0); +lean_inc(x_25); lean_dec(x_11); -x_25 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_25, 0, x_19); -lean_ctor_set(x_25, 1, x_24); -lean_ctor_set(x_25, 2, x_20); -lean_ctor_set(x_25, 3, x_21); -lean_ctor_set(x_25, 4, x_22); -lean_ctor_set(x_25, 5, x_23); -lean_ctor_set(x_7, 0, x_25); -lean_ctor_set(x_4, 0, x_13); -return x_4; +x_26 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_26, 0, x_20); +lean_ctor_set(x_26, 1, x_25); +lean_ctor_set(x_26, 2, x_21); +lean_ctor_set(x_26, 3, x_22); +lean_ctor_set(x_26, 4, x_23); +lean_ctor_set(x_26, 5, x_24); +lean_ctor_set(x_8, 0, x_26); +lean_ctor_set(x_5, 0, x_14); +return x_5; } } 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; -x_26 = lean_ctor_get(x_7, 1); -x_27 = lean_ctor_get(x_7, 2); -x_28 = lean_ctor_get(x_7, 3); -x_29 = lean_ctor_get(x_7, 4); -x_30 = lean_ctor_get(x_7, 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; lean_object* x_40; lean_object* x_41; +x_27 = lean_ctor_get(x_8, 0); +x_28 = lean_ctor_get(x_8, 1); +x_29 = lean_ctor_get(x_8, 2); +x_30 = lean_ctor_get(x_8, 3); +x_31 = lean_ctor_get(x_8, 4); +x_32 = lean_ctor_get(x_8, 5); +lean_inc(x_32); +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_7); -x_31 = lean_ctor_get(x_12, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_12, 2); -lean_inc(x_32); -x_33 = lean_ctor_get(x_12, 3); +lean_dec(x_8); +x_33 = lean_ctor_get(x_27, 0); lean_inc(x_33); -x_34 = lean_ctor_get(x_12, 4); +x_34 = lean_ctor_get(x_27, 2); lean_inc(x_34); -x_35 = lean_ctor_get(x_12, 5); +x_35 = lean_ctor_get(x_27, 3); 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); - lean_ctor_release(x_12, 4); - lean_ctor_release(x_12, 5); - x_36 = x_12; -} else { - lean_dec_ref(x_12); - x_36 = lean_box(0); -} -x_37 = lean_ctor_get(x_11, 0); +x_36 = lean_ctor_get(x_27, 4); +lean_inc(x_36); +x_37 = lean_ctor_get(x_27, 5); lean_inc(x_37); -lean_dec(x_11); -if (lean_is_scalar(x_36)) { - x_38 = lean_alloc_ctor(0, 6, 0); +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); + x_38 = x_27; } else { - x_38 = x_36; + lean_dec_ref(x_27); + x_38 = lean_box(0); } -lean_ctor_set(x_38, 0, x_31); -lean_ctor_set(x_38, 1, x_37); -lean_ctor_set(x_38, 2, x_32); -lean_ctor_set(x_38, 3, x_33); -lean_ctor_set(x_38, 4, x_34); -lean_ctor_set(x_38, 5, x_35); -x_39 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_39, 0, x_38); -lean_ctor_set(x_39, 1, x_26); -lean_ctor_set(x_39, 2, x_27); -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_4, 1, x_39); -lean_ctor_set(x_4, 0, x_13); -return x_4; +x_39 = lean_ctor_get(x_11, 0); +lean_inc(x_39); +lean_dec(x_11); +if (lean_is_scalar(x_38)) { + x_40 = lean_alloc_ctor(0, 6, 0); +} else { + x_40 = x_38; +} +lean_ctor_set(x_40, 0, x_33); +lean_ctor_set(x_40, 1, x_39); +lean_ctor_set(x_40, 2, x_34); +lean_ctor_set(x_40, 3, x_35); +lean_ctor_set(x_40, 4, x_36); +lean_ctor_set(x_40, 5, x_37); +x_41 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_41, 0, x_40); +lean_ctor_set(x_41, 1, x_28); +lean_ctor_set(x_41, 2, x_29); +lean_ctor_set(x_41, 3, x_30); +lean_ctor_set(x_41, 4, x_31); +lean_ctor_set(x_41, 5, x_32); +lean_ctor_set(x_5, 1, x_41); +lean_ctor_set(x_5, 0, x_14); +return x_5; } } 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; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_40 = lean_ctor_get(x_4, 0); -x_41 = lean_ctor_get(x_4, 1); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_4); -x_42 = lean_alloc_closure((void*)(l_Lean_Elab_Term_levelMVarToParam___lambda__1___boxed), 2, 1); -lean_closure_set(x_42, 0, x_2); -x_43 = l_Lean_Closure_mkNewLevelParam___closed__2; -x_44 = lean_unsigned_to_nat(1u); -x_45 = l_Lean_MetavarContext_levelMVarToParam(x_40, x_42, x_1, x_43, x_44); -x_46 = lean_ctor_get(x_41, 0); -lean_inc(x_46); -x_47 = lean_ctor_get(x_45, 3); +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; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_42 = lean_ctor_get(x_5, 0); +x_43 = lean_ctor_get(x_5, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_5); +x_44 = lean_alloc_closure((void*)(l_Lean_Elab_Term_levelMVarToParam___lambda__1___boxed), 2, 1); +lean_closure_set(x_44, 0, x_3); +x_45 = l_Lean_Closure_mkNewLevelParam___closed__2; +x_46 = l_Lean_MetavarContext_levelMVarToParam(x_42, x_44, x_1, x_45, x_2); +x_47 = lean_ctor_get(x_46, 3); lean_inc(x_47); -x_48 = lean_ctor_get(x_41, 1); +x_48 = lean_ctor_get(x_46, 2); lean_inc(x_48); -x_49 = lean_ctor_get(x_41, 2); -lean_inc(x_49); -x_50 = lean_ctor_get(x_41, 3); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_47); +lean_ctor_set(x_49, 1, x_48); +x_50 = lean_ctor_get(x_43, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_41, 4); +x_51 = lean_ctor_get(x_43, 1); lean_inc(x_51); -x_52 = lean_ctor_get(x_41, 5); +x_52 = lean_ctor_get(x_43, 2); lean_inc(x_52); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_53 = x_41; -} else { - lean_dec_ref(x_41); - x_53 = lean_box(0); -} -x_54 = lean_ctor_get(x_46, 0); +x_53 = lean_ctor_get(x_43, 3); +lean_inc(x_53); +x_54 = lean_ctor_get(x_43, 4); lean_inc(x_54); -x_55 = lean_ctor_get(x_46, 2); +x_55 = lean_ctor_get(x_43, 5); lean_inc(x_55); -x_56 = lean_ctor_get(x_46, 3); -lean_inc(x_56); -x_57 = lean_ctor_get(x_46, 4); +if (lean_is_exclusive(x_43)) { + lean_ctor_release(x_43, 0); + lean_ctor_release(x_43, 1); + lean_ctor_release(x_43, 2); + lean_ctor_release(x_43, 3); + lean_ctor_release(x_43, 4); + lean_ctor_release(x_43, 5); + x_56 = x_43; +} else { + lean_dec_ref(x_43); + x_56 = lean_box(0); +} +x_57 = lean_ctor_get(x_50, 0); lean_inc(x_57); -x_58 = lean_ctor_get(x_46, 5); +x_58 = lean_ctor_get(x_50, 2); lean_inc(x_58); -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); - lean_ctor_release(x_46, 5); - x_59 = x_46; -} else { - lean_dec_ref(x_46); - x_59 = lean_box(0); -} -x_60 = lean_ctor_get(x_45, 0); +x_59 = lean_ctor_get(x_50, 3); +lean_inc(x_59); +x_60 = lean_ctor_get(x_50, 4); lean_inc(x_60); -lean_dec(x_45); -if (lean_is_scalar(x_59)) { - x_61 = lean_alloc_ctor(0, 6, 0); +x_61 = lean_ctor_get(x_50, 5); +lean_inc(x_61); +if (lean_is_exclusive(x_50)) { + lean_ctor_release(x_50, 0); + lean_ctor_release(x_50, 1); + lean_ctor_release(x_50, 2); + lean_ctor_release(x_50, 3); + lean_ctor_release(x_50, 4); + lean_ctor_release(x_50, 5); + x_62 = x_50; } else { - x_61 = x_59; + lean_dec_ref(x_50); + x_62 = lean_box(0); } -lean_ctor_set(x_61, 0, x_54); -lean_ctor_set(x_61, 1, x_60); -lean_ctor_set(x_61, 2, x_55); -lean_ctor_set(x_61, 3, x_56); -lean_ctor_set(x_61, 4, x_57); -lean_ctor_set(x_61, 5, x_58); -if (lean_is_scalar(x_53)) { - x_62 = lean_alloc_ctor(0, 6, 0); +x_63 = lean_ctor_get(x_46, 0); +lean_inc(x_63); +lean_dec(x_46); +if (lean_is_scalar(x_62)) { + x_64 = lean_alloc_ctor(0, 6, 0); } else { - x_62 = x_53; + x_64 = x_62; } -lean_ctor_set(x_62, 0, x_61); -lean_ctor_set(x_62, 1, x_48); -lean_ctor_set(x_62, 2, x_49); -lean_ctor_set(x_62, 3, x_50); -lean_ctor_set(x_62, 4, x_51); -lean_ctor_set(x_62, 5, x_52); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_47); -lean_ctor_set(x_63, 1, x_62); -return x_63; +lean_ctor_set(x_64, 0, x_57); +lean_ctor_set(x_64, 1, x_63); +lean_ctor_set(x_64, 2, x_58); +lean_ctor_set(x_64, 3, x_59); +lean_ctor_set(x_64, 4, x_60); +lean_ctor_set(x_64, 5, x_61); +if (lean_is_scalar(x_56)) { + x_65 = lean_alloc_ctor(0, 6, 0); +} else { + x_65 = x_56; +} +lean_ctor_set(x_65, 0, x_64); +lean_ctor_set(x_65, 1, x_51); +lean_ctor_set(x_65, 2, x_52); +lean_ctor_set(x_65, 3, x_53); +lean_ctor_set(x_65, 4, x_54); +lean_ctor_set(x_65, 5, x_55); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_49); +lean_ctor_set(x_66, 1, x_65); +return x_66; } } } @@ -10719,6 +11251,70 @@ x_4 = lean_box(x_3); return x_4; } } +lean_object* l_Lean_Elab_Term_levelMVarToParam_x27(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = l_Lean_Elab_Term_levelMVarToParam(x_1, x_2, x_3, x_4); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_5, 0); +x_8 = !lean_is_exclusive(x_7); +if (x_8 == 0) +{ +return x_5; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_7, 0); +x_10 = lean_ctor_get(x_7, 1); +lean_inc(x_10); +lean_inc(x_9); +lean_dec(x_7); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_9); +lean_ctor_set(x_11, 1, x_10); +lean_ctor_set(x_5, 0, x_11); +return x_5; +} +} +else +{ +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; +x_12 = lean_ctor_get(x_5, 0); +x_13 = lean_ctor_get(x_5, 1); +lean_inc(x_13); +lean_inc(x_12); +lean_dec(x_5); +x_14 = lean_ctor_get(x_12, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_12, 1); +lean_inc(x_15); +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + x_16 = x_12; +} else { + lean_dec_ref(x_12); + x_16 = lean_box(0); +} +if (lean_is_scalar(x_16)) { + x_17 = lean_alloc_ctor(0, 2, 0); +} else { + x_17 = x_16; +} +lean_ctor_set(x_17, 0, x_14); +lean_ctor_set(x_17, 1, x_15); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_13); +return x_18; +} +} +} lean_object* _init_l_Lean_Elab_Term_mkFreshAnonymousName___rarg___closed__1() { _start: { @@ -21591,7 +22187,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_9; +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; x_4 = lean_ctor_get(x_3, 0); lean_inc(x_4); x_5 = lean_ctor_get(x_4, 2); @@ -21600,166 +22196,200 @@ lean_dec(x_4); x_6 = lean_ctor_get(x_5, 2); lean_inc(x_6); lean_dec(x_5); -x_7 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_3); -x_8 = lean_ctor_get(x_7, 1); -lean_inc(x_8); -lean_dec(x_7); -x_9 = lean_apply_2(x_1, x_2, x_8); -if (lean_obj_tag(x_9) == 0) +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) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; -x_10 = lean_ctor_get(x_9, 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); +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; +} +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; +} +block_101: +{ +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_9, 2); lean_inc(x_10); -x_11 = lean_ctor_get(x_10, 0); +x_11 = lean_ctor_get(x_7, 0); lean_inc(x_11); -x_12 = lean_ctor_get(x_11, 2); -lean_inc(x_12); -x_13 = !lean_is_exclusive(x_9); -if (x_13 == 0) +lean_dec(x_7); +x_12 = !lean_is_exclusive(x_8); +if (x_12 == 0) { -lean_object* x_14; uint8_t x_15; -x_14 = lean_ctor_get(x_9, 1); -lean_dec(x_14); -x_15 = !lean_is_exclusive(x_10); -if (x_15 == 0) +lean_object* x_13; uint8_t x_14; +x_13 = lean_ctor_get(x_8, 0); +lean_dec(x_13); +x_14 = !lean_is_exclusive(x_9); +if (x_14 == 0) { -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_10, 0); -lean_dec(x_16); -x_17 = !lean_is_exclusive(x_11); -if (x_17 == 0) +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_9, 2); +lean_dec(x_15); +x_16 = !lean_is_exclusive(x_10); +if (x_16 == 0) { -lean_object* x_18; uint8_t x_19; -x_18 = lean_ctor_get(x_11, 2); -lean_dec(x_18); -x_19 = !lean_is_exclusive(x_12); -if (x_19 == 0) -{ -lean_object* x_20; -x_20 = lean_ctor_get(x_12, 2); -lean_dec(x_20); -lean_ctor_set(x_12, 2, x_6); -return x_9; +lean_object* x_17; lean_object* x_18; +x_17 = lean_ctor_get(x_10, 2); +lean_dec(x_17); +lean_ctor_set(x_10, 2, x_6); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_11); +lean_ctor_set(x_18, 1, x_8); +return x_18; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_12, 0); -x_22 = lean_ctor_get(x_12, 1); -x_23 = lean_ctor_get(x_12, 3); -lean_inc(x_23); -lean_inc(x_22); +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_10, 0); +x_20 = lean_ctor_get(x_10, 1); +x_21 = lean_ctor_get(x_10, 3); 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_6); -lean_ctor_set(x_24, 3, x_23); -lean_ctor_set(x_11, 2, x_24); -return x_9; +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; } } 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; -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_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_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_dec(x_11); -x_30 = lean_ctor_get(x_12, 0); +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); lean_inc(x_30); -x_31 = lean_ctor_get(x_12, 1); +x_31 = lean_ctor_get(x_10, 3); lean_inc(x_31); -x_32 = lean_ctor_get(x_12, 3); -lean_inc(x_32); -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_33 = x_12; +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; } else { - lean_dec_ref(x_12); - x_33 = lean_box(0); + lean_dec_ref(x_10); + x_32 = lean_box(0); } -if (lean_is_scalar(x_33)) { - x_34 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_32)) { + x_33 = lean_alloc_ctor(0, 4, 0); } else { - x_34 = x_33; + x_33 = x_32; } -lean_ctor_set(x_34, 0, x_30); -lean_ctor_set(x_34, 1, x_31); -lean_ctor_set(x_34, 2, x_6); -lean_ctor_set(x_34, 3, x_32); -x_35 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_35, 0, x_25); -lean_ctor_set(x_35, 1, x_26); -lean_ctor_set(x_35, 2, x_34); -lean_ctor_set(x_35, 3, x_27); -lean_ctor_set(x_35, 4, x_28); -lean_ctor_set(x_35, 5, x_29); -lean_ctor_set(x_10, 0, x_35); -return x_9; +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; } } 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; -x_36 = lean_ctor_get(x_10, 1); -x_37 = lean_ctor_get(x_10, 2); -x_38 = lean_ctor_get(x_10, 3); -x_39 = lean_ctor_get(x_10, 4); -x_40 = lean_ctor_get(x_10, 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; +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_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); -lean_dec(x_10); -x_41 = lean_ctor_get(x_11, 0); +lean_dec(x_8); +x_41 = lean_ctor_get(x_9, 0); lean_inc(x_41); -x_42 = lean_ctor_get(x_11, 1); +x_42 = lean_ctor_get(x_9, 1); lean_inc(x_42); -x_43 = lean_ctor_get(x_11, 3); +x_43 = lean_ctor_get(x_9, 3); lean_inc(x_43); -x_44 = lean_ctor_get(x_11, 4); +x_44 = lean_ctor_get(x_9, 4); lean_inc(x_44); -x_45 = lean_ctor_get(x_11, 5); +x_45 = lean_ctor_get(x_9, 5); lean_inc(x_45); -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); - lean_ctor_release(x_11, 5); - x_46 = x_11; +if (lean_is_exclusive(x_9)) { + lean_ctor_release(x_9, 0); + lean_ctor_release(x_9, 1); + lean_ctor_release(x_9, 2); + lean_ctor_release(x_9, 3); + lean_ctor_release(x_9, 4); + lean_ctor_release(x_9, 5); + x_46 = x_9; } else { - lean_dec_ref(x_11); + lean_dec_ref(x_9); x_46 = lean_box(0); } -x_47 = lean_ctor_get(x_12, 0); +x_47 = lean_ctor_get(x_10, 0); lean_inc(x_47); -x_48 = lean_ctor_get(x_12, 1); +x_48 = lean_ctor_get(x_10, 1); lean_inc(x_48); -x_49 = lean_ctor_get(x_12, 3); +x_49 = lean_ctor_get(x_10, 3); lean_inc(x_49); -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_50 = x_12; +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; } else { - lean_dec_ref(x_12); + lean_dec_ref(x_10); x_50 = lean_box(0); } if (lean_is_scalar(x_50)) { @@ -21789,402 +22419,205 @@ 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); -lean_ctor_set(x_9, 1, x_53); -return x_9; +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; } } 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; 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_54 = lean_ctor_get(x_9, 0); -lean_inc(x_54); -lean_dec(x_9); -x_55 = lean_ctor_get(x_10, 1); +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_10, 2); +x_56 = lean_ctor_get(x_55, 2); lean_inc(x_56); -x_57 = lean_ctor_get(x_10, 3); +x_57 = lean_ctor_get(x_7, 0); lean_inc(x_57); -x_58 = lean_ctor_get(x_10, 4); -lean_inc(x_58); -x_59 = lean_ctor_get(x_10, 5); -lean_inc(x_59); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - lean_ctor_release(x_10, 2); - lean_ctor_release(x_10, 3); - lean_ctor_release(x_10, 4); - lean_ctor_release(x_10, 5); - x_60 = x_10; -} else { - lean_dec_ref(x_10); - x_60 = lean_box(0); +lean_dec(x_7); +x_58 = !lean_is_exclusive(x_8); +if (x_58 == 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_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_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; } -x_61 = lean_ctor_get(x_11, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_11, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_11, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_11, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_11, 5); -lean_inc(x_65); -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); - lean_ctor_release(x_11, 5); - x_66 = x_11; -} else { - lean_dec_ref(x_11); - x_66 = lean_box(0); -} -x_67 = lean_ctor_get(x_12, 0); +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); -x_68 = lean_ctor_get(x_12, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_12, 3); -lean_inc(x_69); -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_70 = x_12; -} else { - lean_dec_ref(x_12); - x_70 = lean_box(0); -} -if (lean_is_scalar(x_70)) { - x_71 = lean_alloc_ctor(0, 4, 0); -} else { - x_71 = x_70; -} -lean_ctor_set(x_71, 0, x_67); -lean_ctor_set(x_71, 1, x_68); -lean_ctor_set(x_71, 2, x_6); -lean_ctor_set(x_71, 3, x_69); -if (lean_is_scalar(x_66)) { - x_72 = lean_alloc_ctor(0, 6, 0); -} else { - x_72 = x_66; -} -lean_ctor_set(x_72, 0, x_61); -lean_ctor_set(x_72, 1, x_62); -lean_ctor_set(x_72, 2, x_71); -lean_ctor_set(x_72, 3, x_63); -lean_ctor_set(x_72, 4, x_64); -lean_ctor_set(x_72, 5, x_65); -if (lean_is_scalar(x_60)) { - x_73 = lean_alloc_ctor(0, 6, 0); -} else { - x_73 = x_60; -} -lean_ctor_set(x_73, 0, x_72); -lean_ctor_set(x_73, 1, x_55); -lean_ctor_set(x_73, 2, x_56); -lean_ctor_set(x_73, 3, x_57); -lean_ctor_set(x_73, 4, x_58); -lean_ctor_set(x_73, 5, x_59); -x_74 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_74, 0, x_54); -lean_ctor_set(x_74, 1, x_73); -return x_74; +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_75; lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_75 = lean_ctor_get(x_9, 1); +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_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_75, 0); +x_76 = lean_ctor_get(x_56, 1); lean_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +x_77 = lean_ctor_get(x_56, 3); lean_inc(x_77); -x_78 = !lean_is_exclusive(x_9); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_9, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_75); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_75, 0); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_76); -if (x_82 == 0) -{ -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_76, 2); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_77); -if (x_84 == 0) -{ -lean_object* x_85; -x_85 = lean_ctor_get(x_77, 2); -lean_dec(x_85); -lean_ctor_set(x_77, 2, x_6); -return x_9; +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; +} } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_86 = lean_ctor_get(x_77, 0); -x_87 = lean_ctor_get(x_77, 1); -x_88 = lean_ctor_get(x_77, 3); -lean_inc(x_88); -lean_inc(x_87); +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_dec(x_77); -x_89 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_89, 0, x_86); -lean_ctor_set(x_89, 1, x_87); -lean_ctor_set(x_89, 2, x_6); -lean_ctor_set(x_89, 3, x_88); -lean_ctor_set(x_76, 2, x_89); -return x_9; -} -} -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_76, 0); -x_91 = lean_ctor_get(x_76, 1); -x_92 = lean_ctor_get(x_76, 3); -x_93 = lean_ctor_get(x_76, 4); -x_94 = lean_ctor_get(x_76, 5); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_inc(x_91); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); +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); -lean_dec(x_76); -x_95 = lean_ctor_get(x_77, 0); +x_91 = lean_ctor_get(x_55, 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_93); +x_94 = lean_ctor_get(x_56, 1); +lean_inc(x_94); +x_95 = lean_ctor_get(x_56, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_77, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_77, 3); -lean_inc(x_97); -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); - x_98 = 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_96 = x_56; } else { - lean_dec_ref(x_77); - x_98 = lean_box(0); + lean_dec_ref(x_56); + x_96 = lean_box(0); } -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); } else { - x_99 = x_98; + x_97 = x_96; } -lean_ctor_set(x_99, 0, x_95); -lean_ctor_set(x_99, 1, x_96); -lean_ctor_set(x_99, 2, x_6); -lean_ctor_set(x_99, 3, x_97); -x_100 = lean_alloc_ctor(0, 6, 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_92); -lean_ctor_set(x_100, 4, x_93); -lean_ctor_set(x_100, 5, x_94); -lean_ctor_set(x_75, 0, x_100); -return x_9; -} -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_101 = lean_ctor_get(x_75, 1); -x_102 = lean_ctor_get(x_75, 2); -x_103 = lean_ctor_get(x_75, 3); -x_104 = lean_ctor_get(x_75, 4); -x_105 = lean_ctor_get(x_75, 5); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); -lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_75); -x_106 = lean_ctor_get(x_76, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_76, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_76, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_76, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_76, 5); -lean_inc(x_110); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_111 = x_76; +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); } else { - lean_dec_ref(x_76); - x_111 = lean_box(0); + x_98 = x_92; } -x_112 = lean_ctor_get(x_77, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_77, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_77, 3); -lean_inc(x_114); -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); - x_115 = x_77; -} else { - lean_dec_ref(x_77); - x_115 = lean_box(0); +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; } -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_6); -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); -x_118 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_118, 0, x_117); -lean_ctor_set(x_118, 1, x_101); -lean_ctor_set(x_118, 2, x_102); -lean_ctor_set(x_118, 3, x_103); -lean_ctor_set(x_118, 4, x_104); -lean_ctor_set(x_118, 5, x_105); -lean_ctor_set(x_9, 1, x_118); -return x_9; -} -} -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; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_119 = lean_ctor_get(x_9, 0); -lean_inc(x_119); -lean_dec(x_9); -x_120 = lean_ctor_get(x_75, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_75, 2); -lean_inc(x_121); -x_122 = lean_ctor_get(x_75, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_75, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_75, 5); -lean_inc(x_124); -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); - lean_ctor_release(x_75, 5); - x_125 = x_75; -} else { - lean_dec_ref(x_75); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_76, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_76, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_76, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_76, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_76, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_131 = x_76; -} else { - lean_dec_ref(x_76); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_77, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_77, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_77, 3); -lean_inc(x_134); -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); - x_135 = x_77; -} else { - lean_dec_ref(x_77); - 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_6); -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_125)) { - x_138 = lean_alloc_ctor(0, 6, 0); -} else { - x_138 = x_125; -} -lean_ctor_set(x_138, 0, x_137); -lean_ctor_set(x_138, 1, x_120); -lean_ctor_set(x_138, 2, x_121); -lean_ctor_set(x_138, 3, x_122); -lean_ctor_set(x_138, 4, x_123); -lean_ctor_set(x_138, 5, x_124); -x_139 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_139, 0, x_119); -lean_ctor_set(x_139, 1, x_138); -return x_139; } } } @@ -22208,7 +22641,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_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; x_6 = lean_ctor_get(x_4, 0); lean_inc(x_6); x_7 = lean_ctor_get(x_6, 2); @@ -22217,166 +22650,200 @@ lean_dec(x_6); x_8 = lean_ctor_get(x_7, 2); lean_inc(x_8); lean_dec(x_7); -x_9 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_4); -x_10 = lean_ctor_get(x_9, 1); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_apply_2(x_2, x_3, x_10); -if (lean_obj_tag(x_11) == 0) +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) { -lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_12 = lean_ctor_get(x_11, 1); +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; +} +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; +} +block_103: +{ +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_11, 2); lean_inc(x_12); -x_13 = lean_ctor_get(x_12, 0); +x_13 = lean_ctor_get(x_9, 0); lean_inc(x_13); -x_14 = lean_ctor_get(x_13, 2); -lean_inc(x_14); -x_15 = !lean_is_exclusive(x_11); -if (x_15 == 0) +lean_dec(x_9); +x_14 = !lean_is_exclusive(x_10); +if (x_14 == 0) { -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_11, 1); -lean_dec(x_16); -x_17 = !lean_is_exclusive(x_12); -if (x_17 == 0) +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_10, 0); +lean_dec(x_15); +x_16 = !lean_is_exclusive(x_11); +if (x_16 == 0) { -lean_object* x_18; uint8_t x_19; -x_18 = lean_ctor_get(x_12, 0); -lean_dec(x_18); -x_19 = !lean_is_exclusive(x_13); -if (x_19 == 0) +lean_object* x_17; uint8_t x_18; +x_17 = lean_ctor_get(x_11, 2); +lean_dec(x_17); +x_18 = !lean_is_exclusive(x_12); +if (x_18 == 0) { -lean_object* x_20; uint8_t x_21; -x_20 = lean_ctor_get(x_13, 2); -lean_dec(x_20); -x_21 = !lean_is_exclusive(x_14); -if (x_21 == 0) -{ -lean_object* x_22; -x_22 = lean_ctor_get(x_14, 2); -lean_dec(x_22); -lean_ctor_set(x_14, 2, x_8); -return x_11; +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_12, 2); +lean_dec(x_19); +lean_ctor_set(x_12, 2, x_8); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_13); +lean_ctor_set(x_20, 1, x_10); +return x_20; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_23 = lean_ctor_get(x_14, 0); -x_24 = lean_ctor_get(x_14, 1); -x_25 = lean_ctor_get(x_14, 3); -lean_inc(x_25); -lean_inc(x_24); +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_21 = lean_ctor_get(x_12, 0); +x_22 = lean_ctor_get(x_12, 1); +x_23 = lean_ctor_get(x_12, 3); lean_inc(x_23); -lean_dec(x_14); -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_8); -lean_ctor_set(x_26, 3, x_25); -lean_ctor_set(x_13, 2, x_26); -return x_11; +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; } } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_27 = lean_ctor_get(x_13, 0); -x_28 = lean_ctor_get(x_13, 1); -x_29 = lean_ctor_get(x_13, 3); -x_30 = lean_ctor_get(x_13, 4); -x_31 = lean_ctor_get(x_13, 5); -lean_inc(x_31); +lean_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_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); -lean_dec(x_13); -x_32 = lean_ctor_get(x_14, 0); +lean_inc(x_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); lean_inc(x_32); -x_33 = lean_ctor_get(x_14, 1); +x_33 = lean_ctor_get(x_12, 3); lean_inc(x_33); -x_34 = lean_ctor_get(x_14, 3); -lean_inc(x_34); -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_35 = x_14; +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; } else { - lean_dec_ref(x_14); - x_35 = lean_box(0); + lean_dec_ref(x_12); + x_34 = lean_box(0); } -if (lean_is_scalar(x_35)) { - x_36 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 4, 0); } else { - x_36 = x_35; + x_35 = x_34; } -lean_ctor_set(x_36, 0, x_32); -lean_ctor_set(x_36, 1, x_33); -lean_ctor_set(x_36, 2, x_8); -lean_ctor_set(x_36, 3, x_34); -x_37 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_37, 0, x_27); -lean_ctor_set(x_37, 1, x_28); -lean_ctor_set(x_37, 2, x_36); -lean_ctor_set(x_37, 3, x_29); -lean_ctor_set(x_37, 4, x_30); -lean_ctor_set(x_37, 5, x_31); -lean_ctor_set(x_12, 0, x_37); -return x_11; +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; } } 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; -x_38 = lean_ctor_get(x_12, 1); -x_39 = lean_ctor_get(x_12, 2); -x_40 = lean_ctor_get(x_12, 3); -x_41 = lean_ctor_get(x_12, 4); -x_42 = lean_ctor_get(x_12, 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; +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_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_dec(x_12); -x_43 = lean_ctor_get(x_13, 0); +lean_dec(x_10); +x_43 = lean_ctor_get(x_11, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_13, 1); +x_44 = lean_ctor_get(x_11, 1); lean_inc(x_44); -x_45 = lean_ctor_get(x_13, 3); +x_45 = lean_ctor_get(x_11, 3); lean_inc(x_45); -x_46 = lean_ctor_get(x_13, 4); +x_46 = lean_ctor_get(x_11, 4); lean_inc(x_46); -x_47 = lean_ctor_get(x_13, 5); +x_47 = lean_ctor_get(x_11, 5); lean_inc(x_47); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - lean_ctor_release(x_13, 2); - lean_ctor_release(x_13, 3); - lean_ctor_release(x_13, 4); - lean_ctor_release(x_13, 5); - x_48 = x_13; +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); + lean_ctor_release(x_11, 5); + x_48 = x_11; } else { - lean_dec_ref(x_13); + lean_dec_ref(x_11); x_48 = lean_box(0); } -x_49 = lean_ctor_get(x_14, 0); +x_49 = lean_ctor_get(x_12, 0); lean_inc(x_49); -x_50 = lean_ctor_get(x_14, 1); +x_50 = lean_ctor_get(x_12, 1); lean_inc(x_50); -x_51 = lean_ctor_get(x_14, 3); +x_51 = lean_ctor_get(x_12, 3); lean_inc(x_51); -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_52 = x_14; +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; } else { - lean_dec_ref(x_14); + lean_dec_ref(x_12); x_52 = lean_box(0); } if (lean_is_scalar(x_52)) { @@ -22406,402 +22873,205 @@ 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); -lean_ctor_set(x_11, 1, x_55); -return x_11; +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; } } 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; 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_56 = lean_ctor_get(x_11, 0); -lean_inc(x_56); -lean_dec(x_11); -x_57 = lean_ctor_get(x_12, 1); +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_12, 2); +x_58 = lean_ctor_get(x_57, 2); lean_inc(x_58); -x_59 = lean_ctor_get(x_12, 3); +x_59 = lean_ctor_get(x_9, 0); lean_inc(x_59); -x_60 = lean_ctor_get(x_12, 4); -lean_inc(x_60); -x_61 = lean_ctor_get(x_12, 5); -lean_inc(x_61); -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); - lean_ctor_release(x_12, 5); - x_62 = x_12; -} else { - lean_dec_ref(x_12); - x_62 = lean_box(0); +lean_dec(x_9); +x_60 = !lean_is_exclusive(x_10); +if (x_60 == 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_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_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; } -x_63 = lean_ctor_get(x_13, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_13, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_13, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_13, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_13, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - lean_ctor_release(x_13, 2); - lean_ctor_release(x_13, 3); - lean_ctor_release(x_13, 4); - lean_ctor_release(x_13, 5); - x_68 = x_13; -} else { - lean_dec_ref(x_13); - x_68 = lean_box(0); -} -x_69 = lean_ctor_get(x_14, 0); +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); -x_70 = lean_ctor_get(x_14, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_14, 3); -lean_inc(x_71); -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_72 = x_14; -} else { - lean_dec_ref(x_14); - x_72 = lean_box(0); -} -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_8); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -if (lean_is_scalar(x_62)) { - x_75 = lean_alloc_ctor(0, 6, 0); -} else { - x_75 = x_62; -} -lean_ctor_set(x_75, 0, x_74); -lean_ctor_set(x_75, 1, x_57); -lean_ctor_set(x_75, 2, x_58); -lean_ctor_set(x_75, 3, x_59); -lean_ctor_set(x_75, 4, x_60); -lean_ctor_set(x_75, 5, x_61); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_56); -lean_ctor_set(x_76, 1, x_75); -return x_76; +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_77; lean_object* x_78; lean_object* x_79; uint8_t x_80; -x_77 = lean_ctor_get(x_11, 1); +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_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_77, 0); +x_78 = lean_ctor_get(x_58, 1); lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 2); +x_79 = lean_ctor_get(x_58, 3); lean_inc(x_79); -x_80 = !lean_is_exclusive(x_11); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_11, 1); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_77, 0); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_78); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_78, 2); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_79); -if (x_86 == 0) -{ -lean_object* x_87; -x_87 = lean_ctor_get(x_79, 2); -lean_dec(x_87); -lean_ctor_set(x_79, 2, x_8); -return x_11; +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; +} } else { -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_79, 0); -x_89 = lean_ctor_get(x_79, 1); -x_90 = lean_ctor_get(x_79, 3); -lean_inc(x_90); -lean_inc(x_89); +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_dec(x_79); -x_91 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_91, 0, x_88); -lean_ctor_set(x_91, 1, x_89); -lean_ctor_set(x_91, 2, x_8); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set(x_78, 2, x_91); -return x_11; -} -} -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_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_92 = lean_ctor_get(x_78, 0); -x_93 = lean_ctor_get(x_78, 1); -x_94 = lean_ctor_get(x_78, 3); -x_95 = lean_ctor_get(x_78, 4); -x_96 = lean_ctor_get(x_78, 5); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); +lean_inc(x_87); +lean_inc(x_86); +lean_inc(x_85); +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); -lean_dec(x_78); -x_97 = lean_ctor_get(x_79, 0); +x_93 = lean_ctor_get(x_57, 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_95); +x_96 = lean_ctor_get(x_58, 1); +lean_inc(x_96); +x_97 = lean_ctor_get(x_58, 3); lean_inc(x_97); -x_98 = lean_ctor_get(x_79, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_79, 3); -lean_inc(x_99); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - lean_ctor_release(x_79, 3); - x_100 = 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_98 = x_58; } else { - lean_dec_ref(x_79); - x_100 = lean_box(0); + lean_dec_ref(x_58); + x_98 = lean_box(0); } -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_98)) { + x_99 = lean_alloc_ctor(0, 4, 0); } else { - x_101 = x_100; + x_99 = x_98; } -lean_ctor_set(x_101, 0, x_97); -lean_ctor_set(x_101, 1, x_98); -lean_ctor_set(x_101, 2, x_8); -lean_ctor_set(x_101, 3, x_99); -x_102 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_102, 0, x_92); -lean_ctor_set(x_102, 1, x_93); -lean_ctor_set(x_102, 2, x_101); -lean_ctor_set(x_102, 3, x_94); -lean_ctor_set(x_102, 4, x_95); -lean_ctor_set(x_102, 5, x_96); -lean_ctor_set(x_77, 0, x_102); -return x_11; -} -} -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; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_103 = lean_ctor_get(x_77, 1); -x_104 = lean_ctor_get(x_77, 2); -x_105 = lean_ctor_get(x_77, 3); -x_106 = lean_ctor_get(x_77, 4); -x_107 = lean_ctor_get(x_77, 5); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_77); -x_108 = lean_ctor_get(x_78, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_78, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_78, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_78, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_78, 5); -lean_inc(x_112); -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); - lean_ctor_release(x_78, 5); - x_113 = x_78; +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); } else { - lean_dec_ref(x_78); - x_113 = lean_box(0); + x_100 = x_94; } -x_114 = lean_ctor_get(x_79, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_79, 1); -lean_inc(x_115); -x_116 = lean_ctor_get(x_79, 3); -lean_inc(x_116); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - lean_ctor_release(x_79, 3); - x_117 = x_79; -} else { - lean_dec_ref(x_79); - x_117 = lean_box(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); +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; } -if (lean_is_scalar(x_117)) { - x_118 = lean_alloc_ctor(0, 4, 0); -} else { - x_118 = x_117; -} -lean_ctor_set(x_118, 0, x_114); -lean_ctor_set(x_118, 1, x_115); -lean_ctor_set(x_118, 2, x_8); -lean_ctor_set(x_118, 3, x_116); -if (lean_is_scalar(x_113)) { - x_119 = lean_alloc_ctor(0, 6, 0); -} else { - x_119 = x_113; -} -lean_ctor_set(x_119, 0, x_108); -lean_ctor_set(x_119, 1, x_109); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_110); -lean_ctor_set(x_119, 4, x_111); -lean_ctor_set(x_119, 5, x_112); -x_120 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_103); -lean_ctor_set(x_120, 2, x_104); -lean_ctor_set(x_120, 3, x_105); -lean_ctor_set(x_120, 4, x_106); -lean_ctor_set(x_120, 5, x_107); -lean_ctor_set(x_11, 1, x_120); -return x_11; -} -} -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; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; -x_121 = lean_ctor_get(x_11, 0); -lean_inc(x_121); -lean_dec(x_11); -x_122 = lean_ctor_get(x_77, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_77, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_77, 3); -lean_inc(x_124); -x_125 = lean_ctor_get(x_77, 4); -lean_inc(x_125); -x_126 = lean_ctor_get(x_77, 5); -lean_inc(x_126); -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_127 = x_77; -} else { - lean_dec_ref(x_77); - x_127 = lean_box(0); -} -x_128 = lean_ctor_get(x_78, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_78, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_78, 3); -lean_inc(x_130); -x_131 = lean_ctor_get(x_78, 4); -lean_inc(x_131); -x_132 = lean_ctor_get(x_78, 5); -lean_inc(x_132); -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); - lean_ctor_release(x_78, 5); - x_133 = x_78; -} else { - lean_dec_ref(x_78); - x_133 = lean_box(0); -} -x_134 = lean_ctor_get(x_79, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_79, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_79, 3); -lean_inc(x_136); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - lean_ctor_release(x_79, 3); - x_137 = x_79; -} else { - lean_dec_ref(x_79); - 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_8); -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_127)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_127; -} -lean_ctor_set(x_140, 0, x_139); -lean_ctor_set(x_140, 1, x_122); -lean_ctor_set(x_140, 2, x_123); -lean_ctor_set(x_140, 3, x_124); -lean_ctor_set(x_140, 4, x_125); -lean_ctor_set(x_140, 5, x_126); -x_141 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_141, 0, x_121); -lean_ctor_set(x_141, 1, x_140); -return x_141; } } } @@ -22825,6 +23095,1306 @@ x_6 = l_Lean_Elab_Term_resettingSynthInstanceCacheWhen___rarg(x_5, x_2, x_3, x_4 return x_6; } } +uint8_t l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_4); +x_8 = lean_nat_dec_lt(x_6, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +uint8_t x_9; +lean_dec(x_6); +x_9 = 1; +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_10 = lean_array_fget(x_4, x_6); +x_11 = lean_array_fget(x_5, x_6); +x_12 = l_Lean_LocalInstance_beq(x_10, x_11); +lean_dec(x_11); +lean_dec(x_10); +if (x_12 == 0) +{ +uint8_t x_13; +lean_dec(x_6); +x_13 = 0; +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_unsigned_to_nat(1u); +x_15 = lean_nat_add(x_6, x_14); +lean_dec(x_6); +x_3 = lean_box(0); +x_6 = x_15; +goto _start; +} +} +} +} +lean_object* l_Lean_Elab_Term_withLocalContext___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; uint8_t x_13; +x_6 = l_Lean_Elab_Term_getLocalInsts(x_4, x_5); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + x_9 = x_6; +} else { + lean_dec_ref(x_6); + x_9 = lean_box(0); +} +x_10 = lean_array_get_size(x_2); +x_11 = lean_array_get_size(x_7); +x_12 = lean_nat_dec_eq(x_10, x_11); +lean_dec(x_11); +lean_dec(x_10); +x_13 = !lean_is_exclusive(x_4); +if (x_13 == 0) +{ +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_4, 0); +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_14, 2); +lean_dec(x_16); +x_17 = lean_ctor_get(x_14, 1); +lean_dec(x_17); +lean_inc(x_2); +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_dec(x_7); +lean_dec(x_2); +x_127 = lean_box(0); +x_18 = x_127; +goto block_126; +} +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_dec(x_7); +lean_dec(x_2); +if (x_129 == 0) +{ +lean_object* x_130; +x_130 = lean_box(0); +x_18 = x_130; +goto block_126; +} +else +{ +lean_object* x_131; +lean_dec(x_9); +x_131 = lean_apply_2(x_3, x_4, x_8); +return x_131; +} +} +block_126: +{ +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_dec(x_18); +x_19 = lean_ctor_get(x_8, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_19, 2); +lean_inc(x_20); +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) +{ +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; +} +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; +} +block_116: +{ +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +x_25 = lean_ctor_get(x_24, 2); +lean_inc(x_25); +x_26 = lean_ctor_get(x_22, 0); +lean_inc(x_26); +lean_dec(x_22); +x_27 = !lean_is_exclusive(x_23); +if (x_27 == 0) +{ +lean_object* x_28; uint8_t x_29; +x_28 = lean_ctor_get(x_23, 0); +lean_dec(x_28); +x_29 = !lean_is_exclusive(x_24); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_24, 2); +lean_dec(x_30); +x_31 = !lean_is_exclusive(x_25); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_25, 2); +lean_dec(x_32); +lean_ctor_set(x_25, 2, x_21); +if (lean_is_scalar(x_9)) { + x_33 = lean_alloc_ctor(1, 2, 0); +} else { + x_33 = x_9; + lean_ctor_set_tag(x_33, 1); +} +lean_ctor_set(x_33, 0, x_26); +lean_ctor_set(x_33, 1, x_23); +return x_33; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_34 = lean_ctor_get(x_25, 0); +x_35 = lean_ctor_get(x_25, 1); +x_36 = lean_ctor_get(x_25, 3); +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); +if (lean_is_scalar(x_9)) { + x_38 = lean_alloc_ctor(1, 2, 0); +} else { + x_38 = x_9; + lean_ctor_set_tag(x_38, 1); +} +lean_ctor_set(x_38, 0, x_26); +lean_ctor_set(x_38, 1, x_23); +return x_38; +} +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; 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_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); +lean_inc(x_45); +x_46 = lean_ctor_get(x_25, 3); +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_47 = x_25; +} else { + lean_dec_ref(x_25); + x_47 = lean_box(0); +} +if (lean_is_scalar(x_47)) { + x_48 = lean_alloc_ctor(0, 4, 0); +} else { + x_48 = x_47; +} +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); +if (lean_is_scalar(x_9)) { + x_50 = lean_alloc_ctor(1, 2, 0); +} else { + x_50 = x_9; + lean_ctor_set_tag(x_50, 1); +} +lean_ctor_set(x_50, 0, x_26); +lean_ctor_set(x_50, 1, x_23); +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_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_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); +lean_inc(x_58); +x_59 = lean_ctor_get(x_24, 4); +lean_inc(x_59); +x_60 = lean_ctor_get(x_24, 5); +lean_inc(x_60); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + lean_ctor_release(x_24, 2); + lean_ctor_release(x_24, 3); + lean_ctor_release(x_24, 4); + lean_ctor_release(x_24, 5); + x_61 = x_24; +} else { + lean_dec_ref(x_24); + x_61 = 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); +lean_inc(x_64); +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; +} else { + lean_dec_ref(x_25); + x_65 = lean_box(0); +} +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); +} else { + x_66 = x_65; +} +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); +} else { + x_67 = x_61; +} +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); +if (lean_is_scalar(x_9)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_9; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_26); +lean_ctor_set(x_69, 1, x_68); +return x_69; +} +} +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_dec(x_22); +x_73 = !lean_is_exclusive(x_23); +if (x_73 == 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_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_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); +if (lean_is_scalar(x_9)) { + x_79 = lean_alloc_ctor(0, 2, 0); +} else { + x_79 = x_9; +} +lean_ctor_set(x_79, 0, x_72); +lean_ctor_set(x_79, 1, x_23); +return x_79; +} +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_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_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_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; +} else { + lean_dec_ref(x_70); + x_107 = 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; +} else { + lean_dec_ref(x_71); + x_111 = lean_box(0); +} +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); +if (lean_is_scalar(x_9)) { + x_115 = lean_alloc_ctor(0, 2, 0); +} else { + x_115 = x_9; +} +lean_ctor_set(x_115, 0, x_72); +lean_ctor_set(x_115, 1, x_114); +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_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); +if (x_12 == 0) +{ +lean_object* x_199; +lean_dec(x_7); +lean_dec(x_2); +x_199 = lean_box(0); +x_136 = x_199; +goto block_198; +} +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_dec(x_7); +lean_dec(x_2); +if (x_201 == 0) +{ +lean_object* x_202; +x_202 = lean_box(0); +x_136 = x_202; +goto block_198; +} +else +{ +lean_object* x_203; +lean_dec(x_9); +x_203 = lean_apply_2(x_3, x_4, x_8); +return x_203; +} +} +block_198: +{ +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_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; +} +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; +} +block_188: +{ +if (lean_obj_tag(x_140) == 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_inc(x_148); +x_149 = lean_ctor_get(x_141, 5); +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); +lean_inc(x_151); +x_152 = lean_ctor_get(x_142, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_142, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_142, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_142, 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; +} else { + lean_dec_ref(x_142); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_143, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_143, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_143, 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; +} else { + lean_dec_ref(x_143); + x_160 = 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); +lean_inc(x_165); +x_166 = lean_ctor_get(x_165, 2); +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; +} else { + lean_dec_ref(x_141); + x_173 = 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; +} else { + lean_dec_ref(x_165); + x_179 = lean_box(0); +} +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; +} else { + lean_dec_ref(x_166); + x_183 = lean_box(0); +} +if (lean_is_scalar(x_183)) { + x_184 = lean_alloc_ctor(0, 4, 0); +} else { + x_184 = x_183; +} +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); +if (lean_is_scalar(x_9)) { + x_187 = lean_alloc_ctor(0, 2, 0); +} else { + x_187 = x_9; +} +lean_ctor_set(x_187, 0, x_167); +lean_ctor_set(x_187, 1, x_186); +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_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; +} else { + lean_dec_ref(x_204); + x_220 = lean_box(0); +} +lean_inc(x_2); +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_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); +if (x_12 == 0) +{ +lean_object* x_286; +lean_dec(x_7); +lean_dec(x_2); +x_286 = lean_box(0); +x_223 = x_286; +goto block_285; +} +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_dec(x_7); +lean_dec(x_2); +if (x_288 == 0) +{ +lean_object* x_289; +x_289 = lean_box(0); +x_223 = x_289; +goto block_285; +} +else +{ +lean_object* x_290; +lean_dec(x_9); +x_290 = lean_apply_2(x_3, x_222, x_8); +return x_290; +} +} +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) +{ +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_inc(x_238); +x_239 = lean_ctor_get(x_229, 1); +lean_inc(x_239); +x_240 = lean_ctor_get(x_229, 3); +lean_inc(x_240); +x_241 = lean_ctor_get(x_229, 4); +lean_inc(x_241); +x_242 = lean_ctor_get(x_229, 5); +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); +lean_inc(x_244); +x_245 = lean_ctor_get(x_230, 1); +lean_inc(x_245); +x_246 = lean_ctor_get(x_230, 3); +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; +} else { + lean_dec_ref(x_230); + x_247 = lean_box(0); +} +if (lean_is_scalar(x_247)) { + x_248 = lean_alloc_ctor(0, 4, 0); +} else { + x_248 = x_247; +} +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); +} else { + x_249 = x_243; +} +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); +} else { + x_250 = x_237; +} +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); +if (lean_is_scalar(x_9)) { + x_251 = lean_alloc_ctor(1, 2, 0); +} else { + x_251 = x_9; + lean_ctor_set_tag(x_251, 1); +} +lean_ctor_set(x_251, 0, x_231); +lean_ctor_set(x_251, 1, x_250); +return x_251; +} +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_inc(x_261); +x_262 = lean_ctor_get(x_252, 1); +lean_inc(x_262); +x_263 = lean_ctor_get(x_252, 3); +lean_inc(x_263); +x_264 = lean_ctor_get(x_252, 4); +lean_inc(x_264); +x_265 = lean_ctor_get(x_252, 5); +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); +lean_inc(x_267); +x_268 = lean_ctor_get(x_253, 1); +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; +} else { + lean_dec_ref(x_253); + x_270 = lean_box(0); +} +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 4, 0); +} else { + x_271 = x_270; +} +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); +} else { + x_272 = x_266; +} +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); +} else { + x_273 = x_260; +} +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); +if (lean_is_scalar(x_9)) { + x_274 = lean_alloc_ctor(0, 2, 0); +} else { + x_274 = x_9; +} +lean_ctor_set(x_274, 0, x_254); +lean_ctor_set(x_274, 1, x_273); +return x_274; +} +} +} +} +} +} +lean_object* l_Lean_Elab_Term_withLocalContext(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Elab_Term_withLocalContext___rarg), 5, 0); +return x_2; +} +} +lean_object* l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; lean_object* x_8; +x_7 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_8 = lean_box(x_7); +return x_8; +} +} uint8_t l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { @@ -22870,7 +24440,7 @@ goto _start; lean_object* l_Lean_Elab_Term_withMVarContext___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; x_5 = l_Lean_Elab_Term_getMVarDecl(x_1, x_3, x_4); x_6 = lean_ctor_get(x_3, 0); lean_inc(x_6); @@ -22878,185 +24448,235 @@ x_7 = lean_ctor_get(x_5, 0); lean_inc(x_7); x_8 = lean_ctor_get(x_5, 1); lean_inc(x_8); -lean_dec(x_5); -x_9 = lean_ctor_get(x_3, 1); -lean_inc(x_9); -x_10 = lean_ctor_get(x_3, 2); +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + x_9 = x_5; +} else { + lean_dec_ref(x_5); + x_9 = lean_box(0); +} +x_10 = lean_ctor_get(x_3, 1); lean_inc(x_10); -x_11 = lean_ctor_get(x_3, 3); +x_11 = lean_ctor_get(x_3, 2); lean_inc(x_11); -x_12 = lean_ctor_get(x_3, 4); +x_12 = lean_ctor_get(x_3, 3); lean_inc(x_12); -x_13 = lean_ctor_get(x_3, 5); +x_13 = lean_ctor_get(x_3, 4); lean_inc(x_13); -x_14 = lean_ctor_get(x_3, 6); +x_14 = lean_ctor_get(x_3, 5); lean_inc(x_14); -x_15 = lean_ctor_get(x_3, 7); +x_15 = lean_ctor_get(x_3, 6); lean_inc(x_15); -x_16 = lean_ctor_get(x_3, 8); +x_16 = lean_ctor_get(x_3, 7); lean_inc(x_16); -x_17 = lean_ctor_get(x_3, 9); +x_17 = lean_ctor_get(x_3, 8); lean_inc(x_17); -x_18 = !lean_is_exclusive(x_6); -if (x_18 == 0) +x_18 = lean_ctor_get(x_3, 9); +lean_inc(x_18); +x_19 = !lean_is_exclusive(x_6); +if (x_19 == 0) { -uint8_t x_19; uint8_t x_20; uint8_t 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; uint8_t x_28; lean_object* x_29; -x_19 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_20 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_21 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -x_22 = lean_ctor_get(x_6, 2); -x_23 = lean_ctor_get(x_6, 1); -lean_dec(x_23); -x_24 = lean_ctor_get(x_7, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_7, 4); +uint8_t x_20; uint8_t x_21; uint8_t x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; +x_20 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); +x_21 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); +x_22 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +x_23 = lean_ctor_get(x_6, 2); +x_24 = lean_ctor_get(x_6, 1); +lean_dec(x_24); +x_25 = lean_ctor_get(x_7, 1); lean_inc(x_25); -x_26 = lean_array_get_size(x_22); -x_27 = lean_array_get_size(x_25); -x_28 = lean_nat_dec_eq(x_26, x_27); +x_26 = lean_ctor_get(x_7, 4); +lean_inc(x_26); +x_27 = lean_array_get_size(x_23); +x_28 = lean_array_get_size(x_26); +x_29 = lean_nat_dec_eq(x_27, x_28); +lean_dec(x_28); lean_dec(x_27); +lean_inc(x_26); +lean_ctor_set(x_6, 2, x_26); +lean_ctor_set(x_6, 1, x_25); +x_30 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_30, 0, x_6); +lean_ctor_set(x_30, 1, x_10); +lean_ctor_set(x_30, 2, x_11); +lean_ctor_set(x_30, 3, x_12); +lean_ctor_set(x_30, 4, x_13); +lean_ctor_set(x_30, 5, x_14); +lean_ctor_set(x_30, 6, x_15); +lean_ctor_set(x_30, 7, x_16); +lean_ctor_set(x_30, 8, x_17); +lean_ctor_set(x_30, 9, x_18); +lean_ctor_set_uint8(x_30, sizeof(void*)*10, x_20); +lean_ctor_set_uint8(x_30, sizeof(void*)*10 + 1, x_21); +lean_ctor_set_uint8(x_30, sizeof(void*)*10 + 2, x_22); +if (x_29 == 0) +{ +lean_object* x_31; lean_dec(x_26); -lean_inc(x_25); -lean_ctor_set(x_6, 2, x_25); -lean_ctor_set(x_6, 1, x_24); -x_29 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_29, 0, x_6); -lean_ctor_set(x_29, 1, x_9); -lean_ctor_set(x_29, 2, x_10); -lean_ctor_set(x_29, 3, x_11); -lean_ctor_set(x_29, 4, x_12); -lean_ctor_set(x_29, 5, x_13); -lean_ctor_set(x_29, 6, x_14); -lean_ctor_set(x_29, 7, x_15); -lean_ctor_set(x_29, 8, x_16); -lean_ctor_set(x_29, 9, x_17); -lean_ctor_set_uint8(x_29, sizeof(void*)*10, x_19); -lean_ctor_set_uint8(x_29, sizeof(void*)*10 + 1, x_20); -lean_ctor_set_uint8(x_29, sizeof(void*)*10 + 2, x_21); -if (x_28 == 0) -{ -lean_object* x_30; -lean_dec(x_25); -lean_dec(x_22); +lean_dec(x_23); +lean_dec(x_9); lean_dec(x_7); lean_dec(x_3); -x_30 = lean_apply_2(x_2, x_29, x_8); -return x_30; +x_31 = lean_apply_2(x_2, x_30, x_8); +return x_31; } else { -lean_object* x_31; uint8_t x_32; -x_31 = lean_unsigned_to_nat(0u); -x_32 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_22, x_25, x_31); -lean_dec(x_25); -lean_dec(x_22); +lean_object* x_32; uint8_t x_33; +x_32 = lean_unsigned_to_nat(0u); +x_33 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_23, x_26, x_32); +lean_dec(x_26); +lean_dec(x_23); lean_dec(x_7); lean_dec(x_3); -if (x_32 == 0) +if (x_33 == 0) { -lean_object* x_33; -x_33 = lean_apply_2(x_2, x_29, x_8); -return x_33; +lean_object* x_34; +lean_dec(x_9); +x_34 = lean_apply_2(x_2, x_30, x_8); +return x_34; } else { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_34 = lean_ctor_get(x_8, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_34, 2); +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; +x_35 = lean_ctor_get(x_8, 0); lean_inc(x_35); -lean_dec(x_34); x_36 = lean_ctor_get(x_35, 2); lean_inc(x_36); lean_dec(x_35); -x_37 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_38 = lean_ctor_get(x_37, 1); -lean_inc(x_38); -lean_dec(x_37); -x_39 = lean_apply_2(x_2, x_29, x_38); -if (lean_obj_tag(x_39) == 0) +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) +{ +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; +} +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; +} +block_132: +{ +if (lean_obj_tag(x_38) == 0) { lean_object* x_40; lean_object* x_41; lean_object* x_42; uint8_t x_43; -x_40 = lean_ctor_get(x_39, 1); +x_40 = lean_ctor_get(x_39, 0); lean_inc(x_40); -x_41 = lean_ctor_get(x_40, 0); +x_41 = lean_ctor_get(x_40, 2); lean_inc(x_41); -x_42 = lean_ctor_get(x_41, 2); +x_42 = lean_ctor_get(x_38, 0); lean_inc(x_42); +lean_dec(x_38); x_43 = !lean_is_exclusive(x_39); if (x_43 == 0) { lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 1); +x_44 = lean_ctor_get(x_39, 0); lean_dec(x_44); x_45 = !lean_is_exclusive(x_40); if (x_45 == 0) { lean_object* x_46; uint8_t x_47; -x_46 = lean_ctor_get(x_40, 0); +x_46 = lean_ctor_get(x_40, 2); lean_dec(x_46); x_47 = !lean_is_exclusive(x_41); if (x_47 == 0) { -lean_object* x_48; uint8_t x_49; +lean_object* x_48; lean_object* x_49; x_48 = lean_ctor_get(x_41, 2); lean_dec(x_48); -x_49 = !lean_is_exclusive(x_42); -if (x_49 == 0) -{ -lean_object* x_50; -x_50 = lean_ctor_get(x_42, 2); -lean_dec(x_50); -lean_ctor_set(x_42, 2, x_36); -return x_39; +lean_ctor_set(x_41, 2, x_37); +if (lean_is_scalar(x_9)) { + x_49 = lean_alloc_ctor(1, 2, 0); +} else { + x_49 = x_9; + lean_ctor_set_tag(x_49, 1); +} +lean_ctor_set(x_49, 0, x_42); +lean_ctor_set(x_49, 1, x_39); +return x_49; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_51 = lean_ctor_get(x_42, 0); -x_52 = lean_ctor_get(x_42, 1); -x_53 = lean_ctor_get(x_42, 3); -lean_inc(x_53); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_50 = lean_ctor_get(x_41, 0); +x_51 = lean_ctor_get(x_41, 1); +x_52 = lean_ctor_get(x_41, 3); lean_inc(x_52); lean_inc(x_51); -lean_dec(x_42); -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_36); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_41, 2, x_54); -return x_39; +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); +if (lean_is_scalar(x_9)) { + x_54 = lean_alloc_ctor(1, 2, 0); +} else { + x_54 = x_9; + lean_ctor_set_tag(x_54, 1); +} +lean_ctor_set(x_54, 0, x_42); +lean_ctor_set(x_54, 1, x_39); +return x_54; } } 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; -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_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_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_dec(x_41); -x_60 = lean_ctor_get(x_42, 0); +lean_dec(x_40); +x_60 = lean_ctor_get(x_41, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 1); +x_61 = lean_ctor_get(x_41, 1); lean_inc(x_61); -x_62 = lean_ctor_get(x_42, 3); +x_62 = lean_ctor_get(x_41, 3); lean_inc(x_62); -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_63 = x_42; +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; } else { - lean_dec_ref(x_42); + lean_dec_ref(x_41); x_63 = lean_box(0); } if (lean_is_scalar(x_63)) { @@ -23066,7 +24686,7 @@ if (lean_is_scalar(x_63)) { } lean_ctor_set(x_64, 0, x_60); lean_ctor_set(x_64, 1, x_61); -lean_ctor_set(x_64, 2, x_36); +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); @@ -23075,109 +24695,42 @@ 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_40, 0, x_65); -return x_39; +lean_ctor_set(x_39, 0, x_65); +if (lean_is_scalar(x_9)) { + x_66 = lean_alloc_ctor(1, 2, 0); +} else { + x_66 = x_9; + lean_ctor_set_tag(x_66, 1); +} +lean_ctor_set(x_66, 0, x_42); +lean_ctor_set(x_66, 1, x_39); +return x_66; } } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_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_66 = lean_ctor_get(x_40, 1); -x_67 = lean_ctor_get(x_40, 2); -x_68 = lean_ctor_get(x_40, 3); -x_69 = lean_ctor_get(x_40, 4); -x_70 = lean_ctor_get(x_40, 5); +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_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_40); -x_71 = lean_ctor_get(x_41, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_41, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_41, 3); -lean_inc(x_73); -x_74 = lean_ctor_get(x_41, 4); -lean_inc(x_74); -x_75 = lean_ctor_get(x_41, 5); -lean_inc(x_75); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_76 = x_41; -} else { - lean_dec_ref(x_41); - x_76 = lean_box(0); -} -x_77 = lean_ctor_get(x_42, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_42, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_42, 3); -lean_inc(x_79); -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_80 = x_42; -} else { - lean_dec_ref(x_42); - 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_36); -lean_ctor_set(x_81, 3, x_79); -if (lean_is_scalar(x_76)) { - x_82 = lean_alloc_ctor(0, 6, 0); -} else { - x_82 = x_76; -} -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); -x_83 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_66); -lean_ctor_set(x_83, 2, x_67); -lean_ctor_set(x_83, 3, x_68); -lean_ctor_set(x_83, 4, x_69); -lean_ctor_set(x_83, 5, x_70); -lean_ctor_set(x_39, 1, x_83); -return x_39; -} -} -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; lean_object* x_103; lean_object* x_104; -x_84 = lean_ctor_get(x_39, 0); -lean_inc(x_84); lean_dec(x_39); -x_85 = lean_ctor_get(x_40, 1); -lean_inc(x_85); -x_86 = lean_ctor_get(x_40, 2); -lean_inc(x_86); -x_87 = lean_ctor_get(x_40, 3); -lean_inc(x_87); -x_88 = lean_ctor_get(x_40, 4); -lean_inc(x_88); -x_89 = lean_ctor_get(x_40, 5); -lean_inc(x_89); +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); +lean_inc(x_74); +x_75 = lean_ctor_get(x_40, 4); +lean_inc(x_75); +x_76 = lean_ctor_get(x_40, 5); +lean_inc(x_76); if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 0); lean_ctor_release(x_40, 1); @@ -23185,375 +24738,274 @@ 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_90 = x_40; + x_77 = x_40; } else { lean_dec_ref(x_40); - x_90 = lean_box(0); + x_77 = lean_box(0); } -x_91 = lean_ctor_get(x_41, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_41, 1); -lean_inc(x_92); -x_93 = lean_ctor_get(x_41, 3); -lean_inc(x_93); -x_94 = lean_ctor_get(x_41, 4); -lean_inc(x_94); -x_95 = lean_ctor_get(x_41, 5); -lean_inc(x_95); +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); +lean_inc(x_80); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); lean_ctor_release(x_41, 2); lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_96 = x_41; + x_81 = x_41; } else { lean_dec_ref(x_41); - x_96 = lean_box(0); + x_81 = lean_box(0); } -x_97 = lean_ctor_get(x_42, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_42, 1); +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(0, 4, 0); +} else { + x_82 = x_81; +} +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); +} else { + x_83 = x_77; +} +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); +if (lean_is_scalar(x_9)) { + x_85 = lean_alloc_ctor(1, 2, 0); +} else { + x_85 = x_9; + lean_ctor_set_tag(x_85, 1); +} +lean_ctor_set(x_85, 0, x_42); +lean_ctor_set(x_85, 1, x_84); +return x_85; +} +} +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_dec(x_38); +x_89 = !lean_is_exclusive(x_39); +if (x_89 == 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_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_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); +if (lean_is_scalar(x_9)) { + x_95 = lean_alloc_ctor(0, 2, 0); +} else { + x_95 = x_9; +} +lean_ctor_set(x_95, 0, x_88); +lean_ctor_set(x_95, 1, x_39); +return x_95; +} +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); -x_99 = lean_ctor_get(x_42, 3); -lean_inc(x_99); -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_100 = x_42; +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 { - lean_dec_ref(x_42); - x_100 = lean_box(0); + x_100 = x_9; } -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_36); -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_90)) { - x_103 = lean_alloc_ctor(0, 6, 0); -} else { - x_103 = x_90; -} -lean_ctor_set(x_103, 0, x_102); -lean_ctor_set(x_103, 1, x_85); -lean_ctor_set(x_103, 2, x_86); -lean_ctor_set(x_103, 3, x_87); -lean_ctor_set(x_103, 4, x_88); -lean_ctor_set(x_103, 5, x_89); -x_104 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_104, 0, x_84); -lean_ctor_set(x_104, 1, x_103); -return x_104; +lean_ctor_set(x_100, 0, x_88); +lean_ctor_set(x_100, 1, x_39); +return x_100; } } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; uint8_t x_108; -x_105 = lean_ctor_get(x_39, 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; 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); -x_106 = lean_ctor_get(x_105, 0); +lean_inc(x_104); +lean_inc(x_103); +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_106, 2); +x_107 = lean_ctor_get(x_87, 1); lean_inc(x_107); -x_108 = !lean_is_exclusive(x_39); -if (x_108 == 0) -{ -lean_object* x_109; uint8_t x_110; -x_109 = lean_ctor_get(x_39, 1); -lean_dec(x_109); -x_110 = !lean_is_exclusive(x_105); -if (x_110 == 0) -{ -lean_object* x_111; uint8_t x_112; -x_111 = lean_ctor_get(x_105, 0); -lean_dec(x_111); -x_112 = !lean_is_exclusive(x_106); -if (x_112 == 0) -{ -lean_object* x_113; uint8_t x_114; -x_113 = lean_ctor_get(x_106, 2); -lean_dec(x_113); -x_114 = !lean_is_exclusive(x_107); -if (x_114 == 0) -{ -lean_object* x_115; -x_115 = lean_ctor_get(x_107, 2); -lean_dec(x_115); -lean_ctor_set(x_107, 2, x_36); -return x_39; +x_108 = lean_ctor_get(x_87, 3); +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_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_116 = lean_ctor_get(x_107, 0); -x_117 = lean_ctor_get(x_107, 1); -x_118 = lean_ctor_get(x_107, 3); -lean_inc(x_118); +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_dec(x_107); -x_119 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_119, 0, x_116); -lean_ctor_set(x_119, 1, x_117); -lean_ctor_set(x_119, 2, x_36); -lean_ctor_set(x_119, 3, x_118); -lean_ctor_set(x_106, 2, x_119); -return x_39; -} -} -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; -x_120 = lean_ctor_get(x_106, 0); -x_121 = lean_ctor_get(x_106, 1); -x_122 = lean_ctor_get(x_106, 3); -x_123 = lean_ctor_get(x_106, 4); -x_124 = lean_ctor_get(x_106, 5); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_106); -x_125 = lean_ctor_get(x_107, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_107, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_107, 3); -lean_inc(x_127); -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_128 = x_107; -} else { - lean_dec_ref(x_107); - 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_36); -lean_ctor_set(x_129, 3, x_127); -x_130 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_130, 0, x_120); -lean_ctor_set(x_130, 1, x_121); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_122); -lean_ctor_set(x_130, 4, x_123); -lean_ctor_set(x_130, 5, x_124); -lean_ctor_set(x_105, 0, x_130); -return x_39; -} -} -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_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_131 = lean_ctor_get(x_105, 1); -x_132 = lean_ctor_get(x_105, 2); -x_133 = lean_ctor_get(x_105, 3); -x_134 = lean_ctor_get(x_105, 4); -x_135 = lean_ctor_get(x_105, 5); -lean_inc(x_135); -lean_inc(x_134); -lean_inc(x_133); -lean_inc(x_132); -lean_inc(x_131); -lean_dec(x_105); -x_136 = lean_ctor_get(x_106, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_106, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_106, 3); -lean_inc(x_138); -x_139 = lean_ctor_get(x_106, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_106, 5); -lean_inc(x_140); -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_141 = x_106; -} else { - lean_dec_ref(x_106); - x_141 = lean_box(0); -} -x_142 = lean_ctor_get(x_107, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_107, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_107, 3); -lean_inc(x_144); -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_145 = x_107; -} else { - lean_dec_ref(x_107); - 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_36); -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); -x_148 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_148, 0, x_147); -lean_ctor_set(x_148, 1, x_131); -lean_ctor_set(x_148, 2, x_132); -lean_ctor_set(x_148, 3, x_133); -lean_ctor_set(x_148, 4, x_134); -lean_ctor_set(x_148, 5, x_135); -lean_ctor_set(x_39, 1, x_148); -return x_39; -} -} -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; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -x_149 = lean_ctor_get(x_39, 0); -lean_inc(x_149); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); lean_dec(x_39); -x_150 = lean_ctor_get(x_105, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_105, 2); -lean_inc(x_151); -x_152 = lean_ctor_get(x_105, 3); -lean_inc(x_152); -x_153 = lean_ctor_get(x_105, 4); -lean_inc(x_153); -x_154 = lean_ctor_get(x_105, 5); -lean_inc(x_154); -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_155 = x_105; +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; } else { - lean_dec_ref(x_105); - x_155 = lean_box(0); + lean_dec_ref(x_86); + x_123 = lean_box(0); } -x_156 = lean_ctor_get(x_106, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_106, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_106, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_106, 4); -lean_inc(x_159); -x_160 = lean_ctor_get(x_106, 5); -lean_inc(x_160); -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_161 = x_106; +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; } else { - lean_dec_ref(x_106); - x_161 = lean_box(0); + lean_dec_ref(x_87); + x_127 = lean_box(0); } -x_162 = lean_ctor_get(x_107, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_107, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_107, 3); -lean_inc(x_164); -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_165 = x_107; +if (lean_is_scalar(x_127)) { + x_128 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_107); - x_165 = lean_box(0); + x_128 = x_127; } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(0, 4, 0); +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_166 = x_165; + x_129 = x_123; } -lean_ctor_set(x_166, 0, x_162); -lean_ctor_set(x_166, 1, x_163); -lean_ctor_set(x_166, 2, x_36); -lean_ctor_set(x_166, 3, x_164); -if (lean_is_scalar(x_161)) { - x_167 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_9)) { + x_131 = lean_alloc_ctor(0, 2, 0); } else { - x_167 = x_161; + x_131 = x_9; } -lean_ctor_set(x_167, 0, x_156); -lean_ctor_set(x_167, 1, x_157); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_158); -lean_ctor_set(x_167, 4, x_159); -lean_ctor_set(x_167, 5, x_160); -if (lean_is_scalar(x_155)) { - x_168 = lean_alloc_ctor(0, 6, 0); -} else { - x_168 = x_155; +lean_ctor_set(x_131, 0, x_88); +lean_ctor_set(x_131, 1, x_130); +return x_131; } -lean_ctor_set(x_168, 0, x_167); -lean_ctor_set(x_168, 1, x_150); -lean_ctor_set(x_168, 2, x_151); -lean_ctor_set(x_168, 3, x_152); -lean_ctor_set(x_168, 4, x_153); -lean_ctor_set(x_168, 5, x_154); -x_169 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_169, 0, x_149); -lean_ctor_set(x_169, 1, x_168); -return x_169; } } } @@ -23561,327 +25013,343 @@ return x_169; } else { -uint8_t x_170; uint8_t x_171; uint8_t 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; uint8_t x_181; lean_object* x_182; lean_object* x_183; -x_170 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_171 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_172 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -x_173 = lean_ctor_get(x_6, 0); -x_174 = lean_ctor_get(x_6, 2); -x_175 = lean_ctor_get(x_6, 3); -x_176 = lean_ctor_get(x_6, 4); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_174); -lean_inc(x_173); +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); lean_dec(x_6); -x_177 = lean_ctor_get(x_7, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_7, 4); -lean_inc(x_178); -x_179 = lean_array_get_size(x_174); -x_180 = lean_array_get_size(x_178); -x_181 = lean_nat_dec_eq(x_179, x_180); -lean_dec(x_180); -lean_dec(x_179); -lean_inc(x_178); -x_182 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_182, 0, x_173); -lean_ctor_set(x_182, 1, x_177); -lean_ctor_set(x_182, 2, x_178); -lean_ctor_set(x_182, 3, x_175); -lean_ctor_set(x_182, 4, x_176); -x_183 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_183, 0, x_182); -lean_ctor_set(x_183, 1, x_9); -lean_ctor_set(x_183, 2, x_10); -lean_ctor_set(x_183, 3, x_11); -lean_ctor_set(x_183, 4, x_12); -lean_ctor_set(x_183, 5, x_13); -lean_ctor_set(x_183, 6, x_14); -lean_ctor_set(x_183, 7, x_15); -lean_ctor_set(x_183, 8, x_16); -lean_ctor_set(x_183, 9, x_17); -lean_ctor_set_uint8(x_183, sizeof(void*)*10, x_170); -lean_ctor_set_uint8(x_183, sizeof(void*)*10 + 1, x_171); -lean_ctor_set_uint8(x_183, sizeof(void*)*10 + 2, x_172); -if (x_181 == 0) +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); +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_184; -lean_dec(x_178); -lean_dec(x_174); +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_184 = lean_apply_2(x_2, x_183, x_8); -return x_184; +x_156 = lean_apply_2(x_2, x_155, x_8); +return x_156; } else { -lean_object* x_185; uint8_t x_186; -x_185 = lean_unsigned_to_nat(0u); -x_186 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_174, x_178, x_185); -lean_dec(x_178); -lean_dec(x_174); +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_dec(x_7); lean_dec(x_3); -if (x_186 == 0) +if (x_158 == 0) { -lean_object* x_187; -x_187 = lean_apply_2(x_2, x_183, x_8); +lean_object* x_159; +lean_dec(x_9); +x_159 = lean_apply_2(x_2, x_155, x_8); +return x_159; +} +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_inc(x_166); +x_167 = lean_ctor_get(x_163, 0); +lean_inc(x_167); +lean_dec(x_163); +x_168 = lean_ctor_get(x_164, 1); +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); +} +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; +} else { + lean_dec_ref(x_165); + x_179 = lean_box(0); +} +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; +} else { + lean_dec_ref(x_166); + x_183 = lean_box(0); +} +if (lean_is_scalar(x_183)) { + x_184 = lean_alloc_ctor(0, 4, 0); +} else { + x_184 = x_183; +} +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_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); +if (lean_is_scalar(x_9)) { + x_187 = lean_alloc_ctor(1, 2, 0); +} else { + x_187 = x_9; + lean_ctor_set_tag(x_187, 1); +} +lean_ctor_set(x_187, 0, x_167); +lean_ctor_set(x_187, 1, x_186); return x_187; } 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; -x_188 = lean_ctor_get(x_8, 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; 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); -lean_dec(x_188); -x_190 = lean_ctor_get(x_189, 2); +x_190 = lean_ctor_get(x_163, 0); lean_inc(x_190); -lean_dec(x_189); -x_191 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_192 = lean_ctor_get(x_191, 1); +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); -lean_dec(x_191); -x_193 = lean_apply_2(x_2, x_183, x_192); -if (lean_obj_tag(x_193) == 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; 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_194 = lean_ctor_get(x_193, 1); +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_194, 0); +x_195 = lean_ctor_get(x_164, 5); lean_inc(x_195); -x_196 = lean_ctor_get(x_195, 2); -lean_inc(x_196); -x_197 = lean_ctor_get(x_193, 0); +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); lean_inc(x_197); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - x_198 = x_193; -} else { - lean_dec_ref(x_193); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_194, 1); +x_198 = lean_ctor_get(x_188, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_188, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_194, 2); +x_200 = lean_ctor_get(x_188, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_194, 3); +x_201 = lean_ctor_get(x_188, 5); lean_inc(x_201); -x_202 = lean_ctor_get(x_194, 4); -lean_inc(x_202); -x_203 = lean_ctor_get(x_194, 5); +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; +} else { + lean_dec_ref(x_188); + x_202 = lean_box(0); +} +x_203 = lean_ctor_get(x_189, 0); lean_inc(x_203); -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_204 = x_194; -} else { - lean_dec_ref(x_194); - x_204 = lean_box(0); -} -x_205 = lean_ctor_get(x_195, 0); +x_204 = lean_ctor_get(x_189, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_189, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_195, 1); -lean_inc(x_206); -x_207 = lean_ctor_get(x_195, 3); -lean_inc(x_207); -x_208 = lean_ctor_get(x_195, 4); -lean_inc(x_208); -x_209 = lean_ctor_get(x_195, 5); -lean_inc(x_209); -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_210 = x_195; +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; } else { - lean_dec_ref(x_195); - x_210 = lean_box(0); + lean_dec_ref(x_189); + x_206 = lean_box(0); } -x_211 = lean_ctor_get(x_196, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_196, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_196, 3); -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); - x_214 = x_196; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_196); - x_214 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_214)) { - x_215 = lean_alloc_ctor(0, 4, 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); } else { - x_215 = x_214; + x_208 = x_202; } -lean_ctor_set(x_215, 0, x_211); -lean_ctor_set(x_215, 1, x_212); -lean_ctor_set(x_215, 2, x_190); -lean_ctor_set(x_215, 3, x_213); -if (lean_is_scalar(x_210)) { - x_216 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_216 = x_210; + x_209 = x_196; } -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); -if (lean_is_scalar(x_204)) { - x_217 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_9)) { + x_210 = lean_alloc_ctor(0, 2, 0); } else { - x_217 = x_204; + x_210 = x_9; } -lean_ctor_set(x_217, 0, x_216); -lean_ctor_set(x_217, 1, x_199); -lean_ctor_set(x_217, 2, x_200); -lean_ctor_set(x_217, 3, x_201); -lean_ctor_set(x_217, 4, x_202); -lean_ctor_set(x_217, 5, x_203); -if (lean_is_scalar(x_198)) { - x_218 = lean_alloc_ctor(0, 2, 0); -} else { - x_218 = x_198; +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; -} -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; 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; -x_219 = lean_ctor_get(x_193, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_219, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_220, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_193, 0); -lean_inc(x_222); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - x_223 = x_193; -} else { - lean_dec_ref(x_193); - x_223 = lean_box(0); -} -x_224 = lean_ctor_get(x_219, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_219, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_219, 3); -lean_inc(x_226); -x_227 = lean_ctor_get(x_219, 4); -lean_inc(x_227); -x_228 = lean_ctor_get(x_219, 5); -lean_inc(x_228); -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); - lean_ctor_release(x_219, 5); - x_229 = x_219; -} else { - lean_dec_ref(x_219); - x_229 = lean_box(0); -} -x_230 = lean_ctor_get(x_220, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_220, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_220, 3); -lean_inc(x_232); -x_233 = lean_ctor_get(x_220, 4); -lean_inc(x_233); -x_234 = lean_ctor_get(x_220, 5); -lean_inc(x_234); -if (lean_is_exclusive(x_220)) { - lean_ctor_release(x_220, 0); - lean_ctor_release(x_220, 1); - lean_ctor_release(x_220, 2); - lean_ctor_release(x_220, 3); - lean_ctor_release(x_220, 4); - lean_ctor_release(x_220, 5); - x_235 = x_220; -} else { - lean_dec_ref(x_220); - x_235 = lean_box(0); -} -x_236 = lean_ctor_get(x_221, 0); -lean_inc(x_236); -x_237 = lean_ctor_get(x_221, 1); -lean_inc(x_237); -x_238 = lean_ctor_get(x_221, 3); -lean_inc(x_238); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - lean_ctor_release(x_221, 2); - lean_ctor_release(x_221, 3); - x_239 = x_221; -} else { - lean_dec_ref(x_221); - x_239 = lean_box(0); -} -if (lean_is_scalar(x_239)) { - x_240 = lean_alloc_ctor(0, 4, 0); -} else { - x_240 = x_239; -} -lean_ctor_set(x_240, 0, x_236); -lean_ctor_set(x_240, 1, x_237); -lean_ctor_set(x_240, 2, x_190); -lean_ctor_set(x_240, 3, x_238); -if (lean_is_scalar(x_235)) { - x_241 = lean_alloc_ctor(0, 6, 0); -} else { - x_241 = x_235; -} -lean_ctor_set(x_241, 0, x_230); -lean_ctor_set(x_241, 1, x_231); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_232); -lean_ctor_set(x_241, 4, x_233); -lean_ctor_set(x_241, 5, x_234); -if (lean_is_scalar(x_229)) { - x_242 = lean_alloc_ctor(0, 6, 0); -} else { - x_242 = x_229; -} -lean_ctor_set(x_242, 0, x_241); -lean_ctor_set(x_242, 1, x_224); -lean_ctor_set(x_242, 2, x_225); -lean_ctor_set(x_242, 3, x_226); -lean_ctor_set(x_242, 4, x_227); -lean_ctor_set(x_242, 5, x_228); -if (lean_is_scalar(x_223)) { - x_243 = lean_alloc_ctor(1, 2, 0); -} else { - x_243 = x_223; -} -lean_ctor_set(x_243, 0, x_222); -lean_ctor_set(x_243, 1, x_242); -return x_243; } } } diff --git a/stage0/stdlib/Lean/Environment.c b/stage0/stdlib/Lean/Environment.c index f195e8a2d4..f87978a8be 100644 --- a/stage0/stdlib/Lean/Environment.c +++ b/stage0/stdlib/Lean/Environment.c @@ -39,13 +39,16 @@ lean_object* l_Std_RBNode_insert___at_Lean_NameSet_insert___spec__1(lean_object* lean_object* l_Lean_PersistentEnvExtension_getModuleEntries___rarg(lean_object*, lean_object*, lean_object*); lean_object* lean_display_stats(lean_object*, lean_object*); lean_object* l___private_Lean_Environment_10__setImportedEntries(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_withImportModules(lean_object*); lean_object* l_Lean_namespacesExt___elambda__3(lean_object*, lean_object*); +lean_object* lean_environment_free_regions(lean_object*, lean_object*); lean_object* l_Lean_EnvExtension_setState(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Environment_displayStats___closed__1; lean_object* l_Nat_foldAux___main___at_Lean_mkModuleData___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_USize_decEq(size_t, size_t); lean_object* lean_array_uget(lean_object*, size_t); lean_object* l_Array_iterateMAux___main___at_Lean_importModules___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l_List_repr___rarg___closed__1; lean_object* lean_environment_mark_quot_init(lean_object*); lean_object* l_Lean_mkTagDeclarationExtension___lambda__1(lean_object*, lean_object*); @@ -274,6 +277,7 @@ extern lean_object* l_Lean_Options_empty; extern lean_object* l_IO_Error_Inhabited___closed__1; lean_object* lean_environment_add(lean_object*, lean_object*); lean_object* lean_save_module_data(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_withImportModules___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_EnvExtension_getState___rarg___boxed(lean_object*, lean_object*); lean_object* l_Std_AssocList_replace___main___at_Lean_Environment_addAux___spec__11(lean_object*, lean_object*, lean_object*); size_t lean_usize_modn(size_t, lean_object*); @@ -284,6 +288,7 @@ lean_object* l_Lean_saveModuleData___boxed(lean_object*, lean_object*, lean_obje lean_object* l_Lean_mkModuleData(lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_regNamespacesExtension___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_namespacesExt___elambda__1___boxed(lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Array_qsortAux___main___at_Lean_mkTagDeclarationExtension___spec__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_modListExtension___closed__1; lean_object* l_Lean_modListExtension___closed__2; @@ -301,6 +306,7 @@ lean_object* l_Lean_importModules___closed__1; lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_mkTagDeclarationExtension___spec__6___closed__1; lean_object* l_Lean_Environment_addDecl___boxed(lean_object*, lean_object*); uint8_t lean_kernel_is_def_eq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_CompactedRegion_free___boxed(lean_object*, lean_object*); extern lean_object* l_NonScalar_Inhabited; lean_object* l_Lean_registerPersistentEnvExtensionUnsafe___rarg___lambda__1(lean_object*, lean_object*); uint8_t l_Lean_Format_isNil(lean_object*); @@ -359,6 +365,7 @@ lean_object* l_Lean_SMap_empty___at_Lean_Environment_Inhabited___spec__2; lean_object* l_Array_iterateMAux___main___at_Lean_importModules___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_PersistentEnvExtension_getModuleEntries(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_PersistentEnvExtension_modifyState___rarg___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_withImportModules___rarg(lean_object*, uint32_t, lean_object*, lean_object*); lean_object* l_Lean_mkStateFromImportedEntries(lean_object*, lean_object*); lean_object* l_Lean_EnvExtension_setState___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Environment_addAndCompile(lean_object*, lean_object*, lean_object*); @@ -488,7 +495,9 @@ lean_object* l_Lean_regNamespacesExtension___closed__2; lean_object* l_Lean_EnvExtensionEntry_inhabited; lean_object* l_Lean_EnvExtension_getStateUnsafe(lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_importModules___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_importModules___closed__2; lean_object* l_Lean_Kernel_isDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_compacted_region_free(size_t, lean_object*); lean_object* l_Lean_mkTagDeclarationExtension___lambda__2___boxed(lean_object*); lean_object* l_Lean_SimplePersistentEnvExtension_setState___rarg___lambda__1(lean_object*, lean_object*); lean_object* l_Std_AssocList_foldlM___main___at_Lean_importModules___spec__5(lean_object*, lean_object*); @@ -549,6 +558,16 @@ return x_9; } } } +lean_object* l_Lean_CompactedRegion_free___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +size_t x_3; lean_object* x_4; +x_3 = lean_unbox_usize(x_1); +lean_dec(x_1); +x_4 = lean_compacted_region_free(x_3, x_2); +return x_4; +} +} lean_object* l_Std_mkHashMap___at_Lean_Environment_Inhabited___spec__1(lean_object* x_1) { _start: { @@ -622,12 +641,13 @@ x_2 = 0; x_3 = lean_box(0); x_4 = l_Array_empty___closed__1; x_5 = l_Lean_NameSet_empty; -x_6 = lean_alloc_ctor(0, 3, 5); +x_6 = lean_alloc_ctor(0, 4, 5); lean_ctor_set(x_6, 0, x_3); lean_ctor_set(x_6, 1, x_4); -lean_ctor_set(x_6, 2, x_5); -lean_ctor_set_uint32(x_6, sizeof(void*)*3, x_1); -lean_ctor_set_uint8(x_6, sizeof(void*)*3 + 4, x_2); +lean_ctor_set(x_6, 2, x_4); +lean_ctor_set(x_6, 3, x_5); +lean_ctor_set_uint32(x_6, sizeof(void*)*4, x_1); +lean_ctor_set_uint8(x_6, sizeof(void*)*4 + 4, x_2); return x_6; } } @@ -2136,7 +2156,7 @@ _start: { lean_object* x_2; lean_object* x_3; x_2 = lean_ctor_get(x_1, 3); -x_3 = lean_ctor_get(x_2, 2); +x_3 = lean_ctor_get(x_2, 3); lean_inc(x_3); return x_3; } @@ -2170,67 +2190,74 @@ return x_1; } else { -uint32_t x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_7 = lean_ctor_get_uint32(x_4, sizeof(void*)*3); -x_8 = lean_ctor_get_uint8(x_4, sizeof(void*)*3 + 4); +uint32_t x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_7 = lean_ctor_get_uint32(x_4, sizeof(void*)*4); +x_8 = lean_ctor_get_uint8(x_4, sizeof(void*)*4 + 4); x_9 = lean_ctor_get(x_4, 1); x_10 = lean_ctor_get(x_4, 2); +x_11 = lean_ctor_get(x_4, 3); +lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_dec(x_4); -x_11 = lean_alloc_ctor(0, 3, 5); -lean_ctor_set(x_11, 0, x_2); -lean_ctor_set(x_11, 1, x_9); -lean_ctor_set(x_11, 2, x_10); -lean_ctor_set_uint32(x_11, sizeof(void*)*3, x_7); -lean_ctor_set_uint8(x_11, sizeof(void*)*3 + 4, x_8); -lean_ctor_set(x_1, 3, x_11); +x_12 = lean_alloc_ctor(0, 4, 5); +lean_ctor_set(x_12, 0, x_2); +lean_ctor_set(x_12, 1, x_9); +lean_ctor_set(x_12, 2, x_10); +lean_ctor_set(x_12, 3, x_11); +lean_ctor_set_uint32(x_12, sizeof(void*)*4, x_7); +lean_ctor_set_uint8(x_12, sizeof(void*)*4 + 4, x_8); +lean_ctor_set(x_1, 3, x_12); return x_1; } } else { -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint32_t x_16; uint8_t x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_12 = lean_ctor_get(x_1, 3); -x_13 = lean_ctor_get(x_1, 0); -x_14 = lean_ctor_get(x_1, 1); -x_15 = lean_ctor_get(x_1, 2); -lean_inc(x_12); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint32_t x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_13 = lean_ctor_get(x_1, 3); +x_14 = lean_ctor_get(x_1, 0); +x_15 = lean_ctor_get(x_1, 1); +x_16 = lean_ctor_get(x_1, 2); +lean_inc(x_13); +lean_inc(x_16); lean_inc(x_15); lean_inc(x_14); -lean_inc(x_13); lean_dec(x_1); -x_16 = lean_ctor_get_uint32(x_12, sizeof(void*)*3); -x_17 = lean_ctor_get_uint8(x_12, sizeof(void*)*3 + 4); -x_18 = lean_ctor_get(x_12, 1); -lean_inc(x_18); -x_19 = lean_ctor_get(x_12, 2); +x_17 = lean_ctor_get_uint32(x_13, sizeof(void*)*4); +x_18 = lean_ctor_get_uint8(x_13, sizeof(void*)*4 + 4); +x_19 = lean_ctor_get(x_13, 1); lean_inc(x_19); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - x_20 = x_12; +x_20 = lean_ctor_get(x_13, 2); +lean_inc(x_20); +x_21 = lean_ctor_get(x_13, 3); +lean_inc(x_21); +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); + x_22 = x_13; } else { - lean_dec_ref(x_12); - x_20 = lean_box(0); + lean_dec_ref(x_13); + x_22 = lean_box(0); } -if (lean_is_scalar(x_20)) { - x_21 = lean_alloc_ctor(0, 3, 5); +if (lean_is_scalar(x_22)) { + x_23 = lean_alloc_ctor(0, 4, 5); } else { - x_21 = x_20; + x_23 = x_22; } -lean_ctor_set(x_21, 0, x_2); -lean_ctor_set(x_21, 1, x_18); -lean_ctor_set(x_21, 2, x_19); -lean_ctor_set_uint32(x_21, sizeof(void*)*3, x_16); -lean_ctor_set_uint8(x_21, sizeof(void*)*3 + 4, x_17); -x_22 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_22, 0, x_13); -lean_ctor_set(x_22, 1, x_14); -lean_ctor_set(x_22, 2, x_15); -lean_ctor_set(x_22, 3, x_21); -return x_22; +lean_ctor_set(x_23, 0, x_2); +lean_ctor_set(x_23, 1, x_19); +lean_ctor_set(x_23, 2, x_20); +lean_ctor_set(x_23, 3, x_21); +lean_ctor_set_uint32(x_23, sizeof(void*)*4, x_17); +lean_ctor_set_uint8(x_23, sizeof(void*)*4 + 4, x_18); +x_24 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_24, 0, x_14); +lean_ctor_set(x_24, 1, x_15); +lean_ctor_set(x_24, 2, x_16); +lean_ctor_set(x_24, 3, x_23); +return x_24; } } } @@ -2261,76 +2288,83 @@ if (x_4 == 0) { uint8_t x_5; x_5 = 1; -lean_ctor_set_uint8(x_3, sizeof(void*)*3 + 4, x_5); +lean_ctor_set_uint8(x_3, sizeof(void*)*4 + 4, x_5); return x_1; } else { -uint32_t x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; -x_6 = lean_ctor_get_uint32(x_3, sizeof(void*)*3); +uint32_t 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_uint32(x_3, sizeof(void*)*4); x_7 = lean_ctor_get(x_3, 0); x_8 = lean_ctor_get(x_3, 1); x_9 = lean_ctor_get(x_3, 2); +x_10 = lean_ctor_get(x_3, 3); +lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); lean_dec(x_3); -x_10 = 1; -x_11 = lean_alloc_ctor(0, 3, 5); -lean_ctor_set(x_11, 0, x_7); -lean_ctor_set(x_11, 1, x_8); -lean_ctor_set(x_11, 2, x_9); -lean_ctor_set_uint32(x_11, sizeof(void*)*3, x_6); -lean_ctor_set_uint8(x_11, sizeof(void*)*3 + 4, x_10); -lean_ctor_set(x_1, 3, x_11); +x_11 = 1; +x_12 = lean_alloc_ctor(0, 4, 5); +lean_ctor_set(x_12, 0, x_7); +lean_ctor_set(x_12, 1, x_8); +lean_ctor_set(x_12, 2, x_9); +lean_ctor_set(x_12, 3, x_10); +lean_ctor_set_uint32(x_12, sizeof(void*)*4, x_6); +lean_ctor_set_uint8(x_12, sizeof(void*)*4 + 4, x_11); +lean_ctor_set(x_1, 3, x_12); return x_1; } } else { -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint32_t x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_12 = lean_ctor_get(x_1, 3); -x_13 = lean_ctor_get(x_1, 0); -x_14 = lean_ctor_get(x_1, 1); -x_15 = lean_ctor_get(x_1, 2); -lean_inc(x_12); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint32_t x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; lean_object* x_24; lean_object* x_25; +x_13 = lean_ctor_get(x_1, 3); +x_14 = lean_ctor_get(x_1, 0); +x_15 = lean_ctor_get(x_1, 1); +x_16 = lean_ctor_get(x_1, 2); +lean_inc(x_13); +lean_inc(x_16); lean_inc(x_15); lean_inc(x_14); -lean_inc(x_13); lean_dec(x_1); -x_16 = lean_ctor_get_uint32(x_12, sizeof(void*)*3); -x_17 = lean_ctor_get(x_12, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_12, 1); +x_17 = lean_ctor_get_uint32(x_13, sizeof(void*)*4); +x_18 = lean_ctor_get(x_13, 0); lean_inc(x_18); -x_19 = lean_ctor_get(x_12, 2); +x_19 = lean_ctor_get(x_13, 1); lean_inc(x_19); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - x_20 = x_12; +x_20 = lean_ctor_get(x_13, 2); +lean_inc(x_20); +x_21 = lean_ctor_get(x_13, 3); +lean_inc(x_21); +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); + x_22 = x_13; } else { - lean_dec_ref(x_12); - x_20 = lean_box(0); + lean_dec_ref(x_13); + x_22 = lean_box(0); } -x_21 = 1; -if (lean_is_scalar(x_20)) { - x_22 = lean_alloc_ctor(0, 3, 5); +x_23 = 1; +if (lean_is_scalar(x_22)) { + x_24 = lean_alloc_ctor(0, 4, 5); } else { - x_22 = x_20; + x_24 = x_22; } -lean_ctor_set(x_22, 0, x_17); -lean_ctor_set(x_22, 1, x_18); -lean_ctor_set(x_22, 2, x_19); -lean_ctor_set_uint32(x_22, sizeof(void*)*3, x_16); -lean_ctor_set_uint8(x_22, sizeof(void*)*3 + 4, x_21); -x_23 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_23, 0, x_13); -lean_ctor_set(x_23, 1, x_14); -lean_ctor_set(x_23, 2, x_15); -lean_ctor_set(x_23, 3, x_22); -return x_23; +lean_ctor_set(x_24, 0, x_18); +lean_ctor_set(x_24, 1, x_19); +lean_ctor_set(x_24, 2, x_20); +lean_ctor_set(x_24, 3, x_21); +lean_ctor_set_uint32(x_24, sizeof(void*)*4, x_17); +lean_ctor_set_uint8(x_24, sizeof(void*)*4 + 4, x_23); +x_25 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_25, 0, x_14); +lean_ctor_set(x_25, 1, x_15); +lean_ctor_set(x_25, 2, x_16); +lean_ctor_set(x_25, 3, x_24); +return x_25; } } } @@ -2341,7 +2375,7 @@ lean_object* x_2; uint8_t x_3; x_2 = lean_ctor_get(x_1, 3); lean_inc(x_2); lean_dec(x_1); -x_3 = lean_ctor_get_uint8(x_2, sizeof(void*)*3 + 4); +x_3 = lean_ctor_get_uint8(x_2, sizeof(void*)*4 + 4); lean_dec(x_2); return x_3; } @@ -2362,7 +2396,7 @@ lean_object* x_2; uint32_t x_3; x_2 = lean_ctor_get(x_1, 3); lean_inc(x_2); lean_dec(x_1); -x_3 = lean_ctor_get_uint32(x_2, sizeof(void*)*3); +x_3 = lean_ctor_get_uint32(x_2, sizeof(void*)*4); lean_dec(x_2); return x_3; } @@ -3337,12 +3371,13 @@ x_10 = 0; x_11 = lean_box(0); x_12 = l_Array_empty___closed__1; x_13 = l_Lean_NameSet_empty; -x_14 = lean_alloc_ctor(0, 3, 5); +x_14 = lean_alloc_ctor(0, 4, 5); lean_ctor_set(x_14, 0, x_11); lean_ctor_set(x_14, 1, x_12); -lean_ctor_set(x_14, 2, x_13); -lean_ctor_set_uint32(x_14, sizeof(void*)*3, x_1); -lean_ctor_set_uint8(x_14, sizeof(void*)*3 + 4, x_10); +lean_ctor_set(x_14, 2, x_12); +lean_ctor_set(x_14, 3, x_13); +lean_ctor_set_uint32(x_14, sizeof(void*)*4, x_1); +lean_ctor_set_uint8(x_14, sizeof(void*)*4 + 4, x_10); x_15 = l_Std_HashMap_inhabited___closed__1; x_16 = l_Lean_SMap_empty___at_Lean_Environment_Inhabited___spec__2; x_17 = lean_alloc_ctor(0, 4, 0); @@ -3365,12 +3400,13 @@ x_20 = 0; x_21 = lean_box(0); x_22 = l_Array_empty___closed__1; x_23 = l_Lean_NameSet_empty; -x_24 = lean_alloc_ctor(0, 3, 5); +x_24 = lean_alloc_ctor(0, 4, 5); lean_ctor_set(x_24, 0, x_21); lean_ctor_set(x_24, 1, x_22); -lean_ctor_set(x_24, 2, x_23); -lean_ctor_set_uint32(x_24, sizeof(void*)*3, x_1); -lean_ctor_set_uint8(x_24, sizeof(void*)*3 + 4, x_20); +lean_ctor_set(x_24, 2, x_22); +lean_ctor_set(x_24, 3, x_23); +lean_ctor_set_uint32(x_24, sizeof(void*)*4, x_1); +lean_ctor_set_uint8(x_24, sizeof(void*)*4 + 4, x_20); x_25 = l_Std_HashMap_inhabited___closed__1; x_26 = l_Lean_SMap_empty___at_Lean_Environment_Inhabited___spec__2; x_27 = lean_alloc_ctor(0, 4, 0); @@ -8225,6 +8261,94 @@ lean_dec(x_1); return x_3; } } +lean_object* l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; uint8_t x_5; +x_4 = lean_array_get_size(x_1); +x_5 = lean_nat_dec_lt(x_2, x_4); +lean_dec(x_4); +if (x_5 == 0) +{ +lean_object* x_6; lean_object* x_7; +lean_dec(x_2); +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; size_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_8 = lean_array_fget(x_1, x_2); +x_9 = lean_unbox_usize(x_8); +lean_dec(x_8); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_2, x_10); +lean_dec(x_2); +x_12 = lean_compacted_region_free(x_9, x_3); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +x_2 = x_11; +x_3 = x_13; +goto _start; +} +else +{ +uint8_t x_15; +lean_dec(x_11); +x_15 = !lean_is_exclusive(x_12); +if (x_15 == 0) +{ +return x_12; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_12, 0); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_12); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +} +} +} +lean_object* lean_environment_free_regions(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_3 = lean_ctor_get(x_1, 3); +lean_inc(x_3); +lean_dec(x_1); +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +lean_dec(x_3); +x_5 = lean_unsigned_to_nat(0u); +x_6 = l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1(x_4, x_5, x_2); +lean_dec(x_4); +return x_6; +} +} +lean_object* l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Array_forMAux___main___at_Lean_Environment_freeRegions___spec__1(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} lean_object* _init_l_Nat_foldAux___main___at_Lean_mkModuleData___spec__1___closed__1() { _start: { @@ -8666,495 +8790,402 @@ lean_dec(x_5); x_11 = l_Lean_NameSet_contains(x_8, x_10); if (x_11 == 0) { -uint8_t x_12; -x_12 = !lean_is_exclusive(x_2); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_13 = lean_ctor_get(x_2, 1); -lean_dec(x_13); -x_14 = lean_ctor_get(x_2, 0); -lean_dec(x_14); -x_15 = lean_box(0); +lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_dec(x_2); +x_12 = lean_box(0); lean_inc(x_10); -x_16 = l_Std_RBNode_insert___at_Lean_NameSet_insert___spec__1(x_8, x_10, x_15); -x_17 = l_Lean_findOLean(x_10, x_3); +x_13 = l_Std_RBNode_insert___at_Lean_NameSet_insert___spec__1(x_8, x_10, x_12); +x_14 = l_Lean_findOLean(x_10, x_3); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +x_17 = lean_io_file_exists(x_15, x_16); if (lean_obj_tag(x_17) == 0) { -lean_object* x_18; lean_object* x_19; lean_object* x_20; +lean_object* x_18; uint8_t x_19; x_18 = lean_ctor_get(x_17, 0); lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -x_20 = lean_io_file_exists(x_18, x_19); -if (lean_obj_tag(x_20) == 0) +x_19 = lean_unbox(x_18); +lean_dec(x_18); +if (x_19 == 0) { -lean_object* x_21; uint8_t x_22; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_unbox(x_21); -lean_dec(x_21); -if (x_22 == 0) -{ -uint8_t x_23; -lean_dec(x_16); -lean_free_object(x_2); +uint8_t x_20; +lean_dec(x_13); lean_dec(x_9); lean_dec(x_7); -x_23 = !lean_is_exclusive(x_20); -if (x_23 == 0) +x_20 = !lean_is_exclusive(x_17); +if (x_20 == 0) { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_24 = lean_ctor_get(x_20, 0); -lean_dec(x_24); -x_25 = l_Lean_importModulesAux___main___closed__1; -x_26 = lean_string_append(x_25, x_18); -lean_dec(x_18); -x_27 = l_Lean_importModulesAux___main___closed__2; -x_28 = lean_string_append(x_26, x_27); -x_29 = l_Lean_Name_toString___closed__1; -x_30 = l_Lean_Name_toStringWithSep___main(x_29, x_10); -x_31 = lean_string_append(x_28, x_30); -lean_dec(x_30); -x_32 = l_Lean_importModulesAux___main___closed__3; -x_33 = lean_string_append(x_31, x_32); -x_34 = lean_alloc_ctor(18, 1, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set_tag(x_20, 1); -lean_ctor_set(x_20, 0, x_34); -return 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; +x_21 = lean_ctor_get(x_17, 0); +lean_dec(x_21); +x_22 = l_Lean_importModulesAux___main___closed__1; +x_23 = lean_string_append(x_22, x_15); +lean_dec(x_15); +x_24 = l_Lean_importModulesAux___main___closed__2; +x_25 = lean_string_append(x_23, x_24); +x_26 = l_Lean_Name_toString___closed__1; +x_27 = l_Lean_Name_toStringWithSep___main(x_26, x_10); +x_28 = lean_string_append(x_25, x_27); +lean_dec(x_27); +x_29 = l_Lean_importModulesAux___main___closed__3; +x_30 = lean_string_append(x_28, x_29); +x_31 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set_tag(x_17, 1); +lean_ctor_set(x_17, 0, x_31); +return x_17; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_35 = lean_ctor_get(x_20, 1); -lean_inc(x_35); -lean_dec(x_20); -x_36 = l_Lean_importModulesAux___main___closed__1; -x_37 = lean_string_append(x_36, x_18); -lean_dec(x_18); -x_38 = l_Lean_importModulesAux___main___closed__2; -x_39 = lean_string_append(x_37, x_38); -x_40 = l_Lean_Name_toString___closed__1; -x_41 = l_Lean_Name_toStringWithSep___main(x_40, x_10); -x_42 = lean_string_append(x_39, x_41); -lean_dec(x_41); -x_43 = l_Lean_importModulesAux___main___closed__3; -x_44 = lean_string_append(x_42, x_43); -x_45 = lean_alloc_ctor(18, 1, 0); -lean_ctor_set(x_45, 0, x_44); -x_46 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_35); -return x_46; +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_17, 1); +lean_inc(x_32); +lean_dec(x_17); +x_33 = l_Lean_importModulesAux___main___closed__1; +x_34 = lean_string_append(x_33, x_15); +lean_dec(x_15); +x_35 = l_Lean_importModulesAux___main___closed__2; +x_36 = lean_string_append(x_34, x_35); +x_37 = l_Lean_Name_toString___closed__1; +x_38 = l_Lean_Name_toStringWithSep___main(x_37, x_10); +x_39 = lean_string_append(x_36, x_38); +lean_dec(x_38); +x_40 = l_Lean_importModulesAux___main___closed__3; +x_41 = lean_string_append(x_39, x_40); +x_42 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_42, 0, x_41); +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_32); +return x_43; } } else { -lean_object* x_47; lean_object* x_48; +lean_object* x_44; lean_object* x_45; lean_dec(x_10); -x_47 = lean_ctor_get(x_20, 1); +x_44 = lean_ctor_get(x_17, 1); +lean_inc(x_44); +lean_dec(x_17); +x_45 = lean_read_module_data(x_15, x_44); +lean_dec(x_15); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +x_47 = lean_ctor_get(x_45, 1); lean_inc(x_47); -lean_dec(x_20); -x_48 = lean_read_module_data(x_18, x_47); -lean_dec(x_18); -if (lean_obj_tag(x_48) == 0) +lean_dec(x_45); +x_48 = !lean_is_exclusive(x_46); +if (x_48 == 0) { lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); +x_49 = lean_ctor_get(x_46, 0); +x_50 = lean_ctor_get(x_46, 1); x_51 = lean_ctor_get(x_49, 0); lean_inc(x_51); x_52 = l_Array_toList___rarg(x_51); lean_dec(x_51); -lean_ctor_set(x_2, 0, x_16); -x_53 = l_Lean_importModulesAux___main(x_52, x_2, x_50); +lean_ctor_set(x_46, 1, x_9); +lean_ctor_set(x_46, 0, x_13); +x_53 = l_Lean_importModulesAux___main(x_52, x_46, x_47); if (lean_obj_tag(x_53) == 0) { -lean_object* x_54; lean_object* x_55; uint8_t x_56; +lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; x_54 = lean_ctor_get(x_53, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_53, 1); +x_55 = lean_ctor_get(x_54, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_53, 1); +lean_inc(x_56); lean_dec(x_53); -x_56 = !lean_is_exclusive(x_54); -if (x_56 == 0) +x_57 = !lean_is_exclusive(x_54); +if (x_57 == 0) { -lean_object* x_57; lean_object* x_58; -x_57 = lean_ctor_get(x_54, 1); -x_58 = lean_array_push(x_57, x_49); -lean_ctor_set(x_54, 1, x_58); -x_1 = x_7; -x_2 = x_54; -x_3 = x_55; -goto _start; -} -else +lean_object* x_58; uint8_t x_59; +x_58 = lean_ctor_get(x_54, 1); +lean_dec(x_58); +x_59 = !lean_is_exclusive(x_55); +if (x_59 == 0) { lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_60 = lean_ctor_get(x_54, 0); -x_61 = lean_ctor_get(x_54, 1); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_54); -x_62 = lean_array_push(x_61, x_49); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_62); +x_60 = lean_ctor_get(x_55, 0); +x_61 = lean_ctor_get(x_55, 1); +x_62 = lean_array_push(x_60, x_49); +x_63 = lean_array_push(x_61, x_50); +lean_ctor_set(x_55, 1, x_63); +lean_ctor_set(x_55, 0, x_62); x_1 = x_7; -x_2 = x_63; -x_3 = x_55; +x_2 = x_54; +x_3 = x_56; +goto _start; +} +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_55, 0); +x_66 = lean_ctor_get(x_55, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_55); +x_67 = lean_array_push(x_65, x_49); +x_68 = lean_array_push(x_66, x_50); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_67); +lean_ctor_set(x_69, 1, x_68); +lean_ctor_set(x_54, 1, x_69); +x_1 = x_7; +x_2 = x_54; +x_3 = x_56; goto _start; } } else { -uint8_t x_65; +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_71 = lean_ctor_get(x_54, 0); +lean_inc(x_71); +lean_dec(x_54); +x_72 = lean_ctor_get(x_55, 0); +lean_inc(x_72); +x_73 = lean_ctor_get(x_55, 1); +lean_inc(x_73); +if (lean_is_exclusive(x_55)) { + lean_ctor_release(x_55, 0); + lean_ctor_release(x_55, 1); + x_74 = x_55; +} else { + lean_dec_ref(x_55); + x_74 = lean_box(0); +} +x_75 = lean_array_push(x_72, x_49); +x_76 = lean_array_push(x_73, x_50); +if (lean_is_scalar(x_74)) { + x_77 = lean_alloc_ctor(0, 2, 0); +} else { + x_77 = x_74; +} +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_71); +lean_ctor_set(x_78, 1, x_77); +x_1 = x_7; +x_2 = x_78; +x_3 = x_56; +goto _start; +} +} +else +{ +uint8_t x_80; +lean_dec(x_50); lean_dec(x_49); lean_dec(x_7); -x_65 = !lean_is_exclusive(x_53); -if (x_65 == 0) +x_80 = !lean_is_exclusive(x_53); +if (x_80 == 0) { return x_53; } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_53, 0); -x_67 = lean_ctor_get(x_53, 1); -lean_inc(x_67); -lean_inc(x_66); +lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_81 = lean_ctor_get(x_53, 0); +x_82 = lean_ctor_get(x_53, 1); +lean_inc(x_82); +lean_inc(x_81); lean_dec(x_53); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_66); -lean_ctor_set(x_68, 1, x_67); -return x_68; +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; } } } else { -uint8_t x_69; -lean_dec(x_16); -lean_free_object(x_2); +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_84 = lean_ctor_get(x_46, 0); +x_85 = lean_ctor_get(x_46, 1); +lean_inc(x_85); +lean_inc(x_84); +lean_dec(x_46); +x_86 = lean_ctor_get(x_84, 0); +lean_inc(x_86); +x_87 = l_Array_toList___rarg(x_86); +lean_dec(x_86); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_13); +lean_ctor_set(x_88, 1, x_9); +x_89 = l_Lean_importModulesAux___main(x_87, x_88, x_47); +if (lean_obj_tag(x_89) == 0) +{ +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_90 = lean_ctor_get(x_89, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_90, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_89, 1); +lean_inc(x_92); +lean_dec(x_89); +x_93 = lean_ctor_get(x_90, 0); +lean_inc(x_93); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + x_94 = x_90; +} else { + lean_dec_ref(x_90); + x_94 = lean_box(0); +} +x_95 = lean_ctor_get(x_91, 0); +lean_inc(x_95); +x_96 = lean_ctor_get(x_91, 1); +lean_inc(x_96); +if (lean_is_exclusive(x_91)) { + lean_ctor_release(x_91, 0); + lean_ctor_release(x_91, 1); + x_97 = x_91; +} else { + lean_dec_ref(x_91); + x_97 = lean_box(0); +} +x_98 = lean_array_push(x_95, x_84); +x_99 = lean_array_push(x_96, x_85); +if (lean_is_scalar(x_97)) { + x_100 = lean_alloc_ctor(0, 2, 0); +} else { + x_100 = x_97; +} +lean_ctor_set(x_100, 0, x_98); +lean_ctor_set(x_100, 1, x_99); +if (lean_is_scalar(x_94)) { + x_101 = lean_alloc_ctor(0, 2, 0); +} else { + x_101 = x_94; +} +lean_ctor_set(x_101, 0, x_93); +lean_ctor_set(x_101, 1, x_100); +x_1 = x_7; +x_2 = x_101; +x_3 = x_92; +goto _start; +} +else +{ +lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; +lean_dec(x_85); +lean_dec(x_84); +lean_dec(x_7); +x_103 = lean_ctor_get(x_89, 0); +lean_inc(x_103); +x_104 = lean_ctor_get(x_89, 1); +lean_inc(x_104); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + x_105 = x_89; +} else { + lean_dec_ref(x_89); + x_105 = lean_box(0); +} +if (lean_is_scalar(x_105)) { + x_106 = lean_alloc_ctor(1, 2, 0); +} else { + x_106 = x_105; +} +lean_ctor_set(x_106, 0, x_103); +lean_ctor_set(x_106, 1, x_104); +return x_106; +} +} +} +else +{ +uint8_t x_107; +lean_dec(x_13); lean_dec(x_9); lean_dec(x_7); -x_69 = !lean_is_exclusive(x_48); -if (x_69 == 0) +x_107 = !lean_is_exclusive(x_45); +if (x_107 == 0) { -return x_48; +return x_45; } else { -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_48, 0); -x_71 = lean_ctor_get(x_48, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_48); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_45, 0); +x_109 = lean_ctor_get(x_45, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_45); +x_110 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_110, 0, x_108); +lean_ctor_set(x_110, 1, x_109); +return x_110; } } } } else { -uint8_t x_73; -lean_dec(x_18); -lean_dec(x_16); -lean_free_object(x_2); +uint8_t x_111; +lean_dec(x_15); +lean_dec(x_13); lean_dec(x_10); lean_dec(x_9); lean_dec(x_7); -x_73 = !lean_is_exclusive(x_20); -if (x_73 == 0) -{ -return x_20; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_20, 0); -x_75 = lean_ctor_get(x_20, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_20); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_16); -lean_free_object(x_2); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -x_77 = !lean_is_exclusive(x_17); -if (x_77 == 0) +x_111 = !lean_is_exclusive(x_17); +if (x_111 == 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_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; -} -} -} -else -{ -lean_object* x_81; lean_object* x_82; lean_object* x_83; -lean_dec(x_2); -x_81 = lean_box(0); -lean_inc(x_10); -x_82 = l_Std_RBNode_insert___at_Lean_NameSet_insert___spec__1(x_8, x_10, x_81); -x_83 = l_Lean_findOLean(x_10, x_3); -if (lean_obj_tag(x_83) == 0) -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_83, 1); -lean_inc(x_85); -lean_dec(x_83); -x_86 = lean_io_file_exists(x_84, x_85); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_86, 0); -lean_inc(x_87); -x_88 = lean_unbox(x_87); -lean_dec(x_87); -if (x_88 == 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_dec(x_82); -lean_dec(x_9); -lean_dec(x_7); -x_89 = lean_ctor_get(x_86, 1); -lean_inc(x_89); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_90 = x_86; -} else { - lean_dec_ref(x_86); - x_90 = lean_box(0); -} -x_91 = l_Lean_importModulesAux___main___closed__1; -x_92 = lean_string_append(x_91, x_84); -lean_dec(x_84); -x_93 = l_Lean_importModulesAux___main___closed__2; -x_94 = lean_string_append(x_92, x_93); -x_95 = l_Lean_Name_toString___closed__1; -x_96 = l_Lean_Name_toStringWithSep___main(x_95, x_10); -x_97 = lean_string_append(x_94, x_96); -lean_dec(x_96); -x_98 = l_Lean_importModulesAux___main___closed__3; -x_99 = lean_string_append(x_97, x_98); -x_100 = lean_alloc_ctor(18, 1, 0); -lean_ctor_set(x_100, 0, x_99); -if (lean_is_scalar(x_90)) { - x_101 = lean_alloc_ctor(1, 2, 0); -} else { - x_101 = x_90; - lean_ctor_set_tag(x_101, 1); -} -lean_ctor_set(x_101, 0, x_100); -lean_ctor_set(x_101, 1, x_89); -return x_101; -} -else -{ -lean_object* x_102; lean_object* x_103; -lean_dec(x_10); -x_102 = lean_ctor_get(x_86, 1); -lean_inc(x_102); -lean_dec(x_86); -x_103 = lean_read_module_data(x_84, x_102); -lean_dec(x_84); -if (lean_obj_tag(x_103) == 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; -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_ctor_get(x_104, 0); -lean_inc(x_106); -x_107 = l_Array_toList___rarg(x_106); -lean_dec(x_106); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_82); -lean_ctor_set(x_108, 1, x_9); -x_109 = l_Lean_importModulesAux___main(x_107, x_108, x_105); -if (lean_obj_tag(x_109) == 0) -{ -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_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_ctor_get(x_110, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_110, 1); +lean_object* x_112; lean_object* x_113; lean_object* x_114; +x_112 = lean_ctor_get(x_17, 0); +x_113 = lean_ctor_get(x_17, 1); lean_inc(x_113); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_114 = x_110; -} else { - lean_dec_ref(x_110); - x_114 = lean_box(0); -} -x_115 = lean_array_push(x_113, x_104); -if (lean_is_scalar(x_114)) { - x_116 = lean_alloc_ctor(0, 2, 0); -} else { - x_116 = x_114; -} -lean_ctor_set(x_116, 0, x_112); -lean_ctor_set(x_116, 1, x_115); -x_1 = x_7; -x_2 = x_116; -x_3 = x_111; -goto _start; -} -else -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -lean_dec(x_104); -lean_dec(x_7); -x_118 = lean_ctor_get(x_109, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_109, 1); -lean_inc(x_119); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - 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(1, 2, 0); -} else { - x_121 = x_120; -} -lean_ctor_set(x_121, 0, x_118); -lean_ctor_set(x_121, 1, x_119); -return x_121; -} -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; -lean_dec(x_82); -lean_dec(x_9); -lean_dec(x_7); -x_122 = lean_ctor_get(x_103, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_103, 1); -lean_inc(x_123); -if (lean_is_exclusive(x_103)) { - lean_ctor_release(x_103, 0); - lean_ctor_release(x_103, 1); - x_124 = x_103; -} else { - lean_dec_ref(x_103); - x_124 = lean_box(0); -} -if (lean_is_scalar(x_124)) { - x_125 = lean_alloc_ctor(1, 2, 0); -} else { - x_125 = x_124; -} -lean_ctor_set(x_125, 0, x_122); -lean_ctor_set(x_125, 1, x_123); -return x_125; +lean_inc(x_112); +lean_dec(x_17); +x_114 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_114, 0, x_112); +lean_ctor_set(x_114, 1, x_113); +return x_114; } } } else { -lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; -lean_dec(x_84); -lean_dec(x_82); +uint8_t x_115; +lean_dec(x_13); lean_dec(x_10); lean_dec(x_9); lean_dec(x_7); -x_126 = lean_ctor_get(x_86, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_86, 1); -lean_inc(x_127); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_128 = x_86; -} else { - lean_dec_ref(x_86); - x_128 = lean_box(0); -} -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(1, 2, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -return x_129; -} +x_115 = !lean_is_exclusive(x_14); +if (x_115 == 0) +{ +return x_14; } else { -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; -lean_dec(x_82); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -x_130 = lean_ctor_get(x_83, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_83, 1); -lean_inc(x_131); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_132 = x_83; -} else { - lean_dec_ref(x_83); - x_132 = lean_box(0); -} -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(1, 2, 0); -} else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_130); -lean_ctor_set(x_133, 1, x_131); -return x_133; +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_14, 0); +x_117 = lean_ctor_get(x_14, 1); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_14); +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; } } } @@ -9169,12 +9200,12 @@ goto _start; } else { -lean_object* x_135; +lean_object* x_120; lean_dec(x_5); -x_135 = lean_ctor_get(x_1, 1); -lean_inc(x_135); +x_120 = lean_ctor_get(x_1, 1); +lean_inc(x_120); lean_dec(x_1); -x_1 = x_135; +x_1 = x_120; goto _start; } } @@ -10441,9 +10472,20 @@ return x_20; lean_object* _init_l_Lean_importModules___closed__1() { _start: { +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_empty___closed__1; +x_2 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_2, 0, x_1); +lean_ctor_set(x_2, 1, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_importModules___closed__2() { +_start: +{ lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_NameSet_empty; -x_2 = l_Array_empty___closed__1; +x_2 = l_Lean_importModules___closed__1; x_3 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_3, 0, x_1); lean_ctor_set(x_3, 1, x_2); @@ -10454,385 +10496,394 @@ lean_object* lean_import_modules(lean_object* x_1, uint32_t x_2, lean_object* x_ _start: { lean_object* x_4; lean_object* x_5; -x_4 = l_Lean_importModules___closed__1; +x_4 = l_Lean_importModules___closed__2; lean_inc(x_1); x_5 = l_Lean_importModulesAux___main(x_1, x_4, x_3); if (lean_obj_tag(x_5) == 0) { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; 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_6, 1); lean_inc(x_7); -lean_dec(x_5); -x_8 = lean_ctor_get(x_6, 0); +x_8 = lean_ctor_get(x_5, 1); lean_inc(x_8); -x_9 = lean_ctor_get(x_6, 1); +lean_dec(x_5); +x_9 = lean_ctor_get(x_6, 0); lean_inc(x_9); lean_dec(x_6); -x_10 = lean_unsigned_to_nat(0u); -x_11 = l_Std_HashMap_inhabited___closed__1; -x_12 = l_Array_iterateMAux___main___at_Lean_importModules___spec__8(x_9, x_9, x_10, x_11); -x_13 = l_Lean_SMap_empty___at_Lean_Environment_Inhabited___spec__2; -x_14 = l_Array_iterateMAux___main___at_Lean_importModules___spec__10(x_9, x_9, x_10, x_13, x_7); -if (lean_obj_tag(x_14) == 0) +x_10 = lean_ctor_get(x_7, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_7, 1); +lean_inc(x_11); +lean_dec(x_7); +x_12 = lean_unsigned_to_nat(0u); +x_13 = l_Std_HashMap_inhabited___closed__1; +x_14 = l_Array_iterateMAux___main___at_Lean_importModules___spec__8(x_10, x_10, x_12, x_13); +x_15 = l_Lean_SMap_empty___at_Lean_Environment_Inhabited___spec__2; +x_16 = l_Array_iterateMAux___main___at_Lean_importModules___spec__10(x_10, x_10, x_12, x_15, x_8); +if (lean_obj_tag(x_16) == 0) { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = l_Lean_SMap_switch___at_Lean_importModules___spec__11(x_15); -x_18 = l___private_Lean_Environment_6__mkInitialExtensionStates(x_16); -if (lean_obj_tag(x_18) == 0) +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); +lean_inc(x_18); +lean_dec(x_16); +x_19 = l_Lean_SMap_switch___at_Lean_importModules___spec__11(x_17); +x_20 = l___private_Lean_Environment_6__mkInitialExtensionStates(x_18); +if (lean_obj_tag(x_20) == 0) { -lean_object* x_19; lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_18, 1); -lean_inc(x_20); -lean_dec(x_18); -x_21 = l_List_isEmpty___rarg(x_1); -x_22 = l_List_redLength___main___rarg(x_1); -x_23 = lean_mk_empty_array_with_capacity(x_22); -lean_dec(x_22); -x_24 = l_List_toArrayAux___main___rarg(x_1, x_23); -if (x_21 == 0) +lean_object* x_21; lean_object* x_22; uint8_t x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = l_List_isEmpty___rarg(x_1); +x_24 = l_List_redLength___main___rarg(x_1); +x_25 = lean_mk_empty_array_with_capacity(x_24); +lean_dec(x_24); +x_26 = l_List_toArrayAux___main___rarg(x_1, x_25); +if (x_23 == 0) { -uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_25 = 1; -x_26 = lean_box(0); -x_27 = lean_alloc_ctor(0, 3, 5); -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_24); -lean_ctor_set(x_27, 2, x_8); -lean_ctor_set_uint32(x_27, sizeof(void*)*3, x_2); -lean_ctor_set_uint8(x_27, sizeof(void*)*3 + 4, x_25); -x_28 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_28, 0, x_12); -lean_ctor_set(x_28, 1, x_17); -lean_ctor_set(x_28, 2, x_19); -lean_ctor_set(x_28, 3, x_27); -x_29 = l___private_Lean_Environment_10__setImportedEntries(x_28, x_9, x_20); -if (lean_obj_tag(x_29) == 0) +uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_27 = 1; +x_28 = lean_box(0); +x_29 = lean_alloc_ctor(0, 4, 5); +lean_ctor_set(x_29, 0, x_28); +lean_ctor_set(x_29, 1, x_26); +lean_ctor_set(x_29, 2, x_11); +lean_ctor_set(x_29, 3, x_9); +lean_ctor_set_uint32(x_29, sizeof(void*)*4, x_2); +lean_ctor_set_uint8(x_29, sizeof(void*)*4 + 4, x_27); +x_30 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_30, 0, x_14); +lean_ctor_set(x_30, 1, x_19); +lean_ctor_set(x_30, 2, x_21); +lean_ctor_set(x_30, 3, x_29); +x_31 = l___private_Lean_Environment_10__setImportedEntries(x_30, x_10, x_22); +if (lean_obj_tag(x_31) == 0) { -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); -x_32 = l___private_Lean_Environment_11__finalizePersistentExtensions(x_30, x_31); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_32, 0); +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_31, 1); lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Array_iterateMAux___main___at_Lean_importModules___spec__12(x_9, x_9, x_10, x_33, x_34); -lean_dec(x_9); -if (lean_obj_tag(x_35) == 0) +lean_dec(x_31); +x_34 = l___private_Lean_Environment_11__finalizePersistentExtensions(x_32, x_33); +if (lean_obj_tag(x_34) == 0) { -uint8_t x_36; -x_36 = !lean_is_exclusive(x_35); -if (x_36 == 0) +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); +lean_dec(x_34); +x_37 = l_Array_iterateMAux___main___at_Lean_importModules___spec__12(x_10, x_10, x_12, x_35, x_36); +lean_dec(x_10); +if (lean_obj_tag(x_37) == 0) { -return x_35; +uint8_t x_38; +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) +{ +return x_37; } else { -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_35, 0); -x_38 = lean_ctor_get(x_35, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_35); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_37); -lean_ctor_set(x_39, 1, x_38); -return x_39; +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_37, 0); +x_40 = lean_ctor_get(x_37, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_37); +x_41 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; } } else { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_35); -if (x_40 == 0) +uint8_t x_42; +x_42 = !lean_is_exclusive(x_37); +if (x_42 == 0) { -return x_35; +return x_37; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_35, 0); -x_42 = lean_ctor_get(x_35, 1); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_35); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_41); -lean_ctor_set(x_43, 1, x_42); -return x_43; +lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_43 = lean_ctor_get(x_37, 0); +x_44 = lean_ctor_get(x_37, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_37); +x_45 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_44); +return x_45; } } } else { -uint8_t x_44; -lean_dec(x_9); -x_44 = !lean_is_exclusive(x_32); -if (x_44 == 0) +uint8_t x_46; +lean_dec(x_10); +x_46 = !lean_is_exclusive(x_34); +if (x_46 == 0) { -return x_32; +return x_34; } else { -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_32, 0); -x_46 = lean_ctor_get(x_32, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_32); -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; +lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_47 = lean_ctor_get(x_34, 0); +x_48 = lean_ctor_get(x_34, 1); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_34); +x_49 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_49, 0, x_47); +lean_ctor_set(x_49, 1, x_48); +return x_49; } } } else { -uint8_t x_48; -lean_dec(x_9); -x_48 = !lean_is_exclusive(x_29); -if (x_48 == 0) +uint8_t x_50; +lean_dec(x_10); +x_50 = !lean_is_exclusive(x_31); +if (x_50 == 0) { -return x_29; +return x_31; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_29, 0); -x_50 = lean_ctor_get(x_29, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_29); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_31, 0); +x_52 = lean_ctor_get(x_31, 1); +lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_31); +x_53 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_53, 0, x_51); +lean_ctor_set(x_53, 1, x_52); +return x_53; } } } else { -uint8_t x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_52 = 0; -x_53 = lean_box(0); -x_54 = lean_alloc_ctor(0, 3, 5); -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_24); -lean_ctor_set(x_54, 2, x_8); -lean_ctor_set_uint32(x_54, sizeof(void*)*3, x_2); -lean_ctor_set_uint8(x_54, sizeof(void*)*3 + 4, x_52); -x_55 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_55, 0, x_12); -lean_ctor_set(x_55, 1, x_17); -lean_ctor_set(x_55, 2, x_19); -lean_ctor_set(x_55, 3, x_54); -x_56 = l___private_Lean_Environment_10__setImportedEntries(x_55, x_9, x_20); -if (lean_obj_tag(x_56) == 0) +uint8_t x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_54 = 0; +x_55 = lean_box(0); +x_56 = lean_alloc_ctor(0, 4, 5); +lean_ctor_set(x_56, 0, x_55); +lean_ctor_set(x_56, 1, x_26); +lean_ctor_set(x_56, 2, x_11); +lean_ctor_set(x_56, 3, x_9); +lean_ctor_set_uint32(x_56, sizeof(void*)*4, x_2); +lean_ctor_set_uint8(x_56, sizeof(void*)*4 + 4, x_54); +x_57 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_57, 0, x_14); +lean_ctor_set(x_57, 1, x_19); +lean_ctor_set(x_57, 2, x_21); +lean_ctor_set(x_57, 3, x_56); +x_58 = l___private_Lean_Environment_10__setImportedEntries(x_57, x_10, x_22); +if (lean_obj_tag(x_58) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -lean_dec(x_56); -x_59 = l___private_Lean_Environment_11__finalizePersistentExtensions(x_57, x_58); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_59, 0); +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_58, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_58, 1); lean_inc(x_60); -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); -x_62 = l_Array_iterateMAux___main___at_Lean_importModules___spec__13(x_9, x_9, x_10, x_60, x_61); -lean_dec(x_9); -if (lean_obj_tag(x_62) == 0) +lean_dec(x_58); +x_61 = l___private_Lean_Environment_11__finalizePersistentExtensions(x_59, x_60); +if (lean_obj_tag(x_61) == 0) { -uint8_t x_63; -x_63 = !lean_is_exclusive(x_62); -if (x_63 == 0) +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +x_63 = lean_ctor_get(x_61, 1); +lean_inc(x_63); +lean_dec(x_61); +x_64 = l_Array_iterateMAux___main___at_Lean_importModules___spec__13(x_10, x_10, x_12, x_62, x_63); +lean_dec(x_10); +if (lean_obj_tag(x_64) == 0) { -return x_62; +uint8_t x_65; +x_65 = !lean_is_exclusive(x_64); +if (x_65 == 0) +{ +return x_64; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_62, 0); -x_65 = lean_ctor_get(x_62, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_62); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_64); -lean_ctor_set(x_66, 1, x_65); -return x_66; +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_64, 0); +x_67 = lean_ctor_get(x_64, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_64); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; } } else { -uint8_t x_67; -x_67 = !lean_is_exclusive(x_62); -if (x_67 == 0) +uint8_t x_69; +x_69 = !lean_is_exclusive(x_64); +if (x_69 == 0) { -return x_62; +return x_64; } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_62, 0); -x_69 = lean_ctor_get(x_62, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_62); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_64, 0); +x_71 = lean_ctor_get(x_64, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_64); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } } else { -uint8_t x_71; -lean_dec(x_9); -x_71 = !lean_is_exclusive(x_59); -if (x_71 == 0) +uint8_t x_73; +lean_dec(x_10); +x_73 = !lean_is_exclusive(x_61); +if (x_73 == 0) { -return x_59; +return x_61; } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_59, 0); -x_73 = lean_ctor_get(x_59, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_59); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_61, 0); +x_75 = lean_ctor_get(x_61, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_61); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; } } } else { -uint8_t x_75; -lean_dec(x_9); -x_75 = !lean_is_exclusive(x_56); -if (x_75 == 0) +uint8_t x_77; +lean_dec(x_10); +x_77 = !lean_is_exclusive(x_58); +if (x_77 == 0) { -return x_56; +return x_58; } else { -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_56, 0); -x_77 = lean_ctor_get(x_56, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_56); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_58, 0); +x_79 = lean_ctor_get(x_58, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_58); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; } } } } else { -uint8_t x_79; -lean_dec(x_17); -lean_dec(x_12); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_18); -if (x_79 == 0) -{ -return x_18; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_18, 0); -x_81 = lean_ctor_get(x_18, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_18); -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_12); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_1); -x_83 = !lean_is_exclusive(x_14); -if (x_83 == 0) -{ -return x_14; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_14, 0); -x_85 = lean_ctor_get(x_14, 1); -lean_inc(x_85); -lean_inc(x_84); +uint8_t x_81; +lean_dec(x_19); lean_dec(x_14); -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_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_1); +x_81 = !lean_is_exclusive(x_20); +if (x_81 == 0) +{ +return x_20; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_20, 0); +x_83 = lean_ctor_get(x_20, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_20); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; } } } else { -uint8_t x_87; +uint8_t x_85; +lean_dec(x_14); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); lean_dec(x_1); -x_87 = !lean_is_exclusive(x_5); -if (x_87 == 0) +x_85 = !lean_is_exclusive(x_16); +if (x_85 == 0) +{ +return x_16; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_16, 0); +x_87 = lean_ctor_get(x_16, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_16); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +else +{ +uint8_t x_89; +lean_dec(x_1); +x_89 = !lean_is_exclusive(x_5); +if (x_89 == 0) { return x_5; } else { -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_5, 0); -x_89 = lean_ctor_get(x_5, 1); -lean_inc(x_89); -lean_inc(x_88); +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_5, 0); +x_91 = lean_ctor_get(x_5, 1); +lean_inc(x_91); +lean_inc(x_90); lean_dec(x_5); -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; +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +return x_92; } } } @@ -10919,6 +10970,180 @@ x_5 = lean_import_modules(x_1, x_4, x_3); return x_5; } } +lean_object* l_Lean_withImportModules___rarg(lean_object* x_1, uint32_t x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = lean_import_modules(x_1, x_2, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_6); +x_8 = lean_apply_2(x_3, x_6, x_7); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = lean_environment_free_regions(x_6, x_10); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_11, 0); +lean_dec(x_13); +lean_ctor_set(x_11, 0, x_9); +return x_11; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_11, 1); +lean_inc(x_14); +lean_dec(x_11); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_9); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +else +{ +uint8_t x_16; +lean_dec(x_9); +x_16 = !lean_is_exclusive(x_11); +if (x_16 == 0) +{ +return x_11; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_8, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_8, 1); +lean_inc(x_21); +lean_dec(x_8); +x_22 = lean_environment_free_regions(x_6, x_21); +if (lean_obj_tag(x_22) == 0) +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; +x_24 = lean_ctor_get(x_22, 0); +lean_dec(x_24); +lean_ctor_set_tag(x_22, 1); +lean_ctor_set(x_22, 0, x_20); +return x_22; +} +else +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_22, 1); +lean_inc(x_25); +lean_dec(x_22); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_20); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +else +{ +uint8_t x_27; +lean_dec(x_20); +x_27 = !lean_is_exclusive(x_22); +if (x_27 == 0) +{ +return x_22; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_22, 0); +x_29 = lean_ctor_get(x_22, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_22); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +} +else +{ +uint8_t x_31; +lean_dec(x_3); +x_31 = !lean_is_exclusive(x_5); +if (x_31 == 0) +{ +return x_5; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_5, 0); +x_33 = lean_ctor_get(x_5, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_5); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +} +lean_object* l_Lean_withImportModules(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_withImportModules___rarg___boxed), 4, 0); +return x_2; +} +} +lean_object* l_Lean_withImportModules___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint32_t x_5; lean_object* x_6; +x_5 = lean_unbox_uint32(x_2); +lean_dec(x_2); +x_6 = l_Lean_withImportModules___rarg(x_1, x_5, x_3, x_4); +return x_6; +} +} lean_object* l_Array_iterateMAux___main___at_Lean_regNamespacesExtension___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -11993,7 +12218,7 @@ x_40 = l_Nat_repr(x_39); x_41 = l_Lean_Environment_displayStats___closed__6; x_42 = lean_string_append(x_41, x_40); lean_dec(x_40); -x_43 = lean_ctor_get_uint32(x_14, sizeof(void*)*3); +x_43 = lean_ctor_get_uint32(x_14, sizeof(void*)*4); lean_dec(x_14); x_44 = lean_uint32_to_nat(x_43); x_45 = l_Nat_repr(x_44); @@ -13396,6 +13621,8 @@ l_Array_iterateMAux___main___at_Lean_importModules___spec__9___closed__1 = _init lean_mark_persistent(l_Array_iterateMAux___main___at_Lean_importModules___spec__9___closed__1); l_Lean_importModules___closed__1 = _init_l_Lean_importModules___closed__1(); lean_mark_persistent(l_Lean_importModules___closed__1); +l_Lean_importModules___closed__2 = _init_l_Lean_importModules___closed__2(); +lean_mark_persistent(l_Lean_importModules___closed__2); l_Lean_regNamespacesExtension___closed__1 = _init_l_Lean_regNamespacesExtension___closed__1(); lean_mark_persistent(l_Lean_regNamespacesExtension___closed__1); l_Lean_regNamespacesExtension___closed__2 = _init_l_Lean_regNamespacesExtension___closed__2(); diff --git a/stage0/stdlib/Lean/Expr.c b/stage0/stdlib/Lean/Expr.c index 7c27c989d2..21e8a211b4 100644 --- a/stage0/stdlib/Lean/Expr.c +++ b/stage0/stdlib/Lean/Expr.c @@ -16,6 +16,7 @@ extern "C" { lean_object* l_Lean_Expr_isBinding___boxed(lean_object*); lean_object* l_Lean_Expr_letName_x21___closed__2; lean_object* l___private_Lean_Expr_8__etaExpandedBody(lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_bindingInfo_x21(lean_object*); lean_object* l_Lean_Expr_updateSort___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_forall(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_List_map___main___at_Lean_Expr_instantiateLevelParamsArray___spec__4___boxed(lean_object*, lean_object*, lean_object*); @@ -64,6 +65,7 @@ lean_object* l_Lean_Expr_isLit___boxed(lean_object*); lean_object* l_Lean_Literal_hashable; uint64_t l_UInt64_add(uint64_t, uint64_t); lean_object* l_Lean_Expr_withAppAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_bindingInfo_x21___closed__1; uint64_t l_Bool_toUInt64(uint8_t); lean_object* l_Lean_Expr_updateMData_x21___closed__2; lean_object* l_Lean_Expr_instantiateLevelParamsArray___boxed(lean_object*, lean_object*, lean_object*); @@ -108,6 +110,7 @@ lean_object* l_Lean_Expr_binderInfoEx___boxed(lean_object*); lean_object* l_Lean_Expr_InstantiateLevelParams_instantiate___main___at_Lean_Expr_instantiateLevelParams___spec__1(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isApp(lean_object*); lean_object* l_Lean_Expr_Data_binderInfo___boxed(lean_object*); +uint8_t l_Lean_Expr_hasLooseBVarInExplicitDomain(lean_object*, lean_object*, uint8_t); lean_object* l_Lean_Expr_hasFVarEx___boxed(lean_object*); size_t l_Lean_Level_hash(lean_object*); lean_object* l_Lean_Expr_lt___boxed(lean_object*, lean_object*); @@ -185,6 +188,7 @@ lean_object* lean_expr_lower_loose_bvars(lean_object*, lean_object*, lean_object lean_object* l_Lean_Expr_isMVar___boxed(lean_object*); uint8_t l_Lean_Expr_Data_hasExprMVar(uint64_t); lean_object* l_Lean_Literal_type(lean_object*); +lean_object* l_Lean_Expr_hasLooseBVarInExplicitDomain___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Literal_beq___boxed(lean_object*, lean_object*); lean_object* l_Lean_Expr_isConstOf___boxed(lean_object*, lean_object*); lean_object* l___private_Lean_Expr_1__Expr_mkDataCore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -413,6 +417,7 @@ lean_object* l_Lean_Expr_updateFn___main(lean_object*, lean_object*); lean_object* l_Lean_mkApp7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_updateLambda_x21___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_mk_proj(lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_hasLooseBVarInExplicitDomain___main(lean_object*, lean_object*, uint8_t); lean_object* l_Lean_Expr_appFn_x21___closed__2; lean_object* l_List_foldl___main___at_Lean_mkConst___spec__2___boxed(lean_object*, lean_object*); lean_object* l_Lean_Expr_Data_hasExprMVar___boxed(lean_object*); @@ -430,6 +435,7 @@ lean_object* l_Lean_Expr_isStringLit___boxed(lean_object*); lean_object* l_Lean_Expr_withAppRev(lean_object*); lean_object* l_Lean_Expr_quickLt___boxed(lean_object*, lean_object*); uint64_t l_UInt32_toUInt64(uint32_t); +lean_object* l_Lean_Expr_inferImplicit___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_BinderInfo_isAuxDecl___boxed(lean_object*); uint8_t l_Lean_Expr_isFVar(lean_object*); lean_object* l___private_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); @@ -477,8 +483,10 @@ lean_object* l_Lean_Expr_InstantiateLevelParams_instantiate___main___at_Lean_Exp uint8_t l_Lean_Expr_Data_hasBeq(uint64_t, uint64_t); lean_object* l___private_Lean_Expr_6__mkAppRevRangeAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint32_t lean_expr_loose_bvar_range(lean_object*); +lean_object* l_Lean_Expr_inferImplicit(lean_object*, lean_object*, uint8_t); lean_object* l_Lean_Expr_mkAppRevRange___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_updateForallE_x21(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_inferImplicit___main___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_HasToString; lean_object* l_Lean_BinderInfo_hashable; lean_object* l_Lean_Expr_InstantiateLevelParams_instantiate___main(lean_object*, lean_object*); @@ -495,6 +503,7 @@ lean_object* l_Lean_Expr_isHeadBetaTarget___boxed(lean_object*); lean_object* l___private_Lean_Expr_6__mkAppRevRangeAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_Data_nonDepLet___boxed(lean_object*); lean_object* l___private_Lean_Expr_7__betaRevAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_inferImplicit___main(lean_object*, lean_object*, uint8_t); lean_object* l_Lean_mkNatLit(lean_object*); lean_object* l_Lean_mkStrLit(lean_object*); lean_object* l_Lean_Expr_getArgD(lean_object*, lean_object*, lean_object*, lean_object*); @@ -531,6 +540,7 @@ lean_object* l_Lean_Expr_updateLet_x21(lean_object*, lean_object*, lean_object*, uint8_t l_Lean_Literal_lt(lean_object*, lean_object*); lean_object* l_Lean_Expr_updateForall___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkConst(lean_object*, lean_object*); +lean_object* l_Lean_Expr_bindingInfo_x21___boxed(lean_object*); lean_object* l_Lean_Expr_isLambda___boxed(lean_object*); lean_object* l_Lean_Expr_constName_x21(lean_object*); lean_object* lean_expr_instantiate_range(lean_object*, lean_object*, lean_object*, lean_object*); @@ -554,6 +564,7 @@ lean_object* l_Lean_mkLocal___boxed(lean_object*, lean_object*, lean_object*, le lean_object* l_Lean_mkApp3(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isSort(lean_object*); uint8_t l_Lean_Expr_isLet(lean_object*); +lean_object* l_Lean_Expr_hasLooseBVarInExplicitDomain___main___boxed(lean_object*, lean_object*, lean_object*); uint8_t lean_string_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Expr_isLet___boxed(lean_object*); lean_object* l_Lean_ExprStructEq_hash___boxed(lean_object*); @@ -6376,6 +6387,60 @@ lean_dec(x_1); return x_2; } } +lean_object* _init_l_Lean_Expr_bindingInfo_x21___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; +x_2 = lean_unsigned_to_nat(557u); +x_3 = lean_unsigned_to_nat(21u); +x_4 = l_Lean_Expr_bindingName_x21___closed__1; +x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); +return x_5; +} +} +uint8_t l_Lean_Expr_bindingInfo_x21(lean_object* x_1) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 6: +{ +uint64_t x_2; uint8_t x_3; +x_2 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_3 = (uint8_t)((x_2 << 24) >> 61); +return x_3; +} +case 7: +{ +uint64_t x_4; uint8_t x_5; +x_4 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_5 = (uint8_t)((x_4 << 24) >> 61); +return x_5; +} +default: +{ +uint8_t x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_6 = l_Lean_BinderInfo_inhabited; +x_7 = l_Lean_Expr_bindingInfo_x21___closed__1; +x_8 = lean_box(x_6); +x_9 = lean_panic_fn(x_8, x_7); +x_10 = lean_unbox(x_9); +lean_dec(x_9); +return x_10; +} +} +} +} +lean_object* l_Lean_Expr_bindingInfo_x21___boxed(lean_object* x_1) { +_start: +{ +uint8_t x_2; lean_object* x_3; +x_2 = l_Lean_Expr_bindingInfo_x21(x_1); +lean_dec(x_1); +x_3 = lean_box(x_2); +return x_3; +} +} lean_object* _init_l_Lean_Expr_letName_x21___closed__1() { _start: { @@ -6389,7 +6454,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(556u); +x_2 = lean_unsigned_to_nat(561u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_Lean_Expr_letName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6500,6 +6565,101 @@ x_4 = lean_box(x_3); return x_4; } } +uint8_t l_Lean_Expr_hasLooseBVarInExplicitDomain___main(lean_object* x_1, lean_object* x_2, uint8_t x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 7) +{ +lean_object* x_4; lean_object* x_5; uint64_t x_6; uint8_t x_7; uint8_t x_8; +x_4 = lean_ctor_get(x_1, 1); +x_5 = lean_ctor_get(x_1, 2); +x_6 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_7 = (uint8_t)((x_6 << 24) >> 61); +x_8 = l_Lean_BinderInfo_isExplicit(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_add(x_2, x_9); +lean_dec(x_2); +x_1 = x_5; +x_2 = x_10; +goto _start; +} +else +{ +uint8_t x_12; +x_12 = lean_expr_has_loose_bvar(x_4, x_2); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_unsigned_to_nat(1u); +x_14 = lean_nat_add(x_2, x_13); +lean_dec(x_2); +x_1 = x_5; +x_2 = x_14; +goto _start; +} +else +{ +uint8_t x_16; +lean_dec(x_2); +x_16 = 1; +return x_16; +} +} +} +else +{ +if (x_3 == 0) +{ +uint8_t x_17; +lean_dec(x_2); +x_17 = 0; +return x_17; +} +else +{ +uint8_t x_18; +x_18 = lean_expr_has_loose_bvar(x_1, x_2); +lean_dec(x_2); +return x_18; +} +} +} +} +lean_object* l_Lean_Expr_hasLooseBVarInExplicitDomain___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; uint8_t x_5; lean_object* x_6; +x_4 = lean_unbox(x_3); +lean_dec(x_3); +x_5 = l_Lean_Expr_hasLooseBVarInExplicitDomain___main(x_1, x_2, x_4); +lean_dec(x_1); +x_6 = lean_box(x_5); +return x_6; +} +} +uint8_t l_Lean_Expr_hasLooseBVarInExplicitDomain(lean_object* x_1, lean_object* x_2, uint8_t x_3) { +_start: +{ +uint8_t x_4; +x_4 = l_Lean_Expr_hasLooseBVarInExplicitDomain___main(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Lean_Expr_hasLooseBVarInExplicitDomain___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; uint8_t x_5; lean_object* x_6; +x_4 = lean_unbox(x_3); +lean_dec(x_3); +x_5 = l_Lean_Expr_hasLooseBVarInExplicitDomain(x_1, x_2, x_4); +lean_dec(x_1); +x_6 = lean_box(x_5); +return x_6; +} +} lean_object* l_Lean_Expr_lowerLooseBVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -6522,6 +6682,103 @@ lean_dec(x_1); return x_4; } } +lean_object* l_Lean_Expr_inferImplicit___main(lean_object* x_1, lean_object* x_2, uint8_t x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 7) +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; uint64_t x_7; lean_object* x_8; uint8_t x_9; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +x_5 = lean_ctor_get(x_1, 1); +lean_inc(x_5); +x_6 = lean_ctor_get(x_1, 2); +lean_inc(x_6); +x_7 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_8 = lean_unsigned_to_nat(0u); +x_9 = lean_nat_dec_eq(x_2, x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; uint8_t x_14; +lean_dec(x_1); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_sub(x_2, x_10); +x_12 = l_Lean_Expr_inferImplicit___main(x_6, x_11, x_3); +lean_dec(x_11); +x_13 = (uint8_t)((x_7 << 24) >> 61); +x_14 = l_Lean_BinderInfo_isExplicit(x_13); +if (x_14 == 0) +{ +lean_object* x_15; +x_15 = l_Lean_mkForall(x_4, x_13, x_5, x_12); +lean_dec(x_4); +return x_15; +} +else +{ +uint8_t x_16; +x_16 = l_Lean_Expr_hasLooseBVarInExplicitDomain___main(x_12, x_8, x_3); +if (x_16 == 0) +{ +lean_object* x_17; +x_17 = l_Lean_mkForall(x_4, x_13, x_5, x_12); +lean_dec(x_4); +return x_17; +} +else +{ +uint8_t x_18; lean_object* x_19; +x_18 = 1; +x_19 = l_Lean_mkForall(x_4, x_18, x_5, x_12); +lean_dec(x_4); +return x_19; +} +} +} +else +{ +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_1; +} +} +else +{ +return x_1; +} +} +} +lean_object* l_Lean_Expr_inferImplicit___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; lean_object* x_5; +x_4 = lean_unbox(x_3); +lean_dec(x_3); +x_5 = l_Lean_Expr_inferImplicit___main(x_1, x_2, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l_Lean_Expr_inferImplicit(lean_object* x_1, lean_object* x_2, uint8_t x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Expr_inferImplicit___main(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Lean_Expr_inferImplicit___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; lean_object* x_5; +x_4 = lean_unbox(x_3); +lean_dec(x_3); +x_5 = l_Lean_Expr_inferImplicit(x_1, x_2, x_4); +lean_dec(x_2); +return x_5; +} +} lean_object* l_Lean_Expr_instantiate___boxed(lean_object* x_1, lean_object* x_2) { _start: { @@ -7784,7 +8041,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(797u); +x_2 = lean_unsigned_to_nat(823u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_appFn_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7826,7 +8083,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(806u); +x_2 = lean_unsigned_to_nat(832u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_constName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7875,7 +8132,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(815u); +x_2 = lean_unsigned_to_nat(841u); x_3 = lean_unsigned_to_nat(14u); x_4 = l_Lean_Expr_updateSort_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7932,7 +8189,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(832u); +x_2 = lean_unsigned_to_nat(858u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateMData_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7973,7 +8230,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(837u); +x_2 = lean_unsigned_to_nat(863u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_updateProj_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -8024,7 +8281,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(846u); +x_2 = lean_unsigned_to_nat(872u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_updateForall_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -8068,7 +8325,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(851u); +x_2 = lean_unsigned_to_nat(877u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_updateForall_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -8122,7 +8379,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(860u); +x_2 = lean_unsigned_to_nat(886u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateLambda_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -8166,7 +8423,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(865u); +x_2 = lean_unsigned_to_nat(891u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateLambda_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -8210,7 +8467,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(874u); +x_2 = lean_unsigned_to_nat(900u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_Lean_Expr_letName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -10222,6 +10479,8 @@ l_Lean_Expr_bindingDomain_x21___closed__1 = _init_l_Lean_Expr_bindingDomain_x21_ lean_mark_persistent(l_Lean_Expr_bindingDomain_x21___closed__1); l_Lean_Expr_bindingBody_x21___closed__1 = _init_l_Lean_Expr_bindingBody_x21___closed__1(); lean_mark_persistent(l_Lean_Expr_bindingBody_x21___closed__1); +l_Lean_Expr_bindingInfo_x21___closed__1 = _init_l_Lean_Expr_bindingInfo_x21___closed__1(); +lean_mark_persistent(l_Lean_Expr_bindingInfo_x21___closed__1); l_Lean_Expr_letName_x21___closed__1 = _init_l_Lean_Expr_letName_x21___closed__1(); lean_mark_persistent(l_Lean_Expr_letName_x21___closed__1); l_Lean_Expr_letName_x21___closed__2 = _init_l_Lean_Expr_letName_x21___closed__2(); diff --git a/stage0/stdlib/Lean/Level.c b/stage0/stdlib/Lean/Level.c index 117146c5fa..5830df2e61 100644 --- a/stage0/stdlib/Lean/Level.c +++ b/stage0/stdlib/Lean/Level.c @@ -191,6 +191,7 @@ lean_object* l___private_Lean_Level_5__mkMaxAux___main(lean_object*, lean_object lean_object* l_Lean_Level_normLt___boxed(lean_object*, lean_object*); lean_object* l___private_Lean_Level_3__getMaxArgsAux___main___at_Lean_Level_normalize___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_panic_fn(lean_object*, lean_object*); +lean_object* l_Lean_Level_mkNaryMax(lean_object*); lean_object* l_Lean_Level_Data_depth___boxed(lean_object*); uint32_t l_USize_toUInt32(size_t); lean_object* l_Lean_Level_normalize(lean_object*); @@ -238,6 +239,7 @@ lean_object* l_Lean_Level_updateSucc_x21___closed__1; uint64_t l_UInt64_shiftRight(uint64_t, uint64_t); lean_object* l_Lean_Name_toStringWithSep___main(lean_object*, lean_object*); uint8_t l_Lean_Level_Data_hasBeq(uint64_t, uint64_t); +lean_object* l_Lean_Level_mkNaryMax___main(lean_object*); lean_object* l_Lean_mkLevelParam(lean_object*); lean_object* l_Lean_levelOne; lean_object* l_Lean_Level_Lean_HasFormat___closed__1; @@ -4007,7 +4009,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l_Lean_Level_mkData___closed__2; -x_2 = lean_unsigned_to_nat(435u); +x_2 = lean_unsigned_to_nat(436u); x_3 = lean_unsigned_to_nat(16u); x_4 = l_Lean_Level_updateSucc_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -4056,7 +4058,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l_Lean_Level_mkData___closed__2; -x_2 = lean_unsigned_to_nat(444u); +x_2 = lean_unsigned_to_nat(445u); x_3 = lean_unsigned_to_nat(19u); x_4 = l_Lean_Level_updateMax_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -4106,7 +4108,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l_Lean_Level_mkData___closed__2; -x_2 = lean_unsigned_to_nat(453u); +x_2 = lean_unsigned_to_nat(454u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_Lean_Level_updateIMax_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -4135,6 +4137,49 @@ return x_7; } } } +lean_object* l_Lean_Level_mkNaryMax___main(lean_object* x_1) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +lean_object* x_2; +x_2 = l_Lean_levelZero; +return x_2; +} +else +{ +lean_object* x_3; +x_3 = lean_ctor_get(x_1, 1); +lean_inc(x_3); +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_4; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +return x_4; +} +else +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_ctor_get(x_1, 0); +lean_inc(x_5); +lean_dec(x_1); +x_6 = l_Lean_Level_mkNaryMax___main(x_3); +x_7 = l_Lean_mkLevelMax(x_5, x_6); +return x_7; +} +} +} +} +lean_object* l_Lean_Level_mkNaryMax(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Level_mkNaryMax___main(x_1); +return x_2; +} +} lean_object* l_Lean_Level_instantiateParams___main(lean_object* x_1, lean_object* x_2) { _start: { diff --git a/stage0/stdlib/Lean/Meta/AppBuilder.c b/stage0/stdlib/Lean/Meta/AppBuilder.c index 1bafc574bf..86ebabcb5a 100644 --- a/stage0/stdlib/Lean/Meta/AppBuilder.c +++ b/stage0/stdlib/Lean/Meta/AppBuilder.c @@ -38,6 +38,7 @@ lean_object* l_Lean_Meta_mkEqRec(lean_object*, lean_object*, lean_object*, lean_ lean_object* l_Lean_Expr_appFn_x21(lean_object*); uint8_t l_Lean_Expr_isAppOf(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_AppBuilder_1__infer(lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); @@ -149,7 +150,6 @@ lean_object* l_Lean_Meta_mkFreshLevelMVar___rarg(lean_object*); extern lean_object* l_Lean_mkOptionalNode___closed__2; lean_object* l_Lean_Meta_mkHEq(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkHEqTrans___closed__1; -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_AppBuilder_4__mkFun___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkHEqRefl(lean_object*, lean_object*, lean_object*); @@ -5655,7 +5655,7 @@ lean_object* _init_l_Lean_Meta_mkAppM___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_Exception_toTraceMessageData___closed__68; x_3 = lean_name_mk_string(x_1, x_2); return x_3; diff --git a/stage0/stdlib/Lean/Meta/Basic.c b/stage0/stdlib/Lean/Meta/Basic.c index 57c6f7ec1e..7caae50caa 100644 --- a/stage0/stdlib/Lean/Meta/Basic.c +++ b/stage0/stdlib/Lean/Meta/Basic.c @@ -19,7 +19,6 @@ lean_object* l_Lean_Meta_MetaM_inhabited(lean_object*, lean_object*); size_t l_Lean_Meta_InfoCacheKey_Hashable(lean_object*); lean_object* l_Lean_Meta_getLCtx___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_MetaExtState_inhabited___closed__4; -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses(lean_object*); lean_object* l_Lean_Meta_withLocalDecl(lean_object*); extern lean_object* l_Std_PersistentHashMap_empty___rarg___closed__2; lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -55,6 +54,7 @@ lean_object* l_Lean_MetavarContext_addLevelMVarDecl(lean_object*, lean_object*); lean_object* l_Lean_Format_pretty(lean_object*, lean_object*); extern lean_object* l_EIO_Monad___closed__1; lean_object* l_Lean_Meta_savingCache(lean_object*); +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1; lean_object* l_Lean_Meta_addContext___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshExprMVarAt___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_IO_print___at_Lean_HasRepr_hasEval___spec__2(lean_object*, lean_object*); @@ -67,6 +67,7 @@ lean_object* l_Lean_Meta_forallMetaTelescope___boxed(lean_object*, lean_object*, extern lean_object* l_Lean_maxRecDepthErrorMessage; lean_object* lean_io_prim_handle_put_str(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_resettingSynthInstanceCache___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses(lean_object*); lean_object* l_Lean_Meta_liftStateMCtx(lean_object*); lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); lean_object* l_Lean_mkMVar(lean_object*); @@ -76,6 +77,7 @@ extern lean_object* l_Array_empty___closed__1; lean_object* lean_environment_find(lean_object*, lean_object*); lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_lambdaTelescope(lean_object*); lean_object* l_Lean_Meta_elimMVarDeps(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_setMVarKind(lean_object*, lean_object*, uint8_t); @@ -93,7 +95,10 @@ lean_object* l_Lean_Meta_lambdaMetaTelescope___boxed(lean_object*, lean_object*, lean_object* l_Lean_Meta_withLetDecl___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); lean_object* l_Array_forMAux___main___at_IO_runMeta___spec__6(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_forallBoundedTelescope(lean_object*); +lean_object* lean_expr_instantiate1(lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Meta_getEnv___boxed(lean_object*); @@ -117,6 +122,7 @@ lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTeles lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l_Array_forMAux___main___at_IO_runMeta___spec__5___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReadOnlyLevelMVar___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4; uint8_t l_Lean_isReducible(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkAuxDefinitionFor(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -141,6 +147,7 @@ lean_object* l_Lean_Meta_MetaM_inhabited___rarg(lean_object*); lean_object* l_Lean_Meta_TransparencyMode_Hashable___closed__1; lean_object* l_Lean_Meta_getEnv___rarg(lean_object*); lean_object* l_Lean_MetavarContext_hasAssignableMVar___main(lean_object*, lean_object*); +lean_object* l_Lean_Meta_instantiateForall(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_IO_FS_Handle_putStrLn___rarg___closed__1; lean_object* l_Lean_Meta_getConfig___boxed(lean_object*, lean_object*); uint8_t lean_metavar_ctx_is_expr_assigned(lean_object*, lean_object*); @@ -182,8 +189,10 @@ uint8_t l_Lean_Meta_InfoCacheKey_HasBeq(lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_instantiateLevelMVars___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___closed__2; lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2; +lean_object* l_Lean_Meta_instantiateForall___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withMCtx___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isClassQuickConst___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3; lean_object* l_Lean_Meta_getConstNoEx___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewMCtxDepth___rarg(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -209,6 +218,7 @@ lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTeles lean_object* l_Lean_MetavarContext_MkBinding_elimMVarDeps(lean_object*, lean_object*, uint8_t, lean_object*); lean_object* l_Lean_Meta_ParamInfo_inhabited___closed__1; lean_object* l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId(lean_object*); lean_object* l_Lean_Meta_renameMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isExprMVarAssigned___boxed(lean_object*, lean_object*, lean_object*); @@ -291,7 +301,6 @@ lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main lean_object* l_Lean_Meta_isClassQuick(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_run(lean_object*); lean_object* l_IO_runMeta(lean_object*); -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3; lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Environment_5__envExtensionsRef; lean_object* l_Lean_Meta_forallMetaTelescopeReducing(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); @@ -388,6 +397,7 @@ lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBound lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1(lean_object*, lean_object*); lean_object* l_Std_PersistentArray_forM___at_IO_runMeta___spec__3(lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_lt(uint8_t, uint8_t); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2; lean_object* l_Lean_Meta_assignExprMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkInferTypeRef(lean_object*); lean_object* l_Lean_Meta_isDelayedAssigned(lean_object*, lean_object*, lean_object*); @@ -395,13 +405,14 @@ lean_object* l_Lean_Meta_getConstInfo(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_MkBinding_mkBinding(uint8_t, lean_object*, lean_object*, lean_object*, uint8_t, uint8_t, lean_object*); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getTransparency(lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateMVars(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1; lean_object* l___private_Lean_Meta_Basic_9__withNewFVar(lean_object*); lean_object* l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1(lean_object*); lean_object* l_Lean_Meta_Exception_toStr(lean_object*); size_t lean_usize_mix_hash(size_t, size_t); -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1; lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_empty___at_Lean_Meta_run___spec__1; lean_object* lean_io_initializing(lean_object*); @@ -433,7 +444,6 @@ lean_object* l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; lean_object* l_Lean_Meta_TransparencyMode_hash___boxed(lean_object*); lean_object* l_Lean_Meta_isReadOnlyOrSyntheticOpaqueExprMVar(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main(lean_object*); -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_forMAux___main___at_IO_runMeta___spec__5(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMCtx(lean_object*); @@ -441,7 +451,6 @@ lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_find(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_8__lambdaMetaTelescopeAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4; lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getParamNames(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId___boxed(lean_object*); @@ -6865,86 +6874,117 @@ 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_7; lean_object* x_8; lean_object* x_9; lean_object* x_59; lean_object* x_60; x_7 = lean_ctor_get(x_5, 2); -x_8 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_5, 2, x_8); -x_9 = lean_apply_2(x_1, x_2, x_3); -if (lean_obj_tag(x_9) == 0) +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) +{ +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; +} +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; +} +block_58: +{ +if (lean_obj_tag(x_8) == 0) { lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 1); +x_10 = lean_ctor_get(x_9, 2); lean_inc(x_10); -x_11 = lean_ctor_get(x_10, 2); +x_11 = lean_ctor_get(x_8, 0); lean_inc(x_11); +lean_dec(x_8); x_12 = !lean_is_exclusive(x_9); if (x_12 == 0) { lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_9, 1); +x_13 = lean_ctor_get(x_9, 2); lean_dec(x_13); x_14 = !lean_is_exclusive(x_10); if (x_14 == 0) { -lean_object* x_15; uint8_t x_16; +lean_object* x_15; lean_object* x_16; x_15 = lean_ctor_get(x_10, 2); lean_dec(x_15); -x_16 = !lean_is_exclusive(x_11); -if (x_16 == 0) -{ -lean_object* x_17; -x_17 = lean_ctor_get(x_11, 2); -lean_dec(x_17); -lean_ctor_set(x_11, 2, x_7); -return x_9; +lean_ctor_set(x_10, 2, x_7); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_11); +lean_ctor_set(x_16, 1, x_9); +return x_16; } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_18 = lean_ctor_get(x_11, 0); -x_19 = lean_ctor_get(x_11, 1); -x_20 = lean_ctor_get(x_11, 3); -lean_inc(x_20); +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_17 = lean_ctor_get(x_10, 0); +x_18 = lean_ctor_get(x_10, 1); +x_19 = lean_ctor_get(x_10, 3); lean_inc(x_19); lean_inc(x_18); -lean_dec(x_11); -x_21 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_21, 0, x_18); -lean_ctor_set(x_21, 1, x_19); -lean_ctor_set(x_21, 2, x_7); -lean_ctor_set(x_21, 3, x_20); -lean_ctor_set(x_10, 2, x_21); -return x_9; +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; } } 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; -x_22 = lean_ctor_get(x_10, 0); -x_23 = lean_ctor_get(x_10, 1); -x_24 = lean_ctor_get(x_10, 3); -x_25 = lean_ctor_get(x_10, 4); -x_26 = lean_ctor_get(x_10, 5); +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_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); -lean_dec(x_10); -x_27 = lean_ctor_get(x_11, 0); +lean_dec(x_9); +x_27 = lean_ctor_get(x_10, 0); lean_inc(x_27); -x_28 = lean_ctor_get(x_11, 1); +x_28 = lean_ctor_get(x_10, 1); lean_inc(x_28); -x_29 = lean_ctor_get(x_11, 3); +x_29 = lean_ctor_get(x_10, 3); lean_inc(x_29); -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); - x_30 = x_11; +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; } else { - lean_dec_ref(x_11); + lean_dec_ref(x_10); x_30 = lean_box(0); } if (lean_is_scalar(x_30)) { @@ -6963,657 +7003,533 @@ 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); -lean_ctor_set(x_9, 1, x_32); -return x_9; +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; } } 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; lean_object* x_45; lean_object* x_46; -x_33 = lean_ctor_get(x_9, 0); -lean_inc(x_33); -lean_dec(x_9); -x_34 = lean_ctor_get(x_10, 0); +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_10, 1); +x_35 = lean_ctor_get(x_8, 0); lean_inc(x_35); -x_36 = lean_ctor_get(x_10, 3); -lean_inc(x_36); -x_37 = lean_ctor_get(x_10, 4); -lean_inc(x_37); -x_38 = lean_ctor_get(x_10, 5); -lean_inc(x_38); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - lean_ctor_release(x_10, 2); - lean_ctor_release(x_10, 3); - lean_ctor_release(x_10, 4); - lean_ctor_release(x_10, 5); - x_39 = x_10; -} else { - lean_dec_ref(x_10); - x_39 = lean_box(0); +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); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_34, 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_ctor_get(x_11, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_11, 1); -lean_inc(x_41); -x_42 = lean_ctor_get(x_11, 3); +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_inc(x_43); lean_inc(x_42); -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); - x_43 = x_11; -} else { - lean_dec_ref(x_11); - x_43 = lean_box(0); -} -if (lean_is_scalar(x_43)) { - x_44 = lean_alloc_ctor(0, 4, 0); -} else { - x_44 = x_43; -} -lean_ctor_set(x_44, 0, x_40); -lean_ctor_set(x_44, 1, x_41); +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_42); -if (lean_is_scalar(x_39)) { - x_45 = lean_alloc_ctor(0, 6, 0); -} else { - x_45 = x_39; -} -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(0, 2, 0); -lean_ctor_set(x_46, 0, x_33); -lean_ctor_set(x_46, 1, x_45); -return x_46; +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; } } else { -lean_object* x_47; lean_object* x_48; uint8_t x_49; +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); -lean_inc(x_47); -x_48 = lean_ctor_get(x_47, 2); +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_inc(x_50); +lean_inc(x_49); lean_inc(x_48); -x_49 = !lean_is_exclusive(x_9); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_9, 1); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_47); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_47, 2); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_48); -if (x_53 == 0) -{ -lean_object* x_54; -x_54 = lean_ctor_get(x_48, 2); -lean_dec(x_54); -lean_ctor_set(x_48, 2, x_7); -return x_9; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = lean_ctor_get(x_48, 0); -x_56 = lean_ctor_get(x_48, 1); -x_57 = lean_ctor_get(x_48, 3); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_48); -x_58 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_7); -lean_ctor_set(x_58, 3, x_57); -lean_ctor_set(x_47, 2, x_58); -return x_9; -} -} -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; -x_59 = lean_ctor_get(x_47, 0); -x_60 = lean_ctor_get(x_47, 1); -x_61 = lean_ctor_get(x_47, 3); -x_62 = lean_ctor_get(x_47, 4); -x_63 = lean_ctor_get(x_47, 5); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); -lean_dec(x_47); -x_64 = lean_ctor_get(x_48, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_48, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_48, 3); -lean_inc(x_66); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_67 = x_48; -} else { - lean_dec_ref(x_48); - x_67 = lean_box(0); -} -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 4, 0); -} else { - x_68 = x_67; -} -lean_ctor_set(x_68, 0, x_64); -lean_ctor_set(x_68, 1, x_65); -lean_ctor_set(x_68, 2, x_7); -lean_ctor_set(x_68, 3, x_66); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_59); -lean_ctor_set(x_69, 1, x_60); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_61); -lean_ctor_set(x_69, 4, x_62); -lean_ctor_set(x_69, 5, x_63); -lean_ctor_set(x_9, 1, x_69); -return x_9; -} -} -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; lean_object* x_82; lean_object* x_83; -x_70 = lean_ctor_get(x_9, 0); -lean_inc(x_70); +lean_inc(x_47); +lean_inc(x_46); lean_dec(x_9); -x_71 = lean_ctor_get(x_47, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_47, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_47, 3); -lean_inc(x_73); -x_74 = lean_ctor_get(x_47, 4); -lean_inc(x_74); -x_75 = lean_ctor_get(x_47, 5); -lean_inc(x_75); -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); - lean_ctor_release(x_47, 5); - x_76 = x_47; +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; } else { - lean_dec_ref(x_47); - x_76 = lean_box(0); + lean_dec_ref(x_34); + x_54 = lean_box(0); } -x_77 = lean_ctor_get(x_48, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_48, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_48, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_80 = x_48; +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_48); + x_55 = x_54; +} +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; +} +} +} +} +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_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_81 = lean_alloc_ctor(0, 4, 0); + x_86 = lean_alloc_ctor(0, 6, 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_7); -lean_ctor_set(x_81, 3, x_79); -if (lean_is_scalar(x_76)) { - x_82 = lean_alloc_ctor(0, 6, 0); -} else { - x_82 = x_76; -} -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); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_70); -lean_ctor_set(x_83, 1, x_82); -return x_83; -} + 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_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_84 = lean_ctor_get(x_5, 0); -x_85 = lean_ctor_get(x_5, 1); -x_86 = lean_ctor_get(x_5, 2); -x_87 = lean_ctor_get(x_5, 3); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_5); -x_88 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_89 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_89, 0, x_84); -lean_ctor_set(x_89, 1, x_85); -lean_ctor_set(x_89, 2, x_88); -lean_ctor_set(x_89, 3, x_87); -lean_ctor_set(x_3, 2, x_89); -x_90 = lean_apply_2(x_1, x_2, x_3); -if (lean_obj_tag(x_90) == 0) -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_91 = lean_ctor_get(x_90, 1); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; 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_91, 2); +x_92 = lean_ctor_get(x_72, 3); lean_inc(x_92); -x_93 = lean_ctor_get(x_90, 0); +x_93 = lean_ctor_get(x_72, 4); lean_inc(x_93); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_94 = x_90; +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_90); - x_94 = lean_box(0); + lean_dec_ref(x_72); + x_95 = lean_box(0); } -x_95 = lean_ctor_get(x_91, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_91, 1); +x_96 = lean_ctor_get(x_88, 0); lean_inc(x_96); -x_97 = lean_ctor_get(x_91, 3); +x_97 = lean_ctor_get(x_88, 1); lean_inc(x_97); -x_98 = lean_ctor_get(x_91, 4); +x_98 = lean_ctor_get(x_88, 3); lean_inc(x_98); -x_99 = lean_ctor_get(x_91, 5); -lean_inc(x_99); -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); - lean_ctor_release(x_91, 5); - x_100 = x_91; +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_91); - x_100 = lean_box(0); + lean_dec_ref(x_88); + x_99 = lean_box(0); } -x_101 = lean_ctor_get(x_92, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_92, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_92, 3); -lean_inc(x_103); -if (lean_is_exclusive(x_92)) { - lean_ctor_release(x_92, 0); - lean_ctor_release(x_92, 1); - lean_ctor_release(x_92, 2); - lean_ctor_release(x_92, 3); - x_104 = x_92; +if (lean_is_scalar(x_99)) { + x_100 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_92); - x_104 = lean_box(0); + x_100 = x_99; } -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); +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_105 = x_104; + 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; } -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_86); -lean_ctor_set(x_105, 3, x_103); -if (lean_is_scalar(x_100)) { - x_106 = lean_alloc_ctor(0, 6, 0); -} else { - x_106 = x_100; } -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); -if (lean_is_scalar(x_94)) { - x_107 = lean_alloc_ctor(0, 2, 0); -} else { - x_107 = x_94; } -lean_ctor_set(x_107, 0, x_93); -lean_ctor_set(x_107, 1, x_106); -return x_107; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_108 = lean_ctor_get(x_90, 1); -lean_inc(x_108); -x_109 = lean_ctor_get(x_108, 2); -lean_inc(x_109); -x_110 = lean_ctor_get(x_90, 0); -lean_inc(x_110); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_111 = x_90; -} else { - lean_dec_ref(x_90); - x_111 = lean_box(0); -} -x_112 = lean_ctor_get(x_108, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_108, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_108, 3); -lean_inc(x_114); -x_115 = lean_ctor_get(x_108, 4); -lean_inc(x_115); -x_116 = lean_ctor_get(x_108, 5); -lean_inc(x_116); -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); - lean_ctor_release(x_108, 4); - lean_ctor_release(x_108, 5); - x_117 = x_108; -} else { - lean_dec_ref(x_108); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_109, 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_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); -x_119 = lean_ctor_get(x_109, 1); +lean_inc(x_117); +lean_inc(x_116); +lean_inc(x_113); +lean_inc(x_115); +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_109, 3); +x_120 = lean_ctor_get(x_113, 1); lean_inc(x_120); -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_121 = x_109; +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_109); - x_121 = lean_box(0); + lean_dec_ref(x_113); + x_123 = lean_box(0); } -if (lean_is_scalar(x_121)) { - x_122 = lean_alloc_ctor(0, 4, 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_122 = x_121; -} -lean_ctor_set(x_122, 0, x_118); -lean_ctor_set(x_122, 1, x_119); -lean_ctor_set(x_122, 2, x_86); -lean_ctor_set(x_122, 3, x_120); -if (lean_is_scalar(x_117)) { - x_123 = lean_alloc_ctor(0, 6, 0); -} else { - x_123 = x_117; -} -lean_ctor_set(x_123, 0, x_112); -lean_ctor_set(x_123, 1, x_113); -lean_ctor_set(x_123, 2, x_122); -lean_ctor_set(x_123, 3, x_114); -lean_ctor_set(x_123, 4, x_115); -lean_ctor_set(x_123, 5, x_116); -if (lean_is_scalar(x_111)) { - x_124 = lean_alloc_ctor(1, 2, 0); -} else { - x_124 = x_111; -} -lean_ctor_set(x_124, 0, x_110); -lean_ctor_set(x_124, 1, x_123); -return x_124; -} + 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_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_3, 2); -x_126 = lean_ctor_get(x_3, 0); -x_127 = lean_ctor_get(x_3, 1); -x_128 = lean_ctor_get(x_3, 3); -x_129 = lean_ctor_get(x_3, 4); -x_130 = lean_ctor_get(x_3, 5); -lean_inc(x_130); -lean_inc(x_129); -lean_inc(x_128); -lean_inc(x_125); -lean_inc(x_127); +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_126); -lean_dec(x_3); -x_131 = lean_ctor_get(x_125, 0); +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_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, 1); +x_132 = lean_ctor_get(x_125, 5); lean_inc(x_132); -x_133 = lean_ctor_get(x_125, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_125, 3); -lean_inc(x_134); 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_135 = x_125; + lean_ctor_release(x_125, 4); + lean_ctor_release(x_125, 5); + x_133 = x_125; } else { lean_dec_ref(x_125); - x_135 = lean_box(0); + x_133 = lean_box(0); } -x_136 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_135)) { - x_137 = lean_alloc_ctor(0, 4, 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 { - x_137 = x_135; + lean_dec_ref(x_126); + x_137 = lean_box(0); } -lean_ctor_set(x_137, 0, x_131); -lean_ctor_set(x_137, 1, x_132); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_134); -x_138 = lean_alloc_ctor(0, 6, 0); -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); -x_139 = lean_apply_2(x_1, x_2, x_138); -if (lean_obj_tag(x_139) == 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_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; +} +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; lean_object* x_156; -x_140 = lean_ctor_get(x_139, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_140, 2); +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_139, 0); +x_142 = lean_ctor_get(x_124, 0); lean_inc(x_142); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_143 = x_139; -} else { - lean_dec_ref(x_139); - x_143 = lean_box(0); -} -x_144 = lean_ctor_get(x_140, 0); +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_140, 1); +x_145 = lean_ctor_get(x_125, 3); lean_inc(x_145); -x_146 = lean_ctor_get(x_140, 3); +x_146 = lean_ctor_get(x_125, 4); lean_inc(x_146); -x_147 = lean_ctor_get(x_140, 4); +x_147 = lean_ctor_get(x_125, 5); lean_inc(x_147); -x_148 = lean_ctor_get(x_140, 5); -lean_inc(x_148); -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); - lean_ctor_release(x_140, 5); - x_149 = x_140; +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_140); - x_149 = lean_box(0); + lean_dec_ref(x_125); + x_148 = lean_box(0); } -x_150 = lean_ctor_get(x_141, 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, 1); +x_151 = lean_ctor_get(x_141, 3); lean_inc(x_151); -x_152 = lean_ctor_get(x_141, 3); -lean_inc(x_152); 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_153 = x_141; + x_152 = x_141; } else { lean_dec_ref(x_141); - x_153 = lean_box(0); + x_152 = lean_box(0); } -if (lean_is_scalar(x_153)) { - x_154 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); } else { - x_154 = x_153; + x_153 = x_152; } -lean_ctor_set(x_154, 0, x_150); -lean_ctor_set(x_154, 1, x_151); -lean_ctor_set(x_154, 2, x_133); -lean_ctor_set(x_154, 3, x_152); -if (lean_is_scalar(x_149)) { - x_155 = lean_alloc_ctor(0, 6, 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); } else { - x_155 = x_149; + x_154 = x_148; } -lean_ctor_set(x_155, 0, x_144); -lean_ctor_set(x_155, 1, x_145); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_146); -lean_ctor_set(x_155, 4, x_147); -lean_ctor_set(x_155, 5, x_148); -if (lean_is_scalar(x_143)) { - x_156 = lean_alloc_ctor(0, 2, 0); -} else { - x_156 = x_143; +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_156, 0, x_142); -lean_ctor_set(x_156, 1, x_155); -return x_156; -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_157 = lean_ctor_get(x_139, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_157, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_139, 0); -lean_inc(x_159); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_160 = x_139; -} else { - lean_dec_ref(x_139); - x_160 = lean_box(0); -} -x_161 = lean_ctor_get(x_157, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_157, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_157, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_157, 4); -lean_inc(x_164); -x_165 = lean_ctor_get(x_157, 5); -lean_inc(x_165); -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); - lean_ctor_release(x_157, 5); - x_166 = x_157; -} else { - lean_dec_ref(x_157); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_158, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_158, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_158, 3); -lean_inc(x_169); -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_170 = x_158; -} else { - lean_dec_ref(x_158); - x_170 = lean_box(0); -} -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_133); -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(1, 2, 0); -} else { - x_173 = x_160; -} -lean_ctor_set(x_173, 0, x_159); -lean_ctor_set(x_173, 1, x_172); -return x_173; } } } @@ -7638,1030 +7554,797 @@ 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; uint8_t x_11; +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_61; uint8_t x_62; x_9 = lean_ctor_get(x_7, 2); -x_10 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_7, 2, x_10); -x_11 = !lean_is_exclusive(x_4); -if (x_11 == 0) +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) { -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_12 = lean_ctor_get(x_4, 2); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_1); -lean_ctor_set(x_13, 1, x_2); -x_14 = lean_array_push(x_12, x_13); -lean_ctor_set(x_4, 2, x_14); -x_15 = lean_apply_2(x_3, x_4, x_5); -if (lean_obj_tag(x_15) == 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_16; lean_object* x_17; uint8_t x_18; -x_16 = lean_ctor_get(x_15, 1); -lean_inc(x_16); -x_17 = lean_ctor_get(x_16, 2); -lean_inc(x_17); -x_18 = !lean_is_exclusive(x_15); -if (x_18 == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_15, 1); -lean_dec(x_19); -x_20 = !lean_is_exclusive(x_16); -if (x_20 == 0) -{ -lean_object* x_21; uint8_t x_22; -x_21 = lean_ctor_get(x_16, 2); -lean_dec(x_21); -x_22 = !lean_is_exclusive(x_17); -if (x_22 == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_17, 2); -lean_dec(x_23); -lean_ctor_set(x_17, 2, x_9); -return x_15; +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_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_24 = lean_ctor_get(x_17, 0); -x_25 = lean_ctor_get(x_17, 1); -x_26 = lean_ctor_get(x_17, 3); +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_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; +} +} +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_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; +} +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_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; +} +} +block_60: +{ +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_12 = lean_ctor_get(x_11, 2); +lean_inc(x_12); +x_13 = lean_ctor_get(x_10, 0); +lean_inc(x_13); +lean_dec(x_10); +x_14 = !lean_is_exclusive(x_11); +if (x_14 == 0) +{ +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_11, 2); +lean_dec(x_15); +x_16 = !lean_is_exclusive(x_12); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_ctor_get(x_12, 2); +lean_dec(x_17); +lean_ctor_set(x_12, 2, x_9); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_11); +return x_18; +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_12, 0); +x_20 = lean_ctor_get(x_12, 1); +x_21 = lean_ctor_get(x_12, 3); +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; +} +} +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_inc(x_28); +lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); -lean_dec(x_17); -x_27 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_27, 0, x_24); -lean_ctor_set(x_27, 1, x_25); -lean_ctor_set(x_27, 2, x_9); -lean_ctor_set(x_27, 3, x_26); -lean_ctor_set(x_16, 2, x_27); -return x_15; -} -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_28 = lean_ctor_get(x_16, 0); -x_29 = lean_ctor_get(x_16, 1); -x_30 = lean_ctor_get(x_16, 3); -x_31 = lean_ctor_get(x_16, 4); -x_32 = lean_ctor_get(x_16, 5); -lean_inc(x_32); -lean_inc(x_31); -lean_inc(x_30); +lean_dec(x_11); +x_29 = lean_ctor_get(x_12, 0); lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_16); -x_33 = lean_ctor_get(x_17, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_17, 1); -lean_inc(x_34); -x_35 = lean_ctor_get(x_17, 3); -lean_inc(x_35); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - x_36 = x_17; +x_30 = lean_ctor_get(x_12, 1); +lean_inc(x_30); +x_31 = lean_ctor_get(x_12, 3); +lean_inc(x_31); +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; } else { - lean_dec_ref(x_17); - x_36 = lean_box(0); + lean_dec_ref(x_12); + x_32 = lean_box(0); } -if (lean_is_scalar(x_36)) { - x_37 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_32)) { + x_33 = lean_alloc_ctor(0, 4, 0); } else { - x_37 = x_36; + x_33 = x_32; } -lean_ctor_set(x_37, 0, x_33); -lean_ctor_set(x_37, 1, x_34); -lean_ctor_set(x_37, 2, x_9); -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_15, 1, x_38); -return x_15; +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; } } 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; lean_object* x_51; lean_object* x_52; -x_39 = lean_ctor_get(x_15, 0); -lean_inc(x_39); -lean_dec(x_15); -x_40 = lean_ctor_get(x_16, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_16, 1); -lean_inc(x_41); -x_42 = lean_ctor_get(x_16, 3); -lean_inc(x_42); -x_43 = lean_ctor_get(x_16, 4); -lean_inc(x_43); -x_44 = lean_ctor_get(x_16, 5); +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_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); +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_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; +} +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_inc(x_45); lean_inc(x_44); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - lean_ctor_release(x_16, 2); - lean_ctor_release(x_16, 3); - lean_ctor_release(x_16, 4); - lean_ctor_release(x_16, 5); - x_45 = x_16; -} else { - lean_dec_ref(x_16); - x_45 = lean_box(0); +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; } -x_46 = lean_ctor_get(x_17, 0); -lean_inc(x_46); -x_47 = lean_ctor_get(x_17, 1); -lean_inc(x_47); -x_48 = lean_ctor_get(x_17, 3); +} +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_inc(x_52); +lean_inc(x_51); +lean_inc(x_50); +lean_inc(x_49); lean_inc(x_48); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - x_49 = x_17; -} else { - lean_dec_ref(x_17); - x_49 = lean_box(0); -} -if (lean_is_scalar(x_49)) { - x_50 = lean_alloc_ctor(0, 4, 0); -} else { - x_50 = x_49; -} -lean_ctor_set(x_50, 0, x_46); -lean_ctor_set(x_50, 1, x_47); -lean_ctor_set(x_50, 2, x_9); -lean_ctor_set(x_50, 3, x_48); -if (lean_is_scalar(x_45)) { - x_51 = lean_alloc_ctor(0, 6, 0); -} else { - x_51 = x_45; -} -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); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_39); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -else -{ -lean_object* x_53; lean_object* x_54; uint8_t x_55; -x_53 = lean_ctor_get(x_15, 1); +lean_dec(x_11); +x_53 = lean_ctor_get(x_36, 0); lean_inc(x_53); -x_54 = lean_ctor_get(x_53, 2); +x_54 = lean_ctor_get(x_36, 1); lean_inc(x_54); -x_55 = !lean_is_exclusive(x_15); -if (x_55 == 0) -{ -lean_object* x_56; uint8_t x_57; -x_56 = lean_ctor_get(x_15, 1); -lean_dec(x_56); -x_57 = !lean_is_exclusive(x_53); -if (x_57 == 0) -{ -lean_object* x_58; uint8_t x_59; -x_58 = lean_ctor_get(x_53, 2); -lean_dec(x_58); -x_59 = !lean_is_exclusive(x_54); -if (x_59 == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_54, 2); -lean_dec(x_60); -lean_ctor_set(x_54, 2, x_9); -return x_15; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_61 = lean_ctor_get(x_54, 0); -x_62 = lean_ctor_get(x_54, 1); -x_63 = lean_ctor_get(x_54, 3); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_54); -x_64 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -lean_ctor_set(x_64, 2, x_9); -lean_ctor_set(x_64, 3, x_63); -lean_ctor_set(x_53, 2, x_64); -return x_15; -} -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_65 = lean_ctor_get(x_53, 0); -x_66 = lean_ctor_get(x_53, 1); -x_67 = lean_ctor_get(x_53, 3); -x_68 = lean_ctor_get(x_53, 4); -x_69 = lean_ctor_get(x_53, 5); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_53); -x_70 = lean_ctor_get(x_54, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_54, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_54, 3); -lean_inc(x_72); -if (lean_is_exclusive(x_54)) { - lean_ctor_release(x_54, 0); - lean_ctor_release(x_54, 1); - lean_ctor_release(x_54, 2); - lean_ctor_release(x_54, 3); - x_73 = 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; } else { - lean_dec_ref(x_54); - x_73 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_73)) { - x_74 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_74 = x_73; + x_57 = x_56; } -lean_ctor_set(x_74, 0, x_70); -lean_ctor_set(x_74, 1, x_71); -lean_ctor_set(x_74, 2, x_9); -lean_ctor_set(x_74, 3, x_72); -x_75 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_75, 0, x_65); -lean_ctor_set(x_75, 1, x_66); -lean_ctor_set(x_75, 2, x_74); -lean_ctor_set(x_75, 3, x_67); -lean_ctor_set(x_75, 4, x_68); -lean_ctor_set(x_75, 5, x_69); -lean_ctor_set(x_15, 1, x_75); -return x_15; +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; } } -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; lean_object* x_88; lean_object* x_89; -x_76 = lean_ctor_get(x_15, 0); -lean_inc(x_76); -lean_dec(x_15); -x_77 = lean_ctor_get(x_53, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_53, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_53, 3); -lean_inc(x_79); -x_80 = lean_ctor_get(x_53, 4); -lean_inc(x_80); -x_81 = lean_ctor_get(x_53, 5); -lean_inc(x_81); -if (lean_is_exclusive(x_53)) { - lean_ctor_release(x_53, 0); - lean_ctor_release(x_53, 1); - lean_ctor_release(x_53, 2); - lean_ctor_release(x_53, 3); - lean_ctor_release(x_53, 4); - lean_ctor_release(x_53, 5); - x_82 = x_53; -} else { - lean_dec_ref(x_53); - x_82 = lean_box(0); -} -x_83 = lean_ctor_get(x_54, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_54, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_54, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_54)) { - lean_ctor_release(x_54, 0); - lean_ctor_release(x_54, 1); - lean_ctor_release(x_54, 2); - lean_ctor_release(x_54, 3); - x_86 = x_54; -} else { - lean_dec_ref(x_54); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_9); -lean_ctor_set(x_87, 3, x_85); -if (lean_is_scalar(x_82)) { - x_88 = lean_alloc_ctor(0, 6, 0); -} else { - x_88 = x_82; -} -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); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_76); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} } } 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; -x_90 = lean_ctor_get(x_4, 0); -x_91 = lean_ctor_get(x_4, 1); -x_92 = lean_ctor_get(x_4, 2); -x_93 = lean_ctor_get(x_4, 3); -x_94 = lean_ctor_get(x_4, 4); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); +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_dec(x_4); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_1); -lean_ctor_set(x_95, 1, x_2); -x_96 = lean_array_push(x_92, x_95); -x_97 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_97, 0, x_90); -lean_ctor_set(x_97, 1, x_91); -lean_ctor_set(x_97, 2, x_96); -lean_ctor_set(x_97, 3, x_93); -lean_ctor_set(x_97, 4, x_94); -x_98 = lean_apply_2(x_3, x_97, x_5); -if (lean_obj_tag(x_98) == 0) -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; 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_99 = lean_ctor_get(x_98, 1); -lean_inc(x_99); -x_100 = lean_ctor_get(x_99, 2); -lean_inc(x_100); -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_102 = x_98; -} else { - lean_dec_ref(x_98); - x_102 = lean_box(0); -} -x_103 = lean_ctor_get(x_99, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_99, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_99, 3); -lean_inc(x_105); -x_106 = lean_ctor_get(x_99, 4); -lean_inc(x_106); -x_107 = lean_ctor_get(x_99, 5); -lean_inc(x_107); -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); - lean_ctor_release(x_99, 5); - x_108 = x_99; -} else { - lean_dec_ref(x_99); - x_108 = lean_box(0); -} -x_109 = lean_ctor_get(x_100, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_100, 1); -lean_inc(x_110); -x_111 = lean_ctor_get(x_100, 3); -lean_inc(x_111); -if (lean_is_exclusive(x_100)) { - lean_ctor_release(x_100, 0); - lean_ctor_release(x_100, 1); - lean_ctor_release(x_100, 2); - lean_ctor_release(x_100, 3); - x_112 = x_100; -} else { - lean_dec_ref(x_100); - x_112 = lean_box(0); -} -if (lean_is_scalar(x_112)) { - x_113 = lean_alloc_ctor(0, 4, 0); -} else { - x_113 = x_112; -} -lean_ctor_set(x_113, 0, x_109); -lean_ctor_set(x_113, 1, x_110); -lean_ctor_set(x_113, 2, x_9); -lean_ctor_set(x_113, 3, x_111); -if (lean_is_scalar(x_108)) { - x_114 = lean_alloc_ctor(0, 6, 0); -} else { - x_114 = x_108; -} -lean_ctor_set(x_114, 0, x_103); -lean_ctor_set(x_114, 1, x_104); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_105); -lean_ctor_set(x_114, 4, x_106); -lean_ctor_set(x_114, 5, x_107); -if (lean_is_scalar(x_102)) { - x_115 = lean_alloc_ctor(0, 2, 0); -} else { - x_115 = x_102; -} -lean_ctor_set(x_115, 0, x_101); -lean_ctor_set(x_115, 1, x_114); -return x_115; -} -else -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_116 = lean_ctor_get(x_98, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); -lean_inc(x_117); -x_118 = lean_ctor_get(x_98, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_119 = x_98; -} else { - lean_dec_ref(x_98); - x_119 = lean_box(0); -} -x_120 = lean_ctor_get(x_116, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_116, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_116, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_116, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); -lean_inc(x_124); -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_125 = x_116; -} else { - lean_dec_ref(x_116); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_117, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_117, 3); -lean_inc(x_128); -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_129 = x_117; -} else { - lean_dec_ref(x_117); - 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_9); -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_119)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_119; -} -lean_ctor_set(x_132, 0, x_118); -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; lean_object* x_148; -x_133 = lean_ctor_get(x_7, 0); -x_134 = lean_ctor_get(x_7, 1); -x_135 = lean_ctor_get(x_7, 2); -x_136 = lean_ctor_get(x_7, 3); -lean_inc(x_136); -lean_inc(x_135); -lean_inc(x_134); -lean_inc(x_133); +lean_inc(x_89); +lean_inc(x_88); lean_dec(x_7); -x_137 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_138 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_138, 0, x_133); -lean_ctor_set(x_138, 1, x_134); -lean_ctor_set(x_138, 2, x_137); -lean_ctor_set(x_138, 3, x_136); -lean_ctor_set(x_5, 2, x_138); -x_139 = lean_ctor_get(x_4, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_4, 1); +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_4, 2); +x_141 = lean_ctor_get(x_136, 1); lean_inc(x_141); -x_142 = lean_ctor_get(x_4, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_4, 4); +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_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); -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_144 = x_4; -} else { - lean_dec_ref(x_4); - x_144 = lean_box(0); -} -x_145 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_145, 0, x_1); -lean_ctor_set(x_145, 1, x_2); -x_146 = lean_array_push(x_141, x_145); -if (lean_is_scalar(x_144)) { - x_147 = lean_alloc_ctor(0, 5, 0); -} else { - x_147 = x_144; -} -lean_ctor_set(x_147, 0, x_139); -lean_ctor_set(x_147, 1, x_140); -lean_ctor_set(x_147, 2, x_146); -lean_ctor_set(x_147, 3, x_142); -lean_ctor_set(x_147, 4, x_143); -x_148 = lean_apply_2(x_3, x_147, x_5); -if (lean_obj_tag(x_148) == 0) -{ -lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_148, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_148, 0); -lean_inc(x_151); -if (lean_is_exclusive(x_148)) { - lean_ctor_release(x_148, 0); - lean_ctor_release(x_148, 1); - x_152 = x_148; -} else { - lean_dec_ref(x_148); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; -} else { - lean_dec_ref(x_149); - x_158 = lean_box(0); -} -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; -} else { - lean_dec_ref(x_150); - x_162 = lean_box(0); -} -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); -} else { - x_163 = x_162; -} -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_135); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); -} else { - x_164 = x_158; -} -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(0, 2, 0); -} else { - x_165 = x_152; -} -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_166 = lean_ctor_get(x_148, 1); -lean_inc(x_166); -x_167 = lean_ctor_get(x_166, 2); -lean_inc(x_167); -x_168 = lean_ctor_get(x_148, 0); -lean_inc(x_168); -if (lean_is_exclusive(x_148)) { - lean_ctor_release(x_148, 0); - lean_ctor_release(x_148, 1); - x_169 = x_148; -} else { - lean_dec_ref(x_148); - x_169 = lean_box(0); -} -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_166, 3); -lean_inc(x_172); -x_173 = lean_ctor_get(x_166, 4); -lean_inc(x_173); -x_174 = lean_ctor_get(x_166, 5); -lean_inc(x_174); -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); - lean_ctor_release(x_166, 4); - lean_ctor_release(x_166, 5); - x_175 = x_166; -} else { - lean_dec_ref(x_166); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_167, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_167, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_167, 3); -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); - 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, 4, 0); -} else { - x_180 = x_179; -} -lean_ctor_set(x_180, 0, x_176); -lean_ctor_set(x_180, 1, x_177); -lean_ctor_set(x_180, 2, x_135); -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); -if (lean_is_scalar(x_169)) { - x_182 = lean_alloc_ctor(1, 2, 0); -} else { - x_182 = x_169; -} -lean_ctor_set(x_182, 0, x_168); -lean_ctor_set(x_182, 1, x_181); -return x_182; -} -} -} -else -{ -lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; 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_183 = lean_ctor_get(x_5, 2); -x_184 = lean_ctor_get(x_5, 0); -x_185 = lean_ctor_get(x_5, 1); -x_186 = lean_ctor_get(x_5, 3); -x_187 = lean_ctor_get(x_5, 4); -x_188 = lean_ctor_get(x_5, 5); -lean_inc(x_188); -lean_inc(x_187); -lean_inc(x_186); -lean_inc(x_183); -lean_inc(x_185); -lean_inc(x_184); +lean_inc(x_145); +lean_inc(x_144); lean_dec(x_5); -x_189 = lean_ctor_get(x_183, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_183, 1); +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_183, 2); +x_191 = lean_ctor_get(x_4, 1); lean_inc(x_191); -x_192 = lean_ctor_get(x_183, 3); +x_192 = lean_ctor_get(x_4, 2); lean_inc(x_192); -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); - x_193 = x_183; -} else { - lean_dec_ref(x_183); - x_193 = lean_box(0); -} -x_194 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_193)) { - x_195 = lean_alloc_ctor(0, 4, 0); -} else { - x_195 = x_193; -} -lean_ctor_set(x_195, 0, x_189); -lean_ctor_set(x_195, 1, x_190); -lean_ctor_set(x_195, 2, x_194); -lean_ctor_set(x_195, 3, x_192); -x_196 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_196, 0, x_184); -lean_ctor_set(x_196, 1, x_185); -lean_ctor_set(x_196, 2, x_195); -lean_ctor_set(x_196, 3, x_186); -lean_ctor_set(x_196, 4, x_187); -lean_ctor_set(x_196, 5, x_188); -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); +x_193 = lean_ctor_get(x_4, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_4, 4); +lean_inc(x_194); 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_195 = x_4; } else { lean_dec_ref(x_4); - x_202 = lean_box(0); + x_195 = lean_box(0); } -x_203 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_203, 0, x_1); -lean_ctor_set(x_203, 1, x_2); -x_204 = lean_array_push(x_199, x_203); -if (lean_is_scalar(x_202)) { - x_205 = lean_alloc_ctor(0, 5, 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_198 = lean_alloc_ctor(0, 5, 0); } else { - x_205 = x_202; + x_198 = x_195; } -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_2(x_3, x_205, x_196); -if (lean_obj_tag(x_206) == 0) +lean_ctor_set(x_198, 0, x_190); +lean_ctor_set(x_198, 1, x_191); +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_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; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_207 = lean_ctor_get(x_206, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_207, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_206, 0); -lean_inc(x_209); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - x_210 = x_206; -} else { - lean_dec_ref(x_206); - x_210 = lean_box(0); -} -x_211 = lean_ctor_get(x_207, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_207, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_207, 3); -lean_inc(x_213); -x_214 = lean_ctor_get(x_207, 4); -lean_inc(x_214); -x_215 = lean_ctor_get(x_207, 5); -lean_inc(x_215); -if (lean_is_exclusive(x_207)) { - lean_ctor_release(x_207, 0); - lean_ctor_release(x_207, 1); - lean_ctor_release(x_207, 2); - lean_ctor_release(x_207, 3); - lean_ctor_release(x_207, 4); - lean_ctor_release(x_207, 5); - x_216 = x_207; -} else { - lean_dec_ref(x_207); - x_216 = lean_box(0); -} -x_217 = lean_ctor_get(x_208, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_208, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_208, 3); -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); - 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, 4, 0); -} else { - x_221 = x_220; -} -lean_ctor_set(x_221, 0, x_217); -lean_ctor_set(x_221, 1, x_218); -lean_ctor_set(x_221, 2, x_191); -lean_ctor_set(x_221, 3, x_219); -if (lean_is_scalar(x_216)) { - x_222 = lean_alloc_ctor(0, 6, 0); -} else { - x_222 = x_216; -} -lean_ctor_set(x_222, 0, x_211); -lean_ctor_set(x_222, 1, x_212); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_213); -lean_ctor_set(x_222, 4, x_214); -lean_ctor_set(x_222, 5, x_215); -if (lean_is_scalar(x_210)) { - x_223 = lean_alloc_ctor(0, 2, 0); -} else { - x_223 = x_210; -} -lean_ctor_set(x_223, 0, x_209); -lean_ctor_set(x_223, 1, x_222); -return x_223; +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_154 = x_202; +x_155 = x_201; +goto block_186; } else { -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_224 = lean_ctor_get(x_206, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_206, 0); -lean_inc(x_226); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - x_227 = x_206; -} else { - lean_dec_ref(x_206); - x_227 = lean_box(0); +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_154 = x_205; +x_155 = x_204; +goto block_186; } -x_228 = lean_ctor_get(x_224, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_224, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_224, 3); -lean_inc(x_230); -x_231 = lean_ctor_get(x_224, 4); -lean_inc(x_231); -x_232 = lean_ctor_get(x_224, 5); -lean_inc(x_232); -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); - lean_ctor_release(x_224, 5); - x_233 = x_224; +block_186: +{ +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_224); - x_233 = lean_box(0); + lean_dec_ref(x_155); + x_163 = lean_box(0); } -x_234 = lean_ctor_get(x_225, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_225, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_225, 3); -lean_inc(x_236); -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); - x_237 = x_225; +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_225); - x_237 = lean_box(0); + lean_dec_ref(x_156); + x_167 = lean_box(0); } -if (lean_is_scalar(x_237)) { - x_238 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_167)) { + x_168 = lean_alloc_ctor(0, 4, 0); } else { - x_238 = x_237; + x_168 = x_167; } -lean_ctor_set(x_238, 0, x_234); -lean_ctor_set(x_238, 1, x_235); -lean_ctor_set(x_238, 2, x_191); -lean_ctor_set(x_238, 3, x_236); -if (lean_is_scalar(x_233)) { - x_239 = lean_alloc_ctor(0, 6, 0); +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_239 = x_233; + x_169 = x_163; } -lean_ctor_set(x_239, 0, x_228); -lean_ctor_set(x_239, 1, x_229); -lean_ctor_set(x_239, 2, x_238); -lean_ctor_set(x_239, 3, x_230); -lean_ctor_set(x_239, 4, x_231); -lean_ctor_set(x_239, 5, x_232); -if (lean_is_scalar(x_227)) { - x_240 = lean_alloc_ctor(1, 2, 0); +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; +} +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_inc(x_172); +lean_dec(x_154); +x_173 = lean_ctor_get(x_155, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_155, 1); +lean_inc(x_174); +x_175 = lean_ctor_get(x_155, 3); +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; } else { - x_240 = x_227; + lean_dec_ref(x_155); + x_178 = lean_box(0); +} +x_179 = lean_ctor_get(x_171, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_171, 1); +lean_inc(x_180); +x_181 = lean_ctor_get(x_171, 3); +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; +} else { + lean_dec_ref(x_171); + x_182 = lean_box(0); +} +if (lean_is_scalar(x_182)) { + x_183 = lean_alloc_ctor(0, 4, 0); +} else { + x_183 = x_182; +} +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); +} else { + x_184 = x_178; +} +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_240, 0, x_226); -lean_ctor_set(x_240, 1, x_239); -return x_240; } } } @@ -8731,2153 +8414,1791 @@ goto _start; } case 1: { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; uint8_t x_25; +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_dec(x_14); x_21 = lean_ctor_get(x_15, 1); lean_inc(x_21); -lean_dec(x_15); -x_22 = lean_ctor_get(x_16, 0); -lean_inc(x_22); +if (lean_is_exclusive(x_15)) { + lean_ctor_release(x_15, 0); + lean_ctor_release(x_15, 1); + x_22 = x_15; +} else { + lean_dec_ref(x_15); + x_22 = lean_box(0); +} +x_23 = lean_ctor_get(x_16, 0); +lean_inc(x_23); lean_dec(x_16); -x_23 = lean_unsigned_to_nat(1u); -x_24 = lean_nat_add(x_3, x_23); +x_24 = lean_unsigned_to_nat(1u); +x_25 = lean_nat_add(x_3, x_24); lean_dec(x_3); -x_25 = !lean_is_exclusive(x_21); -if (x_25 == 0) +x_26 = !lean_is_exclusive(x_21); +if (x_26 == 0) { -lean_object* x_26; uint8_t x_27; -x_26 = lean_ctor_get(x_21, 2); -x_27 = !lean_is_exclusive(x_26); -if (x_27 == 0) +lean_object* x_27; uint8_t x_28; +x_27 = lean_ctor_get(x_21, 2); +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) { -lean_object* x_28; lean_object* x_29; uint8_t x_30; -x_28 = lean_ctor_get(x_26, 2); -x_29 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_26, 2, x_29); -x_30 = !lean_is_exclusive(x_5); -if (x_30 == 0) +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_81; uint8_t x_82; +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) { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_5, 2); -x_32 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_32, 0, x_22); -lean_ctor_set(x_32, 1, x_10); -x_33 = lean_array_push(x_31, x_32); -lean_ctor_set(x_5, 2, x_33); -x_34 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_24, x_4, x_5, x_21); -if (lean_obj_tag(x_34) == 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_35; lean_object* x_36; uint8_t x_37; -x_35 = lean_ctor_get(x_34, 1); -lean_inc(x_35); -x_36 = lean_ctor_get(x_35, 2); -lean_inc(x_36); -x_37 = !lean_is_exclusive(x_34); -if (x_37 == 0) -{ -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_34, 1); -lean_dec(x_38); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -lean_dec(x_40); -x_41 = !lean_is_exclusive(x_36); -if (x_41 == 0) -{ -lean_object* x_42; -x_42 = lean_ctor_get(x_36, 2); -lean_dec(x_42); -lean_ctor_set(x_36, 2, x_28); -return x_34; +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_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -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_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_28); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); -return x_34; +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_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; } } 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; -x_47 = lean_ctor_get(x_35, 0); -x_48 = lean_ctor_get(x_35, 1); -x_49 = lean_ctor_get(x_35, 3); -x_50 = lean_ctor_get(x_35, 4); -x_51 = lean_ctor_get(x_35, 5); -lean_inc(x_51); -lean_inc(x_50); -lean_inc(x_49); +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_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; +} +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_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; +} +} +block_80: +{ +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_32 = lean_ctor_get(x_31, 2); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 0); +lean_inc(x_33); +lean_dec(x_30); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_31, 2); +lean_dec(x_35); +x_36 = !lean_is_exclusive(x_32); +if (x_36 == 0) +{ +lean_object* x_37; lean_object* x_38; +x_37 = lean_ctor_get(x_32, 2); +lean_dec(x_37); +lean_ctor_set(x_32, 2, x_29); +if (lean_is_scalar(x_22)) { + x_38 = lean_alloc_ctor(1, 2, 0); +} else { + x_38 = x_22; + lean_ctor_set_tag(x_38, 1); +} +lean_ctor_set(x_38, 0, x_33); +lean_ctor_set(x_38, 1, x_31); +return x_38; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_39 = lean_ctor_get(x_32, 0); +x_40 = lean_ctor_get(x_32, 1); +x_41 = lean_ctor_get(x_32, 3); +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); +if (lean_is_scalar(x_22)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_22; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_33); +lean_ctor_set(x_43, 1, x_31); +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_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_inc(x_48); lean_inc(x_47); -lean_dec(x_35); -x_52 = lean_ctor_get(x_36, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_36, 1); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 3); -lean_inc(x_54); -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_55 = x_36; +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); +lean_inc(x_50); +x_51 = lean_ctor_get(x_32, 3); +lean_inc(x_51); +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; } else { - lean_dec_ref(x_36); - x_55 = lean_box(0); + lean_dec_ref(x_32); + x_52 = lean_box(0); } -if (lean_is_scalar(x_55)) { - x_56 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(0, 4, 0); } else { - x_56 = x_55; + x_53 = x_52; } -lean_ctor_set(x_56, 0, x_52); -lean_ctor_set(x_56, 1, x_53); -lean_ctor_set(x_56, 2, x_28); -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_34, 1, x_57); -return x_34; +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); +if (lean_is_scalar(x_22)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_22; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_33); +lean_ctor_set(x_55, 1, x_54); +return x_55; } } 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; lean_object* x_70; lean_object* x_71; -x_58 = lean_ctor_get(x_34, 0); -lean_inc(x_58); -lean_dec(x_34); -x_59 = lean_ctor_get(x_35, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_35, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_35, 3); -lean_inc(x_61); -x_62 = lean_ctor_get(x_35, 4); -lean_inc(x_62); -x_63 = lean_ctor_get(x_35, 5); -lean_inc(x_63); -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); - lean_ctor_release(x_35, 4); - lean_ctor_release(x_35, 5); - x_64 = x_35; +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_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); +if (x_60 == 0) +{ +lean_object* x_61; lean_object* x_62; +x_61 = lean_ctor_get(x_56, 2); +lean_dec(x_61); +lean_ctor_set(x_56, 2, x_29); +if (lean_is_scalar(x_22)) { + x_62 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_35); - x_64 = lean_box(0); + x_62 = x_22; } -x_65 = lean_ctor_get(x_36, 0); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_31); +return x_62; +} +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_inc(x_65); -x_66 = lean_ctor_get(x_36, 1); -lean_inc(x_66); -x_67 = lean_ctor_get(x_36, 3); -lean_inc(x_67); -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_68 = x_36; +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); +if (lean_is_scalar(x_22)) { + x_67 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_36); - x_68 = lean_box(0); + x_67 = x_22; } -if (lean_is_scalar(x_68)) { - x_69 = lean_alloc_ctor(0, 4, 0); -} else { - x_69 = x_68; -} -lean_ctor_set(x_69, 0, x_65); -lean_ctor_set(x_69, 1, x_66); -lean_ctor_set(x_69, 2, x_28); -lean_ctor_set(x_69, 3, x_67); -if (lean_is_scalar(x_64)) { - x_70 = lean_alloc_ctor(0, 6, 0); -} else { - x_70 = x_64; -} -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); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_58); -lean_ctor_set(x_71, 1, x_70); -return x_71; +lean_ctor_set(x_67, 0, x_57); +lean_ctor_set(x_67, 1, x_31); +return x_67; } } else { -lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_72 = lean_ctor_get(x_34, 1); +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_inc(x_72); -x_73 = lean_ctor_get(x_72, 2); +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_is_exclusive(x_34); -if (x_74 == 0) -{ -lean_object* x_75; uint8_t x_76; -x_75 = lean_ctor_get(x_34, 1); -lean_dec(x_75); -x_76 = !lean_is_exclusive(x_72); -if (x_76 == 0) -{ -lean_object* x_77; uint8_t x_78; -x_77 = lean_ctor_get(x_72, 2); -lean_dec(x_77); -x_78 = !lean_is_exclusive(x_73); -if (x_78 == 0) -{ -lean_object* x_79; -x_79 = lean_ctor_get(x_73, 2); -lean_dec(x_79); -lean_ctor_set(x_73, 2, x_28); -return x_34; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -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_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_28); -lean_ctor_set(x_83, 3, x_82); -lean_ctor_set(x_72, 2, x_83); -return x_34; -} -} -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; -x_84 = lean_ctor_get(x_72, 0); -x_85 = lean_ctor_get(x_72, 1); -x_86 = lean_ctor_get(x_72, 3); -x_87 = lean_ctor_get(x_72, 4); -x_88 = lean_ctor_get(x_72, 5); -lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_72); -x_89 = lean_ctor_get(x_73, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_73, 1); -lean_inc(x_90); -x_91 = lean_ctor_get(x_73, 3); -lean_inc(x_91); -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_92 = 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; } else { - lean_dec_ref(x_73); - x_92 = lean_box(0); + lean_dec_ref(x_56); + x_76 = lean_box(0); } -if (lean_is_scalar(x_92)) { - x_93 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 4, 0); } else { - x_93 = x_92; + x_77 = x_76; } -lean_ctor_set(x_93, 0, x_89); -lean_ctor_set(x_93, 1, x_90); -lean_ctor_set(x_93, 2, x_28); -lean_ctor_set(x_93, 3, x_91); -x_94 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_94, 0, x_84); -lean_ctor_set(x_94, 1, x_85); -lean_ctor_set(x_94, 2, x_93); -lean_ctor_set(x_94, 3, x_86); -lean_ctor_set(x_94, 4, x_87); -lean_ctor_set(x_94, 5, x_88); -lean_ctor_set(x_34, 1, x_94); -return x_34; -} -} -else -{ -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_95 = lean_ctor_get(x_34, 0); -lean_inc(x_95); -lean_dec(x_34); -x_96 = lean_ctor_get(x_72, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_72, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_72, 3); -lean_inc(x_98); -x_99 = lean_ctor_get(x_72, 4); -lean_inc(x_99); -x_100 = lean_ctor_get(x_72, 5); -lean_inc(x_100); -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_101 = x_72; +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); +if (lean_is_scalar(x_22)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_72); - x_101 = lean_box(0); + x_79 = x_22; } -x_102 = lean_ctor_get(x_73, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_73, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_73, 3); -lean_inc(x_104); -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_105 = x_73; -} else { - lean_dec_ref(x_73); - x_105 = lean_box(0); +lean_ctor_set(x_79, 0, x_57); +lean_ctor_set(x_79, 1, x_78); +return x_79; } -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_28); -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; -x_109 = lean_ctor_get(x_5, 0); -x_110 = lean_ctor_get(x_5, 1); -x_111 = lean_ctor_get(x_5, 2); -x_112 = lean_ctor_get(x_5, 3); -x_113 = lean_ctor_get(x_5, 4); -lean_inc(x_113); -lean_inc(x_112); +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_dec(x_5); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_22); -lean_ctor_set(x_114, 1, x_10); -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___rarg(x_1, x_2, x_24, x_4, x_116, x_21); -if (lean_obj_tag(x_117) == 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; lean_object* x_133; lean_object* x_134; -x_118 = lean_ctor_get(x_117, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_118, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_117, 0); -lean_inc(x_120); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_121 = x_117; +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_117); + 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_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_118, 0); +x_122 = lean_ctor_get(x_114, 0); lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 1); +x_123 = lean_ctor_get(x_114, 1); lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 3); +x_124 = lean_ctor_get(x_114, 3); lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 4); -lean_inc(x_125); -x_126 = lean_ctor_get(x_118, 5); -lean_inc(x_126); -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_127 = x_118; +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_118); - x_127 = lean_box(0); + lean_dec_ref(x_114); + x_125 = lean_box(0); } -x_128 = lean_ctor_get(x_119, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_119, 3); -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); - x_131 = x_119; +if (lean_is_scalar(x_125)) { + x_126 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_119); - x_131 = lean_box(0); + x_126 = x_125; } -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_28); -lean_ctor_set(x_132, 3, x_130); -if (lean_is_scalar(x_127)) { - x_133 = lean_alloc_ctor(0, 6, 0); -} else { - x_133 = x_127; -} -lean_ctor_set(x_133, 0, x_122); -lean_ctor_set(x_133, 1, x_123); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_124); -lean_ctor_set(x_133, 4, x_125); -lean_ctor_set(x_133, 5, x_126); +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_134 = lean_alloc_ctor(0, 2, 0); + x_127 = lean_alloc_ctor(0, 6, 0); } else { - x_134 = x_121; + x_127 = x_121; } -lean_ctor_set(x_134, 0, x_120); -lean_ctor_set(x_134, 1, x_133); -return x_134; +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_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_135 = lean_ctor_get(x_117, 1); +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); -x_136 = lean_ctor_get(x_135, 2); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 0); +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); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_138 = x_117; -} else { - lean_dec_ref(x_117); - x_138 = lean_box(0); -} -x_139 = lean_ctor_get(x_135, 0); +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_135, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); -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; +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_135); - x_144 = lean_box(0); + lean_dec_ref(x_129); + x_140 = lean_box(0); } -x_145 = lean_ctor_get(x_136, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_136, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 3); -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); - x_148 = x_136; +if (lean_is_scalar(x_140)) { + x_141 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_136); - x_148 = lean_box(0); + x_141 = x_140; } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); +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_149 = x_148; + x_142 = x_136; } -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_28); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); +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_150 = x_144; + x_143 = x_22; } -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(1, 2, 0); -} else { - x_151 = x_138; +lean_ctor_set(x_143, 0, x_130); +lean_ctor_set(x_143, 1, x_142); +return x_143; } -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_26, 0); -x_153 = lean_ctor_get(x_26, 1); -x_154 = lean_ctor_get(x_26, 2); -x_155 = lean_ctor_get(x_26, 3); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); -lean_dec(x_26); -x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_157 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_157, 0, x_152); -lean_ctor_set(x_157, 1, x_153); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_155); -lean_ctor_set(x_21, 2, x_157); -x_158 = lean_ctor_get(x_5, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_5, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_5, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_5, 3); -lean_inc(x_161); -x_162 = lean_ctor_get(x_5, 4); -lean_inc(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_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); 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_163 = x_5; + x_215 = x_5; } else { lean_dec_ref(x_5); - x_163 = lean_box(0); + x_215 = lean_box(0); } -x_164 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_164, 0, x_22); -lean_ctor_set(x_164, 1, x_10); -x_165 = lean_array_push(x_160, x_164); -if (lean_is_scalar(x_163)) { - x_166 = lean_alloc_ctor(0, 5, 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_218 = lean_alloc_ctor(0, 5, 0); } else { - x_166 = x_163; + x_218 = x_215; } -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___rarg(x_1, x_2, x_24, x_4, x_166, x_21); -if (lean_obj_tag(x_167) == 0) +lean_ctor_set(x_218, 0, x_210); +lean_ctor_set(x_218, 1, x_211); +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_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; -x_168 = lean_ctor_get(x_167, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_168, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_167, 0); -lean_inc(x_170); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - x_171 = x_167; -} else { - lean_dec_ref(x_167); - x_171 = lean_box(0); -} -x_172 = lean_ctor_get(x_168, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_168, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_168, 3); -lean_inc(x_174); -x_175 = lean_ctor_get(x_168, 4); -lean_inc(x_175); -x_176 = lean_ctor_get(x_168, 5); -lean_inc(x_176); -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); - lean_ctor_release(x_168, 4); - lean_ctor_release(x_168, 5); - x_177 = x_168; -} else { - lean_dec_ref(x_168); - x_177 = lean_box(0); -} -x_178 = lean_ctor_get(x_169, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_169, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_169, 3); -lean_inc(x_180); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - x_181 = x_169; -} else { - lean_dec_ref(x_169); - x_181 = lean_box(0); -} -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 4, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_178); -lean_ctor_set(x_182, 1, x_179); -lean_ctor_set(x_182, 2, x_154); -lean_ctor_set(x_182, 3, x_180); -if (lean_is_scalar(x_177)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_177; -} -lean_ctor_set(x_183, 0, x_172); -lean_ctor_set(x_183, 1, x_173); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_174); -lean_ctor_set(x_183, 4, x_175); -lean_ctor_set(x_183, 5, x_176); -if (lean_is_scalar(x_171)) { - x_184 = lean_alloc_ctor(0, 2, 0); -} else { - x_184 = x_171; -} -lean_ctor_set(x_184, 0, x_170); -lean_ctor_set(x_184, 1, x_183); -return x_184; +lean_object* x_220; lean_object* x_221; lean_object* x_222; +x_220 = lean_ctor_get(x_219, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_219, 1); +lean_inc(x_221); +lean_dec(x_219); +x_222 = 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_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; lean_object* x_200; lean_object* x_201; -x_185 = lean_ctor_get(x_167, 1); +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_219, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_219, 1); +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; +} +block_206: +{ +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_185, 2); +x_186 = lean_ctor_get(x_176, 3); lean_inc(x_186); -x_187 = lean_ctor_get(x_167, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - x_188 = x_167; +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_167); - x_188 = lean_box(0); + lean_dec_ref(x_176); + x_187 = lean_box(0); } -x_189 = lean_ctor_get(x_185, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 3); +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; +} +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_185, 4); +x_192 = lean_ctor_get(x_174, 0); lean_inc(x_192); -x_193 = lean_ctor_get(x_185, 5); +lean_dec(x_174); +x_193 = lean_ctor_get(x_175, 0); lean_inc(x_193); -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_194 = x_185; -} else { - lean_dec_ref(x_185); - x_194 = lean_box(0); -} -x_195 = lean_ctor_get(x_186, 0); +x_194 = lean_ctor_get(x_175, 1); +lean_inc(x_194); +x_195 = lean_ctor_get(x_175, 3); lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); +x_196 = lean_ctor_get(x_175, 4); lean_inc(x_196); -x_197 = lean_ctor_get(x_186, 3); +x_197 = lean_ctor_get(x_175, 5); lean_inc(x_197); -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_198 = x_186; +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; } else { - lean_dec_ref(x_186); + lean_dec_ref(x_175); x_198 = 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; +} else { + lean_dec_ref(x_191); + x_202 = lean_box(0); +} +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); +} else { + x_203 = x_202; +} +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_199 = lean_alloc_ctor(0, 4, 0); + x_204 = lean_alloc_ctor(0, 6, 0); } else { - x_199 = x_198; + x_204 = 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_154); -lean_ctor_set(x_199, 3, x_197); -if (lean_is_scalar(x_194)) { - x_200 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_22)) { + x_205 = lean_alloc_ctor(0, 2, 0); } else { - x_200 = x_194; + x_205 = x_22; } -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_188)) { - x_201 = lean_alloc_ctor(1, 2, 0); -} else { - x_201 = x_188; +lean_ctor_set(x_205, 0, x_192); +lean_ctor_set(x_205, 1, x_204); +return x_205; } -lean_ctor_set(x_201, 0, x_187); -lean_ctor_set(x_201, 1, x_200); -return x_201; -} -} -} -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; 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_202 = lean_ctor_get(x_21, 2); -x_203 = lean_ctor_get(x_21, 0); -x_204 = lean_ctor_get(x_21, 1); -x_205 = lean_ctor_get(x_21, 3); -x_206 = lean_ctor_get(x_21, 4); -x_207 = lean_ctor_get(x_21, 5); -lean_inc(x_207); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_202); -lean_inc(x_204); -lean_inc(x_203); -lean_dec(x_21); -x_208 = lean_ctor_get(x_202, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_202, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_202, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_202, 3); -lean_inc(x_211); -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_212 = x_202; -} else { - lean_dec_ref(x_202); - x_212 = lean_box(0); -} -x_213 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_212)) { - x_214 = lean_alloc_ctor(0, 4, 0); -} else { - x_214 = x_212; -} -lean_ctor_set(x_214, 0, x_208); -lean_ctor_set(x_214, 1, x_209); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_211); -x_215 = lean_alloc_ctor(0, 6, 0); -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); -x_216 = lean_ctor_get(x_5, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_5, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_5, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_5, 3); -lean_inc(x_219); -x_220 = lean_ctor_get(x_5, 4); -lean_inc(x_220); -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_221 = x_5; -} else { - lean_dec_ref(x_5); - x_221 = lean_box(0); -} -x_222 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_222, 0, x_22); -lean_ctor_set(x_222, 1, x_10); -x_223 = lean_array_push(x_218, x_222); -if (lean_is_scalar(x_221)) { - x_224 = lean_alloc_ctor(0, 5, 0); -} else { - x_224 = x_221; -} -lean_ctor_set(x_224, 0, x_216); -lean_ctor_set(x_224, 1, x_217); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_219); -lean_ctor_set(x_224, 4, x_220); -x_225 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_24, x_4, x_224, x_215); -if (lean_obj_tag(x_225) == 0) -{ -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; -x_226 = lean_ctor_get(x_225, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_226, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_225, 0); -lean_inc(x_228); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_229 = x_225; -} else { - lean_dec_ref(x_225); - x_229 = lean_box(0); -} -x_230 = lean_ctor_get(x_226, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_226, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_226, 3); -lean_inc(x_232); -x_233 = lean_ctor_get(x_226, 4); -lean_inc(x_233); -x_234 = lean_ctor_get(x_226, 5); -lean_inc(x_234); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - lean_ctor_release(x_226, 2); - lean_ctor_release(x_226, 3); - lean_ctor_release(x_226, 4); - lean_ctor_release(x_226, 5); - x_235 = x_226; -} else { - lean_dec_ref(x_226); - x_235 = lean_box(0); -} -x_236 = lean_ctor_get(x_227, 0); -lean_inc(x_236); -x_237 = lean_ctor_get(x_227, 1); -lean_inc(x_237); -x_238 = lean_ctor_get(x_227, 3); -lean_inc(x_238); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - lean_ctor_release(x_227, 2); - lean_ctor_release(x_227, 3); - x_239 = x_227; -} else { - lean_dec_ref(x_227); - x_239 = lean_box(0); -} -if (lean_is_scalar(x_239)) { - x_240 = lean_alloc_ctor(0, 4, 0); -} else { - x_240 = x_239; -} -lean_ctor_set(x_240, 0, x_236); -lean_ctor_set(x_240, 1, x_237); -lean_ctor_set(x_240, 2, x_210); -lean_ctor_set(x_240, 3, x_238); -if (lean_is_scalar(x_235)) { - x_241 = lean_alloc_ctor(0, 6, 0); -} else { - x_241 = x_235; -} -lean_ctor_set(x_241, 0, x_230); -lean_ctor_set(x_241, 1, x_231); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_232); -lean_ctor_set(x_241, 4, x_233); -lean_ctor_set(x_241, 5, x_234); -if (lean_is_scalar(x_229)) { - x_242 = lean_alloc_ctor(0, 2, 0); -} else { - x_242 = x_229; -} -lean_ctor_set(x_242, 0, x_228); -lean_ctor_set(x_242, 1, x_241); -return x_242; -} -else -{ -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; -x_243 = lean_ctor_get(x_225, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_243, 2); -lean_inc(x_244); -x_245 = lean_ctor_get(x_225, 0); -lean_inc(x_245); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_246 = x_225; -} else { - lean_dec_ref(x_225); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_243, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_243, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_243, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_243, 4); -lean_inc(x_250); -x_251 = lean_ctor_get(x_243, 5); -lean_inc(x_251); -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); - lean_ctor_release(x_243, 4); - lean_ctor_release(x_243, 5); - x_252 = x_243; -} else { - lean_dec_ref(x_243); - x_252 = lean_box(0); -} -x_253 = lean_ctor_get(x_244, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_244, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_244, 3); -lean_inc(x_255); -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_256 = x_244; -} else { - lean_dec_ref(x_244); - x_256 = lean_box(0); -} -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 4, 0); -} else { - x_257 = x_256; -} -lean_ctor_set(x_257, 0, x_253); -lean_ctor_set(x_257, 1, x_254); -lean_ctor_set(x_257, 2, x_210); -lean_ctor_set(x_257, 3, x_255); -if (lean_is_scalar(x_252)) { - x_258 = lean_alloc_ctor(0, 6, 0); -} else { - x_258 = x_252; -} -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_246)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_246; -} -lean_ctor_set(x_259, 0, x_245); -lean_ctor_set(x_259, 1, x_258); -return x_259; } } } default: { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_15, 1); -lean_inc(x_260); +lean_object* x_226; lean_object* x_227; +x_226 = lean_ctor_get(x_15, 1); +lean_inc(x_226); lean_dec(x_15); lean_inc(x_1); lean_inc(x_5); -x_261 = lean_apply_3(x_1, x_14, x_5, x_260); -if (lean_obj_tag(x_261) == 0) +x_227 = lean_apply_3(x_1, x_14, x_5, x_226); +if (lean_obj_tag(x_227) == 0) { -lean_object* x_262; -x_262 = lean_ctor_get(x_261, 0); -lean_inc(x_262); -if (lean_obj_tag(x_262) == 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_263; lean_object* x_264; lean_object* x_265; +lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_dec(x_10); -x_263 = lean_ctor_get(x_261, 1); -lean_inc(x_263); -lean_dec(x_261); -x_264 = lean_unsigned_to_nat(1u); -x_265 = lean_nat_add(x_3, x_264); +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); lean_dec(x_3); -x_3 = x_265; -x_6 = x_263; +x_3 = x_231; +x_6 = x_229; goto _start; } else { -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; uint8_t x_271; -x_267 = lean_ctor_get(x_261, 1); -lean_inc(x_267); -lean_dec(x_261); -x_268 = lean_ctor_get(x_262, 0); -lean_inc(x_268); -lean_dec(x_262); -x_269 = lean_unsigned_to_nat(1u); -x_270 = lean_nat_add(x_3, x_269); +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; +} else { + lean_dec_ref(x_227); + x_234 = 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_271 = !lean_is_exclusive(x_267); -if (x_271 == 0) +x_238 = !lean_is_exclusive(x_233); +if (x_238 == 0) { -lean_object* x_272; uint8_t x_273; -x_272 = lean_ctor_get(x_267, 2); -x_273 = !lean_is_exclusive(x_272); -if (x_273 == 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_274; lean_object* x_275; uint8_t x_276; -x_274 = lean_ctor_get(x_272, 2); -x_275 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_272, 2, x_275); -x_276 = !lean_is_exclusive(x_5); -if (x_276 == 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_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_5, 2); -x_278 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_10); -x_279 = lean_array_push(x_277, x_278); -lean_ctor_set(x_5, 2, x_279); -x_280 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_270, x_4, x_5, x_267); -if (lean_obj_tag(x_280) == 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_281; lean_object* x_282; uint8_t x_283; -x_281 = lean_ctor_get(x_280, 1); -lean_inc(x_281); -x_282 = lean_ctor_get(x_281, 2); -lean_inc(x_282); -x_283 = !lean_is_exclusive(x_280); -if (x_283 == 0) -{ -lean_object* x_284; uint8_t x_285; -x_284 = lean_ctor_get(x_280, 1); -lean_dec(x_284); -x_285 = !lean_is_exclusive(x_281); -if (x_285 == 0) -{ -lean_object* x_286; uint8_t x_287; -x_286 = lean_ctor_get(x_281, 2); -lean_dec(x_286); -x_287 = !lean_is_exclusive(x_282); -if (x_287 == 0) -{ -lean_object* x_288; -x_288 = lean_ctor_get(x_282, 2); -lean_dec(x_288); -lean_ctor_set(x_282, 2, x_274); -return x_280; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; -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_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_274); -lean_ctor_set(x_292, 3, x_291); -lean_ctor_set(x_281, 2, x_292); -return x_280; -} -} -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; -x_293 = lean_ctor_get(x_281, 0); -x_294 = lean_ctor_get(x_281, 1); -x_295 = lean_ctor_get(x_281, 3); -x_296 = lean_ctor_get(x_281, 4); -x_297 = lean_ctor_get(x_281, 5); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_281); -x_298 = lean_ctor_get(x_282, 0); -lean_inc(x_298); -x_299 = lean_ctor_get(x_282, 1); +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_282, 3); +x_300 = lean_ctor_get(x_298, 1); lean_inc(x_300); -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_301 = x_282; -} else { - lean_dec_ref(x_282); - x_301 = lean_box(0); +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; } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 4, 0); -} else { - x_302 = x_301; -} -lean_ctor_set(x_302, 0, x_298); -lean_ctor_set(x_302, 1, x_299); -lean_ctor_set(x_302, 2, x_274); -lean_ctor_set(x_302, 3, x_300); -x_303 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_303, 0, x_293); -lean_ctor_set(x_303, 1, x_294); -lean_ctor_set(x_303, 2, x_302); -lean_ctor_set(x_303, 3, x_295); -lean_ctor_set(x_303, 4, x_296); -lean_ctor_set(x_303, 5, x_297); -lean_ctor_set(x_280, 1, x_303); -return x_280; +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_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; lean_object* x_317; -x_304 = lean_ctor_get(x_280, 0); -lean_inc(x_304); -lean_dec(x_280); -x_305 = lean_ctor_get(x_281, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_281, 1); -lean_inc(x_306); -x_307 = lean_ctor_get(x_281, 3); -lean_inc(x_307); -x_308 = lean_ctor_get(x_281, 4); -lean_inc(x_308); -x_309 = lean_ctor_get(x_281, 5); +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); -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); - x_310 = x_281; -} else { - lean_dec_ref(x_281); - x_310 = lean_box(0); -} -x_311 = lean_ctor_get(x_282, 0); -lean_inc(x_311); -x_312 = lean_ctor_get(x_282, 1); -lean_inc(x_312); -x_313 = lean_ctor_get(x_282, 3); -lean_inc(x_313); -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_314 = x_282; -} else { - lean_dec_ref(x_282); - x_314 = lean_box(0); -} -if (lean_is_scalar(x_314)) { - x_315 = lean_alloc_ctor(0, 4, 0); -} else { - x_315 = x_314; -} -lean_ctor_set(x_315, 0, x_311); -lean_ctor_set(x_315, 1, x_312); -lean_ctor_set(x_315, 2, x_274); -lean_ctor_set(x_315, 3, x_313); -if (lean_is_scalar(x_310)) { - x_316 = lean_alloc_ctor(0, 6, 0); -} else { - x_316 = x_310; -} -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); -x_317 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_317, 0, x_304); -lean_ctor_set(x_317, 1, x_316); -return x_317; -} -} -else -{ -lean_object* x_318; lean_object* x_319; uint8_t x_320; -x_318 = lean_ctor_get(x_280, 1); -lean_inc(x_318); -x_319 = lean_ctor_get(x_318, 2); -lean_inc(x_319); -x_320 = !lean_is_exclusive(x_280); -if (x_320 == 0) -{ -lean_object* x_321; uint8_t x_322; -x_321 = lean_ctor_get(x_280, 1); -lean_dec(x_321); -x_322 = !lean_is_exclusive(x_318); -if (x_322 == 0) -{ -lean_object* x_323; uint8_t x_324; -x_323 = lean_ctor_get(x_318, 2); -lean_dec(x_323); -x_324 = !lean_is_exclusive(x_319); -if (x_324 == 0) -{ -lean_object* x_325; -x_325 = lean_ctor_get(x_319, 2); -lean_dec(x_325); -lean_ctor_set(x_319, 2, x_274); -return x_280; -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_326 = lean_ctor_get(x_319, 0); -x_327 = lean_ctor_get(x_319, 1); -x_328 = lean_ctor_get(x_319, 3); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_dec(x_319); -x_329 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_329, 0, x_326); -lean_ctor_set(x_329, 1, x_327); -lean_ctor_set(x_329, 2, x_274); -lean_ctor_set(x_329, 3, x_328); -lean_ctor_set(x_318, 2, x_329); -return x_280; -} -} -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_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; -x_330 = lean_ctor_get(x_318, 0); -x_331 = lean_ctor_get(x_318, 1); -x_332 = lean_ctor_get(x_318, 3); -x_333 = lean_ctor_get(x_318, 4); -x_334 = lean_ctor_get(x_318, 5); -lean_inc(x_334); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_318); -x_335 = lean_ctor_get(x_319, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_319, 1); -lean_inc(x_336); -x_337 = lean_ctor_get(x_319, 3); -lean_inc(x_337); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - lean_ctor_release(x_319, 3); - x_338 = x_319; -} else { - lean_dec_ref(x_319); - x_338 = lean_box(0); -} -if (lean_is_scalar(x_338)) { - x_339 = lean_alloc_ctor(0, 4, 0); -} else { - x_339 = x_338; -} -lean_ctor_set(x_339, 0, x_335); -lean_ctor_set(x_339, 1, x_336); -lean_ctor_set(x_339, 2, x_274); -lean_ctor_set(x_339, 3, x_337); -x_340 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_340, 0, x_330); -lean_ctor_set(x_340, 1, x_331); -lean_ctor_set(x_340, 2, x_339); -lean_ctor_set(x_340, 3, x_332); -lean_ctor_set(x_340, 4, x_333); -lean_ctor_set(x_340, 5, x_334); -lean_ctor_set(x_280, 1, x_340); -return x_280; -} -} -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; -x_341 = lean_ctor_get(x_280, 0); -lean_inc(x_341); -lean_dec(x_280); -x_342 = lean_ctor_get(x_318, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_318, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_318, 3); -lean_inc(x_344); -x_345 = lean_ctor_get(x_318, 4); -lean_inc(x_345); -x_346 = lean_ctor_get(x_318, 5); -lean_inc(x_346); -if (lean_is_exclusive(x_318)) { - lean_ctor_release(x_318, 0); - lean_ctor_release(x_318, 1); - lean_ctor_release(x_318, 2); - lean_ctor_release(x_318, 3); - lean_ctor_release(x_318, 4); - lean_ctor_release(x_318, 5); - x_347 = x_318; -} else { - lean_dec_ref(x_318); - x_347 = lean_box(0); -} -x_348 = lean_ctor_get(x_319, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_319, 1); -lean_inc(x_349); -x_350 = lean_ctor_get(x_319, 3); -lean_inc(x_350); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - lean_ctor_release(x_319, 3); - x_351 = x_319; -} else { - lean_dec_ref(x_319); - 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_274); -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); -x_354 = lean_alloc_ctor(1, 2, 0); -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; -x_355 = lean_ctor_get(x_5, 0); -x_356 = lean_ctor_get(x_5, 1); -x_357 = lean_ctor_get(x_5, 2); -x_358 = lean_ctor_get(x_5, 3); -x_359 = lean_ctor_get(x_5, 4); -lean_inc(x_359); -lean_inc(x_358); -lean_inc(x_357); -lean_inc(x_356); -lean_inc(x_355); +lean_inc(x_308); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); lean_dec(x_5); -x_360 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_360, 0, x_268); -lean_ctor_set(x_360, 1, x_10); -x_361 = lean_array_push(x_357, x_360); -x_362 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_362, 0, x_355); -lean_ctor_set(x_362, 1, x_356); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_358); -lean_ctor_set(x_362, 4, x_359); -x_363 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_270, x_4, x_362, x_267); -if (lean_obj_tag(x_363) == 0) +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_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; -x_364 = lean_ctor_get(x_363, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_363, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_363)) { - lean_ctor_release(x_363, 0); - lean_ctor_release(x_363, 1); - x_367 = x_363; -} else { - lean_dec_ref(x_363); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_364, 1); -lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); -lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); -lean_inc(x_372); -if (lean_is_exclusive(x_364)) { - lean_ctor_release(x_364, 0); - lean_ctor_release(x_364, 1); - lean_ctor_release(x_364, 2); - lean_ctor_release(x_364, 3); - lean_ctor_release(x_364, 4); - lean_ctor_release(x_364, 5); - x_373 = x_364; -} else { - lean_dec_ref(x_364); - x_373 = lean_box(0); -} -x_374 = lean_ctor_get(x_365, 0); -lean_inc(x_374); -x_375 = lean_ctor_get(x_365, 1); -lean_inc(x_375); -x_376 = lean_ctor_get(x_365, 3); -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); - 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, 4, 0); -} else { - x_378 = x_377; -} -lean_ctor_set(x_378, 0, x_374); -lean_ctor_set(x_378, 1, x_375); -lean_ctor_set(x_378, 2, x_274); -lean_ctor_set(x_378, 3, x_376); -if (lean_is_scalar(x_373)) { - x_379 = lean_alloc_ctor(0, 6, 0); -} else { - x_379 = x_373; -} -lean_ctor_set(x_379, 0, x_368); -lean_ctor_set(x_379, 1, x_369); -lean_ctor_set(x_379, 2, x_378); -lean_ctor_set(x_379, 3, x_370); -lean_ctor_set(x_379, 4, x_371); -lean_ctor_set(x_379, 5, x_372); -if (lean_is_scalar(x_367)) { - x_380 = lean_alloc_ctor(0, 2, 0); -} else { - x_380 = x_367; -} -lean_ctor_set(x_380, 0, x_366); -lean_ctor_set(x_380, 1, x_379); -return x_380; +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_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_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_381 = lean_ctor_get(x_363, 1); -lean_inc(x_381); -x_382 = lean_ctor_get(x_381, 2); -lean_inc(x_382); -x_383 = lean_ctor_get(x_363, 0); -lean_inc(x_383); -if (lean_is_exclusive(x_363)) { - lean_ctor_release(x_363, 0); - lean_ctor_release(x_363, 1); - x_384 = x_363; -} else { - lean_dec_ref(x_363); - x_384 = lean_box(0); +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; } -x_385 = lean_ctor_get(x_381, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_381, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_381, 3); -lean_inc(x_387); -x_388 = lean_ctor_get(x_381, 4); -lean_inc(x_388); -x_389 = lean_ctor_get(x_381, 5); -lean_inc(x_389); -if (lean_is_exclusive(x_381)) { - lean_ctor_release(x_381, 0); - lean_ctor_release(x_381, 1); - lean_ctor_release(x_381, 2); - lean_ctor_release(x_381, 3); - lean_ctor_release(x_381, 4); - lean_ctor_release(x_381, 5); - x_390 = x_381; -} else { - lean_dec_ref(x_381); - x_390 = lean_box(0); } -x_391 = lean_ctor_get(x_382, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_382, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_382, 3); -lean_inc(x_393); -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_394 = x_382; +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); +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); +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 { - lean_dec_ref(x_382); - x_394 = lean_box(0); + x_250 = x_234; + lean_ctor_set_tag(x_250, 1); } -if (lean_is_scalar(x_394)) { - x_395 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_250, 0, x_245); +lean_ctor_set(x_250, 1, x_243); +return x_250; +} +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_395 = x_394; + x_255 = x_234; + lean_ctor_set_tag(x_255, 1); } -lean_ctor_set(x_395, 0, x_391); -lean_ctor_set(x_395, 1, x_392); -lean_ctor_set(x_395, 2, x_274); -lean_ctor_set(x_395, 3, x_393); -if (lean_is_scalar(x_390)) { - x_396 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_255, 0, x_245); +lean_ctor_set(x_255, 1, x_243); +return x_255; +} +} +else +{ +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; +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_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 { - x_396 = x_390; + lean_dec_ref(x_244); + x_264 = lean_box(0); } -lean_ctor_set(x_396, 0, x_385); -lean_ctor_set(x_396, 1, x_386); -lean_ctor_set(x_396, 2, x_395); -lean_ctor_set(x_396, 3, x_387); -lean_ctor_set(x_396, 4, x_388); -lean_ctor_set(x_396, 5, x_389); -if (lean_is_scalar(x_384)) { - x_397 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(0, 4, 0); } else { - x_397 = x_384; + x_265 = x_264; +} +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, 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); +} else { + x_267 = x_234; + lean_ctor_set_tag(x_267, 1); +} +lean_ctor_set(x_267, 0, x_245); +lean_ctor_set(x_267, 1, x_266); +return x_267; +} +} +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_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_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); +} else { + x_279 = x_234; +} +lean_ctor_set(x_279, 0, x_269); +lean_ctor_set(x_279, 1, x_243); +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_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); +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; +} else { + lean_dec_ref(x_268); + x_288 = lean_box(0); +} +if (lean_is_scalar(x_288)) { + x_289 = lean_alloc_ctor(0, 4, 0); +} else { + x_289 = x_288; +} +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); +} else { + x_291 = x_234; +} +lean_ctor_set(x_291, 0, x_269); +lean_ctor_set(x_291, 1, x_290); +return x_291; } -lean_ctor_set(x_397, 0, x_383); -lean_ctor_set(x_397, 1, x_396); -return x_397; } } } else { -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; lean_object* x_413; -x_398 = lean_ctor_get(x_272, 0); -x_399 = lean_ctor_get(x_272, 1); -x_400 = lean_ctor_get(x_272, 2); -x_401 = lean_ctor_get(x_272, 3); -lean_inc(x_401); -lean_inc(x_400); -lean_inc(x_399); -lean_inc(x_398); -lean_dec(x_272); -x_402 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_403 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_403, 0, x_398); -lean_ctor_set(x_403, 1, x_399); -lean_ctor_set(x_403, 2, x_402); -lean_ctor_set(x_403, 3, x_401); -lean_ctor_set(x_267, 2, x_403); -x_404 = lean_ctor_get(x_5, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_5, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_5, 2); -lean_inc(x_406); -x_407 = lean_ctor_get(x_5, 3); -lean_inc(x_407); -x_408 = lean_ctor_get(x_5, 4); -lean_inc(x_408); +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); 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_409 = x_5; + x_364 = x_5; } else { lean_dec_ref(x_5); - x_409 = lean_box(0); + x_364 = lean_box(0); } -x_410 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_410, 0, x_268); -lean_ctor_set(x_410, 1, x_10); -x_411 = lean_array_push(x_406, x_410); -if (lean_is_scalar(x_409)) { - x_412 = lean_alloc_ctor(0, 5, 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); } else { - x_412 = x_409; + x_367 = x_364; } -lean_ctor_set(x_412, 0, x_404); -lean_ctor_set(x_412, 1, x_405); -lean_ctor_set(x_412, 2, x_411); -lean_ctor_set(x_412, 3, x_407); -lean_ctor_set(x_412, 4, x_408); -x_413 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_270, x_4, x_412, x_267); -if (lean_obj_tag(x_413) == 0) +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_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; lean_object* x_430; -x_414 = lean_ctor_get(x_413, 1); -lean_inc(x_414); -x_415 = lean_ctor_get(x_414, 2); -lean_inc(x_415); -x_416 = lean_ctor_get(x_413, 0); -lean_inc(x_416); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - x_417 = x_413; -} else { - lean_dec_ref(x_413); - x_417 = lean_box(0); -} -x_418 = lean_ctor_get(x_414, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_414, 1); -lean_inc(x_419); -x_420 = lean_ctor_get(x_414, 3); -lean_inc(x_420); -x_421 = lean_ctor_get(x_414, 4); -lean_inc(x_421); -x_422 = lean_ctor_get(x_414, 5); -lean_inc(x_422); -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_423 = x_414; -} else { - lean_dec_ref(x_414); - x_423 = lean_box(0); -} -x_424 = lean_ctor_get(x_415, 0); -lean_inc(x_424); -x_425 = lean_ctor_get(x_415, 1); -lean_inc(x_425); -x_426 = lean_ctor_get(x_415, 3); -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); - x_427 = x_415; -} else { - lean_dec_ref(x_415); - x_427 = lean_box(0); -} -if (lean_is_scalar(x_427)) { - x_428 = lean_alloc_ctor(0, 4, 0); -} else { - x_428 = x_427; -} -lean_ctor_set(x_428, 0, x_424); -lean_ctor_set(x_428, 1, x_425); -lean_ctor_set(x_428, 2, x_400); -lean_ctor_set(x_428, 3, x_426); -if (lean_is_scalar(x_423)) { - x_429 = lean_alloc_ctor(0, 6, 0); -} else { - x_429 = x_423; -} -lean_ctor_set(x_429, 0, x_418); -lean_ctor_set(x_429, 1, x_419); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_420); -lean_ctor_set(x_429, 4, x_421); -lean_ctor_set(x_429, 5, x_422); -if (lean_is_scalar(x_417)) { - x_430 = lean_alloc_ctor(0, 2, 0); -} else { - x_430 = x_417; -} -lean_ctor_set(x_430, 0, x_416); -lean_ctor_set(x_430, 1, x_429); -return x_430; +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; } 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; lean_object* x_447; -x_431 = lean_ctor_get(x_413, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_431, 2); -lean_inc(x_432); -x_433 = lean_ctor_get(x_413, 0); -lean_inc(x_433); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - x_434 = x_413; -} else { - lean_dec_ref(x_413); - x_434 = lean_box(0); +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; } +block_356: +{ +if (lean_obj_tag(x_324) == 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_inc(x_341); +x_342 = lean_ctor_get(x_324, 0); +lean_inc(x_342); +lean_dec(x_324); +x_343 = lean_ctor_get(x_325, 0); +lean_inc(x_343); +x_344 = lean_ctor_get(x_325, 1); +lean_inc(x_344); +x_345 = lean_ctor_get(x_325, 3); +lean_inc(x_345); +x_346 = lean_ctor_get(x_325, 4); +lean_inc(x_346); +x_347 = lean_ctor_get(x_325, 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; +} else { + lean_dec_ref(x_325); + x_348 = lean_box(0); +} +x_349 = lean_ctor_get(x_341, 0); +lean_inc(x_349); +x_350 = lean_ctor_get(x_341, 1); +lean_inc(x_350); +x_351 = lean_ctor_get(x_341, 3); +lean_inc(x_351); +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; +} else { + lean_dec_ref(x_341); + x_352 = lean_box(0); +} +if (lean_is_scalar(x_352)) { + x_353 = lean_alloc_ctor(0, 4, 0); +} else { + x_353 = x_352; +} +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); +if (lean_is_scalar(x_348)) { + x_354 = lean_alloc_ctor(0, 6, 0); +} else { + x_354 = 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); +} else { + x_355 = x_234; +} +lean_ctor_set(x_355, 0, x_342); +lean_ctor_set(x_355, 1, x_354); +return x_355; +} +} +} +} +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; +} else { + lean_dec_ref(x_375); + x_385 = 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); +} else { + x_420 = x_385; +} +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); +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; +} else { + lean_dec_ref(x_5); + x_427 = 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); +} else { + x_430 = x_427; +} +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_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; +} +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); -x_437 = lean_ctor_get(x_431, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_431, 4); -lean_inc(x_438); -x_439 = lean_ctor_get(x_431, 5); -lean_inc(x_439); -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); - lean_ctor_release(x_431, 5); - x_440 = x_431; +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; +} +block_418: +{ +if (lean_obj_tag(x_386) == 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_431); - x_440 = lean_box(0); + lean_dec_ref(x_387); + x_395 = lean_box(0); } -x_441 = lean_ctor_get(x_432, 0); -lean_inc(x_441); -x_442 = lean_ctor_get(x_432, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_432, 3); -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); - x_444 = x_432; +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_432); - x_444 = lean_box(0); + lean_dec_ref(x_388); + x_399 = lean_box(0); } -if (lean_is_scalar(x_444)) { - x_445 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_399)) { + x_400 = lean_alloc_ctor(0, 4, 0); } else { - x_445 = x_444; + x_400 = x_399; } -lean_ctor_set(x_445, 0, x_441); -lean_ctor_set(x_445, 1, x_442); -lean_ctor_set(x_445, 2, x_400); -lean_ctor_set(x_445, 3, x_443); -if (lean_is_scalar(x_440)) { - x_446 = lean_alloc_ctor(0, 6, 0); +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_446 = x_440; + x_401 = x_395; } -lean_ctor_set(x_446, 0, x_435); -lean_ctor_set(x_446, 1, x_436); -lean_ctor_set(x_446, 2, x_445); -lean_ctor_set(x_446, 3, x_437); -lean_ctor_set(x_446, 4, x_438); -lean_ctor_set(x_446, 5, x_439); -if (lean_is_scalar(x_434)) { - x_447 = lean_alloc_ctor(1, 2, 0); +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_447 = x_434; -} -lean_ctor_set(x_447, 0, x_433); -lean_ctor_set(x_447, 1, x_446); -return x_447; -} + 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_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; 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; lean_object* x_469; lean_object* x_470; lean_object* x_471; -x_448 = lean_ctor_get(x_267, 2); -x_449 = lean_ctor_get(x_267, 0); -x_450 = lean_ctor_get(x_267, 1); -x_451 = lean_ctor_get(x_267, 3); -x_452 = lean_ctor_get(x_267, 4); -x_453 = lean_ctor_get(x_267, 5); -lean_inc(x_453); -lean_inc(x_452); -lean_inc(x_451); -lean_inc(x_448); -lean_inc(x_450); -lean_inc(x_449); -lean_dec(x_267); -x_454 = lean_ctor_get(x_448, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_448, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_448, 2); -lean_inc(x_456); -x_457 = lean_ctor_get(x_448, 3); -lean_inc(x_457); -if (lean_is_exclusive(x_448)) { - lean_ctor_release(x_448, 0); - lean_ctor_release(x_448, 1); - lean_ctor_release(x_448, 2); - lean_ctor_release(x_448, 3); - x_458 = x_448; +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_inc(x_406); +x_407 = lean_ctor_get(x_387, 3); +lean_inc(x_407); +x_408 = lean_ctor_get(x_387, 4); +lean_inc(x_408); +x_409 = lean_ctor_get(x_387, 5); +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_448); - x_458 = lean_box(0); + lean_dec_ref(x_387); + x_410 = lean_box(0); } -x_459 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_458)) { - x_460 = lean_alloc_ctor(0, 4, 0); +x_411 = lean_ctor_get(x_403, 0); +lean_inc(x_411); +x_412 = lean_ctor_get(x_403, 1); +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; } else { - x_460 = x_458; + lean_dec_ref(x_403); + x_414 = lean_box(0); } -lean_ctor_set(x_460, 0, x_454); -lean_ctor_set(x_460, 1, x_455); -lean_ctor_set(x_460, 2, x_459); -lean_ctor_set(x_460, 3, x_457); -x_461 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_461, 0, x_449); -lean_ctor_set(x_461, 1, x_450); -lean_ctor_set(x_461, 2, x_460); -lean_ctor_set(x_461, 3, x_451); -lean_ctor_set(x_461, 4, x_452); -lean_ctor_set(x_461, 5, x_453); -x_462 = lean_ctor_get(x_5, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_5, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_5, 2); -lean_inc(x_464); -x_465 = lean_ctor_get(x_5, 3); -lean_inc(x_465); -x_466 = lean_ctor_get(x_5, 4); -lean_inc(x_466); -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_467 = x_5; +if (lean_is_scalar(x_414)) { + x_415 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_5); - x_467 = lean_box(0); + x_415 = x_414; } -x_468 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_468, 0, x_268); -lean_ctor_set(x_468, 1, x_10); -x_469 = lean_array_push(x_464, x_468); -if (lean_is_scalar(x_467)) { - x_470 = lean_alloc_ctor(0, 5, 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); } else { - x_470 = x_467; + x_416 = x_410; } -lean_ctor_set(x_470, 0, x_462); -lean_ctor_set(x_470, 1, x_463); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_465); -lean_ctor_set(x_470, 4, x_466); -x_471 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_270, x_4, x_470, x_461); -if (lean_obj_tag(x_471) == 0) -{ -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; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; -x_472 = lean_ctor_get(x_471, 1); -lean_inc(x_472); -x_473 = lean_ctor_get(x_472, 2); -lean_inc(x_473); -x_474 = lean_ctor_get(x_471, 0); -lean_inc(x_474); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - x_475 = x_471; +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); } else { - lean_dec_ref(x_471); - x_475 = lean_box(0); + x_417 = x_234; } -x_476 = lean_ctor_get(x_472, 0); -lean_inc(x_476); -x_477 = lean_ctor_get(x_472, 1); -lean_inc(x_477); -x_478 = lean_ctor_get(x_472, 3); -lean_inc(x_478); -x_479 = lean_ctor_get(x_472, 4); -lean_inc(x_479); -x_480 = lean_ctor_get(x_472, 5); -lean_inc(x_480); -if (lean_is_exclusive(x_472)) { - lean_ctor_release(x_472, 0); - lean_ctor_release(x_472, 1); - lean_ctor_release(x_472, 2); - lean_ctor_release(x_472, 3); - lean_ctor_release(x_472, 4); - lean_ctor_release(x_472, 5); - x_481 = x_472; -} else { - lean_dec_ref(x_472); - x_481 = lean_box(0); +lean_ctor_set(x_417, 0, x_404); +lean_ctor_set(x_417, 1, x_416); +return x_417; } -x_482 = lean_ctor_get(x_473, 0); -lean_inc(x_482); -x_483 = lean_ctor_get(x_473, 1); -lean_inc(x_483); -x_484 = lean_ctor_get(x_473, 3); -lean_inc(x_484); -if (lean_is_exclusive(x_473)) { - lean_ctor_release(x_473, 0); - lean_ctor_release(x_473, 1); - lean_ctor_release(x_473, 2); - lean_ctor_release(x_473, 3); - x_485 = x_473; -} else { - lean_dec_ref(x_473); - x_485 = lean_box(0); -} -if (lean_is_scalar(x_485)) { - x_486 = lean_alloc_ctor(0, 4, 0); -} else { - x_486 = x_485; -} -lean_ctor_set(x_486, 0, x_482); -lean_ctor_set(x_486, 1, x_483); -lean_ctor_set(x_486, 2, x_456); -lean_ctor_set(x_486, 3, x_484); -if (lean_is_scalar(x_481)) { - x_487 = lean_alloc_ctor(0, 6, 0); -} else { - x_487 = x_481; -} -lean_ctor_set(x_487, 0, x_476); -lean_ctor_set(x_487, 1, x_477); -lean_ctor_set(x_487, 2, x_486); -lean_ctor_set(x_487, 3, x_478); -lean_ctor_set(x_487, 4, x_479); -lean_ctor_set(x_487, 5, x_480); -if (lean_is_scalar(x_475)) { - x_488 = lean_alloc_ctor(0, 2, 0); -} else { - x_488 = x_475; -} -lean_ctor_set(x_488, 0, x_474); -lean_ctor_set(x_488, 1, x_487); -return x_488; -} -else -{ -lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; -x_489 = lean_ctor_get(x_471, 1); -lean_inc(x_489); -x_490 = lean_ctor_get(x_489, 2); -lean_inc(x_490); -x_491 = lean_ctor_get(x_471, 0); -lean_inc(x_491); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - x_492 = x_471; -} else { - lean_dec_ref(x_471); - x_492 = lean_box(0); -} -x_493 = lean_ctor_get(x_489, 0); -lean_inc(x_493); -x_494 = lean_ctor_get(x_489, 1); -lean_inc(x_494); -x_495 = lean_ctor_get(x_489, 3); -lean_inc(x_495); -x_496 = lean_ctor_get(x_489, 4); -lean_inc(x_496); -x_497 = lean_ctor_get(x_489, 5); -lean_inc(x_497); -if (lean_is_exclusive(x_489)) { - lean_ctor_release(x_489, 0); - lean_ctor_release(x_489, 1); - lean_ctor_release(x_489, 2); - lean_ctor_release(x_489, 3); - lean_ctor_release(x_489, 4); - lean_ctor_release(x_489, 5); - x_498 = x_489; -} else { - lean_dec_ref(x_489); - x_498 = lean_box(0); -} -x_499 = lean_ctor_get(x_490, 0); -lean_inc(x_499); -x_500 = lean_ctor_get(x_490, 1); -lean_inc(x_500); -x_501 = lean_ctor_get(x_490, 3); -lean_inc(x_501); -if (lean_is_exclusive(x_490)) { - lean_ctor_release(x_490, 0); - lean_ctor_release(x_490, 1); - lean_ctor_release(x_490, 2); - lean_ctor_release(x_490, 3); - x_502 = x_490; -} else { - lean_dec_ref(x_490); - x_502 = lean_box(0); -} -if (lean_is_scalar(x_502)) { - x_503 = lean_alloc_ctor(0, 4, 0); -} else { - x_503 = x_502; -} -lean_ctor_set(x_503, 0, x_499); -lean_ctor_set(x_503, 1, x_500); -lean_ctor_set(x_503, 2, x_456); -lean_ctor_set(x_503, 3, x_501); -if (lean_is_scalar(x_498)) { - x_504 = lean_alloc_ctor(0, 6, 0); -} else { - x_504 = x_498; -} -lean_ctor_set(x_504, 0, x_493); -lean_ctor_set(x_504, 1, x_494); -lean_ctor_set(x_504, 2, x_503); -lean_ctor_set(x_504, 3, x_495); -lean_ctor_set(x_504, 4, x_496); -lean_ctor_set(x_504, 5, x_497); -if (lean_is_scalar(x_492)) { - x_505 = lean_alloc_ctor(1, 2, 0); -} else { - x_505 = x_492; -} -lean_ctor_set(x_505, 0, x_491); -lean_ctor_set(x_505, 1, x_504); -return x_505; } } } } else { -uint8_t x_506; +uint8_t x_438; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_506 = !lean_is_exclusive(x_261); -if (x_506 == 0) +x_438 = !lean_is_exclusive(x_227); +if (x_438 == 0) { -return x_261; +return x_227; } else { -lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_507 = lean_ctor_get(x_261, 0); -x_508 = lean_ctor_get(x_261, 1); -lean_inc(x_508); -lean_inc(x_507); -lean_dec(x_261); -x_509 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_509, 0, x_507); -lean_ctor_set(x_509, 1, x_508); -return x_509; +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; } } } @@ -10885,58 +10206,58 @@ return x_509; } else { -uint8_t x_510; +uint8_t x_442; 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_510 = !lean_is_exclusive(x_15); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_15); +if (x_442 == 0) { return x_15; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_15, 0); -x_512 = lean_ctor_get(x_15, 1); -lean_inc(x_512); -lean_inc(x_511); +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_dec(x_15); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } else { -uint8_t x_514; +uint8_t x_446; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_514 = !lean_is_exclusive(x_11); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_11); +if (x_446 == 0) { return x_11; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_11, 0); -x_516 = lean_ctor_get(x_11, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_11); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } @@ -11489,2150 +10810,1788 @@ goto _start; } case 1: { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_dec(x_22); x_29 = lean_ctor_get(x_23, 1); lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); +if (lean_is_exclusive(x_23)) { + lean_ctor_release(x_23, 0); + lean_ctor_release(x_23, 1); + x_30 = x_23; +} else { + lean_dec_ref(x_23); + x_30 = lean_box(0); +} +x_31 = lean_ctor_get(x_24, 0); +lean_inc(x_31); lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_3, x_32); lean_dec(x_3); -x_33 = !lean_is_exclusive(x_29); -if (x_33 == 0) +x_34 = !lean_is_exclusive(x_29); +if (x_34 == 0) { -lean_object* x_34; uint8_t x_35; -x_34 = lean_ctor_get(x_29, 2); -x_35 = !lean_is_exclusive(x_34); -if (x_35 == 0) +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_29, 2); +x_36 = !lean_is_exclusive(x_35); +if (x_36 == 0) { -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_34, 2); -x_37 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_34, 2, x_37); -x_38 = !lean_is_exclusive(x_4); -if (x_38 == 0) +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_89; uint8_t x_90; +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) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_39 = lean_ctor_get(x_4, 2); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_30); -lean_ctor_set(x_40, 1, x_18); -x_41 = lean_array_push(x_39, x_40); -lean_ctor_set(x_4, 2, x_41); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_4, x_29); -if (lean_obj_tag(x_42) == 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_43; lean_object* x_44; uint8_t x_45; -x_43 = lean_ctor_get(x_42, 1); -lean_inc(x_43); -x_44 = lean_ctor_get(x_43, 2); -lean_inc(x_44); -x_45 = !lean_is_exclusive(x_42); -if (x_45 == 0) -{ -lean_object* x_46; uint8_t x_47; -x_46 = lean_ctor_get(x_42, 1); -lean_dec(x_46); -x_47 = !lean_is_exclusive(x_43); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_43, 2); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_44); -if (x_49 == 0) -{ -lean_object* x_50; -x_50 = lean_ctor_get(x_44, 2); -lean_dec(x_50); -lean_ctor_set(x_44, 2, x_36); -return x_42; +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_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -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_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_36); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_43, 2, x_54); -return x_42; +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_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; } } 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; -x_55 = lean_ctor_get(x_43, 0); -x_56 = lean_ctor_get(x_43, 1); -x_57 = lean_ctor_get(x_43, 3); -x_58 = lean_ctor_get(x_43, 4); -x_59 = lean_ctor_get(x_43, 5); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); +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_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; +} +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_38 = x_115; +x_39 = x_114; +goto block_88; +} +} +block_88: +{ +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_40; lean_object* x_41; uint8_t x_42; +x_40 = lean_ctor_get(x_39, 2); +lean_inc(x_40); +x_41 = lean_ctor_get(x_38, 0); +lean_inc(x_41); +lean_dec(x_38); +x_42 = !lean_is_exclusive(x_39); +if (x_42 == 0) +{ +lean_object* x_43; uint8_t x_44; +x_43 = lean_ctor_get(x_39, 2); +lean_dec(x_43); +x_44 = !lean_is_exclusive(x_40); +if (x_44 == 0) +{ +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_40, 2); +lean_dec(x_45); +lean_ctor_set(x_40, 2, x_37); +if (lean_is_scalar(x_30)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_30; + lean_ctor_set_tag(x_46, 1); +} +lean_ctor_set(x_46, 0, x_41); +lean_ctor_set(x_46, 1, x_39); +return x_46; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_47 = lean_ctor_get(x_40, 0); +x_48 = lean_ctor_get(x_40, 1); +x_49 = lean_ctor_get(x_40, 3); +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); +if (lean_is_scalar(x_30)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_30; + lean_ctor_set_tag(x_51, 1); +} +lean_ctor_set(x_51, 0, x_41); +lean_ctor_set(x_51, 1, x_39); +return x_51; +} +} +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_inc(x_56); lean_inc(x_55); -lean_dec(x_43); -x_60 = lean_ctor_get(x_44, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_44, 1); -lean_inc(x_61); -x_62 = lean_ctor_get(x_44, 3); -lean_inc(x_62); -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_63 = x_44; +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); +lean_inc(x_58); +x_59 = lean_ctor_get(x_40, 3); +lean_inc(x_59); +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; } else { - lean_dec_ref(x_44); - x_63 = lean_box(0); + lean_dec_ref(x_40); + x_60 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_60)) { + x_61 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_61 = x_60; } -lean_ctor_set(x_64, 0, x_60); -lean_ctor_set(x_64, 1, x_61); -lean_ctor_set(x_64, 2, x_36); -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_42, 1, x_65); -return x_42; +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); +if (lean_is_scalar(x_30)) { + x_63 = lean_alloc_ctor(1, 2, 0); +} else { + x_63 = x_30; + lean_ctor_set_tag(x_63, 1); +} +lean_ctor_set(x_63, 0, x_41); +lean_ctor_set(x_63, 1, x_62); +return x_63; } } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_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_66 = lean_ctor_get(x_42, 0); -lean_inc(x_66); -lean_dec(x_42); -x_67 = lean_ctor_get(x_43, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_43, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_43, 3); -lean_inc(x_69); -x_70 = lean_ctor_get(x_43, 4); -lean_inc(x_70); -x_71 = lean_ctor_get(x_43, 5); -lean_inc(x_71); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - lean_ctor_release(x_43, 2); - lean_ctor_release(x_43, 3); - lean_ctor_release(x_43, 4); - lean_ctor_release(x_43, 5); - x_72 = x_43; +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_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); +if (x_68 == 0) +{ +lean_object* x_69; lean_object* x_70; +x_69 = lean_ctor_get(x_64, 2); +lean_dec(x_69); +lean_ctor_set(x_64, 2, x_37); +if (lean_is_scalar(x_30)) { + x_70 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_43); - x_72 = lean_box(0); + x_70 = x_30; } -x_73 = lean_ctor_get(x_44, 0); +lean_ctor_set(x_70, 0, x_65); +lean_ctor_set(x_70, 1, x_39); +return x_70; +} +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_inc(x_73); -x_74 = lean_ctor_get(x_44, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_44, 3); -lean_inc(x_75); -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_76 = x_44; +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); +if (lean_is_scalar(x_30)) { + x_75 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_44); - x_76 = lean_box(0); + x_75 = x_30; } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); -} else { - x_77 = x_76; -} -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_36); -lean_ctor_set(x_77, 3, x_75); -if (lean_is_scalar(x_72)) { - x_78 = lean_alloc_ctor(0, 6, 0); -} else { - x_78 = x_72; -} -lean_ctor_set(x_78, 0, x_67); -lean_ctor_set(x_78, 1, x_68); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_69); -lean_ctor_set(x_78, 4, x_70); -lean_ctor_set(x_78, 5, x_71); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_66); -lean_ctor_set(x_79, 1, x_78); -return x_79; +lean_ctor_set(x_75, 0, x_65); +lean_ctor_set(x_75, 1, x_39); +return x_75; } } else { -lean_object* x_80; lean_object* x_81; uint8_t x_82; -x_80 = lean_ctor_get(x_42, 1); +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_inc(x_80); -x_81 = lean_ctor_get(x_80, 2); +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_is_exclusive(x_42); -if (x_82 == 0) -{ -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_42, 1); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_80); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_80, 2); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_81); -if (x_86 == 0) -{ -lean_object* x_87; -x_87 = lean_ctor_get(x_81, 2); -lean_dec(x_87); -lean_ctor_set(x_81, 2, x_36); -return x_42; -} -else -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_81, 0); -x_89 = lean_ctor_get(x_81, 1); -x_90 = lean_ctor_get(x_81, 3); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_81); -x_91 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_91, 0, x_88); -lean_ctor_set(x_91, 1, x_89); -lean_ctor_set(x_91, 2, x_36); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set(x_80, 2, x_91); -return x_42; -} -} -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_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_92 = lean_ctor_get(x_80, 0); -x_93 = lean_ctor_get(x_80, 1); -x_94 = lean_ctor_get(x_80, 3); -x_95 = lean_ctor_get(x_80, 4); -x_96 = lean_ctor_get(x_80, 5); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_80); -x_97 = lean_ctor_get(x_81, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_81, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_81, 3); -lean_inc(x_99); -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); - x_100 = 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; } else { - lean_dec_ref(x_81); - x_100 = lean_box(0); + lean_dec_ref(x_64); + x_84 = lean_box(0); } -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 4, 0); } else { - x_101 = x_100; + x_85 = x_84; } -lean_ctor_set(x_101, 0, x_97); -lean_ctor_set(x_101, 1, x_98); -lean_ctor_set(x_101, 2, x_36); -lean_ctor_set(x_101, 3, x_99); -x_102 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_102, 0, x_92); -lean_ctor_set(x_102, 1, x_93); -lean_ctor_set(x_102, 2, x_101); -lean_ctor_set(x_102, 3, x_94); -lean_ctor_set(x_102, 4, x_95); -lean_ctor_set(x_102, 5, x_96); -lean_ctor_set(x_42, 1, x_102); -return x_42; -} -} -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; lean_object* x_116; -x_103 = lean_ctor_get(x_42, 0); -lean_inc(x_103); -lean_dec(x_42); -x_104 = lean_ctor_get(x_80, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_80, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_80, 3); -lean_inc(x_106); -x_107 = lean_ctor_get(x_80, 4); -lean_inc(x_107); -x_108 = lean_ctor_get(x_80, 5); -lean_inc(x_108); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - lean_ctor_release(x_80, 3); - lean_ctor_release(x_80, 4); - lean_ctor_release(x_80, 5); - x_109 = x_80; +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); +if (lean_is_scalar(x_30)) { + x_87 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + x_87 = x_30; } -x_110 = lean_ctor_get(x_81, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_81, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_81, 3); -lean_inc(x_112); -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); - x_113 = x_81; -} else { - lean_dec_ref(x_81); - x_113 = lean_box(0); +lean_ctor_set(x_87, 0, x_65); +lean_ctor_set(x_87, 1, x_86); +return x_87; } -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_36); -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); -x_116 = lean_alloc_ctor(1, 2, 0); -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; -x_117 = lean_ctor_get(x_4, 0); -x_118 = lean_ctor_get(x_4, 1); -x_119 = lean_ctor_get(x_4, 2); -x_120 = lean_ctor_get(x_4, 3); -x_121 = lean_ctor_get(x_4, 4); -lean_inc(x_121); -lean_inc(x_120); +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_dec(x_4); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_30); -lean_ctor_set(x_122, 1, x_18); -x_123 = lean_array_push(x_119, x_122); -x_124 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_124, 0, x_117); -lean_ctor_set(x_124, 1, x_118); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_120); -lean_ctor_set(x_124, 4, x_121); -x_125 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_124, x_29); -if (lean_obj_tag(x_125) == 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; lean_object* x_141; lean_object* x_142; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); -lean_inc(x_127); -x_128 = lean_ctor_get(x_125, 0); -lean_inc(x_128); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_129 = x_125; +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_125); + 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_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_126, 0); +x_130 = lean_ctor_get(x_122, 0); lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); +x_131 = lean_ctor_get(x_122, 1); lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +x_132 = lean_ctor_get(x_122, 3); lean_inc(x_132); -x_133 = lean_ctor_get(x_126, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); -lean_inc(x_134); -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_135 = x_126; +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_126); - x_135 = lean_box(0); + lean_dec_ref(x_122); + x_133 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_127, 3); -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); - x_139 = x_127; +if (lean_is_scalar(x_133)) { + x_134 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_127); - x_139 = lean_box(0); + x_134 = x_133; } -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_36); -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); +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_142 = lean_alloc_ctor(0, 2, 0); + x_135 = lean_alloc_ctor(0, 6, 0); } else { - x_142 = x_129; + x_135 = x_129; } -lean_ctor_set(x_142, 0, x_128); -lean_ctor_set(x_142, 1, x_141); -return x_142; +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_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_143 = lean_ctor_get(x_125, 1); +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); -x_144 = lean_ctor_get(x_143, 2); -lean_inc(x_144); -x_145 = lean_ctor_get(x_125, 0); +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); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_146 = x_125; -} else { - lean_dec_ref(x_125); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_143, 0); +x_146 = lean_ctor_get(x_137, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_137, 3); lean_inc(x_147); -x_148 = lean_ctor_get(x_143, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_143, 3); -lean_inc(x_149); -x_150 = lean_ctor_get(x_143, 4); -lean_inc(x_150); -x_151 = lean_ctor_get(x_143, 5); -lean_inc(x_151); -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); - lean_ctor_release(x_143, 5); - x_152 = x_143; +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_143); - x_152 = lean_box(0); + lean_dec_ref(x_137); + x_148 = lean_box(0); } -x_153 = lean_ctor_get(x_144, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_144, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_144, 3); -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); - x_156 = x_144; +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_144); - x_156 = lean_box(0); + x_149 = x_148; } -if (lean_is_scalar(x_156)) { - x_157 = lean_alloc_ctor(0, 4, 0); +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_157 = x_156; + x_150 = x_144; } -lean_ctor_set(x_157, 0, x_153); -lean_ctor_set(x_157, 1, x_154); -lean_ctor_set(x_157, 2, x_36); -lean_ctor_set(x_157, 3, x_155); -if (lean_is_scalar(x_152)) { - x_158 = lean_alloc_ctor(0, 6, 0); +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_158 = x_152; + x_151 = x_30; } -lean_ctor_set(x_158, 0, x_147); -lean_ctor_set(x_158, 1, x_148); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_149); -lean_ctor_set(x_158, 4, x_150); -lean_ctor_set(x_158, 5, x_151); -if (lean_is_scalar(x_146)) { - x_159 = lean_alloc_ctor(1, 2, 0); -} else { - x_159 = x_146; +lean_ctor_set(x_151, 0, x_138); +lean_ctor_set(x_151, 1, x_150); +return x_151; } -lean_ctor_set(x_159, 0, x_145); -lean_ctor_set(x_159, 1, x_158); -return x_159; } } } 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; 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_160 = lean_ctor_get(x_34, 0); -x_161 = lean_ctor_get(x_34, 1); -x_162 = lean_ctor_get(x_34, 2); -x_163 = lean_ctor_get(x_34, 3); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_dec(x_34); -x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_165 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_165, 0, x_160); -lean_ctor_set(x_165, 1, x_161); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_163); -lean_ctor_set(x_29, 2, x_165); -x_166 = lean_ctor_get(x_4, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_4, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_4, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_4, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_4, 4); -lean_inc(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_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); 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_171 = x_4; + x_223 = x_4; } else { lean_dec_ref(x_4); - x_171 = lean_box(0); + x_223 = lean_box(0); } -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_30); -lean_ctor_set(x_172, 1, x_18); -x_173 = lean_array_push(x_168, x_172); -if (lean_is_scalar(x_171)) { - x_174 = lean_alloc_ctor(0, 5, 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_226 = lean_alloc_ctor(0, 5, 0); } else { - x_174 = x_171; + x_226 = x_223; } -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_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_174, x_29); -if (lean_obj_tag(x_175) == 0) +lean_ctor_set(x_226, 0, x_218); +lean_ctor_set(x_226, 1, x_219); +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_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; -x_176 = lean_ctor_get(x_175, 1); -lean_inc(x_176); -x_177 = lean_ctor_get(x_176, 2); -lean_inc(x_177); -x_178 = lean_ctor_get(x_175, 0); -lean_inc(x_178); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_179 = x_175; -} else { - lean_dec_ref(x_175); - x_179 = lean_box(0); -} -x_180 = lean_ctor_get(x_176, 0); -lean_inc(x_180); -x_181 = lean_ctor_get(x_176, 1); -lean_inc(x_181); -x_182 = lean_ctor_get(x_176, 3); -lean_inc(x_182); -x_183 = lean_ctor_get(x_176, 4); -lean_inc(x_183); -x_184 = lean_ctor_get(x_176, 5); -lean_inc(x_184); -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); - lean_ctor_release(x_176, 4); - lean_ctor_release(x_176, 5); - x_185 = x_176; -} else { - lean_dec_ref(x_176); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_177, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_177, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_177, 3); -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); - 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, 4, 0); -} else { - x_190 = x_189; -} -lean_ctor_set(x_190, 0, x_186); -lean_ctor_set(x_190, 1, x_187); -lean_ctor_set(x_190, 2, x_162); -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); -if (lean_is_scalar(x_179)) { - x_192 = lean_alloc_ctor(0, 2, 0); -} else { - x_192 = x_179; -} -lean_ctor_set(x_192, 0, x_178); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_object* x_228; lean_object* x_229; lean_object* x_230; +x_228 = lean_ctor_get(x_227, 0); +lean_inc(x_228); +x_229 = lean_ctor_get(x_227, 1); +lean_inc(x_229); +lean_dec(x_227); +x_230 = lean_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_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; -x_193 = lean_ctor_get(x_175, 1); +lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_231 = lean_ctor_get(x_227, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_227, 1); +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; +} +block_214: +{ +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_193, 2); +x_194 = lean_ctor_get(x_184, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_175, 0); -lean_inc(x_195); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_196 = 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); + x_195 = x_184; } else { - lean_dec_ref(x_175); - x_196 = lean_box(0); + lean_dec_ref(x_184); + x_195 = lean_box(0); } -x_197 = lean_ctor_get(x_193, 0); -lean_inc(x_197); -x_198 = lean_ctor_get(x_193, 1); -lean_inc(x_198); -x_199 = lean_ctor_get(x_193, 3); +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; +} +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_193, 4); +x_200 = lean_ctor_get(x_182, 0); lean_inc(x_200); -x_201 = lean_ctor_get(x_193, 5); +lean_dec(x_182); +x_201 = lean_ctor_get(x_183, 0); lean_inc(x_201); -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_202 = x_193; -} else { - lean_dec_ref(x_193); - x_202 = lean_box(0); -} -x_203 = lean_ctor_get(x_194, 0); +x_202 = lean_ctor_get(x_183, 1); +lean_inc(x_202); +x_203 = lean_ctor_get(x_183, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_194, 1); +x_204 = lean_ctor_get(x_183, 4); lean_inc(x_204); -x_205 = lean_ctor_get(x_194, 3); +x_205 = lean_ctor_get(x_183, 5); lean_inc(x_205); -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_206 = x_194; +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; } else { - lean_dec_ref(x_194); + lean_dec_ref(x_183); x_206 = 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; +} else { + lean_dec_ref(x_199); + x_210 = lean_box(0); +} +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 4, 0); +} else { + x_211 = x_210; +} +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_207 = lean_alloc_ctor(0, 4, 0); + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_212 = x_206; } -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); +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); +if (lean_is_scalar(x_30)) { + x_213 = lean_alloc_ctor(0, 2, 0); } else { - x_208 = x_202; + x_213 = x_30; } -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(1, 2, 0); -} else { - x_209 = x_196; +lean_ctor_set(x_213, 0, x_200); +lean_ctor_set(x_213, 1, x_212); +return x_213; } -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; 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_210 = lean_ctor_get(x_29, 2); -x_211 = lean_ctor_get(x_29, 0); -x_212 = lean_ctor_get(x_29, 1); -x_213 = lean_ctor_get(x_29, 3); -x_214 = lean_ctor_get(x_29, 4); -x_215 = lean_ctor_get(x_29, 5); -lean_inc(x_215); -lean_inc(x_214); -lean_inc(x_213); -lean_inc(x_210); -lean_inc(x_212); -lean_inc(x_211); -lean_dec(x_29); -x_216 = lean_ctor_get(x_210, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_210, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_210, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_210, 3); -lean_inc(x_219); -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_220 = x_210; -} else { - lean_dec_ref(x_210); - x_220 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_220)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_220; -} -lean_ctor_set(x_222, 0, x_216); -lean_ctor_set(x_222, 1, x_217); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_219); -x_223 = lean_alloc_ctor(0, 6, 0); -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); -x_224 = lean_ctor_get(x_4, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_4, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_4, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_4, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_4, 4); -lean_inc(x_228); -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_229 = x_4; -} else { - lean_dec_ref(x_4); - x_229 = lean_box(0); -} -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_30); -lean_ctor_set(x_230, 1, x_18); -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_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -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; -x_234 = lean_ctor_get(x_233, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_233, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_237 = x_233; -} else { - lean_dec_ref(x_233); - x_237 = lean_box(0); -} -x_238 = lean_ctor_get(x_234, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_234, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_234, 3); -lean_inc(x_240); -x_241 = lean_ctor_get(x_234, 4); -lean_inc(x_241); -x_242 = lean_ctor_get(x_234, 5); -lean_inc(x_242); -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_243 = x_234; -} else { - lean_dec_ref(x_234); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_235, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_235, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_235, 3); -lean_inc(x_246); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - lean_ctor_release(x_235, 3); - x_247 = x_235; -} else { - lean_dec_ref(x_235); - x_247 = lean_box(0); -} -if (lean_is_scalar(x_247)) { - x_248 = lean_alloc_ctor(0, 4, 0); -} else { - x_248 = x_247; -} -lean_ctor_set(x_248, 0, x_244); -lean_ctor_set(x_248, 1, x_245); -lean_ctor_set(x_248, 2, x_218); -lean_ctor_set(x_248, 3, x_246); -if (lean_is_scalar(x_243)) { - x_249 = lean_alloc_ctor(0, 6, 0); -} else { - x_249 = x_243; -} -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, 2, 0); -} else { - x_250 = x_237; -} -lean_ctor_set(x_250, 0, x_236); -lean_ctor_set(x_250, 1, x_249); -return x_250; -} -else -{ -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_251 = lean_ctor_get(x_233, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_251, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_233, 0); -lean_inc(x_253); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_254 = x_233; -} else { - lean_dec_ref(x_233); - x_254 = lean_box(0); -} -x_255 = lean_ctor_get(x_251, 0); -lean_inc(x_255); -x_256 = lean_ctor_get(x_251, 1); -lean_inc(x_256); -x_257 = lean_ctor_get(x_251, 3); -lean_inc(x_257); -x_258 = lean_ctor_get(x_251, 4); -lean_inc(x_258); -x_259 = lean_ctor_get(x_251, 5); -lean_inc(x_259); -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_260 = x_251; -} else { - lean_dec_ref(x_251); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_252, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_252, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_252, 3); -lean_inc(x_263); -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_264 = x_252; -} else { - lean_dec_ref(x_252); - 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_ctor_set(x_265, 0, x_261); -lean_ctor_set(x_265, 1, x_262); -lean_ctor_set(x_265, 2, x_218); -lean_ctor_set(x_265, 3, x_263); -if (lean_is_scalar(x_260)) { - x_266 = lean_alloc_ctor(0, 6, 0); -} else { - x_266 = x_260; -} -lean_ctor_set(x_266, 0, x_255); -lean_ctor_set(x_266, 1, x_256); -lean_ctor_set(x_266, 2, x_265); -lean_ctor_set(x_266, 3, x_257); -lean_ctor_set(x_266, 4, x_258); -lean_ctor_set(x_266, 5, x_259); -if (lean_is_scalar(x_254)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_254; -} -lean_ctor_set(x_267, 0, x_253); -lean_ctor_set(x_267, 1, x_266); -return x_267; } } } default: { -lean_object* x_268; lean_object* x_269; -x_268 = lean_ctor_get(x_23, 1); -lean_inc(x_268); +lean_object* x_234; lean_object* x_235; +x_234 = lean_ctor_get(x_23, 1); +lean_inc(x_234); lean_dec(x_23); lean_inc(x_4); -x_269 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_268); -if (lean_obj_tag(x_269) == 0) +x_235 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_234); +if (lean_obj_tag(x_235) == 0) { -lean_object* x_270; -x_270 = lean_ctor_get(x_269, 0); -lean_inc(x_270); -if (lean_obj_tag(x_270) == 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_271; lean_object* x_272; lean_object* x_273; +lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_dec(x_18); -x_271 = lean_ctor_get(x_269, 1); -lean_inc(x_271); -lean_dec(x_269); -x_272 = lean_unsigned_to_nat(1u); -x_273 = lean_nat_add(x_3, x_272); +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); lean_dec(x_3); -x_3 = x_273; -x_5 = x_271; +x_3 = x_239; +x_5 = x_237; goto _start; } else { -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_275 = lean_ctor_get(x_269, 1); -lean_inc(x_275); -lean_dec(x_269); -x_276 = lean_ctor_get(x_270, 0); -lean_inc(x_276); -lean_dec(x_270); -x_277 = lean_unsigned_to_nat(1u); -x_278 = lean_nat_add(x_3, x_277); +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; +} else { + lean_dec_ref(x_235); + x_242 = 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_279 = !lean_is_exclusive(x_275); -if (x_279 == 0) +x_246 = !lean_is_exclusive(x_241); +if (x_246 == 0) { -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_275, 2); -x_281 = !lean_is_exclusive(x_280); -if (x_281 == 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_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_280, 2); -x_283 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_280, 2, x_283); -x_284 = !lean_is_exclusive(x_4); -if (x_284 == 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_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_285 = lean_ctor_get(x_4, 2); -x_286 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_286, 0, x_276); -lean_ctor_set(x_286, 1, x_18); -x_287 = lean_array_push(x_285, x_286); -lean_ctor_set(x_4, 2, x_287); -x_288 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_278, x_4, x_275); -if (lean_obj_tag(x_288) == 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_289; lean_object* x_290; uint8_t x_291; -x_289 = lean_ctor_get(x_288, 1); -lean_inc(x_289); -x_290 = lean_ctor_get(x_289, 2); -lean_inc(x_290); -x_291 = !lean_is_exclusive(x_288); -if (x_291 == 0) -{ -lean_object* x_292; uint8_t x_293; -x_292 = lean_ctor_get(x_288, 1); -lean_dec(x_292); -x_293 = !lean_is_exclusive(x_289); -if (x_293 == 0) -{ -lean_object* x_294; uint8_t x_295; -x_294 = lean_ctor_get(x_289, 2); -lean_dec(x_294); -x_295 = !lean_is_exclusive(x_290); -if (x_295 == 0) -{ -lean_object* x_296; -x_296 = lean_ctor_get(x_290, 2); -lean_dec(x_296); -lean_ctor_set(x_290, 2, x_282); -return x_288; -} -else -{ -lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; -x_297 = lean_ctor_get(x_290, 0); -x_298 = lean_ctor_get(x_290, 1); -x_299 = lean_ctor_get(x_290, 3); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_290); -x_300 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_282); -lean_ctor_set(x_300, 3, x_299); -lean_ctor_set(x_289, 2, x_300); -return x_288; -} -} -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; -x_301 = lean_ctor_get(x_289, 0); -x_302 = lean_ctor_get(x_289, 1); -x_303 = lean_ctor_get(x_289, 3); -x_304 = lean_ctor_get(x_289, 4); -x_305 = lean_ctor_get(x_289, 5); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_inc(x_302); -lean_inc(x_301); -lean_dec(x_289); -x_306 = lean_ctor_get(x_290, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_290, 1); +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_290, 3); +x_308 = lean_ctor_get(x_306, 1); lean_inc(x_308); -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); - x_309 = x_290; -} else { - lean_dec_ref(x_290); - x_309 = lean_box(0); +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; } -if (lean_is_scalar(x_309)) { - x_310 = lean_alloc_ctor(0, 4, 0); -} else { - x_310 = x_309; -} -lean_ctor_set(x_310, 0, x_306); -lean_ctor_set(x_310, 1, x_307); -lean_ctor_set(x_310, 2, x_282); -lean_ctor_set(x_310, 3, x_308); -x_311 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_311, 0, x_301); -lean_ctor_set(x_311, 1, x_302); -lean_ctor_set(x_311, 2, x_310); -lean_ctor_set(x_311, 3, x_303); -lean_ctor_set(x_311, 4, x_304); -lean_ctor_set(x_311, 5, x_305); -lean_ctor_set(x_288, 1, x_311); -return x_288; +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_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_312 = lean_ctor_get(x_288, 0); -lean_inc(x_312); -lean_dec(x_288); -x_313 = lean_ctor_get(x_289, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_289, 1); -lean_inc(x_314); -x_315 = lean_ctor_get(x_289, 3); -lean_inc(x_315); -x_316 = lean_ctor_get(x_289, 4); -lean_inc(x_316); -x_317 = lean_ctor_get(x_289, 5); +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); -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); - lean_ctor_release(x_289, 5); - x_318 = x_289; -} else { - lean_dec_ref(x_289); - x_318 = lean_box(0); -} -x_319 = lean_ctor_get(x_290, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_290, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_290, 3); -lean_inc(x_321); -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); - x_322 = x_290; -} else { - lean_dec_ref(x_290); - x_322 = lean_box(0); -} -if (lean_is_scalar(x_322)) { - x_323 = lean_alloc_ctor(0, 4, 0); -} else { - x_323 = x_322; -} -lean_ctor_set(x_323, 0, x_319); -lean_ctor_set(x_323, 1, x_320); -lean_ctor_set(x_323, 2, x_282); -lean_ctor_set(x_323, 3, x_321); -if (lean_is_scalar(x_318)) { - x_324 = lean_alloc_ctor(0, 6, 0); -} else { - x_324 = x_318; -} -lean_ctor_set(x_324, 0, x_313); -lean_ctor_set(x_324, 1, x_314); -lean_ctor_set(x_324, 2, x_323); -lean_ctor_set(x_324, 3, x_315); -lean_ctor_set(x_324, 4, x_316); -lean_ctor_set(x_324, 5, x_317); -x_325 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_325, 0, x_312); -lean_ctor_set(x_325, 1, x_324); -return x_325; -} -} -else -{ -lean_object* x_326; lean_object* x_327; uint8_t x_328; -x_326 = lean_ctor_get(x_288, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_326, 2); -lean_inc(x_327); -x_328 = !lean_is_exclusive(x_288); -if (x_328 == 0) -{ -lean_object* x_329; uint8_t x_330; -x_329 = lean_ctor_get(x_288, 1); -lean_dec(x_329); -x_330 = !lean_is_exclusive(x_326); -if (x_330 == 0) -{ -lean_object* x_331; uint8_t x_332; -x_331 = lean_ctor_get(x_326, 2); -lean_dec(x_331); -x_332 = !lean_is_exclusive(x_327); -if (x_332 == 0) -{ -lean_object* x_333; -x_333 = lean_ctor_get(x_327, 2); -lean_dec(x_333); -lean_ctor_set(x_327, 2, x_282); -return x_288; -} -else -{ -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; -x_334 = lean_ctor_get(x_327, 0); -x_335 = lean_ctor_get(x_327, 1); -x_336 = lean_ctor_get(x_327, 3); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_327); -x_337 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_337, 0, x_334); -lean_ctor_set(x_337, 1, x_335); -lean_ctor_set(x_337, 2, x_282); -lean_ctor_set(x_337, 3, x_336); -lean_ctor_set(x_326, 2, x_337); -return x_288; -} -} -else -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; -x_338 = lean_ctor_get(x_326, 0); -x_339 = lean_ctor_get(x_326, 1); -x_340 = lean_ctor_get(x_326, 3); -x_341 = lean_ctor_get(x_326, 4); -x_342 = lean_ctor_get(x_326, 5); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_dec(x_326); -x_343 = lean_ctor_get(x_327, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_327, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_327, 3); -lean_inc(x_345); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - x_346 = x_327; -} else { - lean_dec_ref(x_327); - 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_282); -lean_ctor_set(x_347, 3, x_345); -x_348 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_348, 0, x_338); -lean_ctor_set(x_348, 1, x_339); -lean_ctor_set(x_348, 2, x_347); -lean_ctor_set(x_348, 3, x_340); -lean_ctor_set(x_348, 4, x_341); -lean_ctor_set(x_348, 5, x_342); -lean_ctor_set(x_288, 1, x_348); -return x_288; -} -} -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; -x_349 = lean_ctor_get(x_288, 0); -lean_inc(x_349); -lean_dec(x_288); -x_350 = lean_ctor_get(x_326, 0); -lean_inc(x_350); -x_351 = lean_ctor_get(x_326, 1); -lean_inc(x_351); -x_352 = lean_ctor_get(x_326, 3); -lean_inc(x_352); -x_353 = lean_ctor_get(x_326, 4); -lean_inc(x_353); -x_354 = lean_ctor_get(x_326, 5); -lean_inc(x_354); -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); - x_355 = x_326; -} else { - lean_dec_ref(x_326); - x_355 = lean_box(0); -} -x_356 = lean_ctor_get(x_327, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_327, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_327, 3); -lean_inc(x_358); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - x_359 = x_327; -} else { - lean_dec_ref(x_327); - x_359 = lean_box(0); -} -if (lean_is_scalar(x_359)) { - x_360 = lean_alloc_ctor(0, 4, 0); -} else { - x_360 = x_359; -} -lean_ctor_set(x_360, 0, x_356); -lean_ctor_set(x_360, 1, x_357); -lean_ctor_set(x_360, 2, x_282); -lean_ctor_set(x_360, 3, x_358); -if (lean_is_scalar(x_355)) { - x_361 = lean_alloc_ctor(0, 6, 0); -} else { - x_361 = x_355; -} -lean_ctor_set(x_361, 0, x_350); -lean_ctor_set(x_361, 1, x_351); -lean_ctor_set(x_361, 2, x_360); -lean_ctor_set(x_361, 3, x_352); -lean_ctor_set(x_361, 4, x_353); -lean_ctor_set(x_361, 5, x_354); -x_362 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_362, 0, x_349); -lean_ctor_set(x_362, 1, x_361); -return x_362; -} -} -} -else -{ -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_363 = lean_ctor_get(x_4, 0); -x_364 = lean_ctor_get(x_4, 1); -x_365 = lean_ctor_get(x_4, 2); -x_366 = lean_ctor_get(x_4, 3); -x_367 = lean_ctor_get(x_4, 4); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); -lean_inc(x_364); -lean_inc(x_363); +lean_inc(x_316); +lean_inc(x_315); +lean_inc(x_314); +lean_inc(x_313); lean_dec(x_4); -x_368 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_368, 0, x_276); -lean_ctor_set(x_368, 1, x_18); -x_369 = lean_array_push(x_365, x_368); -x_370 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_370, 0, x_363); -lean_ctor_set(x_370, 1, x_364); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_366); -lean_ctor_set(x_370, 4, x_367); -x_371 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_278, x_370, x_275); -if (lean_obj_tag(x_371) == 0) +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_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; lean_object* x_387; lean_object* x_388; -x_372 = lean_ctor_get(x_371, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_372, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_371, 0); -lean_inc(x_374); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - x_375 = x_371; -} else { - lean_dec_ref(x_371); - x_375 = lean_box(0); -} -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_372, 3); -lean_inc(x_378); -x_379 = lean_ctor_get(x_372, 4); -lean_inc(x_379); -x_380 = lean_ctor_get(x_372, 5); -lean_inc(x_380); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - lean_ctor_release(x_372, 2); - lean_ctor_release(x_372, 3); - lean_ctor_release(x_372, 4); - lean_ctor_release(x_372, 5); - x_381 = x_372; -} else { - lean_dec_ref(x_372); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_373, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_373, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_373, 3); -lean_inc(x_384); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - lean_ctor_release(x_373, 3); - x_385 = x_373; -} else { - lean_dec_ref(x_373); - x_385 = lean_box(0); -} -if (lean_is_scalar(x_385)) { - x_386 = lean_alloc_ctor(0, 4, 0); -} else { - x_386 = x_385; -} -lean_ctor_set(x_386, 0, x_382); -lean_ctor_set(x_386, 1, x_383); -lean_ctor_set(x_386, 2, x_282); -lean_ctor_set(x_386, 3, x_384); -if (lean_is_scalar(x_381)) { - x_387 = lean_alloc_ctor(0, 6, 0); -} else { - x_387 = x_381; -} -lean_ctor_set(x_387, 0, x_376); -lean_ctor_set(x_387, 1, x_377); -lean_ctor_set(x_387, 2, x_386); -lean_ctor_set(x_387, 3, x_378); -lean_ctor_set(x_387, 4, x_379); -lean_ctor_set(x_387, 5, x_380); -if (lean_is_scalar(x_375)) { - x_388 = lean_alloc_ctor(0, 2, 0); -} else { - x_388 = x_375; -} -lean_ctor_set(x_388, 0, x_374); -lean_ctor_set(x_388, 1, x_387); -return x_388; +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_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; lean_object* x_403; lean_object* x_404; lean_object* x_405; -x_389 = lean_ctor_get(x_371, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_389, 2); -lean_inc(x_390); -x_391 = lean_ctor_get(x_371, 0); -lean_inc(x_391); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - x_392 = x_371; -} else { - lean_dec_ref(x_371); - x_392 = lean_box(0); +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; } -x_393 = lean_ctor_get(x_389, 0); -lean_inc(x_393); -x_394 = lean_ctor_get(x_389, 1); -lean_inc(x_394); -x_395 = lean_ctor_get(x_389, 3); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 4); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 5); -lean_inc(x_397); -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); - lean_ctor_release(x_389, 4); - lean_ctor_release(x_389, 5); - x_398 = x_389; -} else { - lean_dec_ref(x_389); - x_398 = lean_box(0); } -x_399 = lean_ctor_get(x_390, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_390, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_390, 3); -lean_inc(x_401); -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); - x_402 = x_390; +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); +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); +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 { - lean_dec_ref(x_390); - x_402 = lean_box(0); + x_258 = x_242; + lean_ctor_set_tag(x_258, 1); } -if (lean_is_scalar(x_402)) { - x_403 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_258, 0, x_253); +lean_ctor_set(x_258, 1, x_251); +return x_258; +} +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_403 = x_402; + x_263 = x_242; + lean_ctor_set_tag(x_263, 1); } -lean_ctor_set(x_403, 0, x_399); -lean_ctor_set(x_403, 1, x_400); -lean_ctor_set(x_403, 2, x_282); -lean_ctor_set(x_403, 3, x_401); -if (lean_is_scalar(x_398)) { - x_404 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_263, 0, x_253); +lean_ctor_set(x_263, 1, x_251); +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; 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_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 { - x_404 = x_398; + lean_dec_ref(x_252); + x_272 = lean_box(0); } -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_392)) { - x_405 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_272)) { + x_273 = lean_alloc_ctor(0, 4, 0); } else { - x_405 = x_392; + x_273 = x_272; +} +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, 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); +} else { + x_275 = x_242; + lean_ctor_set_tag(x_275, 1); +} +lean_ctor_set(x_275, 0, x_253); +lean_ctor_set(x_275, 1, x_274); +return x_275; +} +} +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_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_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); +} else { + x_287 = x_242; +} +lean_ctor_set(x_287, 0, x_277); +lean_ctor_set(x_287, 1, x_251); +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_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); +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; +} else { + lean_dec_ref(x_276); + x_296 = lean_box(0); +} +if (lean_is_scalar(x_296)) { + x_297 = lean_alloc_ctor(0, 4, 0); +} else { + x_297 = x_296; +} +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); +} else { + x_299 = x_242; +} +lean_ctor_set(x_299, 0, x_277); +lean_ctor_set(x_299, 1, x_298); +return x_299; } -lean_ctor_set(x_405, 0, x_391); -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; lean_object* x_421; -x_406 = lean_ctor_get(x_280, 0); -x_407 = lean_ctor_get(x_280, 1); -x_408 = lean_ctor_get(x_280, 2); -x_409 = lean_ctor_get(x_280, 3); -lean_inc(x_409); -lean_inc(x_408); -lean_inc(x_407); -lean_inc(x_406); -lean_dec(x_280); -x_410 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_411 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_411, 0, x_406); -lean_ctor_set(x_411, 1, x_407); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_409); -lean_ctor_set(x_275, 2, x_411); -x_412 = lean_ctor_get(x_4, 0); -lean_inc(x_412); -x_413 = lean_ctor_get(x_4, 1); -lean_inc(x_413); -x_414 = lean_ctor_get(x_4, 2); -lean_inc(x_414); -x_415 = lean_ctor_get(x_4, 3); -lean_inc(x_415); -x_416 = lean_ctor_get(x_4, 4); -lean_inc(x_416); +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); 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_417 = x_4; + x_372 = x_4; } else { lean_dec_ref(x_4); - x_417 = lean_box(0); + x_372 = lean_box(0); } -x_418 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_418, 0, x_276); -lean_ctor_set(x_418, 1, x_18); -x_419 = lean_array_push(x_414, x_418); -if (lean_is_scalar(x_417)) { - x_420 = lean_alloc_ctor(0, 5, 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); } else { - x_420 = x_417; + x_375 = x_372; } -lean_ctor_set(x_420, 0, x_412); -lean_ctor_set(x_420, 1, x_413); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_415); -lean_ctor_set(x_420, 4, x_416); -x_421 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_278, x_420, x_275); -if (lean_obj_tag(x_421) == 0) +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_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; lean_object* x_438; -x_422 = lean_ctor_get(x_421, 1); -lean_inc(x_422); -x_423 = lean_ctor_get(x_422, 2); -lean_inc(x_423); -x_424 = lean_ctor_get(x_421, 0); -lean_inc(x_424); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - x_425 = x_421; -} else { - lean_dec_ref(x_421); - x_425 = lean_box(0); -} -x_426 = lean_ctor_get(x_422, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_422, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_422, 3); -lean_inc(x_428); -x_429 = lean_ctor_get(x_422, 4); -lean_inc(x_429); -x_430 = lean_ctor_get(x_422, 5); -lean_inc(x_430); -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_431 = x_422; -} else { - lean_dec_ref(x_422); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_423, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_423, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_423, 3); -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); - x_435 = x_423; -} else { - lean_dec_ref(x_423); - x_435 = lean_box(0); -} -if (lean_is_scalar(x_435)) { - x_436 = lean_alloc_ctor(0, 4, 0); -} else { - x_436 = x_435; -} -lean_ctor_set(x_436, 0, x_432); -lean_ctor_set(x_436, 1, x_433); -lean_ctor_set(x_436, 2, x_408); -lean_ctor_set(x_436, 3, x_434); -if (lean_is_scalar(x_431)) { - x_437 = lean_alloc_ctor(0, 6, 0); -} else { - x_437 = x_431; -} -lean_ctor_set(x_437, 0, x_426); -lean_ctor_set(x_437, 1, x_427); -lean_ctor_set(x_437, 2, x_436); -lean_ctor_set(x_437, 3, x_428); -lean_ctor_set(x_437, 4, x_429); -lean_ctor_set(x_437, 5, x_430); -if (lean_is_scalar(x_425)) { - x_438 = lean_alloc_ctor(0, 2, 0); -} else { - x_438 = x_425; -} -lean_ctor_set(x_438, 0, x_424); -lean_ctor_set(x_438, 1, x_437); -return x_438; +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; } 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; lean_object* x_455; -x_439 = lean_ctor_get(x_421, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_439, 2); -lean_inc(x_440); -x_441 = lean_ctor_get(x_421, 0); -lean_inc(x_441); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - x_442 = x_421; -} else { - lean_dec_ref(x_421); - x_442 = lean_box(0); +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; } +block_364: +{ +if (lean_obj_tag(x_332) == 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_inc(x_349); +x_350 = lean_ctor_get(x_332, 0); +lean_inc(x_350); +lean_dec(x_332); +x_351 = lean_ctor_get(x_333, 0); +lean_inc(x_351); +x_352 = lean_ctor_get(x_333, 1); +lean_inc(x_352); +x_353 = lean_ctor_get(x_333, 3); +lean_inc(x_353); +x_354 = lean_ctor_get(x_333, 4); +lean_inc(x_354); +x_355 = lean_ctor_get(x_333, 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; +} else { + lean_dec_ref(x_333); + x_356 = lean_box(0); +} +x_357 = lean_ctor_get(x_349, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_349, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_349, 3); +lean_inc(x_359); +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; +} else { + lean_dec_ref(x_349); + x_360 = lean_box(0); +} +if (lean_is_scalar(x_360)) { + x_361 = lean_alloc_ctor(0, 4, 0); +} else { + x_361 = x_360; +} +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); +if (lean_is_scalar(x_356)) { + x_362 = lean_alloc_ctor(0, 6, 0); +} else { + x_362 = 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); +} else { + x_363 = x_242; +} +lean_ctor_set(x_363, 0, x_350); +lean_ctor_set(x_363, 1, x_362); +return x_363; +} +} +} +} +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; +} else { + lean_dec_ref(x_383); + x_393 = 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); +} else { + x_428 = x_393; +} +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); +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; +} else { + lean_dec_ref(x_4); + x_435 = 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); +} else { + x_438 = x_435; +} +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_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; +} +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); -x_445 = lean_ctor_get(x_439, 3); -lean_inc(x_445); -x_446 = lean_ctor_get(x_439, 4); -lean_inc(x_446); -x_447 = lean_ctor_get(x_439, 5); -lean_inc(x_447); -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); - lean_ctor_release(x_439, 5); - x_448 = x_439; +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; +} +block_426: +{ +if (lean_obj_tag(x_394) == 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_439); - x_448 = lean_box(0); + lean_dec_ref(x_395); + x_403 = lean_box(0); } -x_449 = lean_ctor_get(x_440, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_440, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_440, 3); -lean_inc(x_451); -if (lean_is_exclusive(x_440)) { - lean_ctor_release(x_440, 0); - lean_ctor_release(x_440, 1); - lean_ctor_release(x_440, 2); - lean_ctor_release(x_440, 3); - x_452 = x_440; +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_440); - x_452 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -if (lean_is_scalar(x_452)) { - x_453 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_407)) { + x_408 = lean_alloc_ctor(0, 4, 0); } else { - x_453 = x_452; + x_408 = x_407; } -lean_ctor_set(x_453, 0, x_449); -lean_ctor_set(x_453, 1, x_450); -lean_ctor_set(x_453, 2, x_408); -lean_ctor_set(x_453, 3, x_451); -if (lean_is_scalar(x_448)) { - x_454 = lean_alloc_ctor(0, 6, 0); +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_454 = x_448; + x_409 = x_403; } -lean_ctor_set(x_454, 0, x_443); -lean_ctor_set(x_454, 1, x_444); -lean_ctor_set(x_454, 2, x_453); -lean_ctor_set(x_454, 3, x_445); -lean_ctor_set(x_454, 4, x_446); -lean_ctor_set(x_454, 5, x_447); -if (lean_is_scalar(x_442)) { - x_455 = lean_alloc_ctor(1, 2, 0); +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_455 = x_442; -} -lean_ctor_set(x_455, 0, x_441); -lean_ctor_set(x_455, 1, x_454); -return x_455; -} + 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_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; 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; -x_456 = lean_ctor_get(x_275, 2); -x_457 = lean_ctor_get(x_275, 0); -x_458 = lean_ctor_get(x_275, 1); -x_459 = lean_ctor_get(x_275, 3); -x_460 = lean_ctor_get(x_275, 4); -x_461 = lean_ctor_get(x_275, 5); -lean_inc(x_461); -lean_inc(x_460); -lean_inc(x_459); -lean_inc(x_456); -lean_inc(x_458); -lean_inc(x_457); -lean_dec(x_275); -x_462 = lean_ctor_get(x_456, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_456, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_456, 2); -lean_inc(x_464); -x_465 = lean_ctor_get(x_456, 3); -lean_inc(x_465); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - lean_ctor_release(x_456, 2); - lean_ctor_release(x_456, 3); - x_466 = x_456; +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_inc(x_414); +x_415 = lean_ctor_get(x_395, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_395, 4); +lean_inc(x_416); +x_417 = lean_ctor_get(x_395, 5); +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_456); - x_466 = lean_box(0); + lean_dec_ref(x_395); + x_418 = lean_box(0); } -x_467 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_466)) { - x_468 = 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); +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; } else { - x_468 = x_466; + lean_dec_ref(x_411); + x_422 = lean_box(0); } -lean_ctor_set(x_468, 0, x_462); -lean_ctor_set(x_468, 1, x_463); -lean_ctor_set(x_468, 2, x_467); -lean_ctor_set(x_468, 3, x_465); -x_469 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_469, 0, x_457); -lean_ctor_set(x_469, 1, x_458); -lean_ctor_set(x_469, 2, x_468); -lean_ctor_set(x_469, 3, x_459); -lean_ctor_set(x_469, 4, x_460); -lean_ctor_set(x_469, 5, x_461); -x_470 = lean_ctor_get(x_4, 0); -lean_inc(x_470); -x_471 = lean_ctor_get(x_4, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_4, 2); -lean_inc(x_472); -x_473 = lean_ctor_get(x_4, 3); -lean_inc(x_473); -x_474 = lean_ctor_get(x_4, 4); -lean_inc(x_474); -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_475 = x_4; +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_4); - x_475 = lean_box(0); + x_423 = x_422; } -x_476 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_476, 0, x_276); -lean_ctor_set(x_476, 1, x_18); -x_477 = lean_array_push(x_472, x_476); -if (lean_is_scalar(x_475)) { - x_478 = lean_alloc_ctor(0, 5, 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); } else { - x_478 = x_475; + x_424 = x_418; } -lean_ctor_set(x_478, 0, x_470); -lean_ctor_set(x_478, 1, x_471); -lean_ctor_set(x_478, 2, x_477); -lean_ctor_set(x_478, 3, x_473); -lean_ctor_set(x_478, 4, x_474); -x_479 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_278, x_478, x_469); -if (lean_obj_tag(x_479) == 0) -{ -lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; -x_480 = lean_ctor_get(x_479, 1); -lean_inc(x_480); -x_481 = lean_ctor_get(x_480, 2); -lean_inc(x_481); -x_482 = lean_ctor_get(x_479, 0); -lean_inc(x_482); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - x_483 = x_479; +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); } else { - lean_dec_ref(x_479); - x_483 = lean_box(0); + x_425 = x_242; } -x_484 = lean_ctor_get(x_480, 0); -lean_inc(x_484); -x_485 = lean_ctor_get(x_480, 1); -lean_inc(x_485); -x_486 = lean_ctor_get(x_480, 3); -lean_inc(x_486); -x_487 = lean_ctor_get(x_480, 4); -lean_inc(x_487); -x_488 = lean_ctor_get(x_480, 5); -lean_inc(x_488); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - lean_ctor_release(x_480, 2); - lean_ctor_release(x_480, 3); - lean_ctor_release(x_480, 4); - lean_ctor_release(x_480, 5); - x_489 = x_480; -} else { - lean_dec_ref(x_480); - x_489 = lean_box(0); +lean_ctor_set(x_425, 0, x_412); +lean_ctor_set(x_425, 1, x_424); +return x_425; } -x_490 = lean_ctor_get(x_481, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_481, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_481, 3); -lean_inc(x_492); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - lean_ctor_release(x_481, 2); - lean_ctor_release(x_481, 3); - x_493 = x_481; -} else { - lean_dec_ref(x_481); - x_493 = lean_box(0); -} -if (lean_is_scalar(x_493)) { - x_494 = lean_alloc_ctor(0, 4, 0); -} else { - x_494 = x_493; -} -lean_ctor_set(x_494, 0, x_490); -lean_ctor_set(x_494, 1, x_491); -lean_ctor_set(x_494, 2, x_464); -lean_ctor_set(x_494, 3, x_492); -if (lean_is_scalar(x_489)) { - x_495 = lean_alloc_ctor(0, 6, 0); -} else { - x_495 = x_489; -} -lean_ctor_set(x_495, 0, x_484); -lean_ctor_set(x_495, 1, x_485); -lean_ctor_set(x_495, 2, x_494); -lean_ctor_set(x_495, 3, x_486); -lean_ctor_set(x_495, 4, x_487); -lean_ctor_set(x_495, 5, x_488); -if (lean_is_scalar(x_483)) { - x_496 = lean_alloc_ctor(0, 2, 0); -} else { - x_496 = x_483; -} -lean_ctor_set(x_496, 0, x_482); -lean_ctor_set(x_496, 1, x_495); -return x_496; -} -else -{ -lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_497 = lean_ctor_get(x_479, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_497, 2); -lean_inc(x_498); -x_499 = lean_ctor_get(x_479, 0); -lean_inc(x_499); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - x_500 = x_479; -} else { - lean_dec_ref(x_479); - x_500 = lean_box(0); -} -x_501 = lean_ctor_get(x_497, 0); -lean_inc(x_501); -x_502 = lean_ctor_get(x_497, 1); -lean_inc(x_502); -x_503 = lean_ctor_get(x_497, 3); -lean_inc(x_503); -x_504 = lean_ctor_get(x_497, 4); -lean_inc(x_504); -x_505 = lean_ctor_get(x_497, 5); -lean_inc(x_505); -if (lean_is_exclusive(x_497)) { - lean_ctor_release(x_497, 0); - lean_ctor_release(x_497, 1); - lean_ctor_release(x_497, 2); - lean_ctor_release(x_497, 3); - lean_ctor_release(x_497, 4); - lean_ctor_release(x_497, 5); - x_506 = x_497; -} else { - lean_dec_ref(x_497); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_498, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_498, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_498, 3); -lean_inc(x_509); -if (lean_is_exclusive(x_498)) { - lean_ctor_release(x_498, 0); - lean_ctor_release(x_498, 1); - lean_ctor_release(x_498, 2); - lean_ctor_release(x_498, 3); - x_510 = x_498; -} else { - lean_dec_ref(x_498); - x_510 = lean_box(0); -} -if (lean_is_scalar(x_510)) { - x_511 = lean_alloc_ctor(0, 4, 0); -} else { - x_511 = x_510; -} -lean_ctor_set(x_511, 0, x_507); -lean_ctor_set(x_511, 1, x_508); -lean_ctor_set(x_511, 2, x_464); -lean_ctor_set(x_511, 3, x_509); -if (lean_is_scalar(x_506)) { - x_512 = lean_alloc_ctor(0, 6, 0); -} else { - x_512 = x_506; -} -lean_ctor_set(x_512, 0, x_501); -lean_ctor_set(x_512, 1, x_502); -lean_ctor_set(x_512, 2, x_511); -lean_ctor_set(x_512, 3, x_503); -lean_ctor_set(x_512, 4, x_504); -lean_ctor_set(x_512, 5, x_505); -if (lean_is_scalar(x_500)) { - x_513 = lean_alloc_ctor(1, 2, 0); -} else { - x_513 = x_500; -} -lean_ctor_set(x_513, 0, x_499); -lean_ctor_set(x_513, 1, x_512); -return x_513; } } } } else { -uint8_t x_514; +uint8_t x_446; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_514 = !lean_is_exclusive(x_269); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_235); +if (x_446 == 0) { -return x_269; +return x_235; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_269, 0); -x_516 = lean_ctor_get(x_269, 1); -lean_inc(x_516); -lean_inc(x_515); -lean_dec(x_269); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } @@ -13640,54 +12599,54 @@ return x_517; } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_518 = !lean_is_exclusive(x_23); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_23); +if (x_450 == 0) { return x_23; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_23, 0); -x_520 = lean_ctor_get(x_23, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_23); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } else { -uint8_t x_522; +uint8_t x_454; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_522 = !lean_is_exclusive(x_19); -if (x_522 == 0) +x_454 = !lean_is_exclusive(x_19); +if (x_454 == 0) { return x_19; } else { -lean_object* x_523; lean_object* x_524; lean_object* x_525; -x_523 = lean_ctor_get(x_19, 0); -x_524 = lean_ctor_get(x_19, 1); -lean_inc(x_524); -lean_inc(x_523); +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_dec(x_19); -x_525 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_525, 0, x_523); -lean_ctor_set(x_525, 1, x_524); -return x_525; +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; } } } @@ -13888,2130 +12847,1768 @@ goto _start; } case 1: { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; lean_dec(x_23); x_30 = lean_ctor_get(x_24, 1); lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + x_31 = x_24; +} else { + lean_dec_ref(x_24); + x_31 = lean_box(0); +} +x_32 = lean_ctor_get(x_25, 0); +lean_inc(x_32); lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_10, x_32); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_10, x_33); lean_dec(x_10); -x_34 = !lean_is_exclusive(x_30); -if (x_34 == 0) +x_35 = !lean_is_exclusive(x_30); +if (x_35 == 0) { -lean_object* x_35; uint8_t x_36; -x_35 = lean_ctor_get(x_30, 2); -x_36 = !lean_is_exclusive(x_35); -if (x_36 == 0) +lean_object* x_36; uint8_t x_37; +x_36 = lean_ctor_get(x_30, 2); +x_37 = !lean_is_exclusive(x_36); +if (x_37 == 0) { -lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_37 = lean_ctor_get(x_35, 2); -x_38 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_35, 2, x_38); -x_39 = !lean_is_exclusive(x_11); -if (x_39 == 0) +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_90; uint8_t x_91; +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) { -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_40 = lean_ctor_get(x_11, 2); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_31); -lean_ctor_set(x_41, 1, x_19); -x_42 = lean_array_push(x_40, x_41); -lean_ctor_set(x_11, 2, x_42); -x_43 = 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_33, x_11, x_30); -if (lean_obj_tag(x_43) == 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_44; lean_object* x_45; uint8_t x_46; -x_44 = lean_ctor_get(x_43, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_44, 2); -lean_inc(x_45); -x_46 = !lean_is_exclusive(x_43); -if (x_46 == 0) -{ -lean_object* x_47; uint8_t x_48; -x_47 = lean_ctor_get(x_43, 1); -lean_dec(x_47); -x_48 = !lean_is_exclusive(x_44); -if (x_48 == 0) -{ -lean_object* x_49; uint8_t x_50; -x_49 = lean_ctor_get(x_44, 2); -lean_dec(x_49); -x_50 = !lean_is_exclusive(x_45); -if (x_50 == 0) -{ -lean_object* x_51; -x_51 = lean_ctor_get(x_45, 2); -lean_dec(x_51); -lean_ctor_set(x_45, 2, x_37); -return x_43; +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_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -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_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_37); -lean_ctor_set(x_55, 3, x_54); -lean_ctor_set(x_44, 2, x_55); -return x_43; +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_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; } } 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; -x_56 = lean_ctor_get(x_44, 0); -x_57 = lean_ctor_get(x_44, 1); -x_58 = lean_ctor_get(x_44, 3); -x_59 = lean_ctor_get(x_44, 4); -x_60 = lean_ctor_get(x_44, 5); -lean_inc(x_60); -lean_inc(x_59); -lean_inc(x_58); +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_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; +} +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_39 = x_116; +x_40 = x_115; +goto block_89; +} +} +block_89: +{ +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_41; lean_object* x_42; uint8_t x_43; +x_41 = lean_ctor_get(x_40, 2); +lean_inc(x_41); +x_42 = lean_ctor_get(x_39, 0); +lean_inc(x_42); +lean_dec(x_39); +x_43 = !lean_is_exclusive(x_40); +if (x_43 == 0) +{ +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_40, 2); +lean_dec(x_44); +x_45 = !lean_is_exclusive(x_41); +if (x_45 == 0) +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_41, 2); +lean_dec(x_46); +lean_ctor_set(x_41, 2, x_38); +if (lean_is_scalar(x_31)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_31; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_40); +return x_47; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_48 = lean_ctor_get(x_41, 0); +x_49 = lean_ctor_get(x_41, 1); +x_50 = lean_ctor_get(x_41, 3); +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); +if (lean_is_scalar(x_31)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_31; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_42); +lean_ctor_set(x_52, 1, x_40); +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; +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_inc(x_57); lean_inc(x_56); -lean_dec(x_44); -x_61 = lean_ctor_get(x_45, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_45, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_45, 3); -lean_inc(x_63); -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_64 = x_45; +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); +lean_inc(x_59); +x_60 = lean_ctor_get(x_41, 3); +lean_inc(x_60); +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; } else { - lean_dec_ref(x_45); - x_64 = lean_box(0); + lean_dec_ref(x_41); + x_61 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 4, 0); } else { - x_65 = x_64; + x_62 = x_61; } -lean_ctor_set(x_65, 0, x_61); -lean_ctor_set(x_65, 1, x_62); -lean_ctor_set(x_65, 2, x_37); -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_43, 1, x_66); -return x_43; +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); +if (lean_is_scalar(x_31)) { + x_64 = lean_alloc_ctor(1, 2, 0); +} else { + x_64 = x_31; + lean_ctor_set_tag(x_64, 1); +} +lean_ctor_set(x_64, 0, x_42); +lean_ctor_set(x_64, 1, x_63); +return x_64; } } 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; -x_67 = lean_ctor_get(x_43, 0); -lean_inc(x_67); -lean_dec(x_43); -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_44, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_44, 3); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 4); -lean_inc(x_71); -x_72 = lean_ctor_get(x_44, 5); -lean_inc(x_72); -if (lean_is_exclusive(x_44)) { - lean_ctor_release(x_44, 0); - lean_ctor_release(x_44, 1); - lean_ctor_release(x_44, 2); - lean_ctor_release(x_44, 3); - lean_ctor_release(x_44, 4); - lean_ctor_release(x_44, 5); - x_73 = x_44; +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_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); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; +x_70 = lean_ctor_get(x_65, 2); +lean_dec(x_70); +lean_ctor_set(x_65, 2, x_38); +if (lean_is_scalar(x_31)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_44); - x_73 = lean_box(0); + x_71 = x_31; } -x_74 = lean_ctor_get(x_45, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_40); +return x_71; +} +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_inc(x_74); -x_75 = lean_ctor_get(x_45, 1); -lean_inc(x_75); -x_76 = lean_ctor_get(x_45, 3); -lean_inc(x_76); -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_77 = x_45; +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); +if (lean_is_scalar(x_31)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_77 = lean_box(0); + x_76 = x_31; } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 4, 0); -} else { - x_78 = x_77; -} -lean_ctor_set(x_78, 0, x_74); -lean_ctor_set(x_78, 1, x_75); -lean_ctor_set(x_78, 2, x_37); -lean_ctor_set(x_78, 3, x_76); -if (lean_is_scalar(x_73)) { - x_79 = lean_alloc_ctor(0, 6, 0); -} else { - x_79 = x_73; -} -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); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_67); -lean_ctor_set(x_80, 1, x_79); -return x_80; +lean_ctor_set(x_76, 0, x_66); +lean_ctor_set(x_76, 1, x_40); +return x_76; } } else { -lean_object* x_81; lean_object* x_82; uint8_t x_83; -x_81 = lean_ctor_get(x_43, 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; 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_inc(x_81); -x_82 = lean_ctor_get(x_81, 2); +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_is_exclusive(x_43); -if (x_83 == 0) -{ -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_43, 1); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_81); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; -x_86 = lean_ctor_get(x_81, 2); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_82); -if (x_87 == 0) -{ -lean_object* x_88; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -lean_ctor_set(x_82, 2, x_37); -return x_43; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_82, 0); -x_90 = lean_ctor_get(x_82, 1); -x_91 = lean_ctor_get(x_82, 3); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_82); -x_92 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_37); -lean_ctor_set(x_92, 3, x_91); -lean_ctor_set(x_81, 2, x_92); -return x_43; -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_93 = lean_ctor_get(x_81, 0); -x_94 = lean_ctor_get(x_81, 1); -x_95 = lean_ctor_get(x_81, 3); -x_96 = lean_ctor_get(x_81, 4); -x_97 = lean_ctor_get(x_81, 5); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_81); -x_98 = lean_ctor_get(x_82, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_82, 1); -lean_inc(x_99); -x_100 = lean_ctor_get(x_82, 3); -lean_inc(x_100); -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); - x_101 = 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; } else { - lean_dec_ref(x_82); - x_101 = lean_box(0); + lean_dec_ref(x_65); + x_85 = lean_box(0); } -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 4, 0); } else { - x_102 = x_101; + x_86 = x_85; } -lean_ctor_set(x_102, 0, x_98); -lean_ctor_set(x_102, 1, x_99); -lean_ctor_set(x_102, 2, x_37); -lean_ctor_set(x_102, 3, x_100); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_93); -lean_ctor_set(x_103, 1, x_94); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_95); -lean_ctor_set(x_103, 4, x_96); -lean_ctor_set(x_103, 5, x_97); -lean_ctor_set(x_43, 1, x_103); -return x_43; -} -} -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; lean_object* x_117; -x_104 = lean_ctor_get(x_43, 0); -lean_inc(x_104); -lean_dec(x_43); -x_105 = lean_ctor_get(x_81, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_81, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_81, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_81, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_81, 5); -lean_inc(x_109); -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_110 = x_81; +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); +if (lean_is_scalar(x_31)) { + x_88 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_81); - x_110 = lean_box(0); + x_88 = x_31; } -x_111 = lean_ctor_get(x_82, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_82, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_82, 3); -lean_inc(x_113); -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); - x_114 = x_82; -} else { - lean_dec_ref(x_82); - x_114 = lean_box(0); +lean_ctor_set(x_88, 0, x_66); +lean_ctor_set(x_88, 1, x_87); +return x_88; } -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(0, 4, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_111); -lean_ctor_set(x_115, 1, x_112); -lean_ctor_set(x_115, 2, x_37); -lean_ctor_set(x_115, 3, x_113); -if (lean_is_scalar(x_110)) { - x_116 = lean_alloc_ctor(0, 6, 0); -} else { - x_116 = x_110; -} -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); -x_117 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_117, 0, x_104); -lean_ctor_set(x_117, 1, x_116); -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; -x_118 = lean_ctor_get(x_11, 0); -x_119 = lean_ctor_get(x_11, 1); -x_120 = lean_ctor_get(x_11, 2); -x_121 = lean_ctor_get(x_11, 3); -x_122 = lean_ctor_get(x_11, 4); -lean_inc(x_122); -lean_inc(x_121); +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_dec(x_11); -x_123 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_123, 0, x_31); -lean_ctor_set(x_123, 1, x_19); -x_124 = lean_array_push(x_120, x_123); -x_125 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_125, 0, x_118); -lean_ctor_set(x_125, 1, x_119); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_121); -lean_ctor_set(x_125, 4, x_122); -x_126 = 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_33, x_125, x_30); -if (lean_obj_tag(x_126) == 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; lean_object* x_143; -x_127 = lean_ctor_get(x_126, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_130 = x_126; +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_126); + 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_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_127, 0); +x_131 = lean_ctor_get(x_123, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 1); +x_132 = lean_ctor_get(x_123, 1); lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 3); +x_133 = lean_ctor_get(x_123, 3); lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 4); -lean_inc(x_134); -x_135 = lean_ctor_get(x_127, 5); -lean_inc(x_135); -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_136 = x_127; +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_127); - x_136 = lean_box(0); + lean_dec_ref(x_123); + x_134 = lean_box(0); } -x_137 = lean_ctor_get(x_128, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_128, 3); -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); - x_140 = x_128; +if (lean_is_scalar(x_134)) { + x_135 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_128); - x_140 = lean_box(0); + x_135 = x_134; } -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_37); -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); +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_143 = lean_alloc_ctor(0, 2, 0); + x_136 = lean_alloc_ctor(0, 6, 0); } else { - x_143 = x_130; + x_136 = x_130; } -lean_ctor_set(x_143, 0, x_129); -lean_ctor_set(x_143, 1, x_142); -return x_143; +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_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_144 = lean_ctor_get(x_126, 1); +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); -x_145 = lean_ctor_get(x_144, 2); -lean_inc(x_145); -x_146 = lean_ctor_get(x_126, 0); +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); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_147 = x_126; -} else { - lean_dec_ref(x_126); - x_147 = lean_box(0); -} -x_148 = lean_ctor_get(x_144, 0); +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_144, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_144, 3); -lean_inc(x_150); -x_151 = lean_ctor_get(x_144, 4); -lean_inc(x_151); -x_152 = lean_ctor_get(x_144, 5); -lean_inc(x_152); -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_153 = x_144; +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_144); - x_153 = lean_box(0); + lean_dec_ref(x_138); + x_149 = lean_box(0); } -x_154 = lean_ctor_get(x_145, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_145, 1); -lean_inc(x_155); -x_156 = lean_ctor_get(x_145, 3); -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); - x_157 = x_145; +if (lean_is_scalar(x_149)) { + x_150 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_145); - x_157 = lean_box(0); + x_150 = x_149; } -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 4, 0); +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_158 = x_157; + x_151 = x_145; } -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_37); -lean_ctor_set(x_158, 3, x_156); -if (lean_is_scalar(x_153)) { - x_159 = lean_alloc_ctor(0, 6, 0); +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_159 = x_153; + x_152 = x_31; } -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_147)) { - x_160 = lean_alloc_ctor(1, 2, 0); -} else { - x_160 = x_147; +lean_ctor_set(x_152, 0, x_139); +lean_ctor_set(x_152, 1, x_151); +return x_152; } -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_35, 0); -x_162 = lean_ctor_get(x_35, 1); -x_163 = lean_ctor_get(x_35, 2); -x_164 = lean_ctor_get(x_35, 3); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_dec(x_35); -x_165 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_166 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_166, 0, x_161); -lean_ctor_set(x_166, 1, x_162); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_164); -lean_ctor_set(x_30, 2, x_166); -x_167 = lean_ctor_get(x_11, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_11, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_11, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_11, 3); -lean_inc(x_170); -x_171 = lean_ctor_get(x_11, 4); -lean_inc(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_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); 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_172 = x_11; + x_224 = x_11; } else { lean_dec_ref(x_11); - x_172 = lean_box(0); + x_224 = lean_box(0); } -x_173 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_173, 0, x_31); -lean_ctor_set(x_173, 1, x_19); -x_174 = lean_array_push(x_169, x_173); -if (lean_is_scalar(x_172)) { - x_175 = lean_alloc_ctor(0, 5, 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_227 = lean_alloc_ctor(0, 5, 0); } else { - x_175 = x_172; + x_227 = x_224; } -lean_ctor_set(x_175, 0, x_167); -lean_ctor_set(x_175, 1, x_168); -lean_ctor_set(x_175, 2, x_174); -lean_ctor_set(x_175, 3, x_170); -lean_ctor_set(x_175, 4, x_171); -x_176 = 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_33, x_175, x_30); -if (lean_obj_tag(x_176) == 0) +lean_ctor_set(x_227, 0, x_219); +lean_ctor_set(x_227, 1, x_220); +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_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; -x_177 = lean_ctor_get(x_176, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_177, 2); -lean_inc(x_178); -x_179 = lean_ctor_get(x_176, 0); -lean_inc(x_179); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - x_180 = x_176; -} else { - lean_dec_ref(x_176); - x_180 = lean_box(0); -} -x_181 = lean_ctor_get(x_177, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_177, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_177, 3); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 4); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 5); -lean_inc(x_185); -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); - lean_ctor_release(x_177, 5); - x_186 = x_177; -} else { - lean_dec_ref(x_177); - x_186 = lean_box(0); -} -x_187 = lean_ctor_get(x_178, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_178, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_178, 3); -lean_inc(x_189); -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_190 = x_178; -} else { - lean_dec_ref(x_178); - 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_163); -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_180)) { - x_193 = lean_alloc_ctor(0, 2, 0); -} else { - x_193 = x_180; -} -lean_ctor_set(x_193, 0, x_179); -lean_ctor_set(x_193, 1, x_192); -return x_193; +lean_object* x_229; lean_object* x_230; lean_object* x_231; +x_229 = lean_ctor_get(x_228, 0); +lean_inc(x_229); +x_230 = lean_ctor_get(x_228, 1); +lean_inc(x_230); +lean_dec(x_228); +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_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_194 = lean_ctor_get(x_176, 1); +lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_232 = lean_ctor_get(x_228, 0); +lean_inc(x_232); +x_233 = lean_ctor_get(x_228, 1); +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; +} +block_215: +{ +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_194, 2); +x_195 = lean_ctor_get(x_185, 3); lean_inc(x_195); -x_196 = lean_ctor_get(x_176, 0); -lean_inc(x_196); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - x_197 = x_176; +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_176); - x_197 = lean_box(0); + lean_dec_ref(x_185); + x_196 = lean_box(0); } -x_198 = lean_ctor_get(x_194, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_194, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_194, 3); +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; +} +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_194, 4); +x_201 = lean_ctor_get(x_183, 0); lean_inc(x_201); -x_202 = lean_ctor_get(x_194, 5); +lean_dec(x_183); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -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_203 = x_194; -} else { - lean_dec_ref(x_194); - x_203 = lean_box(0); -} -x_204 = lean_ctor_get(x_195, 0); +x_203 = lean_ctor_get(x_184, 1); +lean_inc(x_203); +x_204 = lean_ctor_get(x_184, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 1); +x_205 = lean_ctor_get(x_184, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_195, 3); +x_206 = lean_ctor_get(x_184, 5); lean_inc(x_206); -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_207 = x_195; +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; } else { - lean_dec_ref(x_195); + lean_dec_ref(x_184); 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); +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; +} else { + lean_dec_ref(x_200); + x_211 = lean_box(0); +} +if (lean_is_scalar(x_211)) { + x_212 = lean_alloc_ctor(0, 4, 0); +} else { + x_212 = x_211; +} +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_208 = lean_alloc_ctor(0, 4, 0); + x_213 = lean_alloc_ctor(0, 6, 0); } else { - x_208 = x_207; + x_213 = x_207; } -lean_ctor_set(x_208, 0, x_204); -lean_ctor_set(x_208, 1, x_205); -lean_ctor_set(x_208, 2, x_163); -lean_ctor_set(x_208, 3, x_206); -if (lean_is_scalar(x_203)) { - x_209 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_31)) { + x_214 = lean_alloc_ctor(0, 2, 0); } else { - x_209 = x_203; + x_214 = x_31; } -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); -if (lean_is_scalar(x_197)) { - x_210 = lean_alloc_ctor(1, 2, 0); -} else { - x_210 = x_197; +lean_ctor_set(x_214, 0, x_201); +lean_ctor_set(x_214, 1, x_213); +return x_214; } -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; 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_211 = lean_ctor_get(x_30, 2); -x_212 = lean_ctor_get(x_30, 0); -x_213 = lean_ctor_get(x_30, 1); -x_214 = lean_ctor_get(x_30, 3); -x_215 = lean_ctor_get(x_30, 4); -x_216 = lean_ctor_get(x_30, 5); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_214); -lean_inc(x_211); -lean_inc(x_213); -lean_inc(x_212); -lean_dec(x_30); -x_217 = lean_ctor_get(x_211, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_211, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_211, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_211, 3); -lean_inc(x_220); -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); - x_221 = x_211; -} else { - lean_dec_ref(x_211); - x_221 = lean_box(0); -} -x_222 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_221)) { - x_223 = lean_alloc_ctor(0, 4, 0); -} else { - x_223 = x_221; -} -lean_ctor_set(x_223, 0, x_217); -lean_ctor_set(x_223, 1, x_218); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_220); -x_224 = lean_alloc_ctor(0, 6, 0); -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); -x_225 = lean_ctor_get(x_11, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_11, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_11, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_11, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_11, 4); -lean_inc(x_229); -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_230 = x_11; -} else { - lean_dec_ref(x_11); - x_230 = lean_box(0); -} -x_231 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_231, 0, x_31); -lean_ctor_set(x_231, 1, x_19); -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_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_33, x_233, x_224); -if (lean_obj_tag(x_234) == 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; lean_object* x_249; lean_object* x_250; lean_object* x_251; -x_235 = lean_ctor_get(x_234, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_235, 2); -lean_inc(x_236); -x_237 = lean_ctor_get(x_234, 0); -lean_inc(x_237); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_238 = x_234; -} else { - lean_dec_ref(x_234); - x_238 = lean_box(0); -} -x_239 = lean_ctor_get(x_235, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_235, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_235, 3); -lean_inc(x_241); -x_242 = lean_ctor_get(x_235, 4); -lean_inc(x_242); -x_243 = lean_ctor_get(x_235, 5); -lean_inc(x_243); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - lean_ctor_release(x_235, 3); - lean_ctor_release(x_235, 4); - lean_ctor_release(x_235, 5); - x_244 = x_235; -} else { - lean_dec_ref(x_235); - x_244 = lean_box(0); -} -x_245 = lean_ctor_get(x_236, 0); -lean_inc(x_245); -x_246 = lean_ctor_get(x_236, 1); -lean_inc(x_246); -x_247 = lean_ctor_get(x_236, 3); -lean_inc(x_247); -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); - x_248 = x_236; -} else { - lean_dec_ref(x_236); - x_248 = lean_box(0); -} -if (lean_is_scalar(x_248)) { - x_249 = lean_alloc_ctor(0, 4, 0); -} else { - x_249 = x_248; -} -lean_ctor_set(x_249, 0, x_245); -lean_ctor_set(x_249, 1, x_246); -lean_ctor_set(x_249, 2, x_219); -lean_ctor_set(x_249, 3, x_247); -if (lean_is_scalar(x_244)) { - x_250 = lean_alloc_ctor(0, 6, 0); -} else { - x_250 = x_244; -} -lean_ctor_set(x_250, 0, x_239); -lean_ctor_set(x_250, 1, x_240); -lean_ctor_set(x_250, 2, x_249); -lean_ctor_set(x_250, 3, x_241); -lean_ctor_set(x_250, 4, x_242); -lean_ctor_set(x_250, 5, x_243); -if (lean_is_scalar(x_238)) { - x_251 = lean_alloc_ctor(0, 2, 0); -} else { - x_251 = x_238; -} -lean_ctor_set(x_251, 0, x_237); -lean_ctor_set(x_251, 1, x_250); -return x_251; -} -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; -x_252 = lean_ctor_get(x_234, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_252, 2); -lean_inc(x_253); -x_254 = lean_ctor_get(x_234, 0); -lean_inc(x_254); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_255 = x_234; -} else { - lean_dec_ref(x_234); - x_255 = lean_box(0); -} -x_256 = lean_ctor_get(x_252, 0); -lean_inc(x_256); -x_257 = lean_ctor_get(x_252, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_252, 3); -lean_inc(x_258); -x_259 = lean_ctor_get(x_252, 4); -lean_inc(x_259); -x_260 = lean_ctor_get(x_252, 5); -lean_inc(x_260); -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_261 = x_252; -} else { - lean_dec_ref(x_252); - x_261 = lean_box(0); -} -x_262 = lean_ctor_get(x_253, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_253, 1); -lean_inc(x_263); -x_264 = lean_ctor_get(x_253, 3); -lean_inc(x_264); -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_265 = x_253; -} else { - lean_dec_ref(x_253); - x_265 = lean_box(0); -} -if (lean_is_scalar(x_265)) { - x_266 = lean_alloc_ctor(0, 4, 0); -} else { - x_266 = x_265; -} -lean_ctor_set(x_266, 0, x_262); -lean_ctor_set(x_266, 1, x_263); -lean_ctor_set(x_266, 2, x_219); -lean_ctor_set(x_266, 3, x_264); -if (lean_is_scalar(x_261)) { - x_267 = lean_alloc_ctor(0, 6, 0); -} else { - x_267 = x_261; -} -lean_ctor_set(x_267, 0, x_256); -lean_ctor_set(x_267, 1, x_257); -lean_ctor_set(x_267, 2, x_266); -lean_ctor_set(x_267, 3, x_258); -lean_ctor_set(x_267, 4, x_259); -lean_ctor_set(x_267, 5, x_260); -if (lean_is_scalar(x_255)) { - x_268 = lean_alloc_ctor(1, 2, 0); -} else { - x_268 = x_255; -} -lean_ctor_set(x_268, 0, x_254); -lean_ctor_set(x_268, 1, x_267); -return x_268; } } } default: { -lean_object* x_269; lean_object* x_270; -x_269 = lean_ctor_get(x_24, 1); -lean_inc(x_269); +lean_object* x_235; lean_object* x_236; +x_235 = lean_ctor_get(x_24, 1); +lean_inc(x_235); lean_dec(x_24); lean_inc(x_11); -x_270 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_269); -if (lean_obj_tag(x_270) == 0) +x_236 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_235); +if (lean_obj_tag(x_236) == 0) { -lean_object* x_271; -x_271 = lean_ctor_get(x_270, 0); -lean_inc(x_271); -if (lean_obj_tag(x_271) == 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_272; lean_object* x_273; lean_object* x_274; +lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_dec(x_19); -x_272 = lean_ctor_get(x_270, 1); -lean_inc(x_272); -lean_dec(x_270); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_10, x_273); +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); lean_dec(x_10); -x_10 = x_274; -x_12 = x_272; +x_10 = x_240; +x_12 = x_238; goto _start; } else { -lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_276 = lean_ctor_get(x_270, 1); -lean_inc(x_276); -lean_dec(x_270); -x_277 = lean_ctor_get(x_271, 0); -lean_inc(x_277); -lean_dec(x_271); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_10, x_278); +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; +} else { + lean_dec_ref(x_236); + x_243 = 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_280 = !lean_is_exclusive(x_276); -if (x_280 == 0) +x_247 = !lean_is_exclusive(x_242); +if (x_247 == 0) { -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_276, 2); -x_282 = !lean_is_exclusive(x_281); -if (x_282 == 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_283; lean_object* x_284; uint8_t x_285; -x_283 = lean_ctor_get(x_281, 2); -x_284 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_281, 2, x_284); -x_285 = !lean_is_exclusive(x_11); -if (x_285 == 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_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_286 = lean_ctor_get(x_11, 2); -x_287 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_287, 0, x_277); -lean_ctor_set(x_287, 1, x_19); -x_288 = lean_array_push(x_286, x_287); -lean_ctor_set(x_11, 2, x_288); -x_289 = 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_279, x_11, x_276); -if (lean_obj_tag(x_289) == 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_290; lean_object* x_291; uint8_t x_292; -x_290 = lean_ctor_get(x_289, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_290, 2); -lean_inc(x_291); -x_292 = !lean_is_exclusive(x_289); -if (x_292 == 0) -{ -lean_object* x_293; uint8_t x_294; -x_293 = lean_ctor_get(x_289, 1); -lean_dec(x_293); -x_294 = !lean_is_exclusive(x_290); -if (x_294 == 0) -{ -lean_object* x_295; uint8_t x_296; -x_295 = lean_ctor_get(x_290, 2); -lean_dec(x_295); -x_296 = !lean_is_exclusive(x_291); -if (x_296 == 0) -{ -lean_object* x_297; -x_297 = lean_ctor_get(x_291, 2); -lean_dec(x_297); -lean_ctor_set(x_291, 2, x_283); -return x_289; -} -else -{ -lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_298 = lean_ctor_get(x_291, 0); -x_299 = lean_ctor_get(x_291, 1); -x_300 = lean_ctor_get(x_291, 3); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_dec(x_291); -x_301 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_301, 0, x_298); -lean_ctor_set(x_301, 1, x_299); -lean_ctor_set(x_301, 2, x_283); -lean_ctor_set(x_301, 3, x_300); -lean_ctor_set(x_290, 2, x_301); -return x_289; -} -} -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; -x_302 = lean_ctor_get(x_290, 0); -x_303 = lean_ctor_get(x_290, 1); -x_304 = lean_ctor_get(x_290, 3); -x_305 = lean_ctor_get(x_290, 4); -x_306 = lean_ctor_get(x_290, 5); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_inc(x_302); -lean_dec(x_290); -x_307 = lean_ctor_get(x_291, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_291, 1); +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_291, 3); +x_309 = lean_ctor_get(x_307, 1); lean_inc(x_309); -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); - x_310 = x_291; -} else { - lean_dec_ref(x_291); - x_310 = lean_box(0); +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; } -if (lean_is_scalar(x_310)) { - x_311 = lean_alloc_ctor(0, 4, 0); -} else { - x_311 = x_310; -} -lean_ctor_set(x_311, 0, x_307); -lean_ctor_set(x_311, 1, x_308); -lean_ctor_set(x_311, 2, x_283); -lean_ctor_set(x_311, 3, x_309); -x_312 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_312, 0, x_302); -lean_ctor_set(x_312, 1, x_303); -lean_ctor_set(x_312, 2, x_311); -lean_ctor_set(x_312, 3, x_304); -lean_ctor_set(x_312, 4, x_305); -lean_ctor_set(x_312, 5, x_306); -lean_ctor_set(x_289, 1, x_312); -return x_289; +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_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_313 = lean_ctor_get(x_289, 0); -lean_inc(x_313); -lean_dec(x_289); -x_314 = lean_ctor_get(x_290, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_290, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_290, 3); -lean_inc(x_316); -x_317 = lean_ctor_get(x_290, 4); -lean_inc(x_317); -x_318 = lean_ctor_get(x_290, 5); +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); -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); - lean_ctor_release(x_290, 5); - x_319 = x_290; -} else { - lean_dec_ref(x_290); - x_319 = lean_box(0); -} -x_320 = lean_ctor_get(x_291, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_291, 1); -lean_inc(x_321); -x_322 = lean_ctor_get(x_291, 3); -lean_inc(x_322); -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); - x_323 = x_291; -} else { - lean_dec_ref(x_291); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 4, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_320); -lean_ctor_set(x_324, 1, x_321); -lean_ctor_set(x_324, 2, x_283); -lean_ctor_set(x_324, 3, x_322); -if (lean_is_scalar(x_319)) { - x_325 = lean_alloc_ctor(0, 6, 0); -} else { - x_325 = x_319; -} -lean_ctor_set(x_325, 0, x_314); -lean_ctor_set(x_325, 1, x_315); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_316); -lean_ctor_set(x_325, 4, x_317); -lean_ctor_set(x_325, 5, x_318); -x_326 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_326, 0, x_313); -lean_ctor_set(x_326, 1, x_325); -return x_326; -} -} -else -{ -lean_object* x_327; lean_object* x_328; uint8_t x_329; -x_327 = lean_ctor_get(x_289, 1); -lean_inc(x_327); -x_328 = lean_ctor_get(x_327, 2); -lean_inc(x_328); -x_329 = !lean_is_exclusive(x_289); -if (x_329 == 0) -{ -lean_object* x_330; uint8_t x_331; -x_330 = lean_ctor_get(x_289, 1); -lean_dec(x_330); -x_331 = !lean_is_exclusive(x_327); -if (x_331 == 0) -{ -lean_object* x_332; uint8_t x_333; -x_332 = lean_ctor_get(x_327, 2); -lean_dec(x_332); -x_333 = !lean_is_exclusive(x_328); -if (x_333 == 0) -{ -lean_object* x_334; -x_334 = lean_ctor_get(x_328, 2); -lean_dec(x_334); -lean_ctor_set(x_328, 2, x_283); -return x_289; -} -else -{ -lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_335 = lean_ctor_get(x_328, 0); -x_336 = lean_ctor_get(x_328, 1); -x_337 = lean_ctor_get(x_328, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_dec(x_328); -x_338 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_338, 0, x_335); -lean_ctor_set(x_338, 1, x_336); -lean_ctor_set(x_338, 2, x_283); -lean_ctor_set(x_338, 3, x_337); -lean_ctor_set(x_327, 2, x_338); -return x_289; -} -} -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; lean_object* x_347; lean_object* x_348; lean_object* x_349; -x_339 = lean_ctor_get(x_327, 0); -x_340 = lean_ctor_get(x_327, 1); -x_341 = lean_ctor_get(x_327, 3); -x_342 = lean_ctor_get(x_327, 4); -x_343 = lean_ctor_get(x_327, 5); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_inc(x_339); -lean_dec(x_327); -x_344 = lean_ctor_get(x_328, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_328, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 3); -lean_inc(x_346); -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); - x_347 = x_328; -} else { - lean_dec_ref(x_328); - 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_283); -lean_ctor_set(x_348, 3, x_346); -x_349 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_349, 0, x_339); -lean_ctor_set(x_349, 1, x_340); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_341); -lean_ctor_set(x_349, 4, x_342); -lean_ctor_set(x_349, 5, x_343); -lean_ctor_set(x_289, 1, x_349); -return x_289; -} -} -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; -x_350 = lean_ctor_get(x_289, 0); -lean_inc(x_350); -lean_dec(x_289); -x_351 = lean_ctor_get(x_327, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_327, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_327, 3); -lean_inc(x_353); -x_354 = lean_ctor_get(x_327, 4); -lean_inc(x_354); -x_355 = lean_ctor_get(x_327, 5); -lean_inc(x_355); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - lean_ctor_release(x_327, 4); - lean_ctor_release(x_327, 5); - x_356 = x_327; -} else { - lean_dec_ref(x_327); - x_356 = lean_box(0); -} -x_357 = lean_ctor_get(x_328, 0); -lean_inc(x_357); -x_358 = lean_ctor_get(x_328, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_328, 3); -lean_inc(x_359); -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); - x_360 = x_328; -} else { - lean_dec_ref(x_328); - x_360 = lean_box(0); -} -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 4, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_357); -lean_ctor_set(x_361, 1, x_358); -lean_ctor_set(x_361, 2, x_283); -lean_ctor_set(x_361, 3, x_359); -if (lean_is_scalar(x_356)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = 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); -x_363 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_363, 0, x_350); -lean_ctor_set(x_363, 1, x_362); -return x_363; -} -} -} -else -{ -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_364 = lean_ctor_get(x_11, 0); -x_365 = lean_ctor_get(x_11, 1); -x_366 = lean_ctor_get(x_11, 2); -x_367 = lean_ctor_get(x_11, 3); -x_368 = lean_ctor_get(x_11, 4); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); -lean_inc(x_364); +lean_inc(x_317); +lean_inc(x_316); +lean_inc(x_315); +lean_inc(x_314); lean_dec(x_11); -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_277); -lean_ctor_set(x_369, 1, x_19); -x_370 = lean_array_push(x_366, x_369); -x_371 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_371, 0, x_364); -lean_ctor_set(x_371, 1, x_365); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_367); -lean_ctor_set(x_371, 4, x_368); -x_372 = 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_279, x_371, x_276); -if (lean_obj_tag(x_372) == 0) +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_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; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_373 = lean_ctor_get(x_372, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_373, 2); -lean_inc(x_374); -x_375 = lean_ctor_get(x_372, 0); -lean_inc(x_375); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - x_376 = x_372; -} else { - lean_dec_ref(x_372); - x_376 = lean_box(0); -} -x_377 = lean_ctor_get(x_373, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_373, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_373, 3); -lean_inc(x_379); -x_380 = lean_ctor_get(x_373, 4); -lean_inc(x_380); -x_381 = lean_ctor_get(x_373, 5); -lean_inc(x_381); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - lean_ctor_release(x_373, 3); - lean_ctor_release(x_373, 4); - lean_ctor_release(x_373, 5); - x_382 = x_373; -} else { - lean_dec_ref(x_373); - x_382 = lean_box(0); -} -x_383 = lean_ctor_get(x_374, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_374, 1); -lean_inc(x_384); -x_385 = lean_ctor_get(x_374, 3); -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); - 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, 4, 0); -} else { - x_387 = x_386; -} -lean_ctor_set(x_387, 0, x_383); -lean_ctor_set(x_387, 1, x_384); -lean_ctor_set(x_387, 2, x_283); -lean_ctor_set(x_387, 3, x_385); -if (lean_is_scalar(x_382)) { - x_388 = lean_alloc_ctor(0, 6, 0); -} else { - x_388 = x_382; -} -lean_ctor_set(x_388, 0, x_377); -lean_ctor_set(x_388, 1, x_378); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_379); -lean_ctor_set(x_388, 4, x_380); -lean_ctor_set(x_388, 5, x_381); -if (lean_is_scalar(x_376)) { - x_389 = lean_alloc_ctor(0, 2, 0); -} else { - x_389 = x_376; -} -lean_ctor_set(x_389, 0, x_375); -lean_ctor_set(x_389, 1, x_388); -return x_389; +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_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; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_390 = lean_ctor_get(x_372, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_390, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_372, 0); -lean_inc(x_392); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - x_393 = x_372; -} else { - lean_dec_ref(x_372); - x_393 = lean_box(0); +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; } -x_394 = lean_ctor_get(x_390, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_390, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_390, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_390, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_390, 5); -lean_inc(x_398); -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_399 = x_390; -} else { - lean_dec_ref(x_390); - x_399 = lean_box(0); } -x_400 = lean_ctor_get(x_391, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_391, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_391, 3); -lean_inc(x_402); -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_403 = x_391; +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); +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); +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 { - lean_dec_ref(x_391); - x_403 = lean_box(0); + x_259 = x_243; + lean_ctor_set_tag(x_259, 1); } -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_259, 0, x_254); +lean_ctor_set(x_259, 1, x_252); +return x_259; +} +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_404 = x_403; + x_264 = x_243; + lean_ctor_set_tag(x_264, 1); } -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_283); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_264, 0, x_254); +lean_ctor_set(x_264, 1, x_252); +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; 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_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 { - x_405 = x_399; + lean_dec_ref(x_253); + x_273 = lean_box(0); } -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_393)) { - x_406 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_273)) { + x_274 = lean_alloc_ctor(0, 4, 0); } else { - x_406 = x_393; + x_274 = x_273; +} +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, 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); +} else { + x_276 = x_243; + lean_ctor_set_tag(x_276, 1); +} +lean_ctor_set(x_276, 0, x_254); +lean_ctor_set(x_276, 1, x_275); +return x_276; +} +} +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_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_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); +} else { + x_288 = x_243; +} +lean_ctor_set(x_288, 0, x_278); +lean_ctor_set(x_288, 1, x_252); +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_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); +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; +} else { + lean_dec_ref(x_277); + x_297 = lean_box(0); +} +if (lean_is_scalar(x_297)) { + x_298 = lean_alloc_ctor(0, 4, 0); +} else { + x_298 = x_297; +} +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); +} else { + x_300 = x_243; +} +lean_ctor_set(x_300, 0, x_278); +lean_ctor_set(x_300, 1, x_299); +return x_300; } -lean_ctor_set(x_406, 0, x_392); -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; lean_object* x_422; -x_407 = lean_ctor_get(x_281, 0); -x_408 = lean_ctor_get(x_281, 1); -x_409 = lean_ctor_get(x_281, 2); -x_410 = lean_ctor_get(x_281, 3); -lean_inc(x_410); -lean_inc(x_409); -lean_inc(x_408); -lean_inc(x_407); -lean_dec(x_281); -x_411 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_412 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_412, 0, x_407); -lean_ctor_set(x_412, 1, x_408); -lean_ctor_set(x_412, 2, x_411); -lean_ctor_set(x_412, 3, x_410); -lean_ctor_set(x_276, 2, x_412); -x_413 = lean_ctor_get(x_11, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_11, 1); -lean_inc(x_414); -x_415 = lean_ctor_get(x_11, 2); -lean_inc(x_415); -x_416 = lean_ctor_get(x_11, 3); -lean_inc(x_416); -x_417 = lean_ctor_get(x_11, 4); -lean_inc(x_417); +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); 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_418 = x_11; + x_373 = x_11; } else { lean_dec_ref(x_11); - x_418 = lean_box(0); + x_373 = lean_box(0); } -x_419 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_419, 0, x_277); -lean_ctor_set(x_419, 1, x_19); -x_420 = lean_array_push(x_415, x_419); -if (lean_is_scalar(x_418)) { - x_421 = lean_alloc_ctor(0, 5, 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); } else { - x_421 = x_418; + x_376 = x_373; } -lean_ctor_set(x_421, 0, x_413); -lean_ctor_set(x_421, 1, x_414); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_416); -lean_ctor_set(x_421, 4, x_417); -x_422 = 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_279, x_421, x_276); -if (lean_obj_tag(x_422) == 0) +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_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; lean_object* x_439; -x_423 = lean_ctor_get(x_422, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_423, 2); -lean_inc(x_424); -x_425 = lean_ctor_get(x_422, 0); -lean_inc(x_425); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_426 = x_422; -} else { - lean_dec_ref(x_422); - x_426 = lean_box(0); -} -x_427 = lean_ctor_get(x_423, 0); -lean_inc(x_427); -x_428 = lean_ctor_get(x_423, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_423, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_423, 4); -lean_inc(x_430); -x_431 = lean_ctor_get(x_423, 5); -lean_inc(x_431); -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); - lean_ctor_release(x_423, 5); - x_432 = x_423; -} else { - lean_dec_ref(x_423); - x_432 = lean_box(0); -} -x_433 = lean_ctor_get(x_424, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_424, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_424, 3); -lean_inc(x_435); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - x_436 = x_424; -} else { - lean_dec_ref(x_424); - x_436 = lean_box(0); -} -if (lean_is_scalar(x_436)) { - x_437 = lean_alloc_ctor(0, 4, 0); -} else { - x_437 = x_436; -} -lean_ctor_set(x_437, 0, x_433); -lean_ctor_set(x_437, 1, x_434); -lean_ctor_set(x_437, 2, x_409); -lean_ctor_set(x_437, 3, x_435); -if (lean_is_scalar(x_432)) { - x_438 = lean_alloc_ctor(0, 6, 0); -} else { - x_438 = x_432; -} -lean_ctor_set(x_438, 0, x_427); -lean_ctor_set(x_438, 1, x_428); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_429); -lean_ctor_set(x_438, 4, x_430); -lean_ctor_set(x_438, 5, x_431); -if (lean_is_scalar(x_426)) { - x_439 = lean_alloc_ctor(0, 2, 0); -} else { - x_439 = x_426; -} -lean_ctor_set(x_439, 0, x_425); -lean_ctor_set(x_439, 1, x_438); -return x_439; +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; } else { -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; lean_object* x_455; lean_object* x_456; -x_440 = lean_ctor_get(x_422, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_440, 2); -lean_inc(x_441); -x_442 = lean_ctor_get(x_422, 0); -lean_inc(x_442); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_443 = x_422; -} else { - lean_dec_ref(x_422); - x_443 = lean_box(0); +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; } +block_365: +{ +if (lean_obj_tag(x_333) == 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_inc(x_350); +x_351 = lean_ctor_get(x_333, 0); +lean_inc(x_351); +lean_dec(x_333); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +x_353 = lean_ctor_get(x_334, 1); +lean_inc(x_353); +x_354 = lean_ctor_get(x_334, 3); +lean_inc(x_354); +x_355 = lean_ctor_get(x_334, 4); +lean_inc(x_355); +x_356 = lean_ctor_get(x_334, 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; +} else { + lean_dec_ref(x_334); + x_357 = lean_box(0); +} +x_358 = lean_ctor_get(x_350, 0); +lean_inc(x_358); +x_359 = lean_ctor_get(x_350, 1); +lean_inc(x_359); +x_360 = lean_ctor_get(x_350, 3); +lean_inc(x_360); +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; +} else { + lean_dec_ref(x_350); + x_361 = lean_box(0); +} +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 4, 0); +} else { + x_362 = x_361; +} +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); +if (lean_is_scalar(x_357)) { + x_363 = lean_alloc_ctor(0, 6, 0); +} else { + x_363 = 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); +} else { + x_364 = x_243; +} +lean_ctor_set(x_364, 0, x_351); +lean_ctor_set(x_364, 1, x_363); +return x_364; +} +} +} +} +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; +} else { + lean_dec_ref(x_384); + x_394 = 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); +} else { + x_429 = x_394; +} +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); +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; +} else { + lean_dec_ref(x_11); + x_436 = 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); +} else { + x_439 = x_436; +} +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_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; +} +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); -x_446 = lean_ctor_get(x_440, 3); -lean_inc(x_446); -x_447 = lean_ctor_get(x_440, 4); -lean_inc(x_447); -x_448 = lean_ctor_get(x_440, 5); -lean_inc(x_448); -if (lean_is_exclusive(x_440)) { - lean_ctor_release(x_440, 0); - lean_ctor_release(x_440, 1); - lean_ctor_release(x_440, 2); - lean_ctor_release(x_440, 3); - lean_ctor_release(x_440, 4); - lean_ctor_release(x_440, 5); - x_449 = x_440; +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; +} +block_427: +{ +if (lean_obj_tag(x_395) == 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_440); - x_449 = lean_box(0); + lean_dec_ref(x_396); + x_404 = lean_box(0); } -x_450 = lean_ctor_get(x_441, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_441, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_441, 3); -lean_inc(x_452); -if (lean_is_exclusive(x_441)) { - lean_ctor_release(x_441, 0); - lean_ctor_release(x_441, 1); - lean_ctor_release(x_441, 2); - lean_ctor_release(x_441, 3); - x_453 = x_441; +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_441); - x_453 = lean_box(0); + lean_dec_ref(x_397); + x_408 = lean_box(0); } -if (lean_is_scalar(x_453)) { - x_454 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_408)) { + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_454 = x_453; + x_409 = x_408; } -lean_ctor_set(x_454, 0, x_450); -lean_ctor_set(x_454, 1, x_451); -lean_ctor_set(x_454, 2, x_409); -lean_ctor_set(x_454, 3, x_452); -if (lean_is_scalar(x_449)) { - x_455 = lean_alloc_ctor(0, 6, 0); +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_455 = x_449; + x_410 = x_404; } -lean_ctor_set(x_455, 0, x_444); -lean_ctor_set(x_455, 1, x_445); -lean_ctor_set(x_455, 2, x_454); -lean_ctor_set(x_455, 3, x_446); -lean_ctor_set(x_455, 4, x_447); -lean_ctor_set(x_455, 5, x_448); -if (lean_is_scalar(x_443)) { - x_456 = lean_alloc_ctor(1, 2, 0); +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_456 = x_443; -} -lean_ctor_set(x_456, 0, x_442); -lean_ctor_set(x_456, 1, x_455); -return x_456; -} + 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_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; 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_457 = lean_ctor_get(x_276, 2); -x_458 = lean_ctor_get(x_276, 0); -x_459 = lean_ctor_get(x_276, 1); -x_460 = lean_ctor_get(x_276, 3); -x_461 = lean_ctor_get(x_276, 4); -x_462 = lean_ctor_get(x_276, 5); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_460); -lean_inc(x_457); -lean_inc(x_459); -lean_inc(x_458); -lean_dec(x_276); -x_463 = lean_ctor_get(x_457, 0); -lean_inc(x_463); -x_464 = lean_ctor_get(x_457, 1); -lean_inc(x_464); -x_465 = lean_ctor_get(x_457, 2); -lean_inc(x_465); -x_466 = lean_ctor_get(x_457, 3); -lean_inc(x_466); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - lean_ctor_release(x_457, 2); - lean_ctor_release(x_457, 3); - x_467 = x_457; +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_inc(x_415); +x_416 = lean_ctor_get(x_396, 3); +lean_inc(x_416); +x_417 = lean_ctor_get(x_396, 4); +lean_inc(x_417); +x_418 = lean_ctor_get(x_396, 5); +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_457); - x_467 = lean_box(0); + lean_dec_ref(x_396); + x_419 = lean_box(0); } -x_468 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_467)) { - x_469 = lean_alloc_ctor(0, 4, 0); +x_420 = lean_ctor_get(x_412, 0); +lean_inc(x_420); +x_421 = lean_ctor_get(x_412, 1); +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; } else { - x_469 = x_467; + lean_dec_ref(x_412); + x_423 = lean_box(0); } -lean_ctor_set(x_469, 0, x_463); -lean_ctor_set(x_469, 1, x_464); -lean_ctor_set(x_469, 2, x_468); -lean_ctor_set(x_469, 3, x_466); -x_470 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_470, 0, x_458); -lean_ctor_set(x_470, 1, x_459); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_460); -lean_ctor_set(x_470, 4, x_461); -lean_ctor_set(x_470, 5, x_462); -x_471 = lean_ctor_get(x_11, 0); -lean_inc(x_471); -x_472 = lean_ctor_get(x_11, 1); -lean_inc(x_472); -x_473 = lean_ctor_get(x_11, 2); -lean_inc(x_473); -x_474 = lean_ctor_get(x_11, 3); -lean_inc(x_474); -x_475 = lean_ctor_get(x_11, 4); -lean_inc(x_475); -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_476 = x_11; +if (lean_is_scalar(x_423)) { + x_424 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_11); - x_476 = lean_box(0); + x_424 = x_423; } -x_477 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_477, 0, x_277); -lean_ctor_set(x_477, 1, x_19); -x_478 = lean_array_push(x_473, x_477); -if (lean_is_scalar(x_476)) { - x_479 = lean_alloc_ctor(0, 5, 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); } else { - x_479 = x_476; + x_425 = x_419; } -lean_ctor_set(x_479, 0, x_471); -lean_ctor_set(x_479, 1, x_472); -lean_ctor_set(x_479, 2, x_478); -lean_ctor_set(x_479, 3, x_474); -lean_ctor_set(x_479, 4, x_475); -x_480 = 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_279, x_479, x_470); -if (lean_obj_tag(x_480) == 0) -{ -lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_481 = lean_ctor_get(x_480, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_481, 2); -lean_inc(x_482); -x_483 = lean_ctor_get(x_480, 0); -lean_inc(x_483); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - x_484 = x_480; +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); } else { - lean_dec_ref(x_480); - x_484 = lean_box(0); + x_426 = x_243; } -x_485 = lean_ctor_get(x_481, 0); -lean_inc(x_485); -x_486 = lean_ctor_get(x_481, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_481, 3); -lean_inc(x_487); -x_488 = lean_ctor_get(x_481, 4); -lean_inc(x_488); -x_489 = lean_ctor_get(x_481, 5); -lean_inc(x_489); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - lean_ctor_release(x_481, 2); - lean_ctor_release(x_481, 3); - lean_ctor_release(x_481, 4); - lean_ctor_release(x_481, 5); - x_490 = x_481; -} else { - lean_dec_ref(x_481); - x_490 = lean_box(0); +lean_ctor_set(x_426, 0, x_413); +lean_ctor_set(x_426, 1, x_425); +return x_426; } -x_491 = lean_ctor_get(x_482, 0); -lean_inc(x_491); -x_492 = lean_ctor_get(x_482, 1); -lean_inc(x_492); -x_493 = lean_ctor_get(x_482, 3); -lean_inc(x_493); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - x_494 = x_482; -} else { - lean_dec_ref(x_482); - x_494 = lean_box(0); -} -if (lean_is_scalar(x_494)) { - x_495 = lean_alloc_ctor(0, 4, 0); -} else { - x_495 = x_494; -} -lean_ctor_set(x_495, 0, x_491); -lean_ctor_set(x_495, 1, x_492); -lean_ctor_set(x_495, 2, x_465); -lean_ctor_set(x_495, 3, x_493); -if (lean_is_scalar(x_490)) { - x_496 = lean_alloc_ctor(0, 6, 0); -} else { - x_496 = x_490; -} -lean_ctor_set(x_496, 0, x_485); -lean_ctor_set(x_496, 1, x_486); -lean_ctor_set(x_496, 2, x_495); -lean_ctor_set(x_496, 3, x_487); -lean_ctor_set(x_496, 4, x_488); -lean_ctor_set(x_496, 5, x_489); -if (lean_is_scalar(x_484)) { - x_497 = lean_alloc_ctor(0, 2, 0); -} else { - x_497 = x_484; -} -lean_ctor_set(x_497, 0, x_483); -lean_ctor_set(x_497, 1, x_496); -return x_497; -} -else -{ -lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; -x_498 = lean_ctor_get(x_480, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_498, 2); -lean_inc(x_499); -x_500 = lean_ctor_get(x_480, 0); -lean_inc(x_500); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - x_501 = x_480; -} else { - lean_dec_ref(x_480); - x_501 = lean_box(0); -} -x_502 = lean_ctor_get(x_498, 0); -lean_inc(x_502); -x_503 = lean_ctor_get(x_498, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_498, 3); -lean_inc(x_504); -x_505 = lean_ctor_get(x_498, 4); -lean_inc(x_505); -x_506 = lean_ctor_get(x_498, 5); -lean_inc(x_506); -if (lean_is_exclusive(x_498)) { - lean_ctor_release(x_498, 0); - lean_ctor_release(x_498, 1); - lean_ctor_release(x_498, 2); - lean_ctor_release(x_498, 3); - lean_ctor_release(x_498, 4); - lean_ctor_release(x_498, 5); - x_507 = x_498; -} else { - lean_dec_ref(x_498); - x_507 = lean_box(0); -} -x_508 = lean_ctor_get(x_499, 0); -lean_inc(x_508); -x_509 = lean_ctor_get(x_499, 1); -lean_inc(x_509); -x_510 = lean_ctor_get(x_499, 3); -lean_inc(x_510); -if (lean_is_exclusive(x_499)) { - lean_ctor_release(x_499, 0); - lean_ctor_release(x_499, 1); - lean_ctor_release(x_499, 2); - lean_ctor_release(x_499, 3); - x_511 = x_499; -} else { - lean_dec_ref(x_499); - x_511 = lean_box(0); -} -if (lean_is_scalar(x_511)) { - x_512 = lean_alloc_ctor(0, 4, 0); -} else { - x_512 = x_511; -} -lean_ctor_set(x_512, 0, x_508); -lean_ctor_set(x_512, 1, x_509); -lean_ctor_set(x_512, 2, x_465); -lean_ctor_set(x_512, 3, x_510); -if (lean_is_scalar(x_507)) { - x_513 = lean_alloc_ctor(0, 6, 0); -} else { - x_513 = x_507; -} -lean_ctor_set(x_513, 0, x_502); -lean_ctor_set(x_513, 1, x_503); -lean_ctor_set(x_513, 2, x_512); -lean_ctor_set(x_513, 3, x_504); -lean_ctor_set(x_513, 4, x_505); -lean_ctor_set(x_513, 5, x_506); -if (lean_is_scalar(x_501)) { - x_514 = lean_alloc_ctor(1, 2, 0); -} else { - x_514 = x_501; -} -lean_ctor_set(x_514, 0, x_500); -lean_ctor_set(x_514, 1, x_513); -return x_514; } } } } else { -uint8_t x_515; +uint8_t x_447; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -16020,23 +14617,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_515 = !lean_is_exclusive(x_270); -if (x_515 == 0) +x_447 = !lean_is_exclusive(x_236); +if (x_447 == 0) { -return x_270; +return x_236; } else { -lean_object* x_516; lean_object* x_517; lean_object* x_518; -x_516 = lean_ctor_get(x_270, 0); -x_517 = lean_ctor_get(x_270, 1); -lean_inc(x_517); -lean_inc(x_516); -lean_dec(x_270); -x_518 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_518, 0, x_516); -lean_ctor_set(x_518, 1, x_517); -return x_518; +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; } } } @@ -16044,7 +14641,7 @@ return x_518; } else { -uint8_t x_519; +uint8_t x_451; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -16054,29 +14651,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_519 = !lean_is_exclusive(x_24); -if (x_519 == 0) +x_451 = !lean_is_exclusive(x_24); +if (x_451 == 0) { return x_24; } else { -lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_520 = lean_ctor_get(x_24, 0); -x_521 = lean_ctor_get(x_24, 1); -lean_inc(x_521); -lean_inc(x_520); +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_dec(x_24); -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; +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; } } } else { -uint8_t x_523; +uint8_t x_455; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -16085,23 +14682,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_523 = !lean_is_exclusive(x_20); -if (x_523 == 0) +x_455 = !lean_is_exclusive(x_20); +if (x_455 == 0) { return x_20; } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; -x_524 = lean_ctor_get(x_20, 0); -x_525 = lean_ctor_get(x_20, 1); -lean_inc(x_525); -lean_inc(x_524); +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_dec(x_20); -x_526 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_526, 0, x_524); -lean_ctor_set(x_526, 1, x_525); -return x_526; +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; } } } @@ -16204,2150 +14801,1788 @@ goto _start; } case 1: { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_dec(x_22); x_29 = lean_ctor_get(x_23, 1); lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); +if (lean_is_exclusive(x_23)) { + lean_ctor_release(x_23, 0); + lean_ctor_release(x_23, 1); + x_30 = x_23; +} else { + lean_dec_ref(x_23); + x_30 = lean_box(0); +} +x_31 = lean_ctor_get(x_24, 0); +lean_inc(x_31); lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_3, x_32); lean_dec(x_3); -x_33 = !lean_is_exclusive(x_29); -if (x_33 == 0) +x_34 = !lean_is_exclusive(x_29); +if (x_34 == 0) { -lean_object* x_34; uint8_t x_35; -x_34 = lean_ctor_get(x_29, 2); -x_35 = !lean_is_exclusive(x_34); -if (x_35 == 0) +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_29, 2); +x_36 = !lean_is_exclusive(x_35); +if (x_36 == 0) { -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_34, 2); -x_37 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_34, 2, x_37); -x_38 = !lean_is_exclusive(x_4); -if (x_38 == 0) +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_89; uint8_t x_90; +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) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_39 = lean_ctor_get(x_4, 2); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_30); -lean_ctor_set(x_40, 1, x_18); -x_41 = lean_array_push(x_39, x_40); -lean_ctor_set(x_4, 2, x_41); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_4, x_29); -if (lean_obj_tag(x_42) == 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_43; lean_object* x_44; uint8_t x_45; -x_43 = lean_ctor_get(x_42, 1); -lean_inc(x_43); -x_44 = lean_ctor_get(x_43, 2); -lean_inc(x_44); -x_45 = !lean_is_exclusive(x_42); -if (x_45 == 0) -{ -lean_object* x_46; uint8_t x_47; -x_46 = lean_ctor_get(x_42, 1); -lean_dec(x_46); -x_47 = !lean_is_exclusive(x_43); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_43, 2); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_44); -if (x_49 == 0) -{ -lean_object* x_50; -x_50 = lean_ctor_get(x_44, 2); -lean_dec(x_50); -lean_ctor_set(x_44, 2, x_36); -return x_42; +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_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -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_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_36); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_43, 2, x_54); -return x_42; +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_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; } } 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; -x_55 = lean_ctor_get(x_43, 0); -x_56 = lean_ctor_get(x_43, 1); -x_57 = lean_ctor_get(x_43, 3); -x_58 = lean_ctor_get(x_43, 4); -x_59 = lean_ctor_get(x_43, 5); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); +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_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; +} +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_38 = x_115; +x_39 = x_114; +goto block_88; +} +} +block_88: +{ +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_40; lean_object* x_41; uint8_t x_42; +x_40 = lean_ctor_get(x_39, 2); +lean_inc(x_40); +x_41 = lean_ctor_get(x_38, 0); +lean_inc(x_41); +lean_dec(x_38); +x_42 = !lean_is_exclusive(x_39); +if (x_42 == 0) +{ +lean_object* x_43; uint8_t x_44; +x_43 = lean_ctor_get(x_39, 2); +lean_dec(x_43); +x_44 = !lean_is_exclusive(x_40); +if (x_44 == 0) +{ +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_40, 2); +lean_dec(x_45); +lean_ctor_set(x_40, 2, x_37); +if (lean_is_scalar(x_30)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_30; + lean_ctor_set_tag(x_46, 1); +} +lean_ctor_set(x_46, 0, x_41); +lean_ctor_set(x_46, 1, x_39); +return x_46; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_47 = lean_ctor_get(x_40, 0); +x_48 = lean_ctor_get(x_40, 1); +x_49 = lean_ctor_get(x_40, 3); +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); +if (lean_is_scalar(x_30)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_30; + lean_ctor_set_tag(x_51, 1); +} +lean_ctor_set(x_51, 0, x_41); +lean_ctor_set(x_51, 1, x_39); +return x_51; +} +} +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_inc(x_56); lean_inc(x_55); -lean_dec(x_43); -x_60 = lean_ctor_get(x_44, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_44, 1); -lean_inc(x_61); -x_62 = lean_ctor_get(x_44, 3); -lean_inc(x_62); -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_63 = x_44; +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); +lean_inc(x_58); +x_59 = lean_ctor_get(x_40, 3); +lean_inc(x_59); +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; } else { - lean_dec_ref(x_44); - x_63 = lean_box(0); + lean_dec_ref(x_40); + x_60 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_60)) { + x_61 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_61 = x_60; } -lean_ctor_set(x_64, 0, x_60); -lean_ctor_set(x_64, 1, x_61); -lean_ctor_set(x_64, 2, x_36); -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_42, 1, x_65); -return x_42; +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); +if (lean_is_scalar(x_30)) { + x_63 = lean_alloc_ctor(1, 2, 0); +} else { + x_63 = x_30; + lean_ctor_set_tag(x_63, 1); +} +lean_ctor_set(x_63, 0, x_41); +lean_ctor_set(x_63, 1, x_62); +return x_63; } } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_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_66 = lean_ctor_get(x_42, 0); -lean_inc(x_66); -lean_dec(x_42); -x_67 = lean_ctor_get(x_43, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_43, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_43, 3); -lean_inc(x_69); -x_70 = lean_ctor_get(x_43, 4); -lean_inc(x_70); -x_71 = lean_ctor_get(x_43, 5); -lean_inc(x_71); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - lean_ctor_release(x_43, 2); - lean_ctor_release(x_43, 3); - lean_ctor_release(x_43, 4); - lean_ctor_release(x_43, 5); - x_72 = x_43; +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_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); +if (x_68 == 0) +{ +lean_object* x_69; lean_object* x_70; +x_69 = lean_ctor_get(x_64, 2); +lean_dec(x_69); +lean_ctor_set(x_64, 2, x_37); +if (lean_is_scalar(x_30)) { + x_70 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_43); - x_72 = lean_box(0); + x_70 = x_30; } -x_73 = lean_ctor_get(x_44, 0); +lean_ctor_set(x_70, 0, x_65); +lean_ctor_set(x_70, 1, x_39); +return x_70; +} +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_inc(x_73); -x_74 = lean_ctor_get(x_44, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_44, 3); -lean_inc(x_75); -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_76 = x_44; +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); +if (lean_is_scalar(x_30)) { + x_75 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_44); - x_76 = lean_box(0); + x_75 = x_30; } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); -} else { - x_77 = x_76; -} -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_36); -lean_ctor_set(x_77, 3, x_75); -if (lean_is_scalar(x_72)) { - x_78 = lean_alloc_ctor(0, 6, 0); -} else { - x_78 = x_72; -} -lean_ctor_set(x_78, 0, x_67); -lean_ctor_set(x_78, 1, x_68); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_69); -lean_ctor_set(x_78, 4, x_70); -lean_ctor_set(x_78, 5, x_71); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_66); -lean_ctor_set(x_79, 1, x_78); -return x_79; +lean_ctor_set(x_75, 0, x_65); +lean_ctor_set(x_75, 1, x_39); +return x_75; } } else { -lean_object* x_80; lean_object* x_81; uint8_t x_82; -x_80 = lean_ctor_get(x_42, 1); +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_inc(x_80); -x_81 = lean_ctor_get(x_80, 2); +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_is_exclusive(x_42); -if (x_82 == 0) -{ -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_42, 1); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_80); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_80, 2); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_81); -if (x_86 == 0) -{ -lean_object* x_87; -x_87 = lean_ctor_get(x_81, 2); -lean_dec(x_87); -lean_ctor_set(x_81, 2, x_36); -return x_42; -} -else -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_81, 0); -x_89 = lean_ctor_get(x_81, 1); -x_90 = lean_ctor_get(x_81, 3); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_81); -x_91 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_91, 0, x_88); -lean_ctor_set(x_91, 1, x_89); -lean_ctor_set(x_91, 2, x_36); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set(x_80, 2, x_91); -return x_42; -} -} -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_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_92 = lean_ctor_get(x_80, 0); -x_93 = lean_ctor_get(x_80, 1); -x_94 = lean_ctor_get(x_80, 3); -x_95 = lean_ctor_get(x_80, 4); -x_96 = lean_ctor_get(x_80, 5); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_80); -x_97 = lean_ctor_get(x_81, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_81, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_81, 3); -lean_inc(x_99); -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); - x_100 = 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; } else { - lean_dec_ref(x_81); - x_100 = lean_box(0); + lean_dec_ref(x_64); + x_84 = lean_box(0); } -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 4, 0); } else { - x_101 = x_100; + x_85 = x_84; } -lean_ctor_set(x_101, 0, x_97); -lean_ctor_set(x_101, 1, x_98); -lean_ctor_set(x_101, 2, x_36); -lean_ctor_set(x_101, 3, x_99); -x_102 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_102, 0, x_92); -lean_ctor_set(x_102, 1, x_93); -lean_ctor_set(x_102, 2, x_101); -lean_ctor_set(x_102, 3, x_94); -lean_ctor_set(x_102, 4, x_95); -lean_ctor_set(x_102, 5, x_96); -lean_ctor_set(x_42, 1, x_102); -return x_42; -} -} -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; lean_object* x_116; -x_103 = lean_ctor_get(x_42, 0); -lean_inc(x_103); -lean_dec(x_42); -x_104 = lean_ctor_get(x_80, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_80, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_80, 3); -lean_inc(x_106); -x_107 = lean_ctor_get(x_80, 4); -lean_inc(x_107); -x_108 = lean_ctor_get(x_80, 5); -lean_inc(x_108); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - lean_ctor_release(x_80, 3); - lean_ctor_release(x_80, 4); - lean_ctor_release(x_80, 5); - x_109 = x_80; +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); +if (lean_is_scalar(x_30)) { + x_87 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + x_87 = x_30; } -x_110 = lean_ctor_get(x_81, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_81, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_81, 3); -lean_inc(x_112); -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); - x_113 = x_81; -} else { - lean_dec_ref(x_81); - x_113 = lean_box(0); +lean_ctor_set(x_87, 0, x_65); +lean_ctor_set(x_87, 1, x_86); +return x_87; } -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_36); -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); -x_116 = lean_alloc_ctor(1, 2, 0); -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; -x_117 = lean_ctor_get(x_4, 0); -x_118 = lean_ctor_get(x_4, 1); -x_119 = lean_ctor_get(x_4, 2); -x_120 = lean_ctor_get(x_4, 3); -x_121 = lean_ctor_get(x_4, 4); -lean_inc(x_121); -lean_inc(x_120); +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_dec(x_4); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_30); -lean_ctor_set(x_122, 1, x_18); -x_123 = lean_array_push(x_119, x_122); -x_124 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_124, 0, x_117); -lean_ctor_set(x_124, 1, x_118); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_120); -lean_ctor_set(x_124, 4, x_121); -x_125 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_124, x_29); -if (lean_obj_tag(x_125) == 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; lean_object* x_141; lean_object* x_142; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); -lean_inc(x_127); -x_128 = lean_ctor_get(x_125, 0); -lean_inc(x_128); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_129 = x_125; +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_125); + 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_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_126, 0); +x_130 = lean_ctor_get(x_122, 0); lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); +x_131 = lean_ctor_get(x_122, 1); lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +x_132 = lean_ctor_get(x_122, 3); lean_inc(x_132); -x_133 = lean_ctor_get(x_126, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); -lean_inc(x_134); -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_135 = x_126; +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_126); - x_135 = lean_box(0); + lean_dec_ref(x_122); + x_133 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_127, 3); -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); - x_139 = x_127; +if (lean_is_scalar(x_133)) { + x_134 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_127); - x_139 = lean_box(0); + x_134 = x_133; } -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_36); -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); +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_142 = lean_alloc_ctor(0, 2, 0); + x_135 = lean_alloc_ctor(0, 6, 0); } else { - x_142 = x_129; + x_135 = x_129; } -lean_ctor_set(x_142, 0, x_128); -lean_ctor_set(x_142, 1, x_141); -return x_142; +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_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_143 = lean_ctor_get(x_125, 1); +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); -x_144 = lean_ctor_get(x_143, 2); -lean_inc(x_144); -x_145 = lean_ctor_get(x_125, 0); +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); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_146 = x_125; -} else { - lean_dec_ref(x_125); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_143, 0); +x_146 = lean_ctor_get(x_137, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_137, 3); lean_inc(x_147); -x_148 = lean_ctor_get(x_143, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_143, 3); -lean_inc(x_149); -x_150 = lean_ctor_get(x_143, 4); -lean_inc(x_150); -x_151 = lean_ctor_get(x_143, 5); -lean_inc(x_151); -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); - lean_ctor_release(x_143, 5); - x_152 = x_143; +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_143); - x_152 = lean_box(0); + lean_dec_ref(x_137); + x_148 = lean_box(0); } -x_153 = lean_ctor_get(x_144, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_144, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_144, 3); -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); - x_156 = x_144; +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_144); - x_156 = lean_box(0); + x_149 = x_148; } -if (lean_is_scalar(x_156)) { - x_157 = lean_alloc_ctor(0, 4, 0); +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_157 = x_156; + x_150 = x_144; } -lean_ctor_set(x_157, 0, x_153); -lean_ctor_set(x_157, 1, x_154); -lean_ctor_set(x_157, 2, x_36); -lean_ctor_set(x_157, 3, x_155); -if (lean_is_scalar(x_152)) { - x_158 = lean_alloc_ctor(0, 6, 0); +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_158 = x_152; + x_151 = x_30; } -lean_ctor_set(x_158, 0, x_147); -lean_ctor_set(x_158, 1, x_148); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_149); -lean_ctor_set(x_158, 4, x_150); -lean_ctor_set(x_158, 5, x_151); -if (lean_is_scalar(x_146)) { - x_159 = lean_alloc_ctor(1, 2, 0); -} else { - x_159 = x_146; +lean_ctor_set(x_151, 0, x_138); +lean_ctor_set(x_151, 1, x_150); +return x_151; } -lean_ctor_set(x_159, 0, x_145); -lean_ctor_set(x_159, 1, x_158); -return x_159; } } } 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; 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_160 = lean_ctor_get(x_34, 0); -x_161 = lean_ctor_get(x_34, 1); -x_162 = lean_ctor_get(x_34, 2); -x_163 = lean_ctor_get(x_34, 3); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_dec(x_34); -x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_165 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_165, 0, x_160); -lean_ctor_set(x_165, 1, x_161); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_163); -lean_ctor_set(x_29, 2, x_165); -x_166 = lean_ctor_get(x_4, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_4, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_4, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_4, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_4, 4); -lean_inc(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_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); 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_171 = x_4; + x_223 = x_4; } else { lean_dec_ref(x_4); - x_171 = lean_box(0); + x_223 = lean_box(0); } -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_30); -lean_ctor_set(x_172, 1, x_18); -x_173 = lean_array_push(x_168, x_172); -if (lean_is_scalar(x_171)) { - x_174 = lean_alloc_ctor(0, 5, 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_226 = lean_alloc_ctor(0, 5, 0); } else { - x_174 = x_171; + x_226 = x_223; } -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_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_174, x_29); -if (lean_obj_tag(x_175) == 0) +lean_ctor_set(x_226, 0, x_218); +lean_ctor_set(x_226, 1, x_219); +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_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; -x_176 = lean_ctor_get(x_175, 1); -lean_inc(x_176); -x_177 = lean_ctor_get(x_176, 2); -lean_inc(x_177); -x_178 = lean_ctor_get(x_175, 0); -lean_inc(x_178); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_179 = x_175; -} else { - lean_dec_ref(x_175); - x_179 = lean_box(0); -} -x_180 = lean_ctor_get(x_176, 0); -lean_inc(x_180); -x_181 = lean_ctor_get(x_176, 1); -lean_inc(x_181); -x_182 = lean_ctor_get(x_176, 3); -lean_inc(x_182); -x_183 = lean_ctor_get(x_176, 4); -lean_inc(x_183); -x_184 = lean_ctor_get(x_176, 5); -lean_inc(x_184); -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); - lean_ctor_release(x_176, 4); - lean_ctor_release(x_176, 5); - x_185 = x_176; -} else { - lean_dec_ref(x_176); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_177, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_177, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_177, 3); -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); - 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, 4, 0); -} else { - x_190 = x_189; -} -lean_ctor_set(x_190, 0, x_186); -lean_ctor_set(x_190, 1, x_187); -lean_ctor_set(x_190, 2, x_162); -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); -if (lean_is_scalar(x_179)) { - x_192 = lean_alloc_ctor(0, 2, 0); -} else { - x_192 = x_179; -} -lean_ctor_set(x_192, 0, x_178); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_object* x_228; lean_object* x_229; lean_object* x_230; +x_228 = lean_ctor_get(x_227, 0); +lean_inc(x_228); +x_229 = lean_ctor_get(x_227, 1); +lean_inc(x_229); +lean_dec(x_227); +x_230 = lean_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_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; -x_193 = lean_ctor_get(x_175, 1); +lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_231 = lean_ctor_get(x_227, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_227, 1); +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; +} +block_214: +{ +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_193, 2); +x_194 = lean_ctor_get(x_184, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_175, 0); -lean_inc(x_195); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_196 = 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); + x_195 = x_184; } else { - lean_dec_ref(x_175); - x_196 = lean_box(0); + lean_dec_ref(x_184); + x_195 = lean_box(0); } -x_197 = lean_ctor_get(x_193, 0); -lean_inc(x_197); -x_198 = lean_ctor_get(x_193, 1); -lean_inc(x_198); -x_199 = lean_ctor_get(x_193, 3); +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; +} +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_193, 4); +x_200 = lean_ctor_get(x_182, 0); lean_inc(x_200); -x_201 = lean_ctor_get(x_193, 5); +lean_dec(x_182); +x_201 = lean_ctor_get(x_183, 0); lean_inc(x_201); -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_202 = x_193; -} else { - lean_dec_ref(x_193); - x_202 = lean_box(0); -} -x_203 = lean_ctor_get(x_194, 0); +x_202 = lean_ctor_get(x_183, 1); +lean_inc(x_202); +x_203 = lean_ctor_get(x_183, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_194, 1); +x_204 = lean_ctor_get(x_183, 4); lean_inc(x_204); -x_205 = lean_ctor_get(x_194, 3); +x_205 = lean_ctor_get(x_183, 5); lean_inc(x_205); -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_206 = x_194; +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; } else { - lean_dec_ref(x_194); + lean_dec_ref(x_183); x_206 = 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; +} else { + lean_dec_ref(x_199); + x_210 = lean_box(0); +} +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 4, 0); +} else { + x_211 = x_210; +} +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_207 = lean_alloc_ctor(0, 4, 0); + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_212 = x_206; } -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); +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); +if (lean_is_scalar(x_30)) { + x_213 = lean_alloc_ctor(0, 2, 0); } else { - x_208 = x_202; + x_213 = x_30; } -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(1, 2, 0); -} else { - x_209 = x_196; +lean_ctor_set(x_213, 0, x_200); +lean_ctor_set(x_213, 1, x_212); +return x_213; } -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; 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_210 = lean_ctor_get(x_29, 2); -x_211 = lean_ctor_get(x_29, 0); -x_212 = lean_ctor_get(x_29, 1); -x_213 = lean_ctor_get(x_29, 3); -x_214 = lean_ctor_get(x_29, 4); -x_215 = lean_ctor_get(x_29, 5); -lean_inc(x_215); -lean_inc(x_214); -lean_inc(x_213); -lean_inc(x_210); -lean_inc(x_212); -lean_inc(x_211); -lean_dec(x_29); -x_216 = lean_ctor_get(x_210, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_210, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_210, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_210, 3); -lean_inc(x_219); -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_220 = x_210; -} else { - lean_dec_ref(x_210); - x_220 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_220)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_220; -} -lean_ctor_set(x_222, 0, x_216); -lean_ctor_set(x_222, 1, x_217); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_219); -x_223 = lean_alloc_ctor(0, 6, 0); -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); -x_224 = lean_ctor_get(x_4, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_4, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_4, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_4, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_4, 4); -lean_inc(x_228); -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_229 = x_4; -} else { - lean_dec_ref(x_4); - x_229 = lean_box(0); -} -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_30); -lean_ctor_set(x_230, 1, x_18); -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_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -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; -x_234 = lean_ctor_get(x_233, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_233, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_237 = x_233; -} else { - lean_dec_ref(x_233); - x_237 = lean_box(0); -} -x_238 = lean_ctor_get(x_234, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_234, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_234, 3); -lean_inc(x_240); -x_241 = lean_ctor_get(x_234, 4); -lean_inc(x_241); -x_242 = lean_ctor_get(x_234, 5); -lean_inc(x_242); -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_243 = x_234; -} else { - lean_dec_ref(x_234); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_235, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_235, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_235, 3); -lean_inc(x_246); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - lean_ctor_release(x_235, 3); - x_247 = x_235; -} else { - lean_dec_ref(x_235); - x_247 = lean_box(0); -} -if (lean_is_scalar(x_247)) { - x_248 = lean_alloc_ctor(0, 4, 0); -} else { - x_248 = x_247; -} -lean_ctor_set(x_248, 0, x_244); -lean_ctor_set(x_248, 1, x_245); -lean_ctor_set(x_248, 2, x_218); -lean_ctor_set(x_248, 3, x_246); -if (lean_is_scalar(x_243)) { - x_249 = lean_alloc_ctor(0, 6, 0); -} else { - x_249 = x_243; -} -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, 2, 0); -} else { - x_250 = x_237; -} -lean_ctor_set(x_250, 0, x_236); -lean_ctor_set(x_250, 1, x_249); -return x_250; -} -else -{ -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_251 = lean_ctor_get(x_233, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_251, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_233, 0); -lean_inc(x_253); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_254 = x_233; -} else { - lean_dec_ref(x_233); - x_254 = lean_box(0); -} -x_255 = lean_ctor_get(x_251, 0); -lean_inc(x_255); -x_256 = lean_ctor_get(x_251, 1); -lean_inc(x_256); -x_257 = lean_ctor_get(x_251, 3); -lean_inc(x_257); -x_258 = lean_ctor_get(x_251, 4); -lean_inc(x_258); -x_259 = lean_ctor_get(x_251, 5); -lean_inc(x_259); -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_260 = x_251; -} else { - lean_dec_ref(x_251); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_252, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_252, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_252, 3); -lean_inc(x_263); -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_264 = x_252; -} else { - lean_dec_ref(x_252); - 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_ctor_set(x_265, 0, x_261); -lean_ctor_set(x_265, 1, x_262); -lean_ctor_set(x_265, 2, x_218); -lean_ctor_set(x_265, 3, x_263); -if (lean_is_scalar(x_260)) { - x_266 = lean_alloc_ctor(0, 6, 0); -} else { - x_266 = x_260; -} -lean_ctor_set(x_266, 0, x_255); -lean_ctor_set(x_266, 1, x_256); -lean_ctor_set(x_266, 2, x_265); -lean_ctor_set(x_266, 3, x_257); -lean_ctor_set(x_266, 4, x_258); -lean_ctor_set(x_266, 5, x_259); -if (lean_is_scalar(x_254)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_254; -} -lean_ctor_set(x_267, 0, x_253); -lean_ctor_set(x_267, 1, x_266); -return x_267; } } } default: { -lean_object* x_268; lean_object* x_269; -x_268 = lean_ctor_get(x_23, 1); -lean_inc(x_268); +lean_object* x_234; lean_object* x_235; +x_234 = lean_ctor_get(x_23, 1); +lean_inc(x_234); lean_dec(x_23); lean_inc(x_4); -x_269 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_268); -if (lean_obj_tag(x_269) == 0) +x_235 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_234); +if (lean_obj_tag(x_235) == 0) { -lean_object* x_270; -x_270 = lean_ctor_get(x_269, 0); -lean_inc(x_270); -if (lean_obj_tag(x_270) == 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_271; lean_object* x_272; lean_object* x_273; +lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_dec(x_18); -x_271 = lean_ctor_get(x_269, 1); -lean_inc(x_271); -lean_dec(x_269); -x_272 = lean_unsigned_to_nat(1u); -x_273 = lean_nat_add(x_3, x_272); +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); lean_dec(x_3); -x_3 = x_273; -x_5 = x_271; +x_3 = x_239; +x_5 = x_237; goto _start; } else { -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_275 = lean_ctor_get(x_269, 1); -lean_inc(x_275); -lean_dec(x_269); -x_276 = lean_ctor_get(x_270, 0); -lean_inc(x_276); -lean_dec(x_270); -x_277 = lean_unsigned_to_nat(1u); -x_278 = lean_nat_add(x_3, x_277); +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; +} else { + lean_dec_ref(x_235); + x_242 = 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_279 = !lean_is_exclusive(x_275); -if (x_279 == 0) +x_246 = !lean_is_exclusive(x_241); +if (x_246 == 0) { -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_275, 2); -x_281 = !lean_is_exclusive(x_280); -if (x_281 == 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_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_280, 2); -x_283 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_280, 2, x_283); -x_284 = !lean_is_exclusive(x_4); -if (x_284 == 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_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_285 = lean_ctor_get(x_4, 2); -x_286 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_286, 0, x_276); -lean_ctor_set(x_286, 1, x_18); -x_287 = lean_array_push(x_285, x_286); -lean_ctor_set(x_4, 2, x_287); -x_288 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_278, x_4, x_275); -if (lean_obj_tag(x_288) == 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_289; lean_object* x_290; uint8_t x_291; -x_289 = lean_ctor_get(x_288, 1); -lean_inc(x_289); -x_290 = lean_ctor_get(x_289, 2); -lean_inc(x_290); -x_291 = !lean_is_exclusive(x_288); -if (x_291 == 0) -{ -lean_object* x_292; uint8_t x_293; -x_292 = lean_ctor_get(x_288, 1); -lean_dec(x_292); -x_293 = !lean_is_exclusive(x_289); -if (x_293 == 0) -{ -lean_object* x_294; uint8_t x_295; -x_294 = lean_ctor_get(x_289, 2); -lean_dec(x_294); -x_295 = !lean_is_exclusive(x_290); -if (x_295 == 0) -{ -lean_object* x_296; -x_296 = lean_ctor_get(x_290, 2); -lean_dec(x_296); -lean_ctor_set(x_290, 2, x_282); -return x_288; -} -else -{ -lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; -x_297 = lean_ctor_get(x_290, 0); -x_298 = lean_ctor_get(x_290, 1); -x_299 = lean_ctor_get(x_290, 3); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_290); -x_300 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_282); -lean_ctor_set(x_300, 3, x_299); -lean_ctor_set(x_289, 2, x_300); -return x_288; -} -} -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; -x_301 = lean_ctor_get(x_289, 0); -x_302 = lean_ctor_get(x_289, 1); -x_303 = lean_ctor_get(x_289, 3); -x_304 = lean_ctor_get(x_289, 4); -x_305 = lean_ctor_get(x_289, 5); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_inc(x_302); -lean_inc(x_301); -lean_dec(x_289); -x_306 = lean_ctor_get(x_290, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_290, 1); +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_290, 3); +x_308 = lean_ctor_get(x_306, 1); lean_inc(x_308); -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); - x_309 = x_290; -} else { - lean_dec_ref(x_290); - x_309 = lean_box(0); +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; } -if (lean_is_scalar(x_309)) { - x_310 = lean_alloc_ctor(0, 4, 0); -} else { - x_310 = x_309; -} -lean_ctor_set(x_310, 0, x_306); -lean_ctor_set(x_310, 1, x_307); -lean_ctor_set(x_310, 2, x_282); -lean_ctor_set(x_310, 3, x_308); -x_311 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_311, 0, x_301); -lean_ctor_set(x_311, 1, x_302); -lean_ctor_set(x_311, 2, x_310); -lean_ctor_set(x_311, 3, x_303); -lean_ctor_set(x_311, 4, x_304); -lean_ctor_set(x_311, 5, x_305); -lean_ctor_set(x_288, 1, x_311); -return x_288; +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_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_312 = lean_ctor_get(x_288, 0); -lean_inc(x_312); -lean_dec(x_288); -x_313 = lean_ctor_get(x_289, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_289, 1); -lean_inc(x_314); -x_315 = lean_ctor_get(x_289, 3); -lean_inc(x_315); -x_316 = lean_ctor_get(x_289, 4); -lean_inc(x_316); -x_317 = lean_ctor_get(x_289, 5); +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); -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); - lean_ctor_release(x_289, 5); - x_318 = x_289; -} else { - lean_dec_ref(x_289); - x_318 = lean_box(0); -} -x_319 = lean_ctor_get(x_290, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_290, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_290, 3); -lean_inc(x_321); -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); - x_322 = x_290; -} else { - lean_dec_ref(x_290); - x_322 = lean_box(0); -} -if (lean_is_scalar(x_322)) { - x_323 = lean_alloc_ctor(0, 4, 0); -} else { - x_323 = x_322; -} -lean_ctor_set(x_323, 0, x_319); -lean_ctor_set(x_323, 1, x_320); -lean_ctor_set(x_323, 2, x_282); -lean_ctor_set(x_323, 3, x_321); -if (lean_is_scalar(x_318)) { - x_324 = lean_alloc_ctor(0, 6, 0); -} else { - x_324 = x_318; -} -lean_ctor_set(x_324, 0, x_313); -lean_ctor_set(x_324, 1, x_314); -lean_ctor_set(x_324, 2, x_323); -lean_ctor_set(x_324, 3, x_315); -lean_ctor_set(x_324, 4, x_316); -lean_ctor_set(x_324, 5, x_317); -x_325 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_325, 0, x_312); -lean_ctor_set(x_325, 1, x_324); -return x_325; -} -} -else -{ -lean_object* x_326; lean_object* x_327; uint8_t x_328; -x_326 = lean_ctor_get(x_288, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_326, 2); -lean_inc(x_327); -x_328 = !lean_is_exclusive(x_288); -if (x_328 == 0) -{ -lean_object* x_329; uint8_t x_330; -x_329 = lean_ctor_get(x_288, 1); -lean_dec(x_329); -x_330 = !lean_is_exclusive(x_326); -if (x_330 == 0) -{ -lean_object* x_331; uint8_t x_332; -x_331 = lean_ctor_get(x_326, 2); -lean_dec(x_331); -x_332 = !lean_is_exclusive(x_327); -if (x_332 == 0) -{ -lean_object* x_333; -x_333 = lean_ctor_get(x_327, 2); -lean_dec(x_333); -lean_ctor_set(x_327, 2, x_282); -return x_288; -} -else -{ -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; -x_334 = lean_ctor_get(x_327, 0); -x_335 = lean_ctor_get(x_327, 1); -x_336 = lean_ctor_get(x_327, 3); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_327); -x_337 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_337, 0, x_334); -lean_ctor_set(x_337, 1, x_335); -lean_ctor_set(x_337, 2, x_282); -lean_ctor_set(x_337, 3, x_336); -lean_ctor_set(x_326, 2, x_337); -return x_288; -} -} -else -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; -x_338 = lean_ctor_get(x_326, 0); -x_339 = lean_ctor_get(x_326, 1); -x_340 = lean_ctor_get(x_326, 3); -x_341 = lean_ctor_get(x_326, 4); -x_342 = lean_ctor_get(x_326, 5); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_dec(x_326); -x_343 = lean_ctor_get(x_327, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_327, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_327, 3); -lean_inc(x_345); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - x_346 = x_327; -} else { - lean_dec_ref(x_327); - 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_282); -lean_ctor_set(x_347, 3, x_345); -x_348 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_348, 0, x_338); -lean_ctor_set(x_348, 1, x_339); -lean_ctor_set(x_348, 2, x_347); -lean_ctor_set(x_348, 3, x_340); -lean_ctor_set(x_348, 4, x_341); -lean_ctor_set(x_348, 5, x_342); -lean_ctor_set(x_288, 1, x_348); -return x_288; -} -} -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; -x_349 = lean_ctor_get(x_288, 0); -lean_inc(x_349); -lean_dec(x_288); -x_350 = lean_ctor_get(x_326, 0); -lean_inc(x_350); -x_351 = lean_ctor_get(x_326, 1); -lean_inc(x_351); -x_352 = lean_ctor_get(x_326, 3); -lean_inc(x_352); -x_353 = lean_ctor_get(x_326, 4); -lean_inc(x_353); -x_354 = lean_ctor_get(x_326, 5); -lean_inc(x_354); -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); - x_355 = x_326; -} else { - lean_dec_ref(x_326); - x_355 = lean_box(0); -} -x_356 = lean_ctor_get(x_327, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_327, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_327, 3); -lean_inc(x_358); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - x_359 = x_327; -} else { - lean_dec_ref(x_327); - x_359 = lean_box(0); -} -if (lean_is_scalar(x_359)) { - x_360 = lean_alloc_ctor(0, 4, 0); -} else { - x_360 = x_359; -} -lean_ctor_set(x_360, 0, x_356); -lean_ctor_set(x_360, 1, x_357); -lean_ctor_set(x_360, 2, x_282); -lean_ctor_set(x_360, 3, x_358); -if (lean_is_scalar(x_355)) { - x_361 = lean_alloc_ctor(0, 6, 0); -} else { - x_361 = x_355; -} -lean_ctor_set(x_361, 0, x_350); -lean_ctor_set(x_361, 1, x_351); -lean_ctor_set(x_361, 2, x_360); -lean_ctor_set(x_361, 3, x_352); -lean_ctor_set(x_361, 4, x_353); -lean_ctor_set(x_361, 5, x_354); -x_362 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_362, 0, x_349); -lean_ctor_set(x_362, 1, x_361); -return x_362; -} -} -} -else -{ -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_363 = lean_ctor_get(x_4, 0); -x_364 = lean_ctor_get(x_4, 1); -x_365 = lean_ctor_get(x_4, 2); -x_366 = lean_ctor_get(x_4, 3); -x_367 = lean_ctor_get(x_4, 4); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); -lean_inc(x_364); -lean_inc(x_363); +lean_inc(x_316); +lean_inc(x_315); +lean_inc(x_314); +lean_inc(x_313); lean_dec(x_4); -x_368 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_368, 0, x_276); -lean_ctor_set(x_368, 1, x_18); -x_369 = lean_array_push(x_365, x_368); -x_370 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_370, 0, x_363); -lean_ctor_set(x_370, 1, x_364); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_366); -lean_ctor_set(x_370, 4, x_367); -x_371 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_278, x_370, x_275); -if (lean_obj_tag(x_371) == 0) +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_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; lean_object* x_387; lean_object* x_388; -x_372 = lean_ctor_get(x_371, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_372, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_371, 0); -lean_inc(x_374); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - x_375 = x_371; -} else { - lean_dec_ref(x_371); - x_375 = lean_box(0); -} -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_372, 3); -lean_inc(x_378); -x_379 = lean_ctor_get(x_372, 4); -lean_inc(x_379); -x_380 = lean_ctor_get(x_372, 5); -lean_inc(x_380); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - lean_ctor_release(x_372, 2); - lean_ctor_release(x_372, 3); - lean_ctor_release(x_372, 4); - lean_ctor_release(x_372, 5); - x_381 = x_372; -} else { - lean_dec_ref(x_372); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_373, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_373, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_373, 3); -lean_inc(x_384); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - lean_ctor_release(x_373, 3); - x_385 = x_373; -} else { - lean_dec_ref(x_373); - x_385 = lean_box(0); -} -if (lean_is_scalar(x_385)) { - x_386 = lean_alloc_ctor(0, 4, 0); -} else { - x_386 = x_385; -} -lean_ctor_set(x_386, 0, x_382); -lean_ctor_set(x_386, 1, x_383); -lean_ctor_set(x_386, 2, x_282); -lean_ctor_set(x_386, 3, x_384); -if (lean_is_scalar(x_381)) { - x_387 = lean_alloc_ctor(0, 6, 0); -} else { - x_387 = x_381; -} -lean_ctor_set(x_387, 0, x_376); -lean_ctor_set(x_387, 1, x_377); -lean_ctor_set(x_387, 2, x_386); -lean_ctor_set(x_387, 3, x_378); -lean_ctor_set(x_387, 4, x_379); -lean_ctor_set(x_387, 5, x_380); -if (lean_is_scalar(x_375)) { - x_388 = lean_alloc_ctor(0, 2, 0); -} else { - x_388 = x_375; -} -lean_ctor_set(x_388, 0, x_374); -lean_ctor_set(x_388, 1, x_387); -return x_388; +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_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; lean_object* x_403; lean_object* x_404; lean_object* x_405; -x_389 = lean_ctor_get(x_371, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_389, 2); -lean_inc(x_390); -x_391 = lean_ctor_get(x_371, 0); -lean_inc(x_391); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - x_392 = x_371; -} else { - lean_dec_ref(x_371); - x_392 = lean_box(0); +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; } -x_393 = lean_ctor_get(x_389, 0); -lean_inc(x_393); -x_394 = lean_ctor_get(x_389, 1); -lean_inc(x_394); -x_395 = lean_ctor_get(x_389, 3); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 4); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 5); -lean_inc(x_397); -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); - lean_ctor_release(x_389, 4); - lean_ctor_release(x_389, 5); - x_398 = x_389; -} else { - lean_dec_ref(x_389); - x_398 = lean_box(0); } -x_399 = lean_ctor_get(x_390, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_390, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_390, 3); -lean_inc(x_401); -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); - x_402 = x_390; +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); +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); +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 { - lean_dec_ref(x_390); - x_402 = lean_box(0); + x_258 = x_242; + lean_ctor_set_tag(x_258, 1); } -if (lean_is_scalar(x_402)) { - x_403 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_258, 0, x_253); +lean_ctor_set(x_258, 1, x_251); +return x_258; +} +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_403 = x_402; + x_263 = x_242; + lean_ctor_set_tag(x_263, 1); } -lean_ctor_set(x_403, 0, x_399); -lean_ctor_set(x_403, 1, x_400); -lean_ctor_set(x_403, 2, x_282); -lean_ctor_set(x_403, 3, x_401); -if (lean_is_scalar(x_398)) { - x_404 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_263, 0, x_253); +lean_ctor_set(x_263, 1, x_251); +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; 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_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 { - x_404 = x_398; + lean_dec_ref(x_252); + x_272 = lean_box(0); } -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_392)) { - x_405 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_272)) { + x_273 = lean_alloc_ctor(0, 4, 0); } else { - x_405 = x_392; + x_273 = x_272; +} +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, 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); +} else { + x_275 = x_242; + lean_ctor_set_tag(x_275, 1); +} +lean_ctor_set(x_275, 0, x_253); +lean_ctor_set(x_275, 1, x_274); +return x_275; +} +} +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_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_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); +} else { + x_287 = x_242; +} +lean_ctor_set(x_287, 0, x_277); +lean_ctor_set(x_287, 1, x_251); +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_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); +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; +} else { + lean_dec_ref(x_276); + x_296 = lean_box(0); +} +if (lean_is_scalar(x_296)) { + x_297 = lean_alloc_ctor(0, 4, 0); +} else { + x_297 = x_296; +} +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); +} else { + x_299 = x_242; +} +lean_ctor_set(x_299, 0, x_277); +lean_ctor_set(x_299, 1, x_298); +return x_299; } -lean_ctor_set(x_405, 0, x_391); -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; lean_object* x_421; -x_406 = lean_ctor_get(x_280, 0); -x_407 = lean_ctor_get(x_280, 1); -x_408 = lean_ctor_get(x_280, 2); -x_409 = lean_ctor_get(x_280, 3); -lean_inc(x_409); -lean_inc(x_408); -lean_inc(x_407); -lean_inc(x_406); -lean_dec(x_280); -x_410 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_411 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_411, 0, x_406); -lean_ctor_set(x_411, 1, x_407); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_409); -lean_ctor_set(x_275, 2, x_411); -x_412 = lean_ctor_get(x_4, 0); -lean_inc(x_412); -x_413 = lean_ctor_get(x_4, 1); -lean_inc(x_413); -x_414 = lean_ctor_get(x_4, 2); -lean_inc(x_414); -x_415 = lean_ctor_get(x_4, 3); -lean_inc(x_415); -x_416 = lean_ctor_get(x_4, 4); -lean_inc(x_416); +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); 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_417 = x_4; + x_372 = x_4; } else { lean_dec_ref(x_4); - x_417 = lean_box(0); + x_372 = lean_box(0); } -x_418 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_418, 0, x_276); -lean_ctor_set(x_418, 1, x_18); -x_419 = lean_array_push(x_414, x_418); -if (lean_is_scalar(x_417)) { - x_420 = lean_alloc_ctor(0, 5, 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); } else { - x_420 = x_417; + x_375 = x_372; } -lean_ctor_set(x_420, 0, x_412); -lean_ctor_set(x_420, 1, x_413); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_415); -lean_ctor_set(x_420, 4, x_416); -x_421 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_278, x_420, x_275); -if (lean_obj_tag(x_421) == 0) +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_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; lean_object* x_438; -x_422 = lean_ctor_get(x_421, 1); -lean_inc(x_422); -x_423 = lean_ctor_get(x_422, 2); -lean_inc(x_423); -x_424 = lean_ctor_get(x_421, 0); -lean_inc(x_424); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - x_425 = x_421; -} else { - lean_dec_ref(x_421); - x_425 = lean_box(0); -} -x_426 = lean_ctor_get(x_422, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_422, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_422, 3); -lean_inc(x_428); -x_429 = lean_ctor_get(x_422, 4); -lean_inc(x_429); -x_430 = lean_ctor_get(x_422, 5); -lean_inc(x_430); -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_431 = x_422; -} else { - lean_dec_ref(x_422); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_423, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_423, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_423, 3); -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); - x_435 = x_423; -} else { - lean_dec_ref(x_423); - x_435 = lean_box(0); -} -if (lean_is_scalar(x_435)) { - x_436 = lean_alloc_ctor(0, 4, 0); -} else { - x_436 = x_435; -} -lean_ctor_set(x_436, 0, x_432); -lean_ctor_set(x_436, 1, x_433); -lean_ctor_set(x_436, 2, x_408); -lean_ctor_set(x_436, 3, x_434); -if (lean_is_scalar(x_431)) { - x_437 = lean_alloc_ctor(0, 6, 0); -} else { - x_437 = x_431; -} -lean_ctor_set(x_437, 0, x_426); -lean_ctor_set(x_437, 1, x_427); -lean_ctor_set(x_437, 2, x_436); -lean_ctor_set(x_437, 3, x_428); -lean_ctor_set(x_437, 4, x_429); -lean_ctor_set(x_437, 5, x_430); -if (lean_is_scalar(x_425)) { - x_438 = lean_alloc_ctor(0, 2, 0); -} else { - x_438 = x_425; -} -lean_ctor_set(x_438, 0, x_424); -lean_ctor_set(x_438, 1, x_437); -return x_438; +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; } 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; lean_object* x_455; -x_439 = lean_ctor_get(x_421, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_439, 2); -lean_inc(x_440); -x_441 = lean_ctor_get(x_421, 0); -lean_inc(x_441); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - x_442 = x_421; -} else { - lean_dec_ref(x_421); - x_442 = lean_box(0); +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; } +block_364: +{ +if (lean_obj_tag(x_332) == 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_inc(x_349); +x_350 = lean_ctor_get(x_332, 0); +lean_inc(x_350); +lean_dec(x_332); +x_351 = lean_ctor_get(x_333, 0); +lean_inc(x_351); +x_352 = lean_ctor_get(x_333, 1); +lean_inc(x_352); +x_353 = lean_ctor_get(x_333, 3); +lean_inc(x_353); +x_354 = lean_ctor_get(x_333, 4); +lean_inc(x_354); +x_355 = lean_ctor_get(x_333, 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; +} else { + lean_dec_ref(x_333); + x_356 = lean_box(0); +} +x_357 = lean_ctor_get(x_349, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_349, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_349, 3); +lean_inc(x_359); +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; +} else { + lean_dec_ref(x_349); + x_360 = lean_box(0); +} +if (lean_is_scalar(x_360)) { + x_361 = lean_alloc_ctor(0, 4, 0); +} else { + x_361 = x_360; +} +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); +if (lean_is_scalar(x_356)) { + x_362 = lean_alloc_ctor(0, 6, 0); +} else { + x_362 = 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); +} else { + x_363 = x_242; +} +lean_ctor_set(x_363, 0, x_350); +lean_ctor_set(x_363, 1, x_362); +return x_363; +} +} +} +} +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; +} else { + lean_dec_ref(x_383); + x_393 = 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); +} else { + x_428 = x_393; +} +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); +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; +} else { + lean_dec_ref(x_4); + x_435 = 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); +} else { + x_438 = x_435; +} +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_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; +} +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); -x_445 = lean_ctor_get(x_439, 3); -lean_inc(x_445); -x_446 = lean_ctor_get(x_439, 4); -lean_inc(x_446); -x_447 = lean_ctor_get(x_439, 5); -lean_inc(x_447); -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); - lean_ctor_release(x_439, 5); - x_448 = x_439; +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; +} +block_426: +{ +if (lean_obj_tag(x_394) == 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_439); - x_448 = lean_box(0); + lean_dec_ref(x_395); + x_403 = lean_box(0); } -x_449 = lean_ctor_get(x_440, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_440, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_440, 3); -lean_inc(x_451); -if (lean_is_exclusive(x_440)) { - lean_ctor_release(x_440, 0); - lean_ctor_release(x_440, 1); - lean_ctor_release(x_440, 2); - lean_ctor_release(x_440, 3); - x_452 = x_440; +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_440); - x_452 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -if (lean_is_scalar(x_452)) { - x_453 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_407)) { + x_408 = lean_alloc_ctor(0, 4, 0); } else { - x_453 = x_452; + x_408 = x_407; } -lean_ctor_set(x_453, 0, x_449); -lean_ctor_set(x_453, 1, x_450); -lean_ctor_set(x_453, 2, x_408); -lean_ctor_set(x_453, 3, x_451); -if (lean_is_scalar(x_448)) { - x_454 = lean_alloc_ctor(0, 6, 0); +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_454 = x_448; + x_409 = x_403; } -lean_ctor_set(x_454, 0, x_443); -lean_ctor_set(x_454, 1, x_444); -lean_ctor_set(x_454, 2, x_453); -lean_ctor_set(x_454, 3, x_445); -lean_ctor_set(x_454, 4, x_446); -lean_ctor_set(x_454, 5, x_447); -if (lean_is_scalar(x_442)) { - x_455 = lean_alloc_ctor(1, 2, 0); +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_455 = x_442; -} -lean_ctor_set(x_455, 0, x_441); -lean_ctor_set(x_455, 1, x_454); -return x_455; -} + 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_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; 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; -x_456 = lean_ctor_get(x_275, 2); -x_457 = lean_ctor_get(x_275, 0); -x_458 = lean_ctor_get(x_275, 1); -x_459 = lean_ctor_get(x_275, 3); -x_460 = lean_ctor_get(x_275, 4); -x_461 = lean_ctor_get(x_275, 5); -lean_inc(x_461); -lean_inc(x_460); -lean_inc(x_459); -lean_inc(x_456); -lean_inc(x_458); -lean_inc(x_457); -lean_dec(x_275); -x_462 = lean_ctor_get(x_456, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_456, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_456, 2); -lean_inc(x_464); -x_465 = lean_ctor_get(x_456, 3); -lean_inc(x_465); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - lean_ctor_release(x_456, 2); - lean_ctor_release(x_456, 3); - x_466 = x_456; +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_inc(x_414); +x_415 = lean_ctor_get(x_395, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_395, 4); +lean_inc(x_416); +x_417 = lean_ctor_get(x_395, 5); +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_456); - x_466 = lean_box(0); + lean_dec_ref(x_395); + x_418 = lean_box(0); } -x_467 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_466)) { - x_468 = 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); +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; } else { - x_468 = x_466; + lean_dec_ref(x_411); + x_422 = lean_box(0); } -lean_ctor_set(x_468, 0, x_462); -lean_ctor_set(x_468, 1, x_463); -lean_ctor_set(x_468, 2, x_467); -lean_ctor_set(x_468, 3, x_465); -x_469 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_469, 0, x_457); -lean_ctor_set(x_469, 1, x_458); -lean_ctor_set(x_469, 2, x_468); -lean_ctor_set(x_469, 3, x_459); -lean_ctor_set(x_469, 4, x_460); -lean_ctor_set(x_469, 5, x_461); -x_470 = lean_ctor_get(x_4, 0); -lean_inc(x_470); -x_471 = lean_ctor_get(x_4, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_4, 2); -lean_inc(x_472); -x_473 = lean_ctor_get(x_4, 3); -lean_inc(x_473); -x_474 = lean_ctor_get(x_4, 4); -lean_inc(x_474); -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_475 = x_4; +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_4); - x_475 = lean_box(0); + x_423 = x_422; } -x_476 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_476, 0, x_276); -lean_ctor_set(x_476, 1, x_18); -x_477 = lean_array_push(x_472, x_476); -if (lean_is_scalar(x_475)) { - x_478 = lean_alloc_ctor(0, 5, 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); } else { - x_478 = x_475; + x_424 = x_418; } -lean_ctor_set(x_478, 0, x_470); -lean_ctor_set(x_478, 1, x_471); -lean_ctor_set(x_478, 2, x_477); -lean_ctor_set(x_478, 3, x_473); -lean_ctor_set(x_478, 4, x_474); -x_479 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_278, x_478, x_469); -if (lean_obj_tag(x_479) == 0) -{ -lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; -x_480 = lean_ctor_get(x_479, 1); -lean_inc(x_480); -x_481 = lean_ctor_get(x_480, 2); -lean_inc(x_481); -x_482 = lean_ctor_get(x_479, 0); -lean_inc(x_482); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - x_483 = x_479; +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); } else { - lean_dec_ref(x_479); - x_483 = lean_box(0); + x_425 = x_242; } -x_484 = lean_ctor_get(x_480, 0); -lean_inc(x_484); -x_485 = lean_ctor_get(x_480, 1); -lean_inc(x_485); -x_486 = lean_ctor_get(x_480, 3); -lean_inc(x_486); -x_487 = lean_ctor_get(x_480, 4); -lean_inc(x_487); -x_488 = lean_ctor_get(x_480, 5); -lean_inc(x_488); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - lean_ctor_release(x_480, 2); - lean_ctor_release(x_480, 3); - lean_ctor_release(x_480, 4); - lean_ctor_release(x_480, 5); - x_489 = x_480; -} else { - lean_dec_ref(x_480); - x_489 = lean_box(0); +lean_ctor_set(x_425, 0, x_412); +lean_ctor_set(x_425, 1, x_424); +return x_425; } -x_490 = lean_ctor_get(x_481, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_481, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_481, 3); -lean_inc(x_492); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - lean_ctor_release(x_481, 2); - lean_ctor_release(x_481, 3); - x_493 = x_481; -} else { - lean_dec_ref(x_481); - x_493 = lean_box(0); -} -if (lean_is_scalar(x_493)) { - x_494 = lean_alloc_ctor(0, 4, 0); -} else { - x_494 = x_493; -} -lean_ctor_set(x_494, 0, x_490); -lean_ctor_set(x_494, 1, x_491); -lean_ctor_set(x_494, 2, x_464); -lean_ctor_set(x_494, 3, x_492); -if (lean_is_scalar(x_489)) { - x_495 = lean_alloc_ctor(0, 6, 0); -} else { - x_495 = x_489; -} -lean_ctor_set(x_495, 0, x_484); -lean_ctor_set(x_495, 1, x_485); -lean_ctor_set(x_495, 2, x_494); -lean_ctor_set(x_495, 3, x_486); -lean_ctor_set(x_495, 4, x_487); -lean_ctor_set(x_495, 5, x_488); -if (lean_is_scalar(x_483)) { - x_496 = lean_alloc_ctor(0, 2, 0); -} else { - x_496 = x_483; -} -lean_ctor_set(x_496, 0, x_482); -lean_ctor_set(x_496, 1, x_495); -return x_496; -} -else -{ -lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_497 = lean_ctor_get(x_479, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_497, 2); -lean_inc(x_498); -x_499 = lean_ctor_get(x_479, 0); -lean_inc(x_499); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - x_500 = x_479; -} else { - lean_dec_ref(x_479); - x_500 = lean_box(0); -} -x_501 = lean_ctor_get(x_497, 0); -lean_inc(x_501); -x_502 = lean_ctor_get(x_497, 1); -lean_inc(x_502); -x_503 = lean_ctor_get(x_497, 3); -lean_inc(x_503); -x_504 = lean_ctor_get(x_497, 4); -lean_inc(x_504); -x_505 = lean_ctor_get(x_497, 5); -lean_inc(x_505); -if (lean_is_exclusive(x_497)) { - lean_ctor_release(x_497, 0); - lean_ctor_release(x_497, 1); - lean_ctor_release(x_497, 2); - lean_ctor_release(x_497, 3); - lean_ctor_release(x_497, 4); - lean_ctor_release(x_497, 5); - x_506 = x_497; -} else { - lean_dec_ref(x_497); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_498, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_498, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_498, 3); -lean_inc(x_509); -if (lean_is_exclusive(x_498)) { - lean_ctor_release(x_498, 0); - lean_ctor_release(x_498, 1); - lean_ctor_release(x_498, 2); - lean_ctor_release(x_498, 3); - x_510 = x_498; -} else { - lean_dec_ref(x_498); - x_510 = lean_box(0); -} -if (lean_is_scalar(x_510)) { - x_511 = lean_alloc_ctor(0, 4, 0); -} else { - x_511 = x_510; -} -lean_ctor_set(x_511, 0, x_507); -lean_ctor_set(x_511, 1, x_508); -lean_ctor_set(x_511, 2, x_464); -lean_ctor_set(x_511, 3, x_509); -if (lean_is_scalar(x_506)) { - x_512 = lean_alloc_ctor(0, 6, 0); -} else { - x_512 = x_506; -} -lean_ctor_set(x_512, 0, x_501); -lean_ctor_set(x_512, 1, x_502); -lean_ctor_set(x_512, 2, x_511); -lean_ctor_set(x_512, 3, x_503); -lean_ctor_set(x_512, 4, x_504); -lean_ctor_set(x_512, 5, x_505); -if (lean_is_scalar(x_500)) { - x_513 = lean_alloc_ctor(1, 2, 0); -} else { - x_513 = x_500; -} -lean_ctor_set(x_513, 0, x_499); -lean_ctor_set(x_513, 1, x_512); -return x_513; } } } } else { -uint8_t x_514; +uint8_t x_446; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_514 = !lean_is_exclusive(x_269); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_235); +if (x_446 == 0) { -return x_269; +return x_235; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_269, 0); -x_516 = lean_ctor_get(x_269, 1); -lean_inc(x_516); -lean_inc(x_515); -lean_dec(x_269); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } @@ -18355,54 +16590,54 @@ return x_517; } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_518 = !lean_is_exclusive(x_23); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_23); +if (x_450 == 0) { return x_23; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_23, 0); -x_520 = lean_ctor_get(x_23, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_23); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } else { -uint8_t x_522; +uint8_t x_454; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_522 = !lean_is_exclusive(x_19); -if (x_522 == 0) +x_454 = !lean_is_exclusive(x_19); +if (x_454 == 0) { return x_19; } else { -lean_object* x_523; lean_object* x_524; lean_object* x_525; -x_523 = lean_ctor_get(x_19, 0); -x_524 = lean_ctor_get(x_19, 1); -lean_inc(x_524); -lean_inc(x_523); +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_dec(x_19); -x_525 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_525, 0, x_523); -lean_ctor_set(x_525, 1, x_524); -return x_525; +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; } } } @@ -19021,2152 +17256,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -21174,58 +19047,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -21345,2130 +19218,1768 @@ goto _start; } case 1: { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_dec(x_24); x_31 = lean_ctor_get(x_25, 1); lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_32 = x_25; +} else { + lean_dec_ref(x_25); + x_32 = lean_box(0); +} +x_33 = lean_ctor_get(x_26, 0); +lean_inc(x_33); lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_11, x_34); lean_dec(x_11); -x_35 = !lean_is_exclusive(x_31); -if (x_35 == 0) +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_31, 2); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_31, 2); +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) { -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_36, 2); -x_39 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_39); -x_40 = !lean_is_exclusive(x_12); -if (x_40 == 0) +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +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) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_12, 2); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_32); -lean_ctor_set(x_42, 1, x_20); -x_43 = lean_array_push(x_41, x_42); -lean_ctor_set(x_12, 2, x_43); -x_44 = 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_34, x_12, x_31); -if (lean_obj_tag(x_44) == 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_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_44, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_45, 2); -lean_inc(x_46); -x_47 = !lean_is_exclusive(x_44); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_44, 1); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_45); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_45, 2); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_46); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_46, 2); -lean_dec(x_52); -lean_ctor_set(x_46, 2, x_38); -return x_44; +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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_53 = lean_ctor_get(x_46, 0); -x_54 = lean_ctor_get(x_46, 1); -x_55 = lean_ctor_get(x_46, 3); -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_38); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); -return x_44; +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_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; } } 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; -x_57 = lean_ctor_get(x_45, 0); -x_58 = lean_ctor_get(x_45, 1); -x_59 = lean_ctor_get(x_45, 3); -x_60 = lean_ctor_get(x_45, 4); -x_61 = lean_ctor_get(x_45, 5); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); +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_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; +} +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_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; +} +} +block_90: +{ +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 2); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 0); +lean_inc(x_43); +lean_dec(x_40); +x_44 = !lean_is_exclusive(x_41); +if (x_44 == 0) +{ +lean_object* x_45; uint8_t x_46; +x_45 = lean_ctor_get(x_41, 2); +lean_dec(x_45); +x_46 = !lean_is_exclusive(x_42); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_42, 2); +lean_dec(x_47); +lean_ctor_set(x_42, 2, x_39); +if (lean_is_scalar(x_32)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_32; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_41); +return x_48; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_49 = lean_ctor_get(x_42, 0); +x_50 = lean_ctor_get(x_42, 1); +x_51 = lean_ctor_get(x_42, 3); +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); +if (lean_is_scalar(x_32)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_32; + lean_ctor_set_tag(x_53, 1); +} +lean_ctor_set(x_53, 0, x_43); +lean_ctor_set(x_53, 1, x_41); +return x_53; +} +} +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_inc(x_58); lean_inc(x_57); -lean_dec(x_45); -x_62 = lean_ctor_get(x_46, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_46, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 3); -lean_inc(x_64); -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_65 = x_46; +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); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 3); +lean_inc(x_61); +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; } else { - lean_dec_ref(x_46); - x_65 = lean_box(0); + lean_dec_ref(x_42); + x_62 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_63 = x_62; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_38); -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); -lean_ctor_set(x_44, 1, x_67); -return x_44; +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); +if (lean_is_scalar(x_32)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_32; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_43); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } 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; lean_object* x_80; lean_object* x_81; -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -lean_dec(x_44); -x_69 = lean_ctor_get(x_45, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_45, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 5); -lean_inc(x_73); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_74 = x_45; +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_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); +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_39); +if (lean_is_scalar(x_32)) { + x_72 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_74 = lean_box(0); + x_72 = x_32; } -x_75 = lean_ctor_get(x_46, 0); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_41); +return x_72; +} +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_inc(x_75); -x_76 = lean_ctor_get(x_46, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_46, 3); -lean_inc(x_77); -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_78 = x_46; +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); +if (lean_is_scalar(x_32)) { + x_77 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_46); - x_78 = lean_box(0); + x_77 = x_32; } -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_38); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); -} else { - x_80 = x_74; -} -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, 2, 0); -lean_ctor_set(x_81, 0, x_68); -lean_ctor_set(x_81, 1, x_80); -return x_81; +lean_ctor_set(x_77, 0, x_67); +lean_ctor_set(x_77, 1, x_41); +return x_77; } } else { -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_44, 1); +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_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); +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_is_exclusive(x_44); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_44, 1); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_82, 2); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) -{ -lean_object* x_89; -x_89 = lean_ctor_get(x_83, 2); -lean_dec(x_89); -lean_ctor_set(x_83, 2, x_38); -return x_44; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_90 = lean_ctor_get(x_83, 0); -x_91 = lean_ctor_get(x_83, 1); -x_92 = lean_ctor_get(x_83, 3); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_83); -x_93 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_93, 0, x_90); -lean_ctor_set(x_93, 1, x_91); -lean_ctor_set(x_93, 2, x_38); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set(x_82, 2, x_93); -return x_44; -} -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_94 = lean_ctor_get(x_82, 0); -x_95 = lean_ctor_get(x_82, 1); -x_96 = lean_ctor_get(x_82, 3); -x_97 = lean_ctor_get(x_82, 4); -x_98 = lean_ctor_get(x_82, 5); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_82); -x_99 = lean_ctor_get(x_83, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_83, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_83, 3); -lean_inc(x_101); -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_102 = 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; } else { - lean_dec_ref(x_83); - x_102 = lean_box(0); + lean_dec_ref(x_66); + x_86 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); } else { - x_103 = x_102; + x_87 = x_86; } -lean_ctor_set(x_103, 0, x_99); -lean_ctor_set(x_103, 1, x_100); -lean_ctor_set(x_103, 2, x_38); -lean_ctor_set(x_103, 3, x_101); -x_104 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_104, 0, x_94); -lean_ctor_set(x_104, 1, x_95); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_96); -lean_ctor_set(x_104, 4, x_97); -lean_ctor_set(x_104, 5, x_98); -lean_ctor_set(x_44, 1, x_104); -return x_44; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_105 = lean_ctor_get(x_44, 0); -lean_inc(x_105); -lean_dec(x_44); -x_106 = lean_ctor_get(x_82, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_82, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_82, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 5); -lean_inc(x_110); -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_111 = x_82; +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); +if (lean_is_scalar(x_32)) { + x_89 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + x_89 = x_32; } -x_112 = lean_ctor_get(x_83, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_83, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_83, 3); -lean_inc(x_114); -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_115 = x_83; -} else { - lean_dec_ref(x_83); - x_115 = lean_box(0); +lean_ctor_set(x_89, 0, x_67); +lean_ctor_set(x_89, 1, x_88); +return x_89; } -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_38); -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); -x_118 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_118, 0, x_105); -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; -x_119 = lean_ctor_get(x_12, 0); -x_120 = lean_ctor_get(x_12, 1); -x_121 = lean_ctor_get(x_12, 2); -x_122 = lean_ctor_get(x_12, 3); -x_123 = lean_ctor_get(x_12, 4); -lean_inc(x_123); -lean_inc(x_122); +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_dec(x_12); -x_124 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_124, 0, x_32); -lean_ctor_set(x_124, 1, x_20); -x_125 = lean_array_push(x_121, x_124); -x_126 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_126, 0, x_119); -lean_ctor_set(x_126, 1, x_120); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_122); -lean_ctor_set(x_126, 4, x_123); -x_127 = 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_34, x_126, x_31); -if (lean_obj_tag(x_127) == 0) -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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_128 = lean_ctor_get(x_127, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_127, 0); -lean_inc(x_130); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_131 = x_127; +lean_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_127); + 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_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_128, 0); +x_132 = lean_ctor_get(x_124, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_128, 1); +x_133 = lean_ctor_get(x_124, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_128, 3); +x_134 = lean_ctor_get(x_124, 3); lean_inc(x_134); -x_135 = lean_ctor_get(x_128, 4); -lean_inc(x_135); -x_136 = lean_ctor_get(x_128, 5); -lean_inc(x_136); -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_137 = x_128; +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_128); - x_137 = lean_box(0); + lean_dec_ref(x_124); + x_135 = lean_box(0); } -x_138 = lean_ctor_get(x_129, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_129, 1); -lean_inc(x_139); -x_140 = lean_ctor_get(x_129, 3); -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); - x_141 = x_129; +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_129); - x_141 = lean_box(0); + x_136 = x_135; } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 4, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_138); -lean_ctor_set(x_142, 1, x_139); -lean_ctor_set(x_142, 2, x_38); -lean_ctor_set(x_142, 3, x_140); -if (lean_is_scalar(x_137)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_137; -} -lean_ctor_set(x_143, 0, x_132); -lean_ctor_set(x_143, 1, x_133); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_134); -lean_ctor_set(x_143, 4, x_135); -lean_ctor_set(x_143, 5, x_136); +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_144 = lean_alloc_ctor(0, 2, 0); + x_137 = lean_alloc_ctor(0, 6, 0); } else { - x_144 = x_131; + x_137 = x_131; } -lean_ctor_set(x_144, 0, x_130); -lean_ctor_set(x_144, 1, x_143); -return x_144; +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_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_145 = lean_ctor_get(x_127, 1); +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); -x_146 = lean_ctor_get(x_145, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 0); +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); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_148 = x_127; -} else { - lean_dec_ref(x_127); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_145, 0); +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_145, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_145, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_145, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_145, 5); -lean_inc(x_153); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - lean_ctor_release(x_145, 3); - lean_ctor_release(x_145, 4); - lean_ctor_release(x_145, 5); - x_154 = x_145; +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_145); - x_154 = lean_box(0); + lean_dec_ref(x_139); + x_150 = lean_box(0); } -x_155 = lean_ctor_get(x_146, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_146, 3); -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); - x_158 = x_146; +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_146); - x_158 = lean_box(0); + x_151 = x_150; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 4, 0); +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_159 = x_158; + x_152 = x_146; } -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_38); -lean_ctor_set(x_159, 3, x_157); -if (lean_is_scalar(x_154)) { - x_160 = lean_alloc_ctor(0, 6, 0); +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_160 = x_154; + x_153 = x_32; } -lean_ctor_set(x_160, 0, x_149); -lean_ctor_set(x_160, 1, x_150); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_151); -lean_ctor_set(x_160, 4, x_152); -lean_ctor_set(x_160, 5, x_153); -if (lean_is_scalar(x_148)) { - x_161 = lean_alloc_ctor(1, 2, 0); -} else { - x_161 = x_148; +lean_ctor_set(x_153, 0, x_140); +lean_ctor_set(x_153, 1, x_152); +return x_153; } -lean_ctor_set(x_161, 0, x_147); -lean_ctor_set(x_161, 1, x_160); -return x_161; } } } else { -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; -x_162 = lean_ctor_get(x_36, 0); -x_163 = lean_ctor_get(x_36, 1); -x_164 = lean_ctor_get(x_36, 2); -x_165 = lean_ctor_get(x_36, 3); -lean_inc(x_165); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_36); -x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_167 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_167, 0, x_162); -lean_ctor_set(x_167, 1, x_163); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_165); -lean_ctor_set(x_31, 2, x_167); -x_168 = lean_ctor_get(x_12, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_12, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_12, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_12, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_12, 4); -lean_inc(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_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); 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_173 = x_12; + x_225 = x_12; } else { lean_dec_ref(x_12); - x_173 = lean_box(0); + x_225 = lean_box(0); } -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_32); -lean_ctor_set(x_174, 1, x_20); -x_175 = lean_array_push(x_170, x_174); -if (lean_is_scalar(x_173)) { - x_176 = lean_alloc_ctor(0, 5, 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_228 = lean_alloc_ctor(0, 5, 0); } else { - x_176 = x_173; + x_228 = x_225; } -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_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_34, x_176, x_31); -if (lean_obj_tag(x_177) == 0) +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___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_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_178 = lean_ctor_get(x_177, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_178, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 0); -lean_inc(x_180); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_181 = x_177; -} else { - lean_dec_ref(x_177); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_178, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 5); -lean_inc(x_186); -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_187 = x_178; -} else { - lean_dec_ref(x_178); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_179, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_179, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_179, 3); -lean_inc(x_190); -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_191 = x_179; -} else { - lean_dec_ref(x_179); - 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_164); -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_181)) { - x_194 = lean_alloc_ctor(0, 2, 0); -} else { - x_194 = x_181; -} -lean_ctor_set(x_194, 0, x_180); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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_184 = x_232; +x_185 = x_231; +goto block_216; } 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; lean_object* x_210; lean_object* x_211; -x_195 = lean_ctor_get(x_177, 1); +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_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; +} 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_195, 2); +x_196 = lean_ctor_get(x_186, 3); lean_inc(x_196); -x_197 = lean_ctor_get(x_177, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_198 = x_177; +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_177); - x_198 = lean_box(0); + lean_dec_ref(x_186); + x_197 = lean_box(0); } -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_195, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_195, 3); +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_195, 4); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 5); +lean_dec(x_184); +x_203 = lean_ctor_get(x_185, 0); lean_inc(x_203); -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_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = lean_ctor_get(x_196, 0); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_185, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 1); +x_206 = lean_ctor_get(x_185, 4); lean_inc(x_206); -x_207 = lean_ctor_get(x_196, 3); +x_207 = lean_ctor_get(x_185, 5); lean_inc(x_207); -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_208 = x_196; +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; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_185); x_208 = 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; +} else { + lean_dec_ref(x_201); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); +} else { + x_213 = x_212; +} +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_209 = lean_alloc_ctor(0, 4, 0); + x_214 = lean_alloc_ctor(0, 6, 0); } else { - x_209 = x_208; + x_214 = x_208; } -lean_ctor_set(x_209, 0, x_205); -lean_ctor_set(x_209, 1, x_206); -lean_ctor_set(x_209, 2, x_164); -lean_ctor_set(x_209, 3, x_207); -if (lean_is_scalar(x_204)) { - x_210 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_32)) { + x_215 = lean_alloc_ctor(0, 2, 0); } else { - x_210 = x_204; + x_215 = x_32; } -lean_ctor_set(x_210, 0, x_199); -lean_ctor_set(x_210, 1, x_200); -lean_ctor_set(x_210, 2, x_209); -lean_ctor_set(x_210, 3, x_201); -lean_ctor_set(x_210, 4, x_202); -lean_ctor_set(x_210, 5, x_203); -if (lean_is_scalar(x_198)) { - x_211 = lean_alloc_ctor(1, 2, 0); -} else { - x_211 = x_198; +lean_ctor_set(x_215, 0, x_202); +lean_ctor_set(x_215, 1, x_214); +return x_215; } -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; 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; -x_212 = lean_ctor_get(x_31, 2); -x_213 = lean_ctor_get(x_31, 0); -x_214 = lean_ctor_get(x_31, 1); -x_215 = lean_ctor_get(x_31, 3); -x_216 = lean_ctor_get(x_31, 4); -x_217 = lean_ctor_get(x_31, 5); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_212); -lean_inc(x_214); -lean_inc(x_213); -lean_dec(x_31); -x_218 = lean_ctor_get(x_212, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_212, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_212, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_212, 3); -lean_inc(x_221); -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); - x_222 = x_212; -} else { - lean_dec_ref(x_212); - x_222 = lean_box(0); -} -x_223 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 4, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_218); -lean_ctor_set(x_224, 1, x_219); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_221); -x_225 = lean_alloc_ctor(0, 6, 0); -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); -x_226 = lean_ctor_get(x_12, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_12, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_12, 2); -lean_inc(x_228); -x_229 = lean_ctor_get(x_12, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_12, 4); -lean_inc(x_230); -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_231 = x_12; -} else { - lean_dec_ref(x_12); - x_231 = lean_box(0); -} -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_32); -lean_ctor_set(x_232, 1, x_20); -x_233 = lean_array_push(x_228, x_232); -if (lean_is_scalar(x_231)) { - x_234 = lean_alloc_ctor(0, 5, 0); -} else { - x_234 = x_231; -} -lean_ctor_set(x_234, 0, x_226); -lean_ctor_set(x_234, 1, x_227); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_229); -lean_ctor_set(x_234, 4, x_230); -x_235 = 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_34, x_234, x_225); -if (lean_obj_tag(x_235) == 0) -{ -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; lean_object* x_252; -x_236 = lean_ctor_get(x_235, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_236, 2); -lean_inc(x_237); -x_238 = lean_ctor_get(x_235, 0); -lean_inc(x_238); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_239 = x_235; -} else { - lean_dec_ref(x_235); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_236, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 3); -lean_inc(x_242); -x_243 = lean_ctor_get(x_236, 4); -lean_inc(x_243); -x_244 = lean_ctor_get(x_236, 5); -lean_inc(x_244); -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); -x_247 = lean_ctor_get(x_237, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_237, 3); -lean_inc(x_248); -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); - x_249 = x_237; -} else { - lean_dec_ref(x_237); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_246); -lean_ctor_set(x_250, 1, x_247); -lean_ctor_set(x_250, 2, x_220); -lean_ctor_set(x_250, 3, x_248); -if (lean_is_scalar(x_245)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_245; -} -lean_ctor_set(x_251, 0, x_240); -lean_ctor_set(x_251, 1, x_241); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_242); -lean_ctor_set(x_251, 4, x_243); -lean_ctor_set(x_251, 5, x_244); -if (lean_is_scalar(x_239)) { - x_252 = lean_alloc_ctor(0, 2, 0); -} else { - x_252 = x_239; -} -lean_ctor_set(x_252, 0, x_238); -lean_ctor_set(x_252, 1, x_251); -return x_252; -} -else -{ -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; -x_253 = lean_ctor_get(x_235, 1); -lean_inc(x_253); -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_235, 0); -lean_inc(x_255); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_256 = x_235; -} else { - lean_dec_ref(x_235); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_253, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_253, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_253, 3); -lean_inc(x_259); -x_260 = lean_ctor_get(x_253, 4); -lean_inc(x_260); -x_261 = lean_ctor_get(x_253, 5); -lean_inc(x_261); -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); - lean_ctor_release(x_253, 4); - lean_ctor_release(x_253, 5); - x_262 = x_253; -} else { - lean_dec_ref(x_253); - x_262 = lean_box(0); -} -x_263 = lean_ctor_get(x_254, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_254, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_254, 3); -lean_inc(x_265); -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_266 = x_254; -} else { - lean_dec_ref(x_254); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(0, 4, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_263); -lean_ctor_set(x_267, 1, x_264); -lean_ctor_set(x_267, 2, x_220); -lean_ctor_set(x_267, 3, x_265); -if (lean_is_scalar(x_262)) { - x_268 = lean_alloc_ctor(0, 6, 0); -} else { - x_268 = x_262; -} -lean_ctor_set(x_268, 0, x_257); -lean_ctor_set(x_268, 1, x_258); -lean_ctor_set(x_268, 2, x_267); -lean_ctor_set(x_268, 3, x_259); -lean_ctor_set(x_268, 4, x_260); -lean_ctor_set(x_268, 5, x_261); -if (lean_is_scalar(x_256)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_256; -} -lean_ctor_set(x_269, 0, x_255); -lean_ctor_set(x_269, 1, x_268); -return x_269; } } } default: { -lean_object* x_270; lean_object* x_271; -x_270 = lean_ctor_get(x_25, 1); -lean_inc(x_270); +lean_object* x_236; lean_object* x_237; +x_236 = lean_ctor_get(x_25, 1); +lean_inc(x_236); lean_dec(x_25); lean_inc(x_12); -x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); -if (lean_obj_tag(x_271) == 0) +x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); +if (lean_obj_tag(x_237) == 0) { -lean_object* x_272; -x_272 = lean_ctor_get(x_271, 0); -lean_inc(x_272); -if (lean_obj_tag(x_272) == 0) +lean_object* x_238; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +if (lean_obj_tag(x_238) == 0) { -lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_dec(x_20); -x_273 = lean_ctor_get(x_271, 1); -lean_inc(x_273); -lean_dec(x_271); -x_274 = lean_unsigned_to_nat(1u); -x_275 = lean_nat_add(x_11, x_274); +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); lean_dec(x_11); -x_11 = x_275; -x_13 = x_273; +x_11 = x_241; +x_13 = x_239; goto _start; } else { -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_277 = lean_ctor_get(x_271, 1); -lean_inc(x_277); -lean_dec(x_271); -x_278 = lean_ctor_get(x_272, 0); -lean_inc(x_278); -lean_dec(x_272); -x_279 = lean_unsigned_to_nat(1u); -x_280 = lean_nat_add(x_11, x_279); +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_237); + x_244 = 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_281 = !lean_is_exclusive(x_277); -if (x_281 == 0) +x_248 = !lean_is_exclusive(x_243); +if (x_248 == 0) { -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_277, 2); -x_283 = !lean_is_exclusive(x_282); -if (x_283 == 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_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_282, 2); -x_285 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_282, 2, x_285); -x_286 = !lean_is_exclusive(x_12); -if (x_286 == 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_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_287 = lean_ctor_get(x_12, 2); -x_288 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_288, 0, x_278); -lean_ctor_set(x_288, 1, x_20); -x_289 = lean_array_push(x_287, x_288); -lean_ctor_set(x_12, 2, x_289); -x_290 = 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_280, x_12, x_277); -if (lean_obj_tag(x_290) == 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_291; lean_object* x_292; uint8_t x_293; -x_291 = lean_ctor_get(x_290, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_291, 2); -lean_inc(x_292); -x_293 = !lean_is_exclusive(x_290); -if (x_293 == 0) -{ -lean_object* x_294; uint8_t x_295; -x_294 = lean_ctor_get(x_290, 1); -lean_dec(x_294); -x_295 = !lean_is_exclusive(x_291); -if (x_295 == 0) -{ -lean_object* x_296; uint8_t x_297; -x_296 = lean_ctor_get(x_291, 2); -lean_dec(x_296); -x_297 = !lean_is_exclusive(x_292); -if (x_297 == 0) -{ -lean_object* x_298; -x_298 = lean_ctor_get(x_292, 2); -lean_dec(x_298); -lean_ctor_set(x_292, 2, x_284); -return x_290; -} -else -{ -lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; -x_299 = lean_ctor_get(x_292, 0); -x_300 = lean_ctor_get(x_292, 1); -x_301 = lean_ctor_get(x_292, 3); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_dec(x_292); -x_302 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_284); -lean_ctor_set(x_302, 3, x_301); -lean_ctor_set(x_291, 2, x_302); -return x_290; -} -} -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; -x_303 = lean_ctor_get(x_291, 0); -x_304 = lean_ctor_get(x_291, 1); -x_305 = lean_ctor_get(x_291, 3); -x_306 = lean_ctor_get(x_291, 4); -x_307 = lean_ctor_get(x_291, 5); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_291); -x_308 = lean_ctor_get(x_292, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_292, 1); +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_292, 3); +x_310 = lean_ctor_get(x_308, 1); lean_inc(x_310); -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); - x_311 = x_292; -} else { - lean_dec_ref(x_292); - x_311 = lean_box(0); +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; } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 4, 0); -} else { - x_312 = x_311; -} -lean_ctor_set(x_312, 0, x_308); -lean_ctor_set(x_312, 1, x_309); -lean_ctor_set(x_312, 2, x_284); -lean_ctor_set(x_312, 3, x_310); -x_313 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_313, 0, x_303); -lean_ctor_set(x_313, 1, x_304); -lean_ctor_set(x_313, 2, x_312); -lean_ctor_set(x_313, 3, x_305); -lean_ctor_set(x_313, 4, x_306); -lean_ctor_set(x_313, 5, x_307); -lean_ctor_set(x_290, 1, x_313); -return x_290; +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_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_314 = lean_ctor_get(x_290, 0); -lean_inc(x_314); -lean_dec(x_290); -x_315 = lean_ctor_get(x_291, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_291, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_291, 3); -lean_inc(x_317); -x_318 = lean_ctor_get(x_291, 4); -lean_inc(x_318); -x_319 = lean_ctor_get(x_291, 5); +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); -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); - lean_ctor_release(x_291, 5); - x_320 = x_291; -} else { - lean_dec_ref(x_291); - x_320 = lean_box(0); -} -x_321 = lean_ctor_get(x_292, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_292, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_292, 3); -lean_inc(x_323); -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); - x_324 = x_292; -} else { - lean_dec_ref(x_292); - x_324 = lean_box(0); -} -if (lean_is_scalar(x_324)) { - x_325 = lean_alloc_ctor(0, 4, 0); -} else { - x_325 = x_324; -} -lean_ctor_set(x_325, 0, x_321); -lean_ctor_set(x_325, 1, x_322); -lean_ctor_set(x_325, 2, x_284); -lean_ctor_set(x_325, 3, x_323); -if (lean_is_scalar(x_320)) { - x_326 = lean_alloc_ctor(0, 6, 0); -} else { - x_326 = x_320; -} -lean_ctor_set(x_326, 0, x_315); -lean_ctor_set(x_326, 1, x_316); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_317); -lean_ctor_set(x_326, 4, x_318); -lean_ctor_set(x_326, 5, x_319); -x_327 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_327, 0, x_314); -lean_ctor_set(x_327, 1, x_326); -return x_327; -} -} -else -{ -lean_object* x_328; lean_object* x_329; uint8_t x_330; -x_328 = lean_ctor_get(x_290, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_328, 2); -lean_inc(x_329); -x_330 = !lean_is_exclusive(x_290); -if (x_330 == 0) -{ -lean_object* x_331; uint8_t x_332; -x_331 = lean_ctor_get(x_290, 1); -lean_dec(x_331); -x_332 = !lean_is_exclusive(x_328); -if (x_332 == 0) -{ -lean_object* x_333; uint8_t x_334; -x_333 = lean_ctor_get(x_328, 2); -lean_dec(x_333); -x_334 = !lean_is_exclusive(x_329); -if (x_334 == 0) -{ -lean_object* x_335; -x_335 = lean_ctor_get(x_329, 2); -lean_dec(x_335); -lean_ctor_set(x_329, 2, x_284); -return x_290; -} -else -{ -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; -x_336 = lean_ctor_get(x_329, 0); -x_337 = lean_ctor_get(x_329, 1); -x_338 = lean_ctor_get(x_329, 3); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_dec(x_329); -x_339 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_339, 0, x_336); -lean_ctor_set(x_339, 1, x_337); -lean_ctor_set(x_339, 2, x_284); -lean_ctor_set(x_339, 3, x_338); -lean_ctor_set(x_328, 2, x_339); -return x_290; -} -} -else -{ -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_340 = lean_ctor_get(x_328, 0); -x_341 = lean_ctor_get(x_328, 1); -x_342 = lean_ctor_get(x_328, 3); -x_343 = lean_ctor_get(x_328, 4); -x_344 = lean_ctor_get(x_328, 5); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_328); -x_345 = lean_ctor_get(x_329, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_329, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_329, 3); -lean_inc(x_347); -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_348 = x_329; -} else { - lean_dec_ref(x_329); - 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_284); -lean_ctor_set(x_349, 3, x_347); -x_350 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_350, 0, x_340); -lean_ctor_set(x_350, 1, x_341); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_342); -lean_ctor_set(x_350, 4, x_343); -lean_ctor_set(x_350, 5, x_344); -lean_ctor_set(x_290, 1, x_350); -return x_290; -} -} -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; -x_351 = lean_ctor_get(x_290, 0); -lean_inc(x_351); -lean_dec(x_290); -x_352 = lean_ctor_get(x_328, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_328, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_328, 3); -lean_inc(x_354); -x_355 = lean_ctor_get(x_328, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_328, 5); -lean_inc(x_356); -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_357 = x_328; -} else { - lean_dec_ref(x_328); - x_357 = lean_box(0); -} -x_358 = lean_ctor_get(x_329, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_329, 1); -lean_inc(x_359); -x_360 = lean_ctor_get(x_329, 3); -lean_inc(x_360); -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_361 = x_329; -} else { - lean_dec_ref(x_329); - x_361 = lean_box(0); -} -if (lean_is_scalar(x_361)) { - x_362 = lean_alloc_ctor(0, 4, 0); -} else { - x_362 = x_361; -} -lean_ctor_set(x_362, 0, x_358); -lean_ctor_set(x_362, 1, x_359); -lean_ctor_set(x_362, 2, x_284); -lean_ctor_set(x_362, 3, x_360); -if (lean_is_scalar(x_357)) { - x_363 = lean_alloc_ctor(0, 6, 0); -} else { - x_363 = 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); -x_364 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_364, 0, x_351); -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; -x_365 = lean_ctor_get(x_12, 0); -x_366 = lean_ctor_get(x_12, 1); -x_367 = lean_ctor_get(x_12, 2); -x_368 = lean_ctor_get(x_12, 3); -x_369 = lean_ctor_get(x_12, 4); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); +lean_inc(x_318); +lean_inc(x_317); +lean_inc(x_316); +lean_inc(x_315); lean_dec(x_12); -x_370 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_370, 0, x_278); -lean_ctor_set(x_370, 1, x_20); -x_371 = lean_array_push(x_367, x_370); -x_372 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_372, 0, x_365); -lean_ctor_set(x_372, 1, x_366); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_368); -lean_ctor_set(x_372, 4, x_369); -x_373 = 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_280, x_372, x_277); -if (lean_obj_tag(x_373) == 0) +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_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; lean_object* x_390; -x_374 = lean_ctor_get(x_373, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_373, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_377 = x_373; -} else { - lean_dec_ref(x_373); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_374, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); -lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); -lean_inc(x_382); -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); - lean_ctor_release(x_374, 5); - x_383 = x_374; -} else { - lean_dec_ref(x_374); - x_383 = lean_box(0); -} -x_384 = lean_ctor_get(x_375, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_375, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_375, 3); -lean_inc(x_386); -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_387 = x_375; -} else { - lean_dec_ref(x_375); - x_387 = lean_box(0); -} -if (lean_is_scalar(x_387)) { - x_388 = lean_alloc_ctor(0, 4, 0); -} else { - x_388 = x_387; -} -lean_ctor_set(x_388, 0, x_384); -lean_ctor_set(x_388, 1, x_385); -lean_ctor_set(x_388, 2, x_284); -lean_ctor_set(x_388, 3, x_386); -if (lean_is_scalar(x_383)) { - x_389 = lean_alloc_ctor(0, 6, 0); -} else { - x_389 = x_383; -} -lean_ctor_set(x_389, 0, x_378); -lean_ctor_set(x_389, 1, x_379); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_389, 3, x_380); -lean_ctor_set(x_389, 4, x_381); -lean_ctor_set(x_389, 5, x_382); -if (lean_is_scalar(x_377)) { - x_390 = lean_alloc_ctor(0, 2, 0); -} else { - x_390 = x_377; -} -lean_ctor_set(x_390, 0, x_376); -lean_ctor_set(x_390, 1, x_389); -return x_390; +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_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; lean_object* x_406; lean_object* x_407; -x_391 = lean_ctor_get(x_373, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_373, 0); -lean_inc(x_393); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_394 = x_373; -} else { - lean_dec_ref(x_373); - x_394 = lean_box(0); +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; } -x_395 = lean_ctor_get(x_391, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 3); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 4); -lean_inc(x_398); -x_399 = lean_ctor_get(x_391, 5); -lean_inc(x_399); -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_400 = x_391; -} else { - lean_dec_ref(x_391); - x_400 = lean_box(0); } -x_401 = lean_ctor_get(x_392, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_392, 3); -lean_inc(x_403); -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_404 = x_392; +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); +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 { - lean_dec_ref(x_392); - x_404 = lean_box(0); + x_260 = x_244; + lean_ctor_set_tag(x_260, 1); } -if (lean_is_scalar(x_404)) { - x_405 = lean_alloc_ctor(0, 4, 0); +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; +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_405 = x_404; + x_265 = x_244; + lean_ctor_set_tag(x_265, 1); } -lean_ctor_set(x_405, 0, x_401); -lean_ctor_set(x_405, 1, x_402); -lean_ctor_set(x_405, 2, x_284); -lean_ctor_set(x_405, 3, x_403); -if (lean_is_scalar(x_400)) { - x_406 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_265, 0, x_255); +lean_ctor_set(x_265, 1, x_253); +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; 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_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 { - x_406 = x_400; + lean_dec_ref(x_254); + x_274 = lean_box(0); } -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_394)) { - x_407 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 4, 0); } else { - x_407 = x_394; + x_275 = x_274; +} +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, 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); +} else { + x_277 = x_244; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_255); +lean_ctor_set(x_277, 1, x_276); +return x_277; +} +} +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_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_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); +} else { + x_289 = x_244; +} +lean_ctor_set(x_289, 0, x_279); +lean_ctor_set(x_289, 1, x_253); +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_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); +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; +} else { + lean_dec_ref(x_278); + x_298 = lean_box(0); +} +if (lean_is_scalar(x_298)) { + x_299 = lean_alloc_ctor(0, 4, 0); +} else { + x_299 = x_298; +} +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); +} else { + x_301 = x_244; +} +lean_ctor_set(x_301, 0, x_279); +lean_ctor_set(x_301, 1, x_300); +return x_301; } -lean_ctor_set(x_407, 0, x_393); -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; lean_object* x_423; -x_408 = lean_ctor_get(x_282, 0); -x_409 = lean_ctor_get(x_282, 1); -x_410 = lean_ctor_get(x_282, 2); -x_411 = lean_ctor_get(x_282, 3); -lean_inc(x_411); -lean_inc(x_410); -lean_inc(x_409); -lean_inc(x_408); -lean_dec(x_282); -x_412 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_413 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_413, 0, x_408); -lean_ctor_set(x_413, 1, x_409); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_411); -lean_ctor_set(x_277, 2, x_413); -x_414 = lean_ctor_get(x_12, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_12, 1); -lean_inc(x_415); -x_416 = lean_ctor_get(x_12, 2); -lean_inc(x_416); -x_417 = lean_ctor_get(x_12, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_12, 4); -lean_inc(x_418); +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); 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_419 = x_12; + x_374 = x_12; } else { lean_dec_ref(x_12); - x_419 = lean_box(0); + x_374 = lean_box(0); } -x_420 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_420, 0, x_278); -lean_ctor_set(x_420, 1, x_20); -x_421 = lean_array_push(x_416, x_420); -if (lean_is_scalar(x_419)) { - x_422 = lean_alloc_ctor(0, 5, 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); } else { - x_422 = x_419; + x_377 = x_374; } -lean_ctor_set(x_422, 0, x_414); -lean_ctor_set(x_422, 1, x_415); -lean_ctor_set(x_422, 2, x_421); -lean_ctor_set(x_422, 3, x_417); -lean_ctor_set(x_422, 4, x_418); -x_423 = 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_280, x_422, x_277); -if (lean_obj_tag(x_423) == 0) +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_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; lean_object* x_439; lean_object* x_440; -x_424 = lean_ctor_get(x_423, 1); -lean_inc(x_424); -x_425 = lean_ctor_get(x_424, 2); -lean_inc(x_425); -x_426 = lean_ctor_get(x_423, 0); -lean_inc(x_426); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_427 = x_423; -} else { - lean_dec_ref(x_423); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_424, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_424, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_424, 3); -lean_inc(x_430); -x_431 = lean_ctor_get(x_424, 4); -lean_inc(x_431); -x_432 = lean_ctor_get(x_424, 5); -lean_inc(x_432); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - lean_ctor_release(x_424, 4); - lean_ctor_release(x_424, 5); - x_433 = x_424; -} else { - lean_dec_ref(x_424); - x_433 = lean_box(0); -} -x_434 = lean_ctor_get(x_425, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_425, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_425, 3); -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); - 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, 4, 0); -} else { - x_438 = x_437; -} -lean_ctor_set(x_438, 0, x_434); -lean_ctor_set(x_438, 1, x_435); -lean_ctor_set(x_438, 2, x_410); -lean_ctor_set(x_438, 3, x_436); -if (lean_is_scalar(x_433)) { - x_439 = lean_alloc_ctor(0, 6, 0); -} else { - x_439 = x_433; -} -lean_ctor_set(x_439, 0, x_428); -lean_ctor_set(x_439, 1, x_429); -lean_ctor_set(x_439, 2, x_438); -lean_ctor_set(x_439, 3, x_430); -lean_ctor_set(x_439, 4, x_431); -lean_ctor_set(x_439, 5, x_432); -if (lean_is_scalar(x_427)) { - x_440 = lean_alloc_ctor(0, 2, 0); -} else { - x_440 = x_427; -} -lean_ctor_set(x_440, 0, x_426); -lean_ctor_set(x_440, 1, x_439); -return x_440; +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; } else { -lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_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; -x_441 = lean_ctor_get(x_423, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_441, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_423, 0); -lean_inc(x_443); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_444 = x_423; -} else { - lean_dec_ref(x_423); - x_444 = lean_box(0); +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; } +block_366: +{ +if (lean_obj_tag(x_334) == 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_inc(x_351); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +lean_dec(x_334); +x_353 = lean_ctor_get(x_335, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_335, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_335, 3); +lean_inc(x_355); +x_356 = lean_ctor_get(x_335, 4); +lean_inc(x_356); +x_357 = lean_ctor_get(x_335, 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; +} else { + lean_dec_ref(x_335); + x_358 = lean_box(0); +} +x_359 = lean_ctor_get(x_351, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_351, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_351, 3); +lean_inc(x_361); +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; +} else { + lean_dec_ref(x_351); + x_362 = lean_box(0); +} +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 4, 0); +} else { + x_363 = x_362; +} +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); +if (lean_is_scalar(x_358)) { + x_364 = lean_alloc_ctor(0, 6, 0); +} else { + x_364 = 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); +} else { + x_365 = x_244; +} +lean_ctor_set(x_365, 0, x_352); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +} +} +} +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; +} else { + lean_dec_ref(x_385); + x_395 = 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); +} else { + x_430 = x_395; +} +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); +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; +} else { + lean_dec_ref(x_12); + x_437 = 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); +} else { + x_440 = x_437; +} +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_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; +} +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); -x_447 = lean_ctor_get(x_441, 3); -lean_inc(x_447); -x_448 = lean_ctor_get(x_441, 4); -lean_inc(x_448); -x_449 = lean_ctor_get(x_441, 5); -lean_inc(x_449); -if (lean_is_exclusive(x_441)) { - lean_ctor_release(x_441, 0); - lean_ctor_release(x_441, 1); - lean_ctor_release(x_441, 2); - lean_ctor_release(x_441, 3); - lean_ctor_release(x_441, 4); - lean_ctor_release(x_441, 5); - x_450 = x_441; +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; +} +block_428: +{ +if (lean_obj_tag(x_396) == 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_441); - x_450 = lean_box(0); + lean_dec_ref(x_397); + x_405 = lean_box(0); } -x_451 = lean_ctor_get(x_442, 0); -lean_inc(x_451); -x_452 = lean_ctor_get(x_442, 1); -lean_inc(x_452); -x_453 = lean_ctor_get(x_442, 3); -lean_inc(x_453); -if (lean_is_exclusive(x_442)) { - lean_ctor_release(x_442, 0); - lean_ctor_release(x_442, 1); - lean_ctor_release(x_442, 2); - lean_ctor_release(x_442, 3); - x_454 = x_442; +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_442); - x_454 = lean_box(0); + lean_dec_ref(x_398); + x_409 = lean_box(0); } -if (lean_is_scalar(x_454)) { - x_455 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_409)) { + x_410 = lean_alloc_ctor(0, 4, 0); } else { - x_455 = x_454; + x_410 = x_409; } -lean_ctor_set(x_455, 0, x_451); -lean_ctor_set(x_455, 1, x_452); -lean_ctor_set(x_455, 2, x_410); -lean_ctor_set(x_455, 3, x_453); -if (lean_is_scalar(x_450)) { - x_456 = lean_alloc_ctor(0, 6, 0); +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_456 = x_450; + x_411 = x_405; } -lean_ctor_set(x_456, 0, x_445); -lean_ctor_set(x_456, 1, x_446); -lean_ctor_set(x_456, 2, x_455); -lean_ctor_set(x_456, 3, x_447); -lean_ctor_set(x_456, 4, x_448); -lean_ctor_set(x_456, 5, x_449); -if (lean_is_scalar(x_444)) { - x_457 = lean_alloc_ctor(1, 2, 0); +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_457 = x_444; -} -lean_ctor_set(x_457, 0, x_443); -lean_ctor_set(x_457, 1, x_456); -return x_457; -} + 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_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; 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; lean_object* x_481; -x_458 = lean_ctor_get(x_277, 2); -x_459 = lean_ctor_get(x_277, 0); -x_460 = lean_ctor_get(x_277, 1); -x_461 = lean_ctor_get(x_277, 3); -x_462 = lean_ctor_get(x_277, 4); -x_463 = lean_ctor_get(x_277, 5); -lean_inc(x_463); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_458); -lean_inc(x_460); -lean_inc(x_459); -lean_dec(x_277); -x_464 = lean_ctor_get(x_458, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_458, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_458, 2); -lean_inc(x_466); -x_467 = lean_ctor_get(x_458, 3); -lean_inc(x_467); -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); - x_468 = x_458; +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_inc(x_416); +x_417 = lean_ctor_get(x_397, 3); +lean_inc(x_417); +x_418 = lean_ctor_get(x_397, 4); +lean_inc(x_418); +x_419 = lean_ctor_get(x_397, 5); +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_458); - x_468 = lean_box(0); + lean_dec_ref(x_397); + x_420 = lean_box(0); } -x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_468)) { - x_470 = lean_alloc_ctor(0, 4, 0); +x_421 = lean_ctor_get(x_413, 0); +lean_inc(x_421); +x_422 = lean_ctor_get(x_413, 1); +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; } else { - x_470 = x_468; + lean_dec_ref(x_413); + x_424 = lean_box(0); } -lean_ctor_set(x_470, 0, x_464); -lean_ctor_set(x_470, 1, x_465); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_467); -x_471 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_471, 0, x_459); -lean_ctor_set(x_471, 1, x_460); -lean_ctor_set(x_471, 2, x_470); -lean_ctor_set(x_471, 3, x_461); -lean_ctor_set(x_471, 4, x_462); -lean_ctor_set(x_471, 5, x_463); -x_472 = lean_ctor_get(x_12, 0); -lean_inc(x_472); -x_473 = lean_ctor_get(x_12, 1); -lean_inc(x_473); -x_474 = lean_ctor_get(x_12, 2); -lean_inc(x_474); -x_475 = lean_ctor_get(x_12, 3); -lean_inc(x_475); -x_476 = lean_ctor_get(x_12, 4); -lean_inc(x_476); -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_477 = x_12; +if (lean_is_scalar(x_424)) { + x_425 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_12); - x_477 = lean_box(0); + x_425 = x_424; } -x_478 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_478, 0, x_278); -lean_ctor_set(x_478, 1, x_20); -x_479 = lean_array_push(x_474, x_478); -if (lean_is_scalar(x_477)) { - x_480 = lean_alloc_ctor(0, 5, 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); } else { - x_480 = x_477; + x_426 = x_420; } -lean_ctor_set(x_480, 0, x_472); -lean_ctor_set(x_480, 1, x_473); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_475); -lean_ctor_set(x_480, 4, x_476); -x_481 = 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_280, x_480, x_471); -if (lean_obj_tag(x_481) == 0) -{ -lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_482 = lean_ctor_get(x_481, 1); -lean_inc(x_482); -x_483 = lean_ctor_get(x_482, 2); -lean_inc(x_483); -x_484 = lean_ctor_get(x_481, 0); -lean_inc(x_484); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_485 = x_481; +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); } else { - lean_dec_ref(x_481); - x_485 = lean_box(0); + x_427 = x_244; } -x_486 = lean_ctor_get(x_482, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_482, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_482, 3); -lean_inc(x_488); -x_489 = lean_ctor_get(x_482, 4); -lean_inc(x_489); -x_490 = lean_ctor_get(x_482, 5); -lean_inc(x_490); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - lean_ctor_release(x_482, 4); - lean_ctor_release(x_482, 5); - x_491 = x_482; -} else { - lean_dec_ref(x_482); - x_491 = lean_box(0); +lean_ctor_set(x_427, 0, x_414); +lean_ctor_set(x_427, 1, x_426); +return x_427; } -x_492 = lean_ctor_get(x_483, 0); -lean_inc(x_492); -x_493 = lean_ctor_get(x_483, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_483, 3); -lean_inc(x_494); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - lean_ctor_release(x_483, 2); - lean_ctor_release(x_483, 3); - x_495 = x_483; -} else { - lean_dec_ref(x_483); - x_495 = lean_box(0); -} -if (lean_is_scalar(x_495)) { - x_496 = lean_alloc_ctor(0, 4, 0); -} else { - x_496 = x_495; -} -lean_ctor_set(x_496, 0, x_492); -lean_ctor_set(x_496, 1, x_493); -lean_ctor_set(x_496, 2, x_466); -lean_ctor_set(x_496, 3, x_494); -if (lean_is_scalar(x_491)) { - x_497 = lean_alloc_ctor(0, 6, 0); -} else { - x_497 = x_491; -} -lean_ctor_set(x_497, 0, x_486); -lean_ctor_set(x_497, 1, x_487); -lean_ctor_set(x_497, 2, x_496); -lean_ctor_set(x_497, 3, x_488); -lean_ctor_set(x_497, 4, x_489); -lean_ctor_set(x_497, 5, x_490); -if (lean_is_scalar(x_485)) { - x_498 = lean_alloc_ctor(0, 2, 0); -} else { - x_498 = x_485; -} -lean_ctor_set(x_498, 0, x_484); -lean_ctor_set(x_498, 1, x_497); -return x_498; -} -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; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; -x_499 = lean_ctor_get(x_481, 1); -lean_inc(x_499); -x_500 = lean_ctor_get(x_499, 2); -lean_inc(x_500); -x_501 = lean_ctor_get(x_481, 0); -lean_inc(x_501); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_502 = x_481; -} else { - lean_dec_ref(x_481); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_499, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_499, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_499, 3); -lean_inc(x_505); -x_506 = lean_ctor_get(x_499, 4); -lean_inc(x_506); -x_507 = lean_ctor_get(x_499, 5); -lean_inc(x_507); -if (lean_is_exclusive(x_499)) { - lean_ctor_release(x_499, 0); - lean_ctor_release(x_499, 1); - lean_ctor_release(x_499, 2); - lean_ctor_release(x_499, 3); - lean_ctor_release(x_499, 4); - lean_ctor_release(x_499, 5); - x_508 = x_499; -} else { - lean_dec_ref(x_499); - x_508 = lean_box(0); -} -x_509 = lean_ctor_get(x_500, 0); -lean_inc(x_509); -x_510 = lean_ctor_get(x_500, 1); -lean_inc(x_510); -x_511 = lean_ctor_get(x_500, 3); -lean_inc(x_511); -if (lean_is_exclusive(x_500)) { - lean_ctor_release(x_500, 0); - lean_ctor_release(x_500, 1); - lean_ctor_release(x_500, 2); - lean_ctor_release(x_500, 3); - x_512 = x_500; -} else { - lean_dec_ref(x_500); - x_512 = lean_box(0); -} -if (lean_is_scalar(x_512)) { - x_513 = lean_alloc_ctor(0, 4, 0); -} else { - x_513 = x_512; -} -lean_ctor_set(x_513, 0, x_509); -lean_ctor_set(x_513, 1, x_510); -lean_ctor_set(x_513, 2, x_466); -lean_ctor_set(x_513, 3, x_511); -if (lean_is_scalar(x_508)) { - x_514 = lean_alloc_ctor(0, 6, 0); -} else { - x_514 = x_508; -} -lean_ctor_set(x_514, 0, x_503); -lean_ctor_set(x_514, 1, x_504); -lean_ctor_set(x_514, 2, x_513); -lean_ctor_set(x_514, 3, x_505); -lean_ctor_set(x_514, 4, x_506); -lean_ctor_set(x_514, 5, x_507); -if (lean_is_scalar(x_502)) { - x_515 = lean_alloc_ctor(1, 2, 0); -} else { - x_515 = x_502; -} -lean_ctor_set(x_515, 0, x_501); -lean_ctor_set(x_515, 1, x_514); -return x_515; } } } } else { -uint8_t x_516; +uint8_t x_448; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -23478,23 +20989,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_516 = !lean_is_exclusive(x_271); -if (x_516 == 0) +x_448 = !lean_is_exclusive(x_237); +if (x_448 == 0) { -return x_271; +return x_237; } else { -lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_517 = lean_ctor_get(x_271, 0); -x_518 = lean_ctor_get(x_271, 1); -lean_inc(x_518); -lean_inc(x_517); -lean_dec(x_271); -x_519 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_519, 0, x_517); -lean_ctor_set(x_519, 1, x_518); -return x_519; +lean_object* x_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; } } } @@ -23502,7 +21013,7 @@ return x_519; } else { -uint8_t x_520; +uint8_t x_452; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -23513,29 +21024,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_520 = !lean_is_exclusive(x_25); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_25); +if (x_452 == 0) { return x_25; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_25, 0); -x_522 = lean_ctor_get(x_25, 1); -lean_inc(x_522); -lean_inc(x_521); +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_dec(x_25); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -23545,23 +21056,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_21); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_21); +if (x_456 == 0) { return x_21; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_21, 0); -x_526 = lean_ctor_get(x_21, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_21); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } @@ -23635,2152 +21146,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -25788,58 +22937,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -26224,2152 +23373,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -28377,58 +25164,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -28548,2130 +25335,1768 @@ goto _start; } case 1: { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_dec(x_24); x_31 = lean_ctor_get(x_25, 1); lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_32 = x_25; +} else { + lean_dec_ref(x_25); + x_32 = lean_box(0); +} +x_33 = lean_ctor_get(x_26, 0); +lean_inc(x_33); lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_11, x_34); lean_dec(x_11); -x_35 = !lean_is_exclusive(x_31); -if (x_35 == 0) +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_31, 2); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_31, 2); +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) { -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_36, 2); -x_39 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_39); -x_40 = !lean_is_exclusive(x_12); -if (x_40 == 0) +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +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) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_12, 2); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_32); -lean_ctor_set(x_42, 1, x_20); -x_43 = lean_array_push(x_41, x_42); -lean_ctor_set(x_12, 2, x_43); -x_44 = 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_34, x_12, x_31); -if (lean_obj_tag(x_44) == 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_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_44, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_45, 2); -lean_inc(x_46); -x_47 = !lean_is_exclusive(x_44); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_44, 1); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_45); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_45, 2); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_46); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_46, 2); -lean_dec(x_52); -lean_ctor_set(x_46, 2, x_38); -return x_44; +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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_53 = lean_ctor_get(x_46, 0); -x_54 = lean_ctor_get(x_46, 1); -x_55 = lean_ctor_get(x_46, 3); -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_38); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); -return x_44; +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_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; } } 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; -x_57 = lean_ctor_get(x_45, 0); -x_58 = lean_ctor_get(x_45, 1); -x_59 = lean_ctor_get(x_45, 3); -x_60 = lean_ctor_get(x_45, 4); -x_61 = lean_ctor_get(x_45, 5); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); +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_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; +} +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_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; +} +} +block_90: +{ +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 2); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 0); +lean_inc(x_43); +lean_dec(x_40); +x_44 = !lean_is_exclusive(x_41); +if (x_44 == 0) +{ +lean_object* x_45; uint8_t x_46; +x_45 = lean_ctor_get(x_41, 2); +lean_dec(x_45); +x_46 = !lean_is_exclusive(x_42); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_42, 2); +lean_dec(x_47); +lean_ctor_set(x_42, 2, x_39); +if (lean_is_scalar(x_32)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_32; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_41); +return x_48; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_49 = lean_ctor_get(x_42, 0); +x_50 = lean_ctor_get(x_42, 1); +x_51 = lean_ctor_get(x_42, 3); +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); +if (lean_is_scalar(x_32)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_32; + lean_ctor_set_tag(x_53, 1); +} +lean_ctor_set(x_53, 0, x_43); +lean_ctor_set(x_53, 1, x_41); +return x_53; +} +} +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_inc(x_58); lean_inc(x_57); -lean_dec(x_45); -x_62 = lean_ctor_get(x_46, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_46, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 3); -lean_inc(x_64); -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_65 = x_46; +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); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 3); +lean_inc(x_61); +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; } else { - lean_dec_ref(x_46); - x_65 = lean_box(0); + lean_dec_ref(x_42); + x_62 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_63 = x_62; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_38); -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); -lean_ctor_set(x_44, 1, x_67); -return x_44; +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); +if (lean_is_scalar(x_32)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_32; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_43); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } 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; lean_object* x_80; lean_object* x_81; -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -lean_dec(x_44); -x_69 = lean_ctor_get(x_45, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_45, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 5); -lean_inc(x_73); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_74 = x_45; +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_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); +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_39); +if (lean_is_scalar(x_32)) { + x_72 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_74 = lean_box(0); + x_72 = x_32; } -x_75 = lean_ctor_get(x_46, 0); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_41); +return x_72; +} +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_inc(x_75); -x_76 = lean_ctor_get(x_46, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_46, 3); -lean_inc(x_77); -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_78 = x_46; +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); +if (lean_is_scalar(x_32)) { + x_77 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_46); - x_78 = lean_box(0); + x_77 = x_32; } -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_38); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); -} else { - x_80 = x_74; -} -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, 2, 0); -lean_ctor_set(x_81, 0, x_68); -lean_ctor_set(x_81, 1, x_80); -return x_81; +lean_ctor_set(x_77, 0, x_67); +lean_ctor_set(x_77, 1, x_41); +return x_77; } } else { -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_44, 1); +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_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); +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_is_exclusive(x_44); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_44, 1); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_82, 2); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) -{ -lean_object* x_89; -x_89 = lean_ctor_get(x_83, 2); -lean_dec(x_89); -lean_ctor_set(x_83, 2, x_38); -return x_44; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_90 = lean_ctor_get(x_83, 0); -x_91 = lean_ctor_get(x_83, 1); -x_92 = lean_ctor_get(x_83, 3); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_83); -x_93 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_93, 0, x_90); -lean_ctor_set(x_93, 1, x_91); -lean_ctor_set(x_93, 2, x_38); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set(x_82, 2, x_93); -return x_44; -} -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_94 = lean_ctor_get(x_82, 0); -x_95 = lean_ctor_get(x_82, 1); -x_96 = lean_ctor_get(x_82, 3); -x_97 = lean_ctor_get(x_82, 4); -x_98 = lean_ctor_get(x_82, 5); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_82); -x_99 = lean_ctor_get(x_83, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_83, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_83, 3); -lean_inc(x_101); -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_102 = 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; } else { - lean_dec_ref(x_83); - x_102 = lean_box(0); + lean_dec_ref(x_66); + x_86 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); } else { - x_103 = x_102; + x_87 = x_86; } -lean_ctor_set(x_103, 0, x_99); -lean_ctor_set(x_103, 1, x_100); -lean_ctor_set(x_103, 2, x_38); -lean_ctor_set(x_103, 3, x_101); -x_104 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_104, 0, x_94); -lean_ctor_set(x_104, 1, x_95); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_96); -lean_ctor_set(x_104, 4, x_97); -lean_ctor_set(x_104, 5, x_98); -lean_ctor_set(x_44, 1, x_104); -return x_44; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_105 = lean_ctor_get(x_44, 0); -lean_inc(x_105); -lean_dec(x_44); -x_106 = lean_ctor_get(x_82, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_82, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_82, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 5); -lean_inc(x_110); -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_111 = x_82; +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); +if (lean_is_scalar(x_32)) { + x_89 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + x_89 = x_32; } -x_112 = lean_ctor_get(x_83, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_83, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_83, 3); -lean_inc(x_114); -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_115 = x_83; -} else { - lean_dec_ref(x_83); - x_115 = lean_box(0); +lean_ctor_set(x_89, 0, x_67); +lean_ctor_set(x_89, 1, x_88); +return x_89; } -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_38); -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); -x_118 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_118, 0, x_105); -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; -x_119 = lean_ctor_get(x_12, 0); -x_120 = lean_ctor_get(x_12, 1); -x_121 = lean_ctor_get(x_12, 2); -x_122 = lean_ctor_get(x_12, 3); -x_123 = lean_ctor_get(x_12, 4); -lean_inc(x_123); -lean_inc(x_122); +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_dec(x_12); -x_124 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_124, 0, x_32); -lean_ctor_set(x_124, 1, x_20); -x_125 = lean_array_push(x_121, x_124); -x_126 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_126, 0, x_119); -lean_ctor_set(x_126, 1, x_120); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_122); -lean_ctor_set(x_126, 4, x_123); -x_127 = 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_34, x_126, x_31); -if (lean_obj_tag(x_127) == 0) -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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_128 = lean_ctor_get(x_127, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_127, 0); -lean_inc(x_130); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_131 = x_127; +lean_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_127); + 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_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_128, 0); +x_132 = lean_ctor_get(x_124, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_128, 1); +x_133 = lean_ctor_get(x_124, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_128, 3); +x_134 = lean_ctor_get(x_124, 3); lean_inc(x_134); -x_135 = lean_ctor_get(x_128, 4); -lean_inc(x_135); -x_136 = lean_ctor_get(x_128, 5); -lean_inc(x_136); -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_137 = x_128; +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_128); - x_137 = lean_box(0); + lean_dec_ref(x_124); + x_135 = lean_box(0); } -x_138 = lean_ctor_get(x_129, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_129, 1); -lean_inc(x_139); -x_140 = lean_ctor_get(x_129, 3); -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); - x_141 = x_129; +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_129); - x_141 = lean_box(0); + x_136 = x_135; } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 4, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_138); -lean_ctor_set(x_142, 1, x_139); -lean_ctor_set(x_142, 2, x_38); -lean_ctor_set(x_142, 3, x_140); -if (lean_is_scalar(x_137)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_137; -} -lean_ctor_set(x_143, 0, x_132); -lean_ctor_set(x_143, 1, x_133); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_134); -lean_ctor_set(x_143, 4, x_135); -lean_ctor_set(x_143, 5, x_136); +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_144 = lean_alloc_ctor(0, 2, 0); + x_137 = lean_alloc_ctor(0, 6, 0); } else { - x_144 = x_131; + x_137 = x_131; } -lean_ctor_set(x_144, 0, x_130); -lean_ctor_set(x_144, 1, x_143); -return x_144; +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_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_145 = lean_ctor_get(x_127, 1); +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); -x_146 = lean_ctor_get(x_145, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 0); +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); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_148 = x_127; -} else { - lean_dec_ref(x_127); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_145, 0); +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_145, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_145, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_145, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_145, 5); -lean_inc(x_153); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - lean_ctor_release(x_145, 3); - lean_ctor_release(x_145, 4); - lean_ctor_release(x_145, 5); - x_154 = x_145; +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_145); - x_154 = lean_box(0); + lean_dec_ref(x_139); + x_150 = lean_box(0); } -x_155 = lean_ctor_get(x_146, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_146, 3); -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); - x_158 = x_146; +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_146); - x_158 = lean_box(0); + x_151 = x_150; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 4, 0); +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_159 = x_158; + x_152 = x_146; } -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_38); -lean_ctor_set(x_159, 3, x_157); -if (lean_is_scalar(x_154)) { - x_160 = lean_alloc_ctor(0, 6, 0); +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_160 = x_154; + x_153 = x_32; } -lean_ctor_set(x_160, 0, x_149); -lean_ctor_set(x_160, 1, x_150); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_151); -lean_ctor_set(x_160, 4, x_152); -lean_ctor_set(x_160, 5, x_153); -if (lean_is_scalar(x_148)) { - x_161 = lean_alloc_ctor(1, 2, 0); -} else { - x_161 = x_148; +lean_ctor_set(x_153, 0, x_140); +lean_ctor_set(x_153, 1, x_152); +return x_153; } -lean_ctor_set(x_161, 0, x_147); -lean_ctor_set(x_161, 1, x_160); -return x_161; } } } else { -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; -x_162 = lean_ctor_get(x_36, 0); -x_163 = lean_ctor_get(x_36, 1); -x_164 = lean_ctor_get(x_36, 2); -x_165 = lean_ctor_get(x_36, 3); -lean_inc(x_165); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_36); -x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_167 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_167, 0, x_162); -lean_ctor_set(x_167, 1, x_163); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_165); -lean_ctor_set(x_31, 2, x_167); -x_168 = lean_ctor_get(x_12, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_12, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_12, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_12, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_12, 4); -lean_inc(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_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); 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_173 = x_12; + x_225 = x_12; } else { lean_dec_ref(x_12); - x_173 = lean_box(0); + x_225 = lean_box(0); } -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_32); -lean_ctor_set(x_174, 1, x_20); -x_175 = lean_array_push(x_170, x_174); -if (lean_is_scalar(x_173)) { - x_176 = lean_alloc_ctor(0, 5, 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_228 = lean_alloc_ctor(0, 5, 0); } else { - x_176 = x_173; + x_228 = x_225; } -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_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_34, x_176, x_31); -if (lean_obj_tag(x_177) == 0) +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___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_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_178 = lean_ctor_get(x_177, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_178, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 0); -lean_inc(x_180); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_181 = x_177; -} else { - lean_dec_ref(x_177); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_178, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 5); -lean_inc(x_186); -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_187 = x_178; -} else { - lean_dec_ref(x_178); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_179, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_179, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_179, 3); -lean_inc(x_190); -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_191 = x_179; -} else { - lean_dec_ref(x_179); - 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_164); -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_181)) { - x_194 = lean_alloc_ctor(0, 2, 0); -} else { - x_194 = x_181; -} -lean_ctor_set(x_194, 0, x_180); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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_184 = x_232; +x_185 = x_231; +goto block_216; } 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; lean_object* x_210; lean_object* x_211; -x_195 = lean_ctor_get(x_177, 1); +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_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; +} 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_195, 2); +x_196 = lean_ctor_get(x_186, 3); lean_inc(x_196); -x_197 = lean_ctor_get(x_177, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_198 = x_177; +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_177); - x_198 = lean_box(0); + lean_dec_ref(x_186); + x_197 = lean_box(0); } -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_195, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_195, 3); +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_195, 4); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 5); +lean_dec(x_184); +x_203 = lean_ctor_get(x_185, 0); lean_inc(x_203); -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_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = lean_ctor_get(x_196, 0); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_185, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 1); +x_206 = lean_ctor_get(x_185, 4); lean_inc(x_206); -x_207 = lean_ctor_get(x_196, 3); +x_207 = lean_ctor_get(x_185, 5); lean_inc(x_207); -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_208 = x_196; +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; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_185); x_208 = 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; +} else { + lean_dec_ref(x_201); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); +} else { + x_213 = x_212; +} +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_209 = lean_alloc_ctor(0, 4, 0); + x_214 = lean_alloc_ctor(0, 6, 0); } else { - x_209 = x_208; + x_214 = x_208; } -lean_ctor_set(x_209, 0, x_205); -lean_ctor_set(x_209, 1, x_206); -lean_ctor_set(x_209, 2, x_164); -lean_ctor_set(x_209, 3, x_207); -if (lean_is_scalar(x_204)) { - x_210 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_32)) { + x_215 = lean_alloc_ctor(0, 2, 0); } else { - x_210 = x_204; + x_215 = x_32; } -lean_ctor_set(x_210, 0, x_199); -lean_ctor_set(x_210, 1, x_200); -lean_ctor_set(x_210, 2, x_209); -lean_ctor_set(x_210, 3, x_201); -lean_ctor_set(x_210, 4, x_202); -lean_ctor_set(x_210, 5, x_203); -if (lean_is_scalar(x_198)) { - x_211 = lean_alloc_ctor(1, 2, 0); -} else { - x_211 = x_198; +lean_ctor_set(x_215, 0, x_202); +lean_ctor_set(x_215, 1, x_214); +return x_215; } -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; 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; -x_212 = lean_ctor_get(x_31, 2); -x_213 = lean_ctor_get(x_31, 0); -x_214 = lean_ctor_get(x_31, 1); -x_215 = lean_ctor_get(x_31, 3); -x_216 = lean_ctor_get(x_31, 4); -x_217 = lean_ctor_get(x_31, 5); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_212); -lean_inc(x_214); -lean_inc(x_213); -lean_dec(x_31); -x_218 = lean_ctor_get(x_212, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_212, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_212, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_212, 3); -lean_inc(x_221); -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); - x_222 = x_212; -} else { - lean_dec_ref(x_212); - x_222 = lean_box(0); -} -x_223 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 4, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_218); -lean_ctor_set(x_224, 1, x_219); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_221); -x_225 = lean_alloc_ctor(0, 6, 0); -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); -x_226 = lean_ctor_get(x_12, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_12, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_12, 2); -lean_inc(x_228); -x_229 = lean_ctor_get(x_12, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_12, 4); -lean_inc(x_230); -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_231 = x_12; -} else { - lean_dec_ref(x_12); - x_231 = lean_box(0); -} -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_32); -lean_ctor_set(x_232, 1, x_20); -x_233 = lean_array_push(x_228, x_232); -if (lean_is_scalar(x_231)) { - x_234 = lean_alloc_ctor(0, 5, 0); -} else { - x_234 = x_231; -} -lean_ctor_set(x_234, 0, x_226); -lean_ctor_set(x_234, 1, x_227); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_229); -lean_ctor_set(x_234, 4, x_230); -x_235 = 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_34, x_234, x_225); -if (lean_obj_tag(x_235) == 0) -{ -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; lean_object* x_252; -x_236 = lean_ctor_get(x_235, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_236, 2); -lean_inc(x_237); -x_238 = lean_ctor_get(x_235, 0); -lean_inc(x_238); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_239 = x_235; -} else { - lean_dec_ref(x_235); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_236, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 3); -lean_inc(x_242); -x_243 = lean_ctor_get(x_236, 4); -lean_inc(x_243); -x_244 = lean_ctor_get(x_236, 5); -lean_inc(x_244); -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); -x_247 = lean_ctor_get(x_237, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_237, 3); -lean_inc(x_248); -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); - x_249 = x_237; -} else { - lean_dec_ref(x_237); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_246); -lean_ctor_set(x_250, 1, x_247); -lean_ctor_set(x_250, 2, x_220); -lean_ctor_set(x_250, 3, x_248); -if (lean_is_scalar(x_245)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_245; -} -lean_ctor_set(x_251, 0, x_240); -lean_ctor_set(x_251, 1, x_241); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_242); -lean_ctor_set(x_251, 4, x_243); -lean_ctor_set(x_251, 5, x_244); -if (lean_is_scalar(x_239)) { - x_252 = lean_alloc_ctor(0, 2, 0); -} else { - x_252 = x_239; -} -lean_ctor_set(x_252, 0, x_238); -lean_ctor_set(x_252, 1, x_251); -return x_252; -} -else -{ -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; -x_253 = lean_ctor_get(x_235, 1); -lean_inc(x_253); -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_235, 0); -lean_inc(x_255); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_256 = x_235; -} else { - lean_dec_ref(x_235); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_253, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_253, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_253, 3); -lean_inc(x_259); -x_260 = lean_ctor_get(x_253, 4); -lean_inc(x_260); -x_261 = lean_ctor_get(x_253, 5); -lean_inc(x_261); -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); - lean_ctor_release(x_253, 4); - lean_ctor_release(x_253, 5); - x_262 = x_253; -} else { - lean_dec_ref(x_253); - x_262 = lean_box(0); -} -x_263 = lean_ctor_get(x_254, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_254, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_254, 3); -lean_inc(x_265); -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_266 = x_254; -} else { - lean_dec_ref(x_254); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(0, 4, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_263); -lean_ctor_set(x_267, 1, x_264); -lean_ctor_set(x_267, 2, x_220); -lean_ctor_set(x_267, 3, x_265); -if (lean_is_scalar(x_262)) { - x_268 = lean_alloc_ctor(0, 6, 0); -} else { - x_268 = x_262; -} -lean_ctor_set(x_268, 0, x_257); -lean_ctor_set(x_268, 1, x_258); -lean_ctor_set(x_268, 2, x_267); -lean_ctor_set(x_268, 3, x_259); -lean_ctor_set(x_268, 4, x_260); -lean_ctor_set(x_268, 5, x_261); -if (lean_is_scalar(x_256)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_256; -} -lean_ctor_set(x_269, 0, x_255); -lean_ctor_set(x_269, 1, x_268); -return x_269; } } } default: { -lean_object* x_270; lean_object* x_271; -x_270 = lean_ctor_get(x_25, 1); -lean_inc(x_270); +lean_object* x_236; lean_object* x_237; +x_236 = lean_ctor_get(x_25, 1); +lean_inc(x_236); lean_dec(x_25); lean_inc(x_12); -x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); -if (lean_obj_tag(x_271) == 0) +x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); +if (lean_obj_tag(x_237) == 0) { -lean_object* x_272; -x_272 = lean_ctor_get(x_271, 0); -lean_inc(x_272); -if (lean_obj_tag(x_272) == 0) +lean_object* x_238; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +if (lean_obj_tag(x_238) == 0) { -lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_dec(x_20); -x_273 = lean_ctor_get(x_271, 1); -lean_inc(x_273); -lean_dec(x_271); -x_274 = lean_unsigned_to_nat(1u); -x_275 = lean_nat_add(x_11, x_274); +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); lean_dec(x_11); -x_11 = x_275; -x_13 = x_273; +x_11 = x_241; +x_13 = x_239; goto _start; } else { -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_277 = lean_ctor_get(x_271, 1); -lean_inc(x_277); -lean_dec(x_271); -x_278 = lean_ctor_get(x_272, 0); -lean_inc(x_278); -lean_dec(x_272); -x_279 = lean_unsigned_to_nat(1u); -x_280 = lean_nat_add(x_11, x_279); +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_237); + x_244 = 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_281 = !lean_is_exclusive(x_277); -if (x_281 == 0) +x_248 = !lean_is_exclusive(x_243); +if (x_248 == 0) { -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_277, 2); -x_283 = !lean_is_exclusive(x_282); -if (x_283 == 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_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_282, 2); -x_285 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_282, 2, x_285); -x_286 = !lean_is_exclusive(x_12); -if (x_286 == 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_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_287 = lean_ctor_get(x_12, 2); -x_288 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_288, 0, x_278); -lean_ctor_set(x_288, 1, x_20); -x_289 = lean_array_push(x_287, x_288); -lean_ctor_set(x_12, 2, x_289); -x_290 = 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_280, x_12, x_277); -if (lean_obj_tag(x_290) == 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_291; lean_object* x_292; uint8_t x_293; -x_291 = lean_ctor_get(x_290, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_291, 2); -lean_inc(x_292); -x_293 = !lean_is_exclusive(x_290); -if (x_293 == 0) -{ -lean_object* x_294; uint8_t x_295; -x_294 = lean_ctor_get(x_290, 1); -lean_dec(x_294); -x_295 = !lean_is_exclusive(x_291); -if (x_295 == 0) -{ -lean_object* x_296; uint8_t x_297; -x_296 = lean_ctor_get(x_291, 2); -lean_dec(x_296); -x_297 = !lean_is_exclusive(x_292); -if (x_297 == 0) -{ -lean_object* x_298; -x_298 = lean_ctor_get(x_292, 2); -lean_dec(x_298); -lean_ctor_set(x_292, 2, x_284); -return x_290; -} -else -{ -lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; -x_299 = lean_ctor_get(x_292, 0); -x_300 = lean_ctor_get(x_292, 1); -x_301 = lean_ctor_get(x_292, 3); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_dec(x_292); -x_302 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_284); -lean_ctor_set(x_302, 3, x_301); -lean_ctor_set(x_291, 2, x_302); -return x_290; -} -} -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; -x_303 = lean_ctor_get(x_291, 0); -x_304 = lean_ctor_get(x_291, 1); -x_305 = lean_ctor_get(x_291, 3); -x_306 = lean_ctor_get(x_291, 4); -x_307 = lean_ctor_get(x_291, 5); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_291); -x_308 = lean_ctor_get(x_292, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_292, 1); +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_292, 3); +x_310 = lean_ctor_get(x_308, 1); lean_inc(x_310); -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); - x_311 = x_292; -} else { - lean_dec_ref(x_292); - x_311 = lean_box(0); +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; } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 4, 0); -} else { - x_312 = x_311; -} -lean_ctor_set(x_312, 0, x_308); -lean_ctor_set(x_312, 1, x_309); -lean_ctor_set(x_312, 2, x_284); -lean_ctor_set(x_312, 3, x_310); -x_313 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_313, 0, x_303); -lean_ctor_set(x_313, 1, x_304); -lean_ctor_set(x_313, 2, x_312); -lean_ctor_set(x_313, 3, x_305); -lean_ctor_set(x_313, 4, x_306); -lean_ctor_set(x_313, 5, x_307); -lean_ctor_set(x_290, 1, x_313); -return x_290; +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_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_314 = lean_ctor_get(x_290, 0); -lean_inc(x_314); -lean_dec(x_290); -x_315 = lean_ctor_get(x_291, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_291, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_291, 3); -lean_inc(x_317); -x_318 = lean_ctor_get(x_291, 4); -lean_inc(x_318); -x_319 = lean_ctor_get(x_291, 5); +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); -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); - lean_ctor_release(x_291, 5); - x_320 = x_291; -} else { - lean_dec_ref(x_291); - x_320 = lean_box(0); -} -x_321 = lean_ctor_get(x_292, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_292, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_292, 3); -lean_inc(x_323); -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); - x_324 = x_292; -} else { - lean_dec_ref(x_292); - x_324 = lean_box(0); -} -if (lean_is_scalar(x_324)) { - x_325 = lean_alloc_ctor(0, 4, 0); -} else { - x_325 = x_324; -} -lean_ctor_set(x_325, 0, x_321); -lean_ctor_set(x_325, 1, x_322); -lean_ctor_set(x_325, 2, x_284); -lean_ctor_set(x_325, 3, x_323); -if (lean_is_scalar(x_320)) { - x_326 = lean_alloc_ctor(0, 6, 0); -} else { - x_326 = x_320; -} -lean_ctor_set(x_326, 0, x_315); -lean_ctor_set(x_326, 1, x_316); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_317); -lean_ctor_set(x_326, 4, x_318); -lean_ctor_set(x_326, 5, x_319); -x_327 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_327, 0, x_314); -lean_ctor_set(x_327, 1, x_326); -return x_327; -} -} -else -{ -lean_object* x_328; lean_object* x_329; uint8_t x_330; -x_328 = lean_ctor_get(x_290, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_328, 2); -lean_inc(x_329); -x_330 = !lean_is_exclusive(x_290); -if (x_330 == 0) -{ -lean_object* x_331; uint8_t x_332; -x_331 = lean_ctor_get(x_290, 1); -lean_dec(x_331); -x_332 = !lean_is_exclusive(x_328); -if (x_332 == 0) -{ -lean_object* x_333; uint8_t x_334; -x_333 = lean_ctor_get(x_328, 2); -lean_dec(x_333); -x_334 = !lean_is_exclusive(x_329); -if (x_334 == 0) -{ -lean_object* x_335; -x_335 = lean_ctor_get(x_329, 2); -lean_dec(x_335); -lean_ctor_set(x_329, 2, x_284); -return x_290; -} -else -{ -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; -x_336 = lean_ctor_get(x_329, 0); -x_337 = lean_ctor_get(x_329, 1); -x_338 = lean_ctor_get(x_329, 3); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_dec(x_329); -x_339 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_339, 0, x_336); -lean_ctor_set(x_339, 1, x_337); -lean_ctor_set(x_339, 2, x_284); -lean_ctor_set(x_339, 3, x_338); -lean_ctor_set(x_328, 2, x_339); -return x_290; -} -} -else -{ -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_340 = lean_ctor_get(x_328, 0); -x_341 = lean_ctor_get(x_328, 1); -x_342 = lean_ctor_get(x_328, 3); -x_343 = lean_ctor_get(x_328, 4); -x_344 = lean_ctor_get(x_328, 5); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_328); -x_345 = lean_ctor_get(x_329, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_329, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_329, 3); -lean_inc(x_347); -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_348 = x_329; -} else { - lean_dec_ref(x_329); - 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_284); -lean_ctor_set(x_349, 3, x_347); -x_350 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_350, 0, x_340); -lean_ctor_set(x_350, 1, x_341); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_342); -lean_ctor_set(x_350, 4, x_343); -lean_ctor_set(x_350, 5, x_344); -lean_ctor_set(x_290, 1, x_350); -return x_290; -} -} -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; -x_351 = lean_ctor_get(x_290, 0); -lean_inc(x_351); -lean_dec(x_290); -x_352 = lean_ctor_get(x_328, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_328, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_328, 3); -lean_inc(x_354); -x_355 = lean_ctor_get(x_328, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_328, 5); -lean_inc(x_356); -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_357 = x_328; -} else { - lean_dec_ref(x_328); - x_357 = lean_box(0); -} -x_358 = lean_ctor_get(x_329, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_329, 1); -lean_inc(x_359); -x_360 = lean_ctor_get(x_329, 3); -lean_inc(x_360); -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_361 = x_329; -} else { - lean_dec_ref(x_329); - x_361 = lean_box(0); -} -if (lean_is_scalar(x_361)) { - x_362 = lean_alloc_ctor(0, 4, 0); -} else { - x_362 = x_361; -} -lean_ctor_set(x_362, 0, x_358); -lean_ctor_set(x_362, 1, x_359); -lean_ctor_set(x_362, 2, x_284); -lean_ctor_set(x_362, 3, x_360); -if (lean_is_scalar(x_357)) { - x_363 = lean_alloc_ctor(0, 6, 0); -} else { - x_363 = 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); -x_364 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_364, 0, x_351); -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; -x_365 = lean_ctor_get(x_12, 0); -x_366 = lean_ctor_get(x_12, 1); -x_367 = lean_ctor_get(x_12, 2); -x_368 = lean_ctor_get(x_12, 3); -x_369 = lean_ctor_get(x_12, 4); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); +lean_inc(x_318); +lean_inc(x_317); +lean_inc(x_316); +lean_inc(x_315); lean_dec(x_12); -x_370 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_370, 0, x_278); -lean_ctor_set(x_370, 1, x_20); -x_371 = lean_array_push(x_367, x_370); -x_372 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_372, 0, x_365); -lean_ctor_set(x_372, 1, x_366); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_368); -lean_ctor_set(x_372, 4, x_369); -x_373 = 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_280, x_372, x_277); -if (lean_obj_tag(x_373) == 0) +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_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; lean_object* x_390; -x_374 = lean_ctor_get(x_373, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_373, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_377 = x_373; -} else { - lean_dec_ref(x_373); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_374, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); -lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); -lean_inc(x_382); -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); - lean_ctor_release(x_374, 5); - x_383 = x_374; -} else { - lean_dec_ref(x_374); - x_383 = lean_box(0); -} -x_384 = lean_ctor_get(x_375, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_375, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_375, 3); -lean_inc(x_386); -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_387 = x_375; -} else { - lean_dec_ref(x_375); - x_387 = lean_box(0); -} -if (lean_is_scalar(x_387)) { - x_388 = lean_alloc_ctor(0, 4, 0); -} else { - x_388 = x_387; -} -lean_ctor_set(x_388, 0, x_384); -lean_ctor_set(x_388, 1, x_385); -lean_ctor_set(x_388, 2, x_284); -lean_ctor_set(x_388, 3, x_386); -if (lean_is_scalar(x_383)) { - x_389 = lean_alloc_ctor(0, 6, 0); -} else { - x_389 = x_383; -} -lean_ctor_set(x_389, 0, x_378); -lean_ctor_set(x_389, 1, x_379); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_389, 3, x_380); -lean_ctor_set(x_389, 4, x_381); -lean_ctor_set(x_389, 5, x_382); -if (lean_is_scalar(x_377)) { - x_390 = lean_alloc_ctor(0, 2, 0); -} else { - x_390 = x_377; -} -lean_ctor_set(x_390, 0, x_376); -lean_ctor_set(x_390, 1, x_389); -return x_390; +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_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; lean_object* x_406; lean_object* x_407; -x_391 = lean_ctor_get(x_373, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_373, 0); -lean_inc(x_393); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_394 = x_373; -} else { - lean_dec_ref(x_373); - x_394 = lean_box(0); +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; } -x_395 = lean_ctor_get(x_391, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 3); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 4); -lean_inc(x_398); -x_399 = lean_ctor_get(x_391, 5); -lean_inc(x_399); -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_400 = x_391; -} else { - lean_dec_ref(x_391); - x_400 = lean_box(0); } -x_401 = lean_ctor_get(x_392, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_392, 3); -lean_inc(x_403); -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_404 = x_392; +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); +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 { - lean_dec_ref(x_392); - x_404 = lean_box(0); + x_260 = x_244; + lean_ctor_set_tag(x_260, 1); } -if (lean_is_scalar(x_404)) { - x_405 = lean_alloc_ctor(0, 4, 0); +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; +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_405 = x_404; + x_265 = x_244; + lean_ctor_set_tag(x_265, 1); } -lean_ctor_set(x_405, 0, x_401); -lean_ctor_set(x_405, 1, x_402); -lean_ctor_set(x_405, 2, x_284); -lean_ctor_set(x_405, 3, x_403); -if (lean_is_scalar(x_400)) { - x_406 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_265, 0, x_255); +lean_ctor_set(x_265, 1, x_253); +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; 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_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 { - x_406 = x_400; + lean_dec_ref(x_254); + x_274 = lean_box(0); } -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_394)) { - x_407 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 4, 0); } else { - x_407 = x_394; + x_275 = x_274; +} +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, 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); +} else { + x_277 = x_244; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_255); +lean_ctor_set(x_277, 1, x_276); +return x_277; +} +} +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_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_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); +} else { + x_289 = x_244; +} +lean_ctor_set(x_289, 0, x_279); +lean_ctor_set(x_289, 1, x_253); +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_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); +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; +} else { + lean_dec_ref(x_278); + x_298 = lean_box(0); +} +if (lean_is_scalar(x_298)) { + x_299 = lean_alloc_ctor(0, 4, 0); +} else { + x_299 = x_298; +} +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); +} else { + x_301 = x_244; +} +lean_ctor_set(x_301, 0, x_279); +lean_ctor_set(x_301, 1, x_300); +return x_301; } -lean_ctor_set(x_407, 0, x_393); -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; lean_object* x_423; -x_408 = lean_ctor_get(x_282, 0); -x_409 = lean_ctor_get(x_282, 1); -x_410 = lean_ctor_get(x_282, 2); -x_411 = lean_ctor_get(x_282, 3); -lean_inc(x_411); -lean_inc(x_410); -lean_inc(x_409); -lean_inc(x_408); -lean_dec(x_282); -x_412 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_413 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_413, 0, x_408); -lean_ctor_set(x_413, 1, x_409); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_411); -lean_ctor_set(x_277, 2, x_413); -x_414 = lean_ctor_get(x_12, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_12, 1); -lean_inc(x_415); -x_416 = lean_ctor_get(x_12, 2); -lean_inc(x_416); -x_417 = lean_ctor_get(x_12, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_12, 4); -lean_inc(x_418); +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); 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_419 = x_12; + x_374 = x_12; } else { lean_dec_ref(x_12); - x_419 = lean_box(0); + x_374 = lean_box(0); } -x_420 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_420, 0, x_278); -lean_ctor_set(x_420, 1, x_20); -x_421 = lean_array_push(x_416, x_420); -if (lean_is_scalar(x_419)) { - x_422 = lean_alloc_ctor(0, 5, 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); } else { - x_422 = x_419; + x_377 = x_374; } -lean_ctor_set(x_422, 0, x_414); -lean_ctor_set(x_422, 1, x_415); -lean_ctor_set(x_422, 2, x_421); -lean_ctor_set(x_422, 3, x_417); -lean_ctor_set(x_422, 4, x_418); -x_423 = 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_280, x_422, x_277); -if (lean_obj_tag(x_423) == 0) +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_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; lean_object* x_439; lean_object* x_440; -x_424 = lean_ctor_get(x_423, 1); -lean_inc(x_424); -x_425 = lean_ctor_get(x_424, 2); -lean_inc(x_425); -x_426 = lean_ctor_get(x_423, 0); -lean_inc(x_426); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_427 = x_423; -} else { - lean_dec_ref(x_423); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_424, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_424, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_424, 3); -lean_inc(x_430); -x_431 = lean_ctor_get(x_424, 4); -lean_inc(x_431); -x_432 = lean_ctor_get(x_424, 5); -lean_inc(x_432); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - lean_ctor_release(x_424, 4); - lean_ctor_release(x_424, 5); - x_433 = x_424; -} else { - lean_dec_ref(x_424); - x_433 = lean_box(0); -} -x_434 = lean_ctor_get(x_425, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_425, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_425, 3); -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); - 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, 4, 0); -} else { - x_438 = x_437; -} -lean_ctor_set(x_438, 0, x_434); -lean_ctor_set(x_438, 1, x_435); -lean_ctor_set(x_438, 2, x_410); -lean_ctor_set(x_438, 3, x_436); -if (lean_is_scalar(x_433)) { - x_439 = lean_alloc_ctor(0, 6, 0); -} else { - x_439 = x_433; -} -lean_ctor_set(x_439, 0, x_428); -lean_ctor_set(x_439, 1, x_429); -lean_ctor_set(x_439, 2, x_438); -lean_ctor_set(x_439, 3, x_430); -lean_ctor_set(x_439, 4, x_431); -lean_ctor_set(x_439, 5, x_432); -if (lean_is_scalar(x_427)) { - x_440 = lean_alloc_ctor(0, 2, 0); -} else { - x_440 = x_427; -} -lean_ctor_set(x_440, 0, x_426); -lean_ctor_set(x_440, 1, x_439); -return x_440; +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; } else { -lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_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; -x_441 = lean_ctor_get(x_423, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_441, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_423, 0); -lean_inc(x_443); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_444 = x_423; -} else { - lean_dec_ref(x_423); - x_444 = lean_box(0); +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; } +block_366: +{ +if (lean_obj_tag(x_334) == 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_inc(x_351); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +lean_dec(x_334); +x_353 = lean_ctor_get(x_335, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_335, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_335, 3); +lean_inc(x_355); +x_356 = lean_ctor_get(x_335, 4); +lean_inc(x_356); +x_357 = lean_ctor_get(x_335, 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; +} else { + lean_dec_ref(x_335); + x_358 = lean_box(0); +} +x_359 = lean_ctor_get(x_351, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_351, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_351, 3); +lean_inc(x_361); +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; +} else { + lean_dec_ref(x_351); + x_362 = lean_box(0); +} +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 4, 0); +} else { + x_363 = x_362; +} +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); +if (lean_is_scalar(x_358)) { + x_364 = lean_alloc_ctor(0, 6, 0); +} else { + x_364 = 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); +} else { + x_365 = x_244; +} +lean_ctor_set(x_365, 0, x_352); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +} +} +} +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; +} else { + lean_dec_ref(x_385); + x_395 = 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); +} else { + x_430 = x_395; +} +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); +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; +} else { + lean_dec_ref(x_12); + x_437 = 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); +} else { + x_440 = x_437; +} +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_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; +} +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); -x_447 = lean_ctor_get(x_441, 3); -lean_inc(x_447); -x_448 = lean_ctor_get(x_441, 4); -lean_inc(x_448); -x_449 = lean_ctor_get(x_441, 5); -lean_inc(x_449); -if (lean_is_exclusive(x_441)) { - lean_ctor_release(x_441, 0); - lean_ctor_release(x_441, 1); - lean_ctor_release(x_441, 2); - lean_ctor_release(x_441, 3); - lean_ctor_release(x_441, 4); - lean_ctor_release(x_441, 5); - x_450 = x_441; +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; +} +block_428: +{ +if (lean_obj_tag(x_396) == 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_441); - x_450 = lean_box(0); + lean_dec_ref(x_397); + x_405 = lean_box(0); } -x_451 = lean_ctor_get(x_442, 0); -lean_inc(x_451); -x_452 = lean_ctor_get(x_442, 1); -lean_inc(x_452); -x_453 = lean_ctor_get(x_442, 3); -lean_inc(x_453); -if (lean_is_exclusive(x_442)) { - lean_ctor_release(x_442, 0); - lean_ctor_release(x_442, 1); - lean_ctor_release(x_442, 2); - lean_ctor_release(x_442, 3); - x_454 = x_442; +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_442); - x_454 = lean_box(0); + lean_dec_ref(x_398); + x_409 = lean_box(0); } -if (lean_is_scalar(x_454)) { - x_455 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_409)) { + x_410 = lean_alloc_ctor(0, 4, 0); } else { - x_455 = x_454; + x_410 = x_409; } -lean_ctor_set(x_455, 0, x_451); -lean_ctor_set(x_455, 1, x_452); -lean_ctor_set(x_455, 2, x_410); -lean_ctor_set(x_455, 3, x_453); -if (lean_is_scalar(x_450)) { - x_456 = lean_alloc_ctor(0, 6, 0); +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_456 = x_450; + x_411 = x_405; } -lean_ctor_set(x_456, 0, x_445); -lean_ctor_set(x_456, 1, x_446); -lean_ctor_set(x_456, 2, x_455); -lean_ctor_set(x_456, 3, x_447); -lean_ctor_set(x_456, 4, x_448); -lean_ctor_set(x_456, 5, x_449); -if (lean_is_scalar(x_444)) { - x_457 = lean_alloc_ctor(1, 2, 0); +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_457 = x_444; -} -lean_ctor_set(x_457, 0, x_443); -lean_ctor_set(x_457, 1, x_456); -return x_457; -} + 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_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; 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; lean_object* x_481; -x_458 = lean_ctor_get(x_277, 2); -x_459 = lean_ctor_get(x_277, 0); -x_460 = lean_ctor_get(x_277, 1); -x_461 = lean_ctor_get(x_277, 3); -x_462 = lean_ctor_get(x_277, 4); -x_463 = lean_ctor_get(x_277, 5); -lean_inc(x_463); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_458); -lean_inc(x_460); -lean_inc(x_459); -lean_dec(x_277); -x_464 = lean_ctor_get(x_458, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_458, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_458, 2); -lean_inc(x_466); -x_467 = lean_ctor_get(x_458, 3); -lean_inc(x_467); -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); - x_468 = x_458; +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_inc(x_416); +x_417 = lean_ctor_get(x_397, 3); +lean_inc(x_417); +x_418 = lean_ctor_get(x_397, 4); +lean_inc(x_418); +x_419 = lean_ctor_get(x_397, 5); +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_458); - x_468 = lean_box(0); + lean_dec_ref(x_397); + x_420 = lean_box(0); } -x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_468)) { - x_470 = lean_alloc_ctor(0, 4, 0); +x_421 = lean_ctor_get(x_413, 0); +lean_inc(x_421); +x_422 = lean_ctor_get(x_413, 1); +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; } else { - x_470 = x_468; + lean_dec_ref(x_413); + x_424 = lean_box(0); } -lean_ctor_set(x_470, 0, x_464); -lean_ctor_set(x_470, 1, x_465); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_467); -x_471 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_471, 0, x_459); -lean_ctor_set(x_471, 1, x_460); -lean_ctor_set(x_471, 2, x_470); -lean_ctor_set(x_471, 3, x_461); -lean_ctor_set(x_471, 4, x_462); -lean_ctor_set(x_471, 5, x_463); -x_472 = lean_ctor_get(x_12, 0); -lean_inc(x_472); -x_473 = lean_ctor_get(x_12, 1); -lean_inc(x_473); -x_474 = lean_ctor_get(x_12, 2); -lean_inc(x_474); -x_475 = lean_ctor_get(x_12, 3); -lean_inc(x_475); -x_476 = lean_ctor_get(x_12, 4); -lean_inc(x_476); -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_477 = x_12; +if (lean_is_scalar(x_424)) { + x_425 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_12); - x_477 = lean_box(0); + x_425 = x_424; } -x_478 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_478, 0, x_278); -lean_ctor_set(x_478, 1, x_20); -x_479 = lean_array_push(x_474, x_478); -if (lean_is_scalar(x_477)) { - x_480 = lean_alloc_ctor(0, 5, 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); } else { - x_480 = x_477; + x_426 = x_420; } -lean_ctor_set(x_480, 0, x_472); -lean_ctor_set(x_480, 1, x_473); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_475); -lean_ctor_set(x_480, 4, x_476); -x_481 = 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_280, x_480, x_471); -if (lean_obj_tag(x_481) == 0) -{ -lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_482 = lean_ctor_get(x_481, 1); -lean_inc(x_482); -x_483 = lean_ctor_get(x_482, 2); -lean_inc(x_483); -x_484 = lean_ctor_get(x_481, 0); -lean_inc(x_484); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_485 = x_481; +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); } else { - lean_dec_ref(x_481); - x_485 = lean_box(0); + x_427 = x_244; } -x_486 = lean_ctor_get(x_482, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_482, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_482, 3); -lean_inc(x_488); -x_489 = lean_ctor_get(x_482, 4); -lean_inc(x_489); -x_490 = lean_ctor_get(x_482, 5); -lean_inc(x_490); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - lean_ctor_release(x_482, 4); - lean_ctor_release(x_482, 5); - x_491 = x_482; -} else { - lean_dec_ref(x_482); - x_491 = lean_box(0); +lean_ctor_set(x_427, 0, x_414); +lean_ctor_set(x_427, 1, x_426); +return x_427; } -x_492 = lean_ctor_get(x_483, 0); -lean_inc(x_492); -x_493 = lean_ctor_get(x_483, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_483, 3); -lean_inc(x_494); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - lean_ctor_release(x_483, 2); - lean_ctor_release(x_483, 3); - x_495 = x_483; -} else { - lean_dec_ref(x_483); - x_495 = lean_box(0); -} -if (lean_is_scalar(x_495)) { - x_496 = lean_alloc_ctor(0, 4, 0); -} else { - x_496 = x_495; -} -lean_ctor_set(x_496, 0, x_492); -lean_ctor_set(x_496, 1, x_493); -lean_ctor_set(x_496, 2, x_466); -lean_ctor_set(x_496, 3, x_494); -if (lean_is_scalar(x_491)) { - x_497 = lean_alloc_ctor(0, 6, 0); -} else { - x_497 = x_491; -} -lean_ctor_set(x_497, 0, x_486); -lean_ctor_set(x_497, 1, x_487); -lean_ctor_set(x_497, 2, x_496); -lean_ctor_set(x_497, 3, x_488); -lean_ctor_set(x_497, 4, x_489); -lean_ctor_set(x_497, 5, x_490); -if (lean_is_scalar(x_485)) { - x_498 = lean_alloc_ctor(0, 2, 0); -} else { - x_498 = x_485; -} -lean_ctor_set(x_498, 0, x_484); -lean_ctor_set(x_498, 1, x_497); -return x_498; -} -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; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; -x_499 = lean_ctor_get(x_481, 1); -lean_inc(x_499); -x_500 = lean_ctor_get(x_499, 2); -lean_inc(x_500); -x_501 = lean_ctor_get(x_481, 0); -lean_inc(x_501); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_502 = x_481; -} else { - lean_dec_ref(x_481); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_499, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_499, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_499, 3); -lean_inc(x_505); -x_506 = lean_ctor_get(x_499, 4); -lean_inc(x_506); -x_507 = lean_ctor_get(x_499, 5); -lean_inc(x_507); -if (lean_is_exclusive(x_499)) { - lean_ctor_release(x_499, 0); - lean_ctor_release(x_499, 1); - lean_ctor_release(x_499, 2); - lean_ctor_release(x_499, 3); - lean_ctor_release(x_499, 4); - lean_ctor_release(x_499, 5); - x_508 = x_499; -} else { - lean_dec_ref(x_499); - x_508 = lean_box(0); -} -x_509 = lean_ctor_get(x_500, 0); -lean_inc(x_509); -x_510 = lean_ctor_get(x_500, 1); -lean_inc(x_510); -x_511 = lean_ctor_get(x_500, 3); -lean_inc(x_511); -if (lean_is_exclusive(x_500)) { - lean_ctor_release(x_500, 0); - lean_ctor_release(x_500, 1); - lean_ctor_release(x_500, 2); - lean_ctor_release(x_500, 3); - x_512 = x_500; -} else { - lean_dec_ref(x_500); - x_512 = lean_box(0); -} -if (lean_is_scalar(x_512)) { - x_513 = lean_alloc_ctor(0, 4, 0); -} else { - x_513 = x_512; -} -lean_ctor_set(x_513, 0, x_509); -lean_ctor_set(x_513, 1, x_510); -lean_ctor_set(x_513, 2, x_466); -lean_ctor_set(x_513, 3, x_511); -if (lean_is_scalar(x_508)) { - x_514 = lean_alloc_ctor(0, 6, 0); -} else { - x_514 = x_508; -} -lean_ctor_set(x_514, 0, x_503); -lean_ctor_set(x_514, 1, x_504); -lean_ctor_set(x_514, 2, x_513); -lean_ctor_set(x_514, 3, x_505); -lean_ctor_set(x_514, 4, x_506); -lean_ctor_set(x_514, 5, x_507); -if (lean_is_scalar(x_502)) { - x_515 = lean_alloc_ctor(1, 2, 0); -} else { - x_515 = x_502; -} -lean_ctor_set(x_515, 0, x_501); -lean_ctor_set(x_515, 1, x_514); -return x_515; } } } } else { -uint8_t x_516; +uint8_t x_448; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -30681,23 +27106,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_516 = !lean_is_exclusive(x_271); -if (x_516 == 0) +x_448 = !lean_is_exclusive(x_237); +if (x_448 == 0) { -return x_271; +return x_237; } else { -lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_517 = lean_ctor_get(x_271, 0); -x_518 = lean_ctor_get(x_271, 1); -lean_inc(x_518); -lean_inc(x_517); -lean_dec(x_271); -x_519 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_519, 0, x_517); -lean_ctor_set(x_519, 1, x_518); -return x_519; +lean_object* x_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; } } } @@ -30705,7 +27130,7 @@ return x_519; } else { -uint8_t x_520; +uint8_t x_452; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -30716,29 +27141,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_520 = !lean_is_exclusive(x_25); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_25); +if (x_452 == 0) { return x_25; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_25, 0); -x_522 = lean_ctor_get(x_25, 1); -lean_inc(x_522); -lean_inc(x_521); +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_dec(x_25); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -30748,23 +27173,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_21); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_21); +if (x_456 == 0) { return x_21; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_21, 0); -x_526 = lean_ctor_get(x_21, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_21); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } @@ -30838,2152 +27263,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -32991,58 +29054,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -33496,2152 +29559,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -35649,58 +31350,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -35820,2130 +31521,1768 @@ goto _start; } case 1: { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_dec(x_24); x_31 = lean_ctor_get(x_25, 1); lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_32 = x_25; +} else { + lean_dec_ref(x_25); + x_32 = lean_box(0); +} +x_33 = lean_ctor_get(x_26, 0); +lean_inc(x_33); lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_11, x_34); lean_dec(x_11); -x_35 = !lean_is_exclusive(x_31); -if (x_35 == 0) +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_31, 2); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_31, 2); +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) { -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_36, 2); -x_39 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_39); -x_40 = !lean_is_exclusive(x_12); -if (x_40 == 0) +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +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) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_12, 2); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_32); -lean_ctor_set(x_42, 1, x_20); -x_43 = lean_array_push(x_41, x_42); -lean_ctor_set(x_12, 2, x_43); -x_44 = 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_34, x_12, x_31); -if (lean_obj_tag(x_44) == 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_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_44, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_45, 2); -lean_inc(x_46); -x_47 = !lean_is_exclusive(x_44); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_44, 1); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_45); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_45, 2); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_46); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_46, 2); -lean_dec(x_52); -lean_ctor_set(x_46, 2, x_38); -return x_44; +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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_53 = lean_ctor_get(x_46, 0); -x_54 = lean_ctor_get(x_46, 1); -x_55 = lean_ctor_get(x_46, 3); -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_38); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); -return x_44; +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_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; } } 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; -x_57 = lean_ctor_get(x_45, 0); -x_58 = lean_ctor_get(x_45, 1); -x_59 = lean_ctor_get(x_45, 3); -x_60 = lean_ctor_get(x_45, 4); -x_61 = lean_ctor_get(x_45, 5); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); +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_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; +} +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_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; +} +} +block_90: +{ +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 2); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 0); +lean_inc(x_43); +lean_dec(x_40); +x_44 = !lean_is_exclusive(x_41); +if (x_44 == 0) +{ +lean_object* x_45; uint8_t x_46; +x_45 = lean_ctor_get(x_41, 2); +lean_dec(x_45); +x_46 = !lean_is_exclusive(x_42); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_42, 2); +lean_dec(x_47); +lean_ctor_set(x_42, 2, x_39); +if (lean_is_scalar(x_32)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_32; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_41); +return x_48; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_49 = lean_ctor_get(x_42, 0); +x_50 = lean_ctor_get(x_42, 1); +x_51 = lean_ctor_get(x_42, 3); +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); +if (lean_is_scalar(x_32)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_32; + lean_ctor_set_tag(x_53, 1); +} +lean_ctor_set(x_53, 0, x_43); +lean_ctor_set(x_53, 1, x_41); +return x_53; +} +} +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_inc(x_58); lean_inc(x_57); -lean_dec(x_45); -x_62 = lean_ctor_get(x_46, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_46, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 3); -lean_inc(x_64); -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_65 = x_46; +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); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 3); +lean_inc(x_61); +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; } else { - lean_dec_ref(x_46); - x_65 = lean_box(0); + lean_dec_ref(x_42); + x_62 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_63 = x_62; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_38); -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); -lean_ctor_set(x_44, 1, x_67); -return x_44; +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); +if (lean_is_scalar(x_32)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_32; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_43); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } 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; lean_object* x_80; lean_object* x_81; -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -lean_dec(x_44); -x_69 = lean_ctor_get(x_45, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_45, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 5); -lean_inc(x_73); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_74 = x_45; +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_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); +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_39); +if (lean_is_scalar(x_32)) { + x_72 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_74 = lean_box(0); + x_72 = x_32; } -x_75 = lean_ctor_get(x_46, 0); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_41); +return x_72; +} +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_inc(x_75); -x_76 = lean_ctor_get(x_46, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_46, 3); -lean_inc(x_77); -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_78 = x_46; +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); +if (lean_is_scalar(x_32)) { + x_77 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_46); - x_78 = lean_box(0); + x_77 = x_32; } -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_38); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); -} else { - x_80 = x_74; -} -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, 2, 0); -lean_ctor_set(x_81, 0, x_68); -lean_ctor_set(x_81, 1, x_80); -return x_81; +lean_ctor_set(x_77, 0, x_67); +lean_ctor_set(x_77, 1, x_41); +return x_77; } } else { -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_44, 1); +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_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); +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_is_exclusive(x_44); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_44, 1); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_82, 2); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) -{ -lean_object* x_89; -x_89 = lean_ctor_get(x_83, 2); -lean_dec(x_89); -lean_ctor_set(x_83, 2, x_38); -return x_44; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_90 = lean_ctor_get(x_83, 0); -x_91 = lean_ctor_get(x_83, 1); -x_92 = lean_ctor_get(x_83, 3); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_83); -x_93 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_93, 0, x_90); -lean_ctor_set(x_93, 1, x_91); -lean_ctor_set(x_93, 2, x_38); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set(x_82, 2, x_93); -return x_44; -} -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_94 = lean_ctor_get(x_82, 0); -x_95 = lean_ctor_get(x_82, 1); -x_96 = lean_ctor_get(x_82, 3); -x_97 = lean_ctor_get(x_82, 4); -x_98 = lean_ctor_get(x_82, 5); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_82); -x_99 = lean_ctor_get(x_83, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_83, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_83, 3); -lean_inc(x_101); -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_102 = 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; } else { - lean_dec_ref(x_83); - x_102 = lean_box(0); + lean_dec_ref(x_66); + x_86 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); } else { - x_103 = x_102; + x_87 = x_86; } -lean_ctor_set(x_103, 0, x_99); -lean_ctor_set(x_103, 1, x_100); -lean_ctor_set(x_103, 2, x_38); -lean_ctor_set(x_103, 3, x_101); -x_104 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_104, 0, x_94); -lean_ctor_set(x_104, 1, x_95); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_96); -lean_ctor_set(x_104, 4, x_97); -lean_ctor_set(x_104, 5, x_98); -lean_ctor_set(x_44, 1, x_104); -return x_44; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_105 = lean_ctor_get(x_44, 0); -lean_inc(x_105); -lean_dec(x_44); -x_106 = lean_ctor_get(x_82, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_82, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_82, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 5); -lean_inc(x_110); -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_111 = x_82; +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); +if (lean_is_scalar(x_32)) { + x_89 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + x_89 = x_32; } -x_112 = lean_ctor_get(x_83, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_83, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_83, 3); -lean_inc(x_114); -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_115 = x_83; -} else { - lean_dec_ref(x_83); - x_115 = lean_box(0); +lean_ctor_set(x_89, 0, x_67); +lean_ctor_set(x_89, 1, x_88); +return x_89; } -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_38); -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); -x_118 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_118, 0, x_105); -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; -x_119 = lean_ctor_get(x_12, 0); -x_120 = lean_ctor_get(x_12, 1); -x_121 = lean_ctor_get(x_12, 2); -x_122 = lean_ctor_get(x_12, 3); -x_123 = lean_ctor_get(x_12, 4); -lean_inc(x_123); -lean_inc(x_122); +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_dec(x_12); -x_124 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_124, 0, x_32); -lean_ctor_set(x_124, 1, x_20); -x_125 = lean_array_push(x_121, x_124); -x_126 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_126, 0, x_119); -lean_ctor_set(x_126, 1, x_120); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_122); -lean_ctor_set(x_126, 4, x_123); -x_127 = 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_34, x_126, x_31); -if (lean_obj_tag(x_127) == 0) -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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_128 = lean_ctor_get(x_127, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_127, 0); -lean_inc(x_130); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_131 = x_127; +lean_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_127); + 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_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_128, 0); +x_132 = lean_ctor_get(x_124, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_128, 1); +x_133 = lean_ctor_get(x_124, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_128, 3); +x_134 = lean_ctor_get(x_124, 3); lean_inc(x_134); -x_135 = lean_ctor_get(x_128, 4); -lean_inc(x_135); -x_136 = lean_ctor_get(x_128, 5); -lean_inc(x_136); -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_137 = x_128; +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_128); - x_137 = lean_box(0); + lean_dec_ref(x_124); + x_135 = lean_box(0); } -x_138 = lean_ctor_get(x_129, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_129, 1); -lean_inc(x_139); -x_140 = lean_ctor_get(x_129, 3); -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); - x_141 = x_129; +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_129); - x_141 = lean_box(0); + x_136 = x_135; } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 4, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_138); -lean_ctor_set(x_142, 1, x_139); -lean_ctor_set(x_142, 2, x_38); -lean_ctor_set(x_142, 3, x_140); -if (lean_is_scalar(x_137)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_137; -} -lean_ctor_set(x_143, 0, x_132); -lean_ctor_set(x_143, 1, x_133); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_134); -lean_ctor_set(x_143, 4, x_135); -lean_ctor_set(x_143, 5, x_136); +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_144 = lean_alloc_ctor(0, 2, 0); + x_137 = lean_alloc_ctor(0, 6, 0); } else { - x_144 = x_131; + x_137 = x_131; } -lean_ctor_set(x_144, 0, x_130); -lean_ctor_set(x_144, 1, x_143); -return x_144; +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_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_145 = lean_ctor_get(x_127, 1); +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); -x_146 = lean_ctor_get(x_145, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 0); +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); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_148 = x_127; -} else { - lean_dec_ref(x_127); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_145, 0); +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_145, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_145, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_145, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_145, 5); -lean_inc(x_153); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - lean_ctor_release(x_145, 3); - lean_ctor_release(x_145, 4); - lean_ctor_release(x_145, 5); - x_154 = x_145; +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_145); - x_154 = lean_box(0); + lean_dec_ref(x_139); + x_150 = lean_box(0); } -x_155 = lean_ctor_get(x_146, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_146, 3); -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); - x_158 = x_146; +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_146); - x_158 = lean_box(0); + x_151 = x_150; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 4, 0); +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_159 = x_158; + x_152 = x_146; } -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_38); -lean_ctor_set(x_159, 3, x_157); -if (lean_is_scalar(x_154)) { - x_160 = lean_alloc_ctor(0, 6, 0); +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_160 = x_154; + x_153 = x_32; } -lean_ctor_set(x_160, 0, x_149); -lean_ctor_set(x_160, 1, x_150); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_151); -lean_ctor_set(x_160, 4, x_152); -lean_ctor_set(x_160, 5, x_153); -if (lean_is_scalar(x_148)) { - x_161 = lean_alloc_ctor(1, 2, 0); -} else { - x_161 = x_148; +lean_ctor_set(x_153, 0, x_140); +lean_ctor_set(x_153, 1, x_152); +return x_153; } -lean_ctor_set(x_161, 0, x_147); -lean_ctor_set(x_161, 1, x_160); -return x_161; } } } else { -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; -x_162 = lean_ctor_get(x_36, 0); -x_163 = lean_ctor_get(x_36, 1); -x_164 = lean_ctor_get(x_36, 2); -x_165 = lean_ctor_get(x_36, 3); -lean_inc(x_165); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_36); -x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_167 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_167, 0, x_162); -lean_ctor_set(x_167, 1, x_163); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_165); -lean_ctor_set(x_31, 2, x_167); -x_168 = lean_ctor_get(x_12, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_12, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_12, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_12, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_12, 4); -lean_inc(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_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); 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_173 = x_12; + x_225 = x_12; } else { lean_dec_ref(x_12); - x_173 = lean_box(0); + x_225 = lean_box(0); } -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_32); -lean_ctor_set(x_174, 1, x_20); -x_175 = lean_array_push(x_170, x_174); -if (lean_is_scalar(x_173)) { - x_176 = lean_alloc_ctor(0, 5, 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_228 = lean_alloc_ctor(0, 5, 0); } else { - x_176 = x_173; + x_228 = x_225; } -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_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_34, x_176, x_31); -if (lean_obj_tag(x_177) == 0) +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___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_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_178 = lean_ctor_get(x_177, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_178, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 0); -lean_inc(x_180); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_181 = x_177; -} else { - lean_dec_ref(x_177); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_178, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 5); -lean_inc(x_186); -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_187 = x_178; -} else { - lean_dec_ref(x_178); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_179, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_179, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_179, 3); -lean_inc(x_190); -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_191 = x_179; -} else { - lean_dec_ref(x_179); - 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_164); -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_181)) { - x_194 = lean_alloc_ctor(0, 2, 0); -} else { - x_194 = x_181; -} -lean_ctor_set(x_194, 0, x_180); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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_184 = x_232; +x_185 = x_231; +goto block_216; } 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; lean_object* x_210; lean_object* x_211; -x_195 = lean_ctor_get(x_177, 1); +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_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; +} 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_195, 2); +x_196 = lean_ctor_get(x_186, 3); lean_inc(x_196); -x_197 = lean_ctor_get(x_177, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_198 = x_177; +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_177); - x_198 = lean_box(0); + lean_dec_ref(x_186); + x_197 = lean_box(0); } -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_195, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_195, 3); +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_195, 4); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 5); +lean_dec(x_184); +x_203 = lean_ctor_get(x_185, 0); lean_inc(x_203); -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_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = lean_ctor_get(x_196, 0); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_185, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 1); +x_206 = lean_ctor_get(x_185, 4); lean_inc(x_206); -x_207 = lean_ctor_get(x_196, 3); +x_207 = lean_ctor_get(x_185, 5); lean_inc(x_207); -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_208 = x_196; +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; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_185); x_208 = 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; +} else { + lean_dec_ref(x_201); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); +} else { + x_213 = x_212; +} +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_209 = lean_alloc_ctor(0, 4, 0); + x_214 = lean_alloc_ctor(0, 6, 0); } else { - x_209 = x_208; + x_214 = x_208; } -lean_ctor_set(x_209, 0, x_205); -lean_ctor_set(x_209, 1, x_206); -lean_ctor_set(x_209, 2, x_164); -lean_ctor_set(x_209, 3, x_207); -if (lean_is_scalar(x_204)) { - x_210 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_32)) { + x_215 = lean_alloc_ctor(0, 2, 0); } else { - x_210 = x_204; + x_215 = x_32; } -lean_ctor_set(x_210, 0, x_199); -lean_ctor_set(x_210, 1, x_200); -lean_ctor_set(x_210, 2, x_209); -lean_ctor_set(x_210, 3, x_201); -lean_ctor_set(x_210, 4, x_202); -lean_ctor_set(x_210, 5, x_203); -if (lean_is_scalar(x_198)) { - x_211 = lean_alloc_ctor(1, 2, 0); -} else { - x_211 = x_198; +lean_ctor_set(x_215, 0, x_202); +lean_ctor_set(x_215, 1, x_214); +return x_215; } -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; 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; -x_212 = lean_ctor_get(x_31, 2); -x_213 = lean_ctor_get(x_31, 0); -x_214 = lean_ctor_get(x_31, 1); -x_215 = lean_ctor_get(x_31, 3); -x_216 = lean_ctor_get(x_31, 4); -x_217 = lean_ctor_get(x_31, 5); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_212); -lean_inc(x_214); -lean_inc(x_213); -lean_dec(x_31); -x_218 = lean_ctor_get(x_212, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_212, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_212, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_212, 3); -lean_inc(x_221); -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); - x_222 = x_212; -} else { - lean_dec_ref(x_212); - x_222 = lean_box(0); -} -x_223 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 4, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_218); -lean_ctor_set(x_224, 1, x_219); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_221); -x_225 = lean_alloc_ctor(0, 6, 0); -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); -x_226 = lean_ctor_get(x_12, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_12, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_12, 2); -lean_inc(x_228); -x_229 = lean_ctor_get(x_12, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_12, 4); -lean_inc(x_230); -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_231 = x_12; -} else { - lean_dec_ref(x_12); - x_231 = lean_box(0); -} -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_32); -lean_ctor_set(x_232, 1, x_20); -x_233 = lean_array_push(x_228, x_232); -if (lean_is_scalar(x_231)) { - x_234 = lean_alloc_ctor(0, 5, 0); -} else { - x_234 = x_231; -} -lean_ctor_set(x_234, 0, x_226); -lean_ctor_set(x_234, 1, x_227); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_229); -lean_ctor_set(x_234, 4, x_230); -x_235 = 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_34, x_234, x_225); -if (lean_obj_tag(x_235) == 0) -{ -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; lean_object* x_252; -x_236 = lean_ctor_get(x_235, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_236, 2); -lean_inc(x_237); -x_238 = lean_ctor_get(x_235, 0); -lean_inc(x_238); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_239 = x_235; -} else { - lean_dec_ref(x_235); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_236, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 3); -lean_inc(x_242); -x_243 = lean_ctor_get(x_236, 4); -lean_inc(x_243); -x_244 = lean_ctor_get(x_236, 5); -lean_inc(x_244); -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); -x_247 = lean_ctor_get(x_237, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_237, 3); -lean_inc(x_248); -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); - x_249 = x_237; -} else { - lean_dec_ref(x_237); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_246); -lean_ctor_set(x_250, 1, x_247); -lean_ctor_set(x_250, 2, x_220); -lean_ctor_set(x_250, 3, x_248); -if (lean_is_scalar(x_245)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_245; -} -lean_ctor_set(x_251, 0, x_240); -lean_ctor_set(x_251, 1, x_241); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_242); -lean_ctor_set(x_251, 4, x_243); -lean_ctor_set(x_251, 5, x_244); -if (lean_is_scalar(x_239)) { - x_252 = lean_alloc_ctor(0, 2, 0); -} else { - x_252 = x_239; -} -lean_ctor_set(x_252, 0, x_238); -lean_ctor_set(x_252, 1, x_251); -return x_252; -} -else -{ -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; -x_253 = lean_ctor_get(x_235, 1); -lean_inc(x_253); -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_235, 0); -lean_inc(x_255); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_256 = x_235; -} else { - lean_dec_ref(x_235); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_253, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_253, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_253, 3); -lean_inc(x_259); -x_260 = lean_ctor_get(x_253, 4); -lean_inc(x_260); -x_261 = lean_ctor_get(x_253, 5); -lean_inc(x_261); -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); - lean_ctor_release(x_253, 4); - lean_ctor_release(x_253, 5); - x_262 = x_253; -} else { - lean_dec_ref(x_253); - x_262 = lean_box(0); -} -x_263 = lean_ctor_get(x_254, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_254, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_254, 3); -lean_inc(x_265); -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_266 = x_254; -} else { - lean_dec_ref(x_254); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(0, 4, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_263); -lean_ctor_set(x_267, 1, x_264); -lean_ctor_set(x_267, 2, x_220); -lean_ctor_set(x_267, 3, x_265); -if (lean_is_scalar(x_262)) { - x_268 = lean_alloc_ctor(0, 6, 0); -} else { - x_268 = x_262; -} -lean_ctor_set(x_268, 0, x_257); -lean_ctor_set(x_268, 1, x_258); -lean_ctor_set(x_268, 2, x_267); -lean_ctor_set(x_268, 3, x_259); -lean_ctor_set(x_268, 4, x_260); -lean_ctor_set(x_268, 5, x_261); -if (lean_is_scalar(x_256)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_256; -} -lean_ctor_set(x_269, 0, x_255); -lean_ctor_set(x_269, 1, x_268); -return x_269; } } } default: { -lean_object* x_270; lean_object* x_271; -x_270 = lean_ctor_get(x_25, 1); -lean_inc(x_270); +lean_object* x_236; lean_object* x_237; +x_236 = lean_ctor_get(x_25, 1); +lean_inc(x_236); lean_dec(x_25); lean_inc(x_12); -x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); -if (lean_obj_tag(x_271) == 0) +x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); +if (lean_obj_tag(x_237) == 0) { -lean_object* x_272; -x_272 = lean_ctor_get(x_271, 0); -lean_inc(x_272); -if (lean_obj_tag(x_272) == 0) +lean_object* x_238; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +if (lean_obj_tag(x_238) == 0) { -lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_dec(x_20); -x_273 = lean_ctor_get(x_271, 1); -lean_inc(x_273); -lean_dec(x_271); -x_274 = lean_unsigned_to_nat(1u); -x_275 = lean_nat_add(x_11, x_274); +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); lean_dec(x_11); -x_11 = x_275; -x_13 = x_273; +x_11 = x_241; +x_13 = x_239; goto _start; } else { -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_277 = lean_ctor_get(x_271, 1); -lean_inc(x_277); -lean_dec(x_271); -x_278 = lean_ctor_get(x_272, 0); -lean_inc(x_278); -lean_dec(x_272); -x_279 = lean_unsigned_to_nat(1u); -x_280 = lean_nat_add(x_11, x_279); +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_237); + x_244 = 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_281 = !lean_is_exclusive(x_277); -if (x_281 == 0) +x_248 = !lean_is_exclusive(x_243); +if (x_248 == 0) { -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_277, 2); -x_283 = !lean_is_exclusive(x_282); -if (x_283 == 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_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_282, 2); -x_285 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_282, 2, x_285); -x_286 = !lean_is_exclusive(x_12); -if (x_286 == 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_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_287 = lean_ctor_get(x_12, 2); -x_288 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_288, 0, x_278); -lean_ctor_set(x_288, 1, x_20); -x_289 = lean_array_push(x_287, x_288); -lean_ctor_set(x_12, 2, x_289); -x_290 = 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_280, x_12, x_277); -if (lean_obj_tag(x_290) == 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_291; lean_object* x_292; uint8_t x_293; -x_291 = lean_ctor_get(x_290, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_291, 2); -lean_inc(x_292); -x_293 = !lean_is_exclusive(x_290); -if (x_293 == 0) -{ -lean_object* x_294; uint8_t x_295; -x_294 = lean_ctor_get(x_290, 1); -lean_dec(x_294); -x_295 = !lean_is_exclusive(x_291); -if (x_295 == 0) -{ -lean_object* x_296; uint8_t x_297; -x_296 = lean_ctor_get(x_291, 2); -lean_dec(x_296); -x_297 = !lean_is_exclusive(x_292); -if (x_297 == 0) -{ -lean_object* x_298; -x_298 = lean_ctor_get(x_292, 2); -lean_dec(x_298); -lean_ctor_set(x_292, 2, x_284); -return x_290; -} -else -{ -lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; -x_299 = lean_ctor_get(x_292, 0); -x_300 = lean_ctor_get(x_292, 1); -x_301 = lean_ctor_get(x_292, 3); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_dec(x_292); -x_302 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_284); -lean_ctor_set(x_302, 3, x_301); -lean_ctor_set(x_291, 2, x_302); -return x_290; -} -} -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; -x_303 = lean_ctor_get(x_291, 0); -x_304 = lean_ctor_get(x_291, 1); -x_305 = lean_ctor_get(x_291, 3); -x_306 = lean_ctor_get(x_291, 4); -x_307 = lean_ctor_get(x_291, 5); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_291); -x_308 = lean_ctor_get(x_292, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_292, 1); +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_292, 3); +x_310 = lean_ctor_get(x_308, 1); lean_inc(x_310); -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); - x_311 = x_292; -} else { - lean_dec_ref(x_292); - x_311 = lean_box(0); +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; } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 4, 0); -} else { - x_312 = x_311; -} -lean_ctor_set(x_312, 0, x_308); -lean_ctor_set(x_312, 1, x_309); -lean_ctor_set(x_312, 2, x_284); -lean_ctor_set(x_312, 3, x_310); -x_313 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_313, 0, x_303); -lean_ctor_set(x_313, 1, x_304); -lean_ctor_set(x_313, 2, x_312); -lean_ctor_set(x_313, 3, x_305); -lean_ctor_set(x_313, 4, x_306); -lean_ctor_set(x_313, 5, x_307); -lean_ctor_set(x_290, 1, x_313); -return x_290; +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_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_314 = lean_ctor_get(x_290, 0); -lean_inc(x_314); -lean_dec(x_290); -x_315 = lean_ctor_get(x_291, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_291, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_291, 3); -lean_inc(x_317); -x_318 = lean_ctor_get(x_291, 4); -lean_inc(x_318); -x_319 = lean_ctor_get(x_291, 5); +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); -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); - lean_ctor_release(x_291, 5); - x_320 = x_291; -} else { - lean_dec_ref(x_291); - x_320 = lean_box(0); -} -x_321 = lean_ctor_get(x_292, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_292, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_292, 3); -lean_inc(x_323); -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); - x_324 = x_292; -} else { - lean_dec_ref(x_292); - x_324 = lean_box(0); -} -if (lean_is_scalar(x_324)) { - x_325 = lean_alloc_ctor(0, 4, 0); -} else { - x_325 = x_324; -} -lean_ctor_set(x_325, 0, x_321); -lean_ctor_set(x_325, 1, x_322); -lean_ctor_set(x_325, 2, x_284); -lean_ctor_set(x_325, 3, x_323); -if (lean_is_scalar(x_320)) { - x_326 = lean_alloc_ctor(0, 6, 0); -} else { - x_326 = x_320; -} -lean_ctor_set(x_326, 0, x_315); -lean_ctor_set(x_326, 1, x_316); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_317); -lean_ctor_set(x_326, 4, x_318); -lean_ctor_set(x_326, 5, x_319); -x_327 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_327, 0, x_314); -lean_ctor_set(x_327, 1, x_326); -return x_327; -} -} -else -{ -lean_object* x_328; lean_object* x_329; uint8_t x_330; -x_328 = lean_ctor_get(x_290, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_328, 2); -lean_inc(x_329); -x_330 = !lean_is_exclusive(x_290); -if (x_330 == 0) -{ -lean_object* x_331; uint8_t x_332; -x_331 = lean_ctor_get(x_290, 1); -lean_dec(x_331); -x_332 = !lean_is_exclusive(x_328); -if (x_332 == 0) -{ -lean_object* x_333; uint8_t x_334; -x_333 = lean_ctor_get(x_328, 2); -lean_dec(x_333); -x_334 = !lean_is_exclusive(x_329); -if (x_334 == 0) -{ -lean_object* x_335; -x_335 = lean_ctor_get(x_329, 2); -lean_dec(x_335); -lean_ctor_set(x_329, 2, x_284); -return x_290; -} -else -{ -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; -x_336 = lean_ctor_get(x_329, 0); -x_337 = lean_ctor_get(x_329, 1); -x_338 = lean_ctor_get(x_329, 3); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_dec(x_329); -x_339 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_339, 0, x_336); -lean_ctor_set(x_339, 1, x_337); -lean_ctor_set(x_339, 2, x_284); -lean_ctor_set(x_339, 3, x_338); -lean_ctor_set(x_328, 2, x_339); -return x_290; -} -} -else -{ -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_340 = lean_ctor_get(x_328, 0); -x_341 = lean_ctor_get(x_328, 1); -x_342 = lean_ctor_get(x_328, 3); -x_343 = lean_ctor_get(x_328, 4); -x_344 = lean_ctor_get(x_328, 5); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_328); -x_345 = lean_ctor_get(x_329, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_329, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_329, 3); -lean_inc(x_347); -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_348 = x_329; -} else { - lean_dec_ref(x_329); - 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_284); -lean_ctor_set(x_349, 3, x_347); -x_350 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_350, 0, x_340); -lean_ctor_set(x_350, 1, x_341); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_342); -lean_ctor_set(x_350, 4, x_343); -lean_ctor_set(x_350, 5, x_344); -lean_ctor_set(x_290, 1, x_350); -return x_290; -} -} -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; -x_351 = lean_ctor_get(x_290, 0); -lean_inc(x_351); -lean_dec(x_290); -x_352 = lean_ctor_get(x_328, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_328, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_328, 3); -lean_inc(x_354); -x_355 = lean_ctor_get(x_328, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_328, 5); -lean_inc(x_356); -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_357 = x_328; -} else { - lean_dec_ref(x_328); - x_357 = lean_box(0); -} -x_358 = lean_ctor_get(x_329, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_329, 1); -lean_inc(x_359); -x_360 = lean_ctor_get(x_329, 3); -lean_inc(x_360); -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_361 = x_329; -} else { - lean_dec_ref(x_329); - x_361 = lean_box(0); -} -if (lean_is_scalar(x_361)) { - x_362 = lean_alloc_ctor(0, 4, 0); -} else { - x_362 = x_361; -} -lean_ctor_set(x_362, 0, x_358); -lean_ctor_set(x_362, 1, x_359); -lean_ctor_set(x_362, 2, x_284); -lean_ctor_set(x_362, 3, x_360); -if (lean_is_scalar(x_357)) { - x_363 = lean_alloc_ctor(0, 6, 0); -} else { - x_363 = 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); -x_364 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_364, 0, x_351); -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; -x_365 = lean_ctor_get(x_12, 0); -x_366 = lean_ctor_get(x_12, 1); -x_367 = lean_ctor_get(x_12, 2); -x_368 = lean_ctor_get(x_12, 3); -x_369 = lean_ctor_get(x_12, 4); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); +lean_inc(x_318); +lean_inc(x_317); +lean_inc(x_316); +lean_inc(x_315); lean_dec(x_12); -x_370 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_370, 0, x_278); -lean_ctor_set(x_370, 1, x_20); -x_371 = lean_array_push(x_367, x_370); -x_372 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_372, 0, x_365); -lean_ctor_set(x_372, 1, x_366); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_368); -lean_ctor_set(x_372, 4, x_369); -x_373 = 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_280, x_372, x_277); -if (lean_obj_tag(x_373) == 0) +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_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; lean_object* x_390; -x_374 = lean_ctor_get(x_373, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_373, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_377 = x_373; -} else { - lean_dec_ref(x_373); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_374, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); -lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); -lean_inc(x_382); -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); - lean_ctor_release(x_374, 5); - x_383 = x_374; -} else { - lean_dec_ref(x_374); - x_383 = lean_box(0); -} -x_384 = lean_ctor_get(x_375, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_375, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_375, 3); -lean_inc(x_386); -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_387 = x_375; -} else { - lean_dec_ref(x_375); - x_387 = lean_box(0); -} -if (lean_is_scalar(x_387)) { - x_388 = lean_alloc_ctor(0, 4, 0); -} else { - x_388 = x_387; -} -lean_ctor_set(x_388, 0, x_384); -lean_ctor_set(x_388, 1, x_385); -lean_ctor_set(x_388, 2, x_284); -lean_ctor_set(x_388, 3, x_386); -if (lean_is_scalar(x_383)) { - x_389 = lean_alloc_ctor(0, 6, 0); -} else { - x_389 = x_383; -} -lean_ctor_set(x_389, 0, x_378); -lean_ctor_set(x_389, 1, x_379); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_389, 3, x_380); -lean_ctor_set(x_389, 4, x_381); -lean_ctor_set(x_389, 5, x_382); -if (lean_is_scalar(x_377)) { - x_390 = lean_alloc_ctor(0, 2, 0); -} else { - x_390 = x_377; -} -lean_ctor_set(x_390, 0, x_376); -lean_ctor_set(x_390, 1, x_389); -return x_390; +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_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; lean_object* x_406; lean_object* x_407; -x_391 = lean_ctor_get(x_373, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_373, 0); -lean_inc(x_393); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_394 = x_373; -} else { - lean_dec_ref(x_373); - x_394 = lean_box(0); +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; } -x_395 = lean_ctor_get(x_391, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 3); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 4); -lean_inc(x_398); -x_399 = lean_ctor_get(x_391, 5); -lean_inc(x_399); -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_400 = x_391; -} else { - lean_dec_ref(x_391); - x_400 = lean_box(0); } -x_401 = lean_ctor_get(x_392, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_392, 3); -lean_inc(x_403); -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_404 = x_392; +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); +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 { - lean_dec_ref(x_392); - x_404 = lean_box(0); + x_260 = x_244; + lean_ctor_set_tag(x_260, 1); } -if (lean_is_scalar(x_404)) { - x_405 = lean_alloc_ctor(0, 4, 0); +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; +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_405 = x_404; + x_265 = x_244; + lean_ctor_set_tag(x_265, 1); } -lean_ctor_set(x_405, 0, x_401); -lean_ctor_set(x_405, 1, x_402); -lean_ctor_set(x_405, 2, x_284); -lean_ctor_set(x_405, 3, x_403); -if (lean_is_scalar(x_400)) { - x_406 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_265, 0, x_255); +lean_ctor_set(x_265, 1, x_253); +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; 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_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 { - x_406 = x_400; + lean_dec_ref(x_254); + x_274 = lean_box(0); } -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_394)) { - x_407 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 4, 0); } else { - x_407 = x_394; + x_275 = x_274; +} +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, 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); +} else { + x_277 = x_244; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_255); +lean_ctor_set(x_277, 1, x_276); +return x_277; +} +} +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_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_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); +} else { + x_289 = x_244; +} +lean_ctor_set(x_289, 0, x_279); +lean_ctor_set(x_289, 1, x_253); +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_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); +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; +} else { + lean_dec_ref(x_278); + x_298 = lean_box(0); +} +if (lean_is_scalar(x_298)) { + x_299 = lean_alloc_ctor(0, 4, 0); +} else { + x_299 = x_298; +} +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); +} else { + x_301 = x_244; +} +lean_ctor_set(x_301, 0, x_279); +lean_ctor_set(x_301, 1, x_300); +return x_301; } -lean_ctor_set(x_407, 0, x_393); -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; lean_object* x_423; -x_408 = lean_ctor_get(x_282, 0); -x_409 = lean_ctor_get(x_282, 1); -x_410 = lean_ctor_get(x_282, 2); -x_411 = lean_ctor_get(x_282, 3); -lean_inc(x_411); -lean_inc(x_410); -lean_inc(x_409); -lean_inc(x_408); -lean_dec(x_282); -x_412 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_413 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_413, 0, x_408); -lean_ctor_set(x_413, 1, x_409); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_411); -lean_ctor_set(x_277, 2, x_413); -x_414 = lean_ctor_get(x_12, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_12, 1); -lean_inc(x_415); -x_416 = lean_ctor_get(x_12, 2); -lean_inc(x_416); -x_417 = lean_ctor_get(x_12, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_12, 4); -lean_inc(x_418); +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); 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_419 = x_12; + x_374 = x_12; } else { lean_dec_ref(x_12); - x_419 = lean_box(0); + x_374 = lean_box(0); } -x_420 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_420, 0, x_278); -lean_ctor_set(x_420, 1, x_20); -x_421 = lean_array_push(x_416, x_420); -if (lean_is_scalar(x_419)) { - x_422 = lean_alloc_ctor(0, 5, 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); } else { - x_422 = x_419; + x_377 = x_374; } -lean_ctor_set(x_422, 0, x_414); -lean_ctor_set(x_422, 1, x_415); -lean_ctor_set(x_422, 2, x_421); -lean_ctor_set(x_422, 3, x_417); -lean_ctor_set(x_422, 4, x_418); -x_423 = 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_280, x_422, x_277); -if (lean_obj_tag(x_423) == 0) +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_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; lean_object* x_439; lean_object* x_440; -x_424 = lean_ctor_get(x_423, 1); -lean_inc(x_424); -x_425 = lean_ctor_get(x_424, 2); -lean_inc(x_425); -x_426 = lean_ctor_get(x_423, 0); -lean_inc(x_426); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_427 = x_423; -} else { - lean_dec_ref(x_423); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_424, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_424, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_424, 3); -lean_inc(x_430); -x_431 = lean_ctor_get(x_424, 4); -lean_inc(x_431); -x_432 = lean_ctor_get(x_424, 5); -lean_inc(x_432); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - lean_ctor_release(x_424, 4); - lean_ctor_release(x_424, 5); - x_433 = x_424; -} else { - lean_dec_ref(x_424); - x_433 = lean_box(0); -} -x_434 = lean_ctor_get(x_425, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_425, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_425, 3); -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); - 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, 4, 0); -} else { - x_438 = x_437; -} -lean_ctor_set(x_438, 0, x_434); -lean_ctor_set(x_438, 1, x_435); -lean_ctor_set(x_438, 2, x_410); -lean_ctor_set(x_438, 3, x_436); -if (lean_is_scalar(x_433)) { - x_439 = lean_alloc_ctor(0, 6, 0); -} else { - x_439 = x_433; -} -lean_ctor_set(x_439, 0, x_428); -lean_ctor_set(x_439, 1, x_429); -lean_ctor_set(x_439, 2, x_438); -lean_ctor_set(x_439, 3, x_430); -lean_ctor_set(x_439, 4, x_431); -lean_ctor_set(x_439, 5, x_432); -if (lean_is_scalar(x_427)) { - x_440 = lean_alloc_ctor(0, 2, 0); -} else { - x_440 = x_427; -} -lean_ctor_set(x_440, 0, x_426); -lean_ctor_set(x_440, 1, x_439); -return x_440; +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; } else { -lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_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; -x_441 = lean_ctor_get(x_423, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_441, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_423, 0); -lean_inc(x_443); -if (lean_is_exclusive(x_423)) { - lean_ctor_release(x_423, 0); - lean_ctor_release(x_423, 1); - x_444 = x_423; -} else { - lean_dec_ref(x_423); - x_444 = lean_box(0); +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; } +block_366: +{ +if (lean_obj_tag(x_334) == 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_inc(x_351); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +lean_dec(x_334); +x_353 = lean_ctor_get(x_335, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_335, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_335, 3); +lean_inc(x_355); +x_356 = lean_ctor_get(x_335, 4); +lean_inc(x_356); +x_357 = lean_ctor_get(x_335, 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; +} else { + lean_dec_ref(x_335); + x_358 = lean_box(0); +} +x_359 = lean_ctor_get(x_351, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_351, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_351, 3); +lean_inc(x_361); +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; +} else { + lean_dec_ref(x_351); + x_362 = lean_box(0); +} +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 4, 0); +} else { + x_363 = x_362; +} +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); +if (lean_is_scalar(x_358)) { + x_364 = lean_alloc_ctor(0, 6, 0); +} else { + x_364 = 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); +} else { + x_365 = x_244; +} +lean_ctor_set(x_365, 0, x_352); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +} +} +} +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; +} else { + lean_dec_ref(x_385); + x_395 = 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); +} else { + x_430 = x_395; +} +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); +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; +} else { + lean_dec_ref(x_12); + x_437 = 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); +} else { + x_440 = x_437; +} +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_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; +} +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); -x_447 = lean_ctor_get(x_441, 3); -lean_inc(x_447); -x_448 = lean_ctor_get(x_441, 4); -lean_inc(x_448); -x_449 = lean_ctor_get(x_441, 5); -lean_inc(x_449); -if (lean_is_exclusive(x_441)) { - lean_ctor_release(x_441, 0); - lean_ctor_release(x_441, 1); - lean_ctor_release(x_441, 2); - lean_ctor_release(x_441, 3); - lean_ctor_release(x_441, 4); - lean_ctor_release(x_441, 5); - x_450 = x_441; +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; +} +block_428: +{ +if (lean_obj_tag(x_396) == 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_441); - x_450 = lean_box(0); + lean_dec_ref(x_397); + x_405 = lean_box(0); } -x_451 = lean_ctor_get(x_442, 0); -lean_inc(x_451); -x_452 = lean_ctor_get(x_442, 1); -lean_inc(x_452); -x_453 = lean_ctor_get(x_442, 3); -lean_inc(x_453); -if (lean_is_exclusive(x_442)) { - lean_ctor_release(x_442, 0); - lean_ctor_release(x_442, 1); - lean_ctor_release(x_442, 2); - lean_ctor_release(x_442, 3); - x_454 = x_442; +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_442); - x_454 = lean_box(0); + lean_dec_ref(x_398); + x_409 = lean_box(0); } -if (lean_is_scalar(x_454)) { - x_455 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_409)) { + x_410 = lean_alloc_ctor(0, 4, 0); } else { - x_455 = x_454; + x_410 = x_409; } -lean_ctor_set(x_455, 0, x_451); -lean_ctor_set(x_455, 1, x_452); -lean_ctor_set(x_455, 2, x_410); -lean_ctor_set(x_455, 3, x_453); -if (lean_is_scalar(x_450)) { - x_456 = lean_alloc_ctor(0, 6, 0); +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_456 = x_450; + x_411 = x_405; } -lean_ctor_set(x_456, 0, x_445); -lean_ctor_set(x_456, 1, x_446); -lean_ctor_set(x_456, 2, x_455); -lean_ctor_set(x_456, 3, x_447); -lean_ctor_set(x_456, 4, x_448); -lean_ctor_set(x_456, 5, x_449); -if (lean_is_scalar(x_444)) { - x_457 = lean_alloc_ctor(1, 2, 0); +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_457 = x_444; -} -lean_ctor_set(x_457, 0, x_443); -lean_ctor_set(x_457, 1, x_456); -return x_457; -} + 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_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; 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; lean_object* x_481; -x_458 = lean_ctor_get(x_277, 2); -x_459 = lean_ctor_get(x_277, 0); -x_460 = lean_ctor_get(x_277, 1); -x_461 = lean_ctor_get(x_277, 3); -x_462 = lean_ctor_get(x_277, 4); -x_463 = lean_ctor_get(x_277, 5); -lean_inc(x_463); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_458); -lean_inc(x_460); -lean_inc(x_459); -lean_dec(x_277); -x_464 = lean_ctor_get(x_458, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_458, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_458, 2); -lean_inc(x_466); -x_467 = lean_ctor_get(x_458, 3); -lean_inc(x_467); -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); - x_468 = x_458; +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_inc(x_416); +x_417 = lean_ctor_get(x_397, 3); +lean_inc(x_417); +x_418 = lean_ctor_get(x_397, 4); +lean_inc(x_418); +x_419 = lean_ctor_get(x_397, 5); +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_458); - x_468 = lean_box(0); + lean_dec_ref(x_397); + x_420 = lean_box(0); } -x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_468)) { - x_470 = lean_alloc_ctor(0, 4, 0); +x_421 = lean_ctor_get(x_413, 0); +lean_inc(x_421); +x_422 = lean_ctor_get(x_413, 1); +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; } else { - x_470 = x_468; + lean_dec_ref(x_413); + x_424 = lean_box(0); } -lean_ctor_set(x_470, 0, x_464); -lean_ctor_set(x_470, 1, x_465); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_467); -x_471 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_471, 0, x_459); -lean_ctor_set(x_471, 1, x_460); -lean_ctor_set(x_471, 2, x_470); -lean_ctor_set(x_471, 3, x_461); -lean_ctor_set(x_471, 4, x_462); -lean_ctor_set(x_471, 5, x_463); -x_472 = lean_ctor_get(x_12, 0); -lean_inc(x_472); -x_473 = lean_ctor_get(x_12, 1); -lean_inc(x_473); -x_474 = lean_ctor_get(x_12, 2); -lean_inc(x_474); -x_475 = lean_ctor_get(x_12, 3); -lean_inc(x_475); -x_476 = lean_ctor_get(x_12, 4); -lean_inc(x_476); -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_477 = x_12; +if (lean_is_scalar(x_424)) { + x_425 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_12); - x_477 = lean_box(0); + x_425 = x_424; } -x_478 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_478, 0, x_278); -lean_ctor_set(x_478, 1, x_20); -x_479 = lean_array_push(x_474, x_478); -if (lean_is_scalar(x_477)) { - x_480 = lean_alloc_ctor(0, 5, 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); } else { - x_480 = x_477; + x_426 = x_420; } -lean_ctor_set(x_480, 0, x_472); -lean_ctor_set(x_480, 1, x_473); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_475); -lean_ctor_set(x_480, 4, x_476); -x_481 = 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_280, x_480, x_471); -if (lean_obj_tag(x_481) == 0) -{ -lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_482 = lean_ctor_get(x_481, 1); -lean_inc(x_482); -x_483 = lean_ctor_get(x_482, 2); -lean_inc(x_483); -x_484 = lean_ctor_get(x_481, 0); -lean_inc(x_484); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_485 = x_481; +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); } else { - lean_dec_ref(x_481); - x_485 = lean_box(0); + x_427 = x_244; } -x_486 = lean_ctor_get(x_482, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_482, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_482, 3); -lean_inc(x_488); -x_489 = lean_ctor_get(x_482, 4); -lean_inc(x_489); -x_490 = lean_ctor_get(x_482, 5); -lean_inc(x_490); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - lean_ctor_release(x_482, 4); - lean_ctor_release(x_482, 5); - x_491 = x_482; -} else { - lean_dec_ref(x_482); - x_491 = lean_box(0); +lean_ctor_set(x_427, 0, x_414); +lean_ctor_set(x_427, 1, x_426); +return x_427; } -x_492 = lean_ctor_get(x_483, 0); -lean_inc(x_492); -x_493 = lean_ctor_get(x_483, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_483, 3); -lean_inc(x_494); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - lean_ctor_release(x_483, 2); - lean_ctor_release(x_483, 3); - x_495 = x_483; -} else { - lean_dec_ref(x_483); - x_495 = lean_box(0); -} -if (lean_is_scalar(x_495)) { - x_496 = lean_alloc_ctor(0, 4, 0); -} else { - x_496 = x_495; -} -lean_ctor_set(x_496, 0, x_492); -lean_ctor_set(x_496, 1, x_493); -lean_ctor_set(x_496, 2, x_466); -lean_ctor_set(x_496, 3, x_494); -if (lean_is_scalar(x_491)) { - x_497 = lean_alloc_ctor(0, 6, 0); -} else { - x_497 = x_491; -} -lean_ctor_set(x_497, 0, x_486); -lean_ctor_set(x_497, 1, x_487); -lean_ctor_set(x_497, 2, x_496); -lean_ctor_set(x_497, 3, x_488); -lean_ctor_set(x_497, 4, x_489); -lean_ctor_set(x_497, 5, x_490); -if (lean_is_scalar(x_485)) { - x_498 = lean_alloc_ctor(0, 2, 0); -} else { - x_498 = x_485; -} -lean_ctor_set(x_498, 0, x_484); -lean_ctor_set(x_498, 1, x_497); -return x_498; -} -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; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; -x_499 = lean_ctor_get(x_481, 1); -lean_inc(x_499); -x_500 = lean_ctor_get(x_499, 2); -lean_inc(x_500); -x_501 = lean_ctor_get(x_481, 0); -lean_inc(x_501); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - x_502 = x_481; -} else { - lean_dec_ref(x_481); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_499, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_499, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_499, 3); -lean_inc(x_505); -x_506 = lean_ctor_get(x_499, 4); -lean_inc(x_506); -x_507 = lean_ctor_get(x_499, 5); -lean_inc(x_507); -if (lean_is_exclusive(x_499)) { - lean_ctor_release(x_499, 0); - lean_ctor_release(x_499, 1); - lean_ctor_release(x_499, 2); - lean_ctor_release(x_499, 3); - lean_ctor_release(x_499, 4); - lean_ctor_release(x_499, 5); - x_508 = x_499; -} else { - lean_dec_ref(x_499); - x_508 = lean_box(0); -} -x_509 = lean_ctor_get(x_500, 0); -lean_inc(x_509); -x_510 = lean_ctor_get(x_500, 1); -lean_inc(x_510); -x_511 = lean_ctor_get(x_500, 3); -lean_inc(x_511); -if (lean_is_exclusive(x_500)) { - lean_ctor_release(x_500, 0); - lean_ctor_release(x_500, 1); - lean_ctor_release(x_500, 2); - lean_ctor_release(x_500, 3); - x_512 = x_500; -} else { - lean_dec_ref(x_500); - x_512 = lean_box(0); -} -if (lean_is_scalar(x_512)) { - x_513 = lean_alloc_ctor(0, 4, 0); -} else { - x_513 = x_512; -} -lean_ctor_set(x_513, 0, x_509); -lean_ctor_set(x_513, 1, x_510); -lean_ctor_set(x_513, 2, x_466); -lean_ctor_set(x_513, 3, x_511); -if (lean_is_scalar(x_508)) { - x_514 = lean_alloc_ctor(0, 6, 0); -} else { - x_514 = x_508; -} -lean_ctor_set(x_514, 0, x_503); -lean_ctor_set(x_514, 1, x_504); -lean_ctor_set(x_514, 2, x_513); -lean_ctor_set(x_514, 3, x_505); -lean_ctor_set(x_514, 4, x_506); -lean_ctor_set(x_514, 5, x_507); -if (lean_is_scalar(x_502)) { - x_515 = lean_alloc_ctor(1, 2, 0); -} else { - x_515 = x_502; -} -lean_ctor_set(x_515, 0, x_501); -lean_ctor_set(x_515, 1, x_514); -return x_515; } } } } else { -uint8_t x_516; +uint8_t x_448; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -37953,23 +33292,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_516 = !lean_is_exclusive(x_271); -if (x_516 == 0) +x_448 = !lean_is_exclusive(x_237); +if (x_448 == 0) { -return x_271; +return x_237; } else { -lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_517 = lean_ctor_get(x_271, 0); -x_518 = lean_ctor_get(x_271, 1); -lean_inc(x_518); -lean_inc(x_517); -lean_dec(x_271); -x_519 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_519, 0, x_517); -lean_ctor_set(x_519, 1, x_518); -return x_519; +lean_object* x_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; } } } @@ -37977,7 +33316,7 @@ return x_519; } else { -uint8_t x_520; +uint8_t x_452; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -37988,29 +33327,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_520 = !lean_is_exclusive(x_25); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_25); +if (x_452 == 0) { return x_25; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_25, 0); -x_522 = lean_ctor_get(x_25, 1); -lean_inc(x_522); -lean_inc(x_521); +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_dec(x_25); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -38020,23 +33359,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_21); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_21); +if (x_456 == 0) { return x_21; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_21, 0); -x_526 = lean_ctor_get(x_21, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_21); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } @@ -38110,2152 +33449,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -40263,58 +35240,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -41033,2152 +36010,1790 @@ goto _start; } case 1: { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; lean_dec(x_18); x_25 = lean_ctor_get(x_19, 1); lean_inc(x_25); -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); lean_dec(x_20); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_6, x_27); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_6, x_28); lean_dec(x_6); -x_29 = !lean_is_exclusive(x_25); -if (x_29 == 0) +x_30 = !lean_is_exclusive(x_25); +if (x_30 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_25, 2); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_25, 2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_32; lean_object* x_33; uint8_t x_34; -x_32 = lean_ctor_get(x_30, 2); -x_33 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_33); -x_34 = !lean_is_exclusive(x_7); -if (x_34 == 0) +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +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) { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_7, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_14); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_7, 2, x_37); -x_38 = 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_28, x_7, x_25); -if (lean_obj_tag(x_38) == 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_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_39, 2); -lean_inc(x_40); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_38, 1); -lean_dec(x_42); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_39, 2); -lean_dec(x_44); -x_45 = !lean_is_exclusive(x_40); -if (x_45 == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_40, 2); -lean_dec(x_46); -lean_ctor_set(x_40, 2, x_32); -return x_38; +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_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_40, 0); -x_48 = lean_ctor_get(x_40, 1); -x_49 = lean_ctor_get(x_40, 3); -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_32); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); -return x_38; +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_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; } } 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; -x_51 = lean_ctor_get(x_39, 0); -x_52 = lean_ctor_get(x_39, 1); -x_53 = lean_ctor_get(x_39, 3); -x_54 = lean_ctor_get(x_39, 4); -x_55 = lean_ctor_get(x_39, 5); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); +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_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; +} +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_34 = x_111; +x_35 = x_110; +goto block_84; +} +} +block_84: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_35, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 0); +lean_inc(x_37); +lean_dec(x_34); +x_38 = !lean_is_exclusive(x_35); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_35, 2); +lean_dec(x_39); +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_33); +if (lean_is_scalar(x_26)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_26; + lean_ctor_set_tag(x_42, 1); +} +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_35); +return x_42; +} +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_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); +if (lean_is_scalar(x_26)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_26; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_37); +lean_ctor_set(x_47, 1, x_35); +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_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_inc(x_52); lean_inc(x_51); -lean_dec(x_39); -x_56 = lean_ctor_get(x_40, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_40, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 3); -lean_inc(x_58); -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_59 = x_40; +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); +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; } else { - lean_dec_ref(x_40); - x_59 = lean_box(0); + lean_dec_ref(x_36); + x_56 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_60 = x_59; + x_57 = x_56; } -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_57); -lean_ctor_set(x_60, 2, x_32); -lean_ctor_set(x_60, 3, x_58); -x_61 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_61, 0, x_51); -lean_ctor_set(x_61, 1, x_52); -lean_ctor_set(x_61, 2, x_60); -lean_ctor_set(x_61, 3, x_53); -lean_ctor_set(x_61, 4, x_54); -lean_ctor_set(x_61, 5, x_55); -lean_ctor_set(x_38, 1, x_61); -return x_38; +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); +if (lean_is_scalar(x_26)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_26; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_37); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; 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_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -lean_dec(x_38); -x_63 = lean_ctor_get(x_39, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 3); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 4); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 5); -lean_inc(x_67); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_68 = x_39; +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_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); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = lean_ctor_get(x_60, 2); +lean_dec(x_65); +lean_ctor_set(x_60, 2, x_33); +if (lean_is_scalar(x_26)) { + x_66 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_68 = lean_box(0); + x_66 = x_26; } -x_69 = lean_ctor_get(x_40, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_35); +return x_66; +} +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_inc(x_69); -x_70 = lean_ctor_get(x_40, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_40, 3); -lean_inc(x_71); -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_72 = x_40; +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); +if (lean_is_scalar(x_26)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_40); - x_72 = lean_box(0); + x_71 = x_26; } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); -} else { - x_73 = x_72; -} -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_32); -lean_ctor_set(x_73, 3, x_71); -if (lean_is_scalar(x_68)) { - x_74 = lean_alloc_ctor(0, 6, 0); -} else { - x_74 = x_68; -} -lean_ctor_set(x_74, 0, x_63); -lean_ctor_set(x_74, 1, x_64); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_65); -lean_ctor_set(x_74, 4, x_66); -lean_ctor_set(x_74, 5, x_67); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_62); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_71, 0, x_61); +lean_ctor_set(x_71, 1, x_35); +return x_71; } } else { -lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_76 = lean_ctor_get(x_38, 1); +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_inc(x_76); -x_77 = lean_ctor_get(x_76, 2); +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_is_exclusive(x_38); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_38, 1); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_76); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; -x_81 = lean_ctor_get(x_76, 2); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_77); -if (x_82 == 0) -{ -lean_object* x_83; -x_83 = lean_ctor_get(x_77, 2); -lean_dec(x_83); -lean_ctor_set(x_77, 2, x_32); -return x_38; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_77, 0); -x_85 = lean_ctor_get(x_77, 1); -x_86 = lean_ctor_get(x_77, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_77); -x_87 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_32); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_76, 2, x_87); -return x_38; -} -} -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; -x_88 = lean_ctor_get(x_76, 0); -x_89 = lean_ctor_get(x_76, 1); -x_90 = lean_ctor_get(x_76, 3); -x_91 = lean_ctor_get(x_76, 4); -x_92 = lean_ctor_get(x_76, 5); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_76); -x_93 = lean_ctor_get(x_77, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_77, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_77, 3); -lean_inc(x_95); -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); - x_96 = 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; } else { - lean_dec_ref(x_77); - x_96 = lean_box(0); + lean_dec_ref(x_60); + x_80 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_81 = x_80; } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_32); -lean_ctor_set(x_97, 3, x_95); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_88); -lean_ctor_set(x_98, 1, x_89); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_90); -lean_ctor_set(x_98, 4, x_91); -lean_ctor_set(x_98, 5, x_92); -lean_ctor_set(x_38, 1, x_98); -return x_38; -} -} -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; lean_object* x_111; lean_object* x_112; -x_99 = lean_ctor_get(x_38, 0); -lean_inc(x_99); -lean_dec(x_38); -x_100 = lean_ctor_get(x_76, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_76, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_76, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_76, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_76, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - lean_ctor_release(x_76, 4); - lean_ctor_release(x_76, 5); - x_105 = x_76; +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); +if (lean_is_scalar(x_26)) { + x_83 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_76); - x_105 = lean_box(0); + x_83 = x_26; } -x_106 = lean_ctor_get(x_77, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_77, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_77, 3); -lean_inc(x_108); -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); - x_109 = x_77; -} else { - lean_dec_ref(x_77); - x_109 = lean_box(0); +lean_ctor_set(x_83, 0, x_61); +lean_ctor_set(x_83, 1, x_82); +return x_83; } -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_32); -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -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; -x_113 = lean_ctor_get(x_7, 0); -x_114 = lean_ctor_get(x_7, 1); -x_115 = lean_ctor_get(x_7, 2); -x_116 = lean_ctor_get(x_7, 3); -x_117 = lean_ctor_get(x_7, 4); -lean_inc(x_117); -lean_inc(x_116); +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_dec(x_7); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_26); -lean_ctor_set(x_118, 1, x_14); -x_119 = lean_array_push(x_115, x_118); -x_120 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_120, 0, x_113); -lean_ctor_set(x_120, 1, x_114); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_116); -lean_ctor_set(x_120, 4, x_117); -x_121 = 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_28, x_120, x_25); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; +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_121); + 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_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_122, 0); +x_126 = lean_ctor_get(x_118, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); +x_127 = lean_ctor_get(x_118, 1); lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +x_128 = lean_ctor_get(x_118, 3); lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_131 = x_122; +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_122); - x_131 = lean_box(0); + lean_dec_ref(x_118); + x_129 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_123, 3); -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); - x_135 = x_123; +if (lean_is_scalar(x_129)) { + x_130 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_123); - x_135 = lean_box(0); + x_130 = x_129; } -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_32); -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); +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_138 = lean_alloc_ctor(0, 2, 0); + x_131 = lean_alloc_ctor(0, 6, 0); } else { - x_138 = x_125; + x_131 = x_125; } -lean_ctor_set(x_138, 0, x_124); -lean_ctor_set(x_138, 1, x_137); -return x_138; +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_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; -x_139 = lean_ctor_get(x_121, 1); +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); -x_140 = lean_ctor_get(x_139, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 0); +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); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_142 = x_121; -} else { - lean_dec_ref(x_121); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_139, 0); +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_139, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_139, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_139, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_139, 5); -lean_inc(x_147); -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; +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_139); - x_148 = lean_box(0); + lean_dec_ref(x_133); + x_144 = lean_box(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, 3); -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); - x_152 = x_140; +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_140); - x_152 = lean_box(0); + x_145 = x_144; } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +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_153 = x_152; + x_146 = x_140; } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_32); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +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_154 = x_148; + x_147 = x_26; } -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_142)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_142; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } -lean_ctor_set(x_155, 0, x_141); -lean_ctor_set(x_155, 1, x_154); -return x_155; } } } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_156 = lean_ctor_get(x_30, 0); -x_157 = lean_ctor_get(x_30, 1); -x_158 = lean_ctor_get(x_30, 2); -x_159 = lean_ctor_get(x_30, 3); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_30); -x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_161 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_161, 0, x_156); -lean_ctor_set(x_161, 1, x_157); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_159); -lean_ctor_set(x_25, 2, x_161); -x_162 = lean_ctor_get(x_7, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_167 = x_7; + x_219 = x_7; } else { lean_dec_ref(x_7); - x_167 = lean_box(0); + x_219 = lean_box(0); } -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_26); -lean_ctor_set(x_168, 1, x_14); -x_169 = lean_array_push(x_164, x_168); -if (lean_is_scalar(x_167)) { - x_170 = lean_alloc_ctor(0, 5, 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_222 = lean_alloc_ctor(0, 5, 0); } else { - x_170 = x_167; + x_222 = x_219; } -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___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_170, x_25); -if (lean_obj_tag(x_171) == 0) +lean_ctor_set(x_222, 0, x_214); +lean_ctor_set(x_222, 1, x_215); +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_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; -x_172 = lean_ctor_get(x_171, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_172, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 0); -lean_inc(x_174); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_175 = x_171; -} else { - lean_dec_ref(x_171); - x_175 = lean_box(0); -} -x_176 = lean_ctor_get(x_172, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_172, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_172, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 4); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 5); -lean_inc(x_180); -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_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_173, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_173, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_173, 3); -lean_inc(x_184); -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_185 = x_173; -} else { - lean_dec_ref(x_173); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 4, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_182); -lean_ctor_set(x_186, 1, x_183); -lean_ctor_set(x_186, 2, x_158); -lean_ctor_set(x_186, 3, x_184); -if (lean_is_scalar(x_181)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_181; -} -lean_ctor_set(x_187, 0, x_176); -lean_ctor_set(x_187, 1, x_177); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_178); -lean_ctor_set(x_187, 4, x_179); -lean_ctor_set(x_187, 5, x_180); -if (lean_is_scalar(x_175)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_175; -} -lean_ctor_set(x_188, 0, x_174); -lean_ctor_set(x_188, 1, x_187); -return x_188; +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_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; -x_189 = lean_ctor_get(x_171, 1); +lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +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; +} +block_210: +{ +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_189, 2); +x_190 = lean_ctor_get(x_180, 3); lean_inc(x_190); -x_191 = lean_ctor_get(x_171, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_192 = x_171; +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_171); - x_192 = lean_box(0); + lean_dec_ref(x_180); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); +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; +} +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_189, 4); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); +lean_dec(x_178); +x_197 = lean_ctor_get(x_179, 0); lean_inc(x_197); -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_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = lean_ctor_get(x_190, 0); +x_198 = lean_ctor_get(x_179, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_179, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_179, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_190, 3); +x_201 = lean_ctor_get(x_179, 5); lean_inc(x_201); -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_202 = x_190; +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; } else { - lean_dec_ref(x_190); + lean_dec_ref(x_179); x_202 = 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; +} else { + lean_dec_ref(x_195); + x_206 = lean_box(0); +} +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); +} else { + x_207 = x_206; +} +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_203 = lean_alloc_ctor(0, 4, 0); + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_208 = x_202; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_158); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); +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_26)) { + x_209 = lean_alloc_ctor(0, 2, 0); } else { - x_204 = x_198; + x_209 = x_26; } -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); -if (lean_is_scalar(x_192)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_192; +lean_ctor_set(x_209, 0, x_196); +lean_ctor_set(x_209, 1, x_208); +return x_209; } -lean_ctor_set(x_205, 0, x_191); -lean_ctor_set(x_205, 1, x_204); -return x_205; -} -} -} -else -{ -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; 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_206 = lean_ctor_get(x_25, 2); -x_207 = lean_ctor_get(x_25, 0); -x_208 = lean_ctor_get(x_25, 1); -x_209 = lean_ctor_get(x_25, 3); -x_210 = lean_ctor_get(x_25, 4); -x_211 = lean_ctor_get(x_25, 5); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_206); -lean_inc(x_208); -lean_inc(x_207); -lean_dec(x_25); -x_212 = lean_ctor_get(x_206, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_206, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_206, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_206, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_206)) { - lean_ctor_release(x_206, 0); - lean_ctor_release(x_206, 1); - lean_ctor_release(x_206, 2); - lean_ctor_release(x_206, 3); - x_216 = x_206; -} else { - lean_dec_ref(x_206); - x_216 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_213); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_215); -x_219 = lean_alloc_ctor(0, 6, 0); -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); -x_220 = lean_ctor_get(x_7, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_7, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_7, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_7, 4); -lean_inc(x_224); -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_225 = x_7; -} else { - lean_dec_ref(x_7); - x_225 = lean_box(0); -} -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_26); -lean_ctor_set(x_226, 1, x_14); -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___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_228, x_219); -if (lean_obj_tag(x_229) == 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; lean_object* x_245; lean_object* x_246; -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_233 = x_229; -} else { - lean_dec_ref(x_229); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; -} else { - lean_dec_ref(x_230); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; -} else { - lean_dec_ref(x_231); - x_243 = lean_box(0); -} -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); -} else { - x_244 = x_243; -} -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_214); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); -} else { - x_245 = x_239; -} -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(0, 2, 0); -} else { - x_246 = x_233; -} -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; -} -else -{ -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; -x_247 = lean_ctor_get(x_229, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - x_250 = x_229; -} else { - lean_dec_ref(x_229); - x_250 = lean_box(0); -} -x_251 = lean_ctor_get(x_247, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_247, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_247, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_247, 5); -lean_inc(x_255); -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); - lean_ctor_release(x_247, 4); - lean_ctor_release(x_247, 5); - x_256 = x_247; -} else { - lean_dec_ref(x_247); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_248, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_248, 3); -lean_inc(x_259); -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_260 = x_248; -} else { - lean_dec_ref(x_248); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 4, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_258); -lean_ctor_set(x_261, 2, x_214); -lean_ctor_set(x_261, 3, x_259); -if (lean_is_scalar(x_256)) { - x_262 = lean_alloc_ctor(0, 6, 0); -} else { - x_262 = x_256; -} -lean_ctor_set(x_262, 0, x_251); -lean_ctor_set(x_262, 1, x_252); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_253); -lean_ctor_set(x_262, 4, x_254); -lean_ctor_set(x_262, 5, x_255); -if (lean_is_scalar(x_250)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_250; -} -lean_ctor_set(x_263, 0, x_249); -lean_ctor_set(x_263, 1, x_262); -return x_263; } } } default: { -lean_object* x_264; lean_object* x_265; -x_264 = lean_ctor_get(x_19, 1); -lean_inc(x_264); +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_19, 1); +lean_inc(x_230); lean_dec(x_19); lean_inc(x_7); -x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); -if (lean_obj_tag(x_265) == 0) +x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); +if (lean_obj_tag(x_231) == 0) { -lean_object* x_266; -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -if (lean_obj_tag(x_266) == 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_267; lean_object* x_268; lean_object* x_269; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_dec(x_14); -x_267 = lean_ctor_get(x_265, 1); -lean_inc(x_267); -lean_dec(x_265); -x_268 = lean_unsigned_to_nat(1u); -x_269 = lean_nat_add(x_6, x_268); +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); lean_dec(x_6); -x_6 = x_269; -x_8 = x_267; +x_6 = x_235; +x_8 = x_233; goto _start; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_271 = lean_ctor_get(x_265, 1); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_ctor_get(x_266, 0); -lean_inc(x_272); -lean_dec(x_266); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_6, x_273); +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; +} else { + lean_dec_ref(x_231); + x_238 = 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_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) +x_242 = !lean_is_exclusive(x_237); +if (x_242 == 0) { -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_271, 2); -x_277 = !lean_is_exclusive(x_276); -if (x_277 == 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_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_276, 2); -x_279 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_276, 2, x_279); -x_280 = !lean_is_exclusive(x_7); -if (x_280 == 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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_281 = lean_ctor_get(x_7, 2); -x_282 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_14); -x_283 = lean_array_push(x_281, x_282); -lean_ctor_set(x_7, 2, x_283); -x_284 = 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_274, x_7, x_271); -if (lean_obj_tag(x_284) == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_284, 1); -lean_inc(x_285); -x_286 = lean_ctor_get(x_285, 2); -lean_inc(x_286); -x_287 = !lean_is_exclusive(x_284); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_284, 1); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; uint8_t x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -x_291 = !lean_is_exclusive(x_286); -if (x_291 == 0) -{ -lean_object* x_292; -x_292 = lean_ctor_get(x_286, 2); -lean_dec(x_292); -lean_ctor_set(x_286, 2, x_278); -return x_284; -} -else -{ -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_293 = lean_ctor_get(x_286, 0); -x_294 = lean_ctor_get(x_286, 1); -x_295 = lean_ctor_get(x_286, 3); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_dec(x_286); -x_296 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_278); -lean_ctor_set(x_296, 3, x_295); -lean_ctor_set(x_285, 2, x_296); -return x_284; -} -} -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; -x_297 = lean_ctor_get(x_285, 0); -x_298 = lean_ctor_get(x_285, 1); -x_299 = lean_ctor_get(x_285, 3); -x_300 = lean_ctor_get(x_285, 4); -x_301 = lean_ctor_get(x_285, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_dec(x_285); -x_302 = lean_ctor_get(x_286, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_286, 1); +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_286, 3); +x_304 = lean_ctor_get(x_302, 1); lean_inc(x_304); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_305 = x_286; -} else { - lean_dec_ref(x_286); - x_305 = lean_box(0); +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; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); -} else { - x_306 = x_305; -} -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_278); -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); -lean_ctor_set(x_284, 1, x_307); -return x_284; +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_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; lean_object* x_320; lean_object* x_321; -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -lean_dec(x_284); -x_309 = lean_ctor_get(x_285, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_285, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_285, 3); -lean_inc(x_311); -x_312 = lean_ctor_get(x_285, 4); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 5); +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); -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); - lean_ctor_release(x_285, 5); - x_314 = x_285; -} else { - lean_dec_ref(x_285); - x_314 = lean_box(0); -} -x_315 = lean_ctor_get(x_286, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_286, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_286, 3); -lean_inc(x_317); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - x_318 = x_286; -} else { - lean_dec_ref(x_286); - x_318 = lean_box(0); -} -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_278); -lean_ctor_set(x_319, 3, x_317); -if (lean_is_scalar(x_314)) { - x_320 = lean_alloc_ctor(0, 6, 0); -} else { - x_320 = x_314; -} -lean_ctor_set(x_320, 0, x_309); -lean_ctor_set(x_320, 1, x_310); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_311); -lean_ctor_set(x_320, 4, x_312); -lean_ctor_set(x_320, 5, x_313); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_308); -lean_ctor_set(x_321, 1, x_320); -return x_321; -} -} -else -{ -lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_322 = lean_ctor_get(x_284, 1); -lean_inc(x_322); -x_323 = lean_ctor_get(x_322, 2); -lean_inc(x_323); -x_324 = !lean_is_exclusive(x_284); -if (x_324 == 0) -{ -lean_object* x_325; uint8_t x_326; -x_325 = lean_ctor_get(x_284, 1); -lean_dec(x_325); -x_326 = !lean_is_exclusive(x_322); -if (x_326 == 0) -{ -lean_object* x_327; uint8_t x_328; -x_327 = lean_ctor_get(x_322, 2); -lean_dec(x_327); -x_328 = !lean_is_exclusive(x_323); -if (x_328 == 0) -{ -lean_object* x_329; -x_329 = lean_ctor_get(x_323, 2); -lean_dec(x_329); -lean_ctor_set(x_323, 2, x_278); -return x_284; -} -else -{ -lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_330 = lean_ctor_get(x_323, 0); -x_331 = lean_ctor_get(x_323, 1); -x_332 = lean_ctor_get(x_323, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_323); -x_333 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_333, 0, x_330); -lean_ctor_set(x_333, 1, x_331); -lean_ctor_set(x_333, 2, x_278); -lean_ctor_set(x_333, 3, x_332); -lean_ctor_set(x_322, 2, x_333); -return x_284; -} -} -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_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_334 = lean_ctor_get(x_322, 0); -x_335 = lean_ctor_get(x_322, 1); -x_336 = lean_ctor_get(x_322, 3); -x_337 = lean_ctor_get(x_322, 4); -x_338 = lean_ctor_get(x_322, 5); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_322); -x_339 = lean_ctor_get(x_323, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_323, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_323, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_342 = x_323; -} else { - lean_dec_ref(x_323); - 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_278); -lean_ctor_set(x_343, 3, x_341); -x_344 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_344, 0, x_334); -lean_ctor_set(x_344, 1, x_335); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_336); -lean_ctor_set(x_344, 4, x_337); -lean_ctor_set(x_344, 5, x_338); -lean_ctor_set(x_284, 1, x_344); -return x_284; -} -} -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; -x_345 = lean_ctor_get(x_284, 0); -lean_inc(x_345); -lean_dec(x_284); -x_346 = lean_ctor_get(x_322, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_322, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_322, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_322, 4); -lean_inc(x_349); -x_350 = lean_ctor_get(x_322, 5); -lean_inc(x_350); -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); - lean_ctor_release(x_322, 4); - lean_ctor_release(x_322, 5); - x_351 = x_322; -} else { - lean_dec_ref(x_322); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_323, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_323, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_323, 3); -lean_inc(x_354); -if (lean_is_exclusive(x_323)) { - lean_ctor_release(x_323, 0); - lean_ctor_release(x_323, 1); - lean_ctor_release(x_323, 2); - lean_ctor_release(x_323, 3); - x_355 = x_323; -} else { - lean_dec_ref(x_323); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_278); -lean_ctor_set(x_356, 3, x_354); -if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = 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); -x_358 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; -} -} -} -else -{ -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_359 = lean_ctor_get(x_7, 0); -x_360 = lean_ctor_get(x_7, 1); -x_361 = lean_ctor_get(x_7, 2); -x_362 = lean_ctor_get(x_7, 3); -x_363 = lean_ctor_get(x_7, 4); -lean_inc(x_363); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); lean_dec(x_7); -x_364 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_364, 0, x_272); -lean_ctor_set(x_364, 1, x_14); -x_365 = lean_array_push(x_361, x_364); -x_366 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_366, 0, x_359); -lean_ctor_set(x_366, 1, x_360); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_362); -lean_ctor_set(x_366, 4, x_363); -x_367 = 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_274, x_366, x_271); -if (lean_obj_tag(x_367) == 0) +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_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; -x_368 = lean_ctor_get(x_367, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); -lean_inc(x_376); -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); - x_377 = x_368; -} else { - lean_dec_ref(x_368); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_369, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_369, 1); -lean_inc(x_379); -x_380 = lean_ctor_get(x_369, 3); -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); - 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, 4, 0); -} else { - x_382 = x_381; -} -lean_ctor_set(x_382, 0, x_378); -lean_ctor_set(x_382, 1, x_379); -lean_ctor_set(x_382, 2, x_278); -lean_ctor_set(x_382, 3, x_380); -if (lean_is_scalar(x_377)) { - x_383 = lean_alloc_ctor(0, 6, 0); -} else { - x_383 = x_377; -} -lean_ctor_set(x_383, 0, x_372); -lean_ctor_set(x_383, 1, x_373); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_374); -lean_ctor_set(x_383, 4, x_375); -lean_ctor_set(x_383, 5, x_376); -if (lean_is_scalar(x_371)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_371; -} -lean_ctor_set(x_384, 0, x_370); -lean_ctor_set(x_384, 1, x_383); -return x_384; +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_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_367, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_385, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_367, 0); -lean_inc(x_387); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_388 = x_367; -} else { - lean_dec_ref(x_367); - x_388 = lean_box(0); +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; } -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_385, 3); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 4); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 5); -lean_inc(x_393); -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); - lean_ctor_release(x_385, 4); - lean_ctor_release(x_385, 5); - x_394 = x_385; -} else { - lean_dec_ref(x_385); - x_394 = lean_box(0); } -x_395 = lean_ctor_get(x_386, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_386, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_386, 3); -lean_inc(x_397); -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_398 = x_386; +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); +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); +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 { - lean_dec_ref(x_386); - x_398 = lean_box(0); + x_254 = x_238; + lean_ctor_set_tag(x_254, 1); } -if (lean_is_scalar(x_398)) { - x_399 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_247); +return x_254; +} +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_399 = x_398; + x_259 = x_238; + lean_ctor_set_tag(x_259, 1); } -lean_ctor_set(x_399, 0, x_395); -lean_ctor_set(x_399, 1, x_396); -lean_ctor_set(x_399, 2, x_278); -lean_ctor_set(x_399, 3, x_397); -if (lean_is_scalar(x_394)) { - x_400 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_259, 0, x_249); +lean_ctor_set(x_259, 1, x_247); +return x_259; +} +} +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_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 { - x_400 = x_394; + lean_dec_ref(x_248); + x_268 = lean_box(0); } -lean_ctor_set(x_400, 0, x_389); -lean_ctor_set(x_400, 1, x_390); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_391); -lean_ctor_set(x_400, 4, x_392); -lean_ctor_set(x_400, 5, x_393); -if (lean_is_scalar(x_388)) { - x_401 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_401 = x_388; + x_269 = x_268; +} +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, 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); +} else { + x_271 = x_238; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_249); +lean_ctor_set(x_271, 1, x_270); +return x_271; +} +} +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_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_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); +} else { + x_283 = x_238; +} +lean_ctor_set(x_283, 0, x_273); +lean_ctor_set(x_283, 1, x_247); +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_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); +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; +} else { + lean_dec_ref(x_272); + x_292 = lean_box(0); +} +if (lean_is_scalar(x_292)) { + x_293 = lean_alloc_ctor(0, 4, 0); +} else { + x_293 = x_292; +} +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); +} else { + x_295 = x_238; +} +lean_ctor_set(x_295, 0, x_273); +lean_ctor_set(x_295, 1, x_294); +return x_295; } -lean_ctor_set(x_401, 0, x_387); -lean_ctor_set(x_401, 1, x_400); -return x_401; } } } else { -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; lean_object* x_417; -x_402 = lean_ctor_get(x_276, 0); -x_403 = lean_ctor_get(x_276, 1); -x_404 = lean_ctor_get(x_276, 2); -x_405 = lean_ctor_get(x_276, 3); -lean_inc(x_405); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_dec(x_276); -x_406 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_407 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_407, 0, x_402); -lean_ctor_set(x_407, 1, x_403); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_405); -lean_ctor_set(x_271, 2, x_407); -x_408 = lean_ctor_get(x_7, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_7, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_7, 2); -lean_inc(x_410); -x_411 = lean_ctor_get(x_7, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_7, 4); -lean_inc(x_412); +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); 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_413 = x_7; + x_368 = x_7; } else { lean_dec_ref(x_7); - x_413 = lean_box(0); + x_368 = lean_box(0); } -x_414 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_414, 0, x_272); -lean_ctor_set(x_414, 1, x_14); -x_415 = lean_array_push(x_410, x_414); -if (lean_is_scalar(x_413)) { - x_416 = lean_alloc_ctor(0, 5, 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); } else { - x_416 = x_413; + x_371 = x_368; } -lean_ctor_set(x_416, 0, x_408); -lean_ctor_set(x_416, 1, x_409); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_411); -lean_ctor_set(x_416, 4, x_412); -x_417 = 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_274, x_416, x_271); -if (lean_obj_tag(x_417) == 0) +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_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; lean_object* x_434; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_418, 2); -lean_inc(x_419); -x_420 = lean_ctor_get(x_417, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_421 = x_417; -} else { - lean_dec_ref(x_417); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_418, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_418, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_418, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_418, 4); -lean_inc(x_425); -x_426 = lean_ctor_get(x_418, 5); -lean_inc(x_426); -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); - lean_ctor_release(x_418, 5); - x_427 = x_418; -} else { - lean_dec_ref(x_418); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_419, 0); -lean_inc(x_428); -x_429 = lean_ctor_get(x_419, 1); -lean_inc(x_429); -x_430 = lean_ctor_get(x_419, 3); -lean_inc(x_430); -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); - x_431 = x_419; -} else { - lean_dec_ref(x_419); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_404); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_427; -} -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_421)) { - x_434 = lean_alloc_ctor(0, 2, 0); -} else { - x_434 = x_421; -} -lean_ctor_set(x_434, 0, x_420); -lean_ctor_set(x_434, 1, x_433); -return x_434; +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; } else { -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; lean_object* x_450; lean_object* x_451; -x_435 = lean_ctor_get(x_417, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_435, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_417, 0); -lean_inc(x_437); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - x_438 = x_417; -} else { - lean_dec_ref(x_417); - x_438 = lean_box(0); +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; } +block_360: +{ +if (lean_obj_tag(x_328) == 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_inc(x_345); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +lean_dec(x_328); +x_347 = lean_ctor_get(x_329, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_329, 1); +lean_inc(x_348); +x_349 = lean_ctor_get(x_329, 3); +lean_inc(x_349); +x_350 = lean_ctor_get(x_329, 4); +lean_inc(x_350); +x_351 = lean_ctor_get(x_329, 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; +} else { + lean_dec_ref(x_329); + x_352 = lean_box(0); +} +x_353 = lean_ctor_get(x_345, 0); +lean_inc(x_353); +x_354 = lean_ctor_get(x_345, 1); +lean_inc(x_354); +x_355 = lean_ctor_get(x_345, 3); +lean_inc(x_355); +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; +} else { + lean_dec_ref(x_345); + x_356 = lean_box(0); +} +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 4, 0); +} else { + x_357 = x_356; +} +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); +if (lean_is_scalar(x_352)) { + x_358 = lean_alloc_ctor(0, 6, 0); +} else { + x_358 = 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); +} else { + x_359 = x_238; +} +lean_ctor_set(x_359, 0, x_346); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +} +} +} +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; +} else { + lean_dec_ref(x_379); + x_389 = 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); +} else { + x_424 = x_389; +} +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); +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; +} else { + lean_dec_ref(x_7); + x_431 = 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); +} else { + x_434 = x_431; +} +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_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; +} +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); -x_441 = lean_ctor_get(x_435, 3); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 4); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 5); -lean_inc(x_443); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - lean_ctor_release(x_435, 4); - lean_ctor_release(x_435, 5); - x_444 = x_435; +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; +} +block_422: +{ +if (lean_obj_tag(x_390) == 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_435); - x_444 = lean_box(0); + lean_dec_ref(x_391); + x_399 = lean_box(0); } -x_445 = lean_ctor_get(x_436, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_436, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_436, 3); -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); - x_448 = x_436; +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_436); - x_448 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -if (lean_is_scalar(x_448)) { - x_449 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_449 = x_448; + x_404 = x_403; } -lean_ctor_set(x_449, 0, x_445); -lean_ctor_set(x_449, 1, x_446); -lean_ctor_set(x_449, 2, x_404); -lean_ctor_set(x_449, 3, x_447); -if (lean_is_scalar(x_444)) { - x_450 = lean_alloc_ctor(0, 6, 0); +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_450 = x_444; + x_405 = x_399; } -lean_ctor_set(x_450, 0, x_439); -lean_ctor_set(x_450, 1, x_440); -lean_ctor_set(x_450, 2, x_449); -lean_ctor_set(x_450, 3, x_441); -lean_ctor_set(x_450, 4, x_442); -lean_ctor_set(x_450, 5, x_443); -if (lean_is_scalar(x_438)) { - x_451 = lean_alloc_ctor(1, 2, 0); +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_451 = x_438; -} -lean_ctor_set(x_451, 0, x_437); -lean_ctor_set(x_451, 1, x_450); -return x_451; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; -x_452 = lean_ctor_get(x_271, 2); -x_453 = lean_ctor_get(x_271, 0); -x_454 = lean_ctor_get(x_271, 1); -x_455 = lean_ctor_get(x_271, 3); -x_456 = lean_ctor_get(x_271, 4); -x_457 = lean_ctor_get(x_271, 5); -lean_inc(x_457); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_452); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_271); -x_458 = lean_ctor_get(x_452, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_452, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_452, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_452, 3); -lean_inc(x_461); -if (lean_is_exclusive(x_452)) { - lean_ctor_release(x_452, 0); - lean_ctor_release(x_452, 1); - lean_ctor_release(x_452, 2); - lean_ctor_release(x_452, 3); - x_462 = x_452; +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_inc(x_410); +x_411 = lean_ctor_get(x_391, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_391, 4); +lean_inc(x_412); +x_413 = lean_ctor_get(x_391, 5); +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_452); - x_462 = lean_box(0); + lean_dec_ref(x_391); + x_414 = lean_box(0); } -x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_462)) { - x_464 = lean_alloc_ctor(0, 4, 0); +x_415 = lean_ctor_get(x_407, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 1); +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; } else { - x_464 = x_462; + lean_dec_ref(x_407); + x_418 = lean_box(0); } -lean_ctor_set(x_464, 0, x_458); -lean_ctor_set(x_464, 1, x_459); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_461); -x_465 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_465, 0, x_453); -lean_ctor_set(x_465, 1, x_454); -lean_ctor_set(x_465, 2, x_464); -lean_ctor_set(x_465, 3, x_455); -lean_ctor_set(x_465, 4, x_456); -lean_ctor_set(x_465, 5, x_457); -x_466 = lean_ctor_get(x_7, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_7, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_7, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_7, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_7, 4); -lean_inc(x_470); -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_471 = x_7; +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_7); - x_471 = lean_box(0); + x_419 = x_418; } -x_472 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_472, 0, x_272); -lean_ctor_set(x_472, 1, x_14); -x_473 = lean_array_push(x_468, x_472); -if (lean_is_scalar(x_471)) { - x_474 = lean_alloc_ctor(0, 5, 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); } else { - x_474 = x_471; + x_420 = x_414; } -lean_ctor_set(x_474, 0, x_466); -lean_ctor_set(x_474, 1, x_467); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_469); -lean_ctor_set(x_474, 4, x_470); -x_475 = 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_274, x_474, x_465); -if (lean_obj_tag(x_475) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_476 = lean_ctor_get(x_475, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_476, 2); -lean_inc(x_477); -x_478 = lean_ctor_get(x_475, 0); -lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_479 = x_475; +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); } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + x_421 = x_238; } -x_480 = lean_ctor_get(x_476, 0); -lean_inc(x_480); -x_481 = lean_ctor_get(x_476, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_476, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_476, 4); -lean_inc(x_483); -x_484 = lean_ctor_get(x_476, 5); -lean_inc(x_484); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - lean_ctor_release(x_476, 4); - lean_ctor_release(x_476, 5); - x_485 = x_476; -} else { - lean_dec_ref(x_476); - x_485 = lean_box(0); +lean_ctor_set(x_421, 0, x_408); +lean_ctor_set(x_421, 1, x_420); +return x_421; } -x_486 = lean_ctor_get(x_477, 0); -lean_inc(x_486); -x_487 = lean_ctor_get(x_477, 1); -lean_inc(x_487); -x_488 = lean_ctor_get(x_477, 3); -lean_inc(x_488); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - lean_ctor_release(x_477, 3); - x_489 = x_477; -} else { - lean_dec_ref(x_477); - x_489 = lean_box(0); -} -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 4, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_486); -lean_ctor_set(x_490, 1, x_487); -lean_ctor_set(x_490, 2, x_460); -lean_ctor_set(x_490, 3, x_488); -if (lean_is_scalar(x_485)) { - x_491 = lean_alloc_ctor(0, 6, 0); -} else { - x_491 = x_485; -} -lean_ctor_set(x_491, 0, x_480); -lean_ctor_set(x_491, 1, x_481); -lean_ctor_set(x_491, 2, x_490); -lean_ctor_set(x_491, 3, x_482); -lean_ctor_set(x_491, 4, x_483); -lean_ctor_set(x_491, 5, x_484); -if (lean_is_scalar(x_479)) { - x_492 = lean_alloc_ctor(0, 2, 0); -} else { - x_492 = x_479; -} -lean_ctor_set(x_492, 0, x_478); -lean_ctor_set(x_492, 1, x_491); -return x_492; -} -else -{ -lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_493 = lean_ctor_get(x_475, 1); -lean_inc(x_493); -x_494 = lean_ctor_get(x_493, 2); -lean_inc(x_494); -x_495 = lean_ctor_get(x_475, 0); -lean_inc(x_495); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - x_496 = x_475; -} else { - lean_dec_ref(x_475); - x_496 = lean_box(0); -} -x_497 = lean_ctor_get(x_493, 0); -lean_inc(x_497); -x_498 = lean_ctor_get(x_493, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_493, 3); -lean_inc(x_499); -x_500 = lean_ctor_get(x_493, 4); -lean_inc(x_500); -x_501 = lean_ctor_get(x_493, 5); -lean_inc(x_501); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - lean_ctor_release(x_493, 4); - lean_ctor_release(x_493, 5); - x_502 = x_493; -} else { - lean_dec_ref(x_493); - x_502 = lean_box(0); -} -x_503 = lean_ctor_get(x_494, 0); -lean_inc(x_503); -x_504 = lean_ctor_get(x_494, 1); -lean_inc(x_504); -x_505 = lean_ctor_get(x_494, 3); -lean_inc(x_505); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - lean_ctor_release(x_494, 2); - lean_ctor_release(x_494, 3); - x_506 = x_494; -} else { - lean_dec_ref(x_494); - x_506 = lean_box(0); -} -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 4, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_503); -lean_ctor_set(x_507, 1, x_504); -lean_ctor_set(x_507, 2, x_460); -lean_ctor_set(x_507, 3, x_505); -if (lean_is_scalar(x_502)) { - x_508 = lean_alloc_ctor(0, 6, 0); -} else { - x_508 = x_502; -} -lean_ctor_set(x_508, 0, x_497); -lean_ctor_set(x_508, 1, x_498); -lean_ctor_set(x_508, 2, x_507); -lean_ctor_set(x_508, 3, x_499); -lean_ctor_set(x_508, 4, x_500); -lean_ctor_set(x_508, 5, x_501); -if (lean_is_scalar(x_496)) { - x_509 = lean_alloc_ctor(1, 2, 0); -} else { - x_509 = x_496; -} -lean_ctor_set(x_509, 0, x_495); -lean_ctor_set(x_509, 1, x_508); -return x_509; } } } } else { -uint8_t x_510; +uint8_t x_442; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_510 = !lean_is_exclusive(x_265); -if (x_510 == 0) +x_442 = !lean_is_exclusive(x_231); +if (x_442 == 0) { -return x_265; +return x_231; } else { -lean_object* x_511; lean_object* x_512; lean_object* x_513; -x_511 = lean_ctor_get(x_265, 0); -x_512 = lean_ctor_get(x_265, 1); -lean_inc(x_512); -lean_inc(x_511); -lean_dec(x_265); -x_513 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_513, 0, x_511); -lean_ctor_set(x_513, 1, x_512); -return x_513; +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; } } } @@ -43186,58 +37801,58 @@ return x_513; } else { -uint8_t x_514; +uint8_t x_446; 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_514 = !lean_is_exclusive(x_19); -if (x_514 == 0) +x_446 = !lean_is_exclusive(x_19); +if (x_446 == 0) { return x_19; } else { -lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_515 = lean_ctor_get(x_19, 0); -x_516 = lean_ctor_get(x_19, 1); -lean_inc(x_516); -lean_inc(x_515); +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_dec(x_19); -x_517 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -return x_517; +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; } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_15); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_15); +if (x_450 == 0) { return x_15; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_15, 0); -x_520 = lean_ctor_get(x_15, 1); -lean_inc(x_520); -lean_inc(x_519); +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_dec(x_15); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -44622,1077 +39237,896 @@ return x_9; } else { -lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; x_10 = lean_ctor_get(x_6, 1); lean_inc(x_10); -lean_dec(x_6); -x_11 = lean_ctor_get(x_10, 2); -lean_inc(x_11); -x_12 = lean_ctor_get(x_7, 0); +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + x_11 = x_6; +} else { + lean_dec_ref(x_6); + x_11 = lean_box(0); +} +x_12 = lean_ctor_get(x_10, 2); lean_inc(x_12); +x_13 = lean_ctor_get(x_7, 0); +lean_inc(x_13); lean_dec(x_7); -x_13 = !lean_is_exclusive(x_10); -if (x_13 == 0) +x_14 = !lean_is_exclusive(x_10); +if (x_14 == 0) { -lean_object* x_14; uint8_t x_15; -x_14 = lean_ctor_get(x_10, 2); -lean_dec(x_14); -x_15 = !lean_is_exclusive(x_11); -if (x_15 == 0) +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_10, 2); +lean_dec(x_15); +x_16 = !lean_is_exclusive(x_12); +if (x_16 == 0) { -lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_16 = lean_ctor_get(x_11, 2); -x_17 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_11, 2, x_17); -x_18 = !lean_is_exclusive(x_4); -if (x_18 == 0) +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_69; uint8_t x_70; +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) { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_4, 2); +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_inc(x_1); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_12); -lean_ctor_set(x_20, 1, x_1); -x_21 = lean_array_push(x_19, x_20); -lean_ctor_set(x_4, 2, x_21); -x_22 = lean_apply_3(x_3, x_1, x_4, x_10); -if (lean_obj_tag(x_22) == 0) +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) { -lean_object* x_23; lean_object* x_24; uint8_t x_25; -x_23 = lean_ctor_get(x_22, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_23, 2); -lean_inc(x_24); -x_25 = !lean_is_exclusive(x_22); -if (x_25 == 0) -{ -lean_object* x_26; uint8_t x_27; -x_26 = lean_ctor_get(x_22, 1); -lean_dec(x_26); -x_27 = !lean_is_exclusive(x_23); -if (x_27 == 0) -{ -lean_object* x_28; uint8_t x_29; -x_28 = lean_ctor_get(x_23, 2); -lean_dec(x_28); -x_29 = !lean_is_exclusive(x_24); -if (x_29 == 0) -{ -lean_object* x_30; -x_30 = lean_ctor_get(x_24, 2); -lean_dec(x_30); -lean_ctor_set(x_24, 2, x_16); -return x_22; +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_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_24, 0); -x_32 = lean_ctor_get(x_24, 1); -x_33 = lean_ctor_get(x_24, 3); -lean_inc(x_33); -lean_inc(x_32); -lean_inc(x_31); -lean_dec(x_24); -x_34 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_34, 0, x_31); -lean_ctor_set(x_34, 1, x_32); -lean_ctor_set(x_34, 2, x_16); -lean_ctor_set(x_34, 3, x_33); -lean_ctor_set(x_23, 2, x_34); -return x_22; +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_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; } } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_35 = lean_ctor_get(x_23, 0); -x_36 = lean_ctor_get(x_23, 1); -x_37 = lean_ctor_get(x_23, 3); -x_38 = lean_ctor_get(x_23, 4); -x_39 = lean_ctor_get(x_23, 5); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); +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_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) +{ +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; +} +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; +} +} +block_68: +{ +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_20 = lean_ctor_get(x_19, 2); +lean_inc(x_20); +x_21 = lean_ctor_get(x_18, 0); +lean_inc(x_21); +lean_dec(x_18); +x_22 = !lean_is_exclusive(x_19); +if (x_22 == 0) +{ +lean_object* x_23; uint8_t x_24; +x_23 = lean_ctor_get(x_19, 2); +lean_dec(x_23); +x_24 = !lean_is_exclusive(x_20); +if (x_24 == 0) +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_20, 2); +lean_dec(x_25); +lean_ctor_set(x_20, 2, x_17); +if (lean_is_scalar(x_11)) { + x_26 = lean_alloc_ctor(1, 2, 0); +} else { + x_26 = x_11; + lean_ctor_set_tag(x_26, 1); +} +lean_ctor_set(x_26, 0, x_21); +lean_ctor_set(x_26, 1, x_19); +return x_26; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_27 = lean_ctor_get(x_20, 0); +x_28 = lean_ctor_get(x_20, 1); +x_29 = lean_ctor_get(x_20, 3); +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); +if (lean_is_scalar(x_11)) { + x_31 = lean_alloc_ctor(1, 2, 0); +} else { + x_31 = x_11; + lean_ctor_set_tag(x_31, 1); +} +lean_ctor_set(x_31, 0, x_21); +lean_ctor_set(x_31, 1, x_19); +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_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_inc(x_36); lean_inc(x_35); -lean_dec(x_23); -x_40 = lean_ctor_get(x_24, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_24, 1); -lean_inc(x_41); -x_42 = lean_ctor_get(x_24, 3); -lean_inc(x_42); -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_43 = x_24; +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); +lean_inc(x_38); +x_39 = lean_ctor_get(x_20, 3); +lean_inc(x_39); +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; } else { - lean_dec_ref(x_24); - x_43 = lean_box(0); + lean_dec_ref(x_20); + x_40 = lean_box(0); } -if (lean_is_scalar(x_43)) { - x_44 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_40)) { + x_41 = lean_alloc_ctor(0, 4, 0); } else { - x_44 = x_43; + x_41 = x_40; } -lean_ctor_set(x_44, 0, x_40); -lean_ctor_set(x_44, 1, x_41); -lean_ctor_set(x_44, 2, x_16); -lean_ctor_set(x_44, 3, x_42); -x_45 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_45, 0, x_35); -lean_ctor_set(x_45, 1, x_36); -lean_ctor_set(x_45, 2, x_44); -lean_ctor_set(x_45, 3, x_37); -lean_ctor_set(x_45, 4, x_38); -lean_ctor_set(x_45, 5, x_39); -lean_ctor_set(x_22, 1, x_45); -return x_22; +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); +if (lean_is_scalar(x_11)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_11; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_21); +lean_ctor_set(x_43, 1, x_42); +return x_43; } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_46 = lean_ctor_get(x_22, 0); -lean_inc(x_46); -lean_dec(x_22); -x_47 = lean_ctor_get(x_23, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_23, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_23, 3); -lean_inc(x_49); -x_50 = lean_ctor_get(x_23, 4); -lean_inc(x_50); -x_51 = lean_ctor_get(x_23, 5); -lean_inc(x_51); -if (lean_is_exclusive(x_23)) { - lean_ctor_release(x_23, 0); - lean_ctor_release(x_23, 1); - lean_ctor_release(x_23, 2); - lean_ctor_release(x_23, 3); - lean_ctor_release(x_23, 4); - lean_ctor_release(x_23, 5); - x_52 = x_23; +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_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); +if (x_48 == 0) +{ +lean_object* x_49; lean_object* x_50; +x_49 = lean_ctor_get(x_44, 2); +lean_dec(x_49); +lean_ctor_set(x_44, 2, x_17); +if (lean_is_scalar(x_11)) { + x_50 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_23); - x_52 = lean_box(0); + x_50 = x_11; } -x_53 = lean_ctor_get(x_24, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_19); +return x_50; +} +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_inc(x_53); -x_54 = lean_ctor_get(x_24, 1); -lean_inc(x_54); -x_55 = lean_ctor_get(x_24, 3); -lean_inc(x_55); -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_56 = x_24; +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); +if (lean_is_scalar(x_11)) { + x_55 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_24); - x_56 = lean_box(0); + x_55 = x_11; } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); -} else { - x_57 = x_56; -} -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_16); -lean_ctor_set(x_57, 3, x_55); -if (lean_is_scalar(x_52)) { - x_58 = lean_alloc_ctor(0, 6, 0); -} else { - x_58 = x_52; -} -lean_ctor_set(x_58, 0, x_47); -lean_ctor_set(x_58, 1, x_48); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_49); -lean_ctor_set(x_58, 4, x_50); -lean_ctor_set(x_58, 5, x_51); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_46); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_55, 0, x_45); +lean_ctor_set(x_55, 1, x_19); +return x_55; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_22, 1); +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_inc(x_60); -x_61 = lean_ctor_get(x_60, 2); +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_is_exclusive(x_22); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_22, 1); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); -if (x_64 == 0) -{ -lean_object* x_65; uint8_t x_66; -x_65 = lean_ctor_get(x_60, 2); -lean_dec(x_65); -x_66 = !lean_is_exclusive(x_61); -if (x_66 == 0) -{ -lean_object* x_67; -x_67 = lean_ctor_get(x_61, 2); -lean_dec(x_67); -lean_ctor_set(x_61, 2, x_16); -return x_22; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -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_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_16); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set(x_60, 2, x_71); -return x_22; -} -} -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; -x_72 = lean_ctor_get(x_60, 0); -x_73 = lean_ctor_get(x_60, 1); -x_74 = lean_ctor_get(x_60, 3); -x_75 = lean_ctor_get(x_60, 4); -x_76 = lean_ctor_get(x_60, 5); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_60); -x_77 = lean_ctor_get(x_61, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_61, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_61, 3); -lean_inc(x_79); -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_80 = 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; } else { - lean_dec_ref(x_61); - x_80 = lean_box(0); + lean_dec_ref(x_44); + x_64 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 4, 0); } else { - x_81 = x_80; + x_65 = x_64; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_16); -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_22, 1, x_82); -return x_22; -} -} -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; -x_83 = lean_ctor_get(x_22, 0); -lean_inc(x_83); -lean_dec(x_22); -x_84 = lean_ctor_get(x_60, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_60, 1); -lean_inc(x_85); -x_86 = lean_ctor_get(x_60, 3); -lean_inc(x_86); -x_87 = lean_ctor_get(x_60, 4); -lean_inc(x_87); -x_88 = lean_ctor_get(x_60, 5); -lean_inc(x_88); -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_89 = x_60; +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); +if (lean_is_scalar(x_11)) { + x_67 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_60); - x_89 = lean_box(0); + x_67 = x_11; } -x_90 = lean_ctor_get(x_61, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_61, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_61, 3); -lean_inc(x_92); -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_93 = x_61; -} else { - lean_dec_ref(x_61); - x_93 = lean_box(0); +lean_ctor_set(x_67, 0, x_45); +lean_ctor_set(x_67, 1, x_66); +return x_67; } -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_16); -lean_ctor_set(x_94, 3, x_92); -if (lean_is_scalar(x_89)) { - x_95 = lean_alloc_ctor(0, 6, 0); -} else { - x_95 = x_89; -} -lean_ctor_set(x_95, 0, x_84); -lean_ctor_set(x_95, 1, x_85); -lean_ctor_set(x_95, 2, x_94); -lean_ctor_set(x_95, 3, x_86); -lean_ctor_set(x_95, 4, x_87); -lean_ctor_set(x_95, 5, x_88); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_83); -lean_ctor_set(x_96, 1, x_95); -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; -x_97 = lean_ctor_get(x_4, 0); -x_98 = lean_ctor_get(x_4, 1); -x_99 = lean_ctor_get(x_4, 2); -x_100 = lean_ctor_get(x_4, 3); -x_101 = lean_ctor_get(x_4, 4); -lean_inc(x_101); -lean_inc(x_100); +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_dec(x_4); -lean_inc(x_1); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_12); -lean_ctor_set(x_102, 1, x_1); -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 = lean_apply_3(x_3, x_1, x_104, x_10); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_106 = lean_ctor_get(x_105, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_106, 2); -lean_inc(x_107); -x_108 = lean_ctor_get(x_105, 0); -lean_inc(x_108); -if (lean_is_exclusive(x_105)) { - lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - x_109 = x_105; +lean_inc(x_96); +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); +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; } else { - lean_dec_ref(x_105); + lean_dec_ref(x_4); + x_140 = 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); +} else { + x_143 = x_140; +} +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_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_106, 0); +x_110 = lean_ctor_get(x_102, 0); lean_inc(x_110); -x_111 = lean_ctor_get(x_106, 1); +x_111 = lean_ctor_get(x_102, 1); lean_inc(x_111); -x_112 = lean_ctor_get(x_106, 3); +x_112 = lean_ctor_get(x_102, 3); lean_inc(x_112); -x_113 = lean_ctor_get(x_106, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_106, 5); -lean_inc(x_114); -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_115 = x_106; +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_106); - x_115 = lean_box(0); + lean_dec_ref(x_102); + x_113 = lean_box(0); } -x_116 = lean_ctor_get(x_107, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_107, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_107, 3); -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); - x_119 = x_107; +if (lean_is_scalar(x_113)) { + x_114 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_107); - x_119 = lean_box(0); + x_114 = x_113; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_16); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); +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_122 = lean_alloc_ctor(0, 2, 0); + x_115 = lean_alloc_ctor(0, 6, 0); } else { - x_122 = x_109; + x_115 = x_109; } -lean_ctor_set(x_122, 0, x_108); -lean_ctor_set(x_122, 1, x_121); -return x_122; +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_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_123 = lean_ctor_get(x_105, 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; +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); -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_105, 0); +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); -if (lean_is_exclusive(x_105)) { - lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - x_126 = x_105; -} else { - lean_dec_ref(x_105); - x_126 = lean_box(0); -} -x_127 = lean_ctor_get(x_123, 0); +x_126 = lean_ctor_get(x_117, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_117, 3); lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 3); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 4); -lean_inc(x_130); -x_131 = lean_ctor_get(x_123, 5); -lean_inc(x_131); -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_132 = x_123; +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_123); - x_132 = lean_box(0); + lean_dec_ref(x_117); + x_128 = lean_box(0); } -x_133 = lean_ctor_get(x_124, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_124, 3); -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); - x_136 = x_124; +if (lean_is_scalar(x_128)) { + x_129 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_124); - x_136 = lean_box(0); + x_129 = x_128; } -if (lean_is_scalar(x_136)) { - x_137 = lean_alloc_ctor(0, 4, 0); +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_137 = x_136; + x_130 = x_124; } -lean_ctor_set(x_137, 0, x_133); -lean_ctor_set(x_137, 1, x_134); -lean_ctor_set(x_137, 2, x_16); -lean_ctor_set(x_137, 3, x_135); -if (lean_is_scalar(x_132)) { - x_138 = lean_alloc_ctor(0, 6, 0); +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_138 = x_132; + x_131 = x_11; } -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_126)) { - x_139 = lean_alloc_ctor(1, 2, 0); -} else { - x_139 = x_126; +lean_ctor_set(x_131, 0, x_118); +lean_ctor_set(x_131, 1, x_130); +return x_131; } -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_11, 0); -x_141 = lean_ctor_get(x_11, 1); -x_142 = lean_ctor_get(x_11, 2); -x_143 = lean_ctor_get(x_11, 3); -lean_inc(x_143); -lean_inc(x_142); -lean_inc(x_141); -lean_inc(x_140); -lean_dec(x_11); -x_144 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_145 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_145, 0, x_140); -lean_ctor_set(x_145, 1, x_141); -lean_ctor_set(x_145, 2, x_144); -lean_ctor_set(x_145, 3, x_143); -lean_ctor_set(x_10, 2, x_145); -x_146 = lean_ctor_get(x_4, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_4, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_4, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_4, 3); -lean_inc(x_149); -x_150 = lean_ctor_get(x_4, 4); -lean_inc(x_150); -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_151 = x_4; -} else { - lean_dec_ref(x_4); - x_151 = lean_box(0); -} -lean_inc(x_1); -x_152 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_152, 0, x_12); -lean_ctor_set(x_152, 1, x_1); -x_153 = lean_array_push(x_148, x_152); -if (lean_is_scalar(x_151)) { - x_154 = lean_alloc_ctor(0, 5, 0); -} else { - x_154 = x_151; -} -lean_ctor_set(x_154, 0, x_146); -lean_ctor_set(x_154, 1, x_147); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_149); -lean_ctor_set(x_154, 4, x_150); -x_155 = lean_apply_3(x_3, x_1, x_154, x_10); -if (lean_obj_tag(x_155) == 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; lean_object* x_171; lean_object* x_172; -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_ctor_get(x_155, 0); -lean_inc(x_158); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_159 = x_155; -} else { - lean_dec_ref(x_155); - x_159 = lean_box(0); -} -x_160 = lean_ctor_get(x_156, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_156, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_156, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_156, 4); -lean_inc(x_163); -x_164 = lean_ctor_get(x_156, 5); -lean_inc(x_164); -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_165 = x_156; -} else { - lean_dec_ref(x_156); - x_165 = lean_box(0); -} -x_166 = lean_ctor_get(x_157, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_157, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_157, 3); -lean_inc(x_168); -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); - x_169 = x_157; -} else { - lean_dec_ref(x_157); - x_169 = lean_box(0); -} -if (lean_is_scalar(x_169)) { - x_170 = lean_alloc_ctor(0, 4, 0); -} else { - x_170 = x_169; -} -lean_ctor_set(x_170, 0, x_166); -lean_ctor_set(x_170, 1, x_167); -lean_ctor_set(x_170, 2, x_142); -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); -if (lean_is_scalar(x_159)) { - x_172 = lean_alloc_ctor(0, 2, 0); -} else { - x_172 = x_159; -} -lean_ctor_set(x_172, 0, x_158); -lean_ctor_set(x_172, 1, x_171); -return x_172; -} -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_187; lean_object* x_188; lean_object* x_189; -x_173 = lean_ctor_get(x_155, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_155, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_176 = x_155; -} else { - lean_dec_ref(x_155); - x_176 = lean_box(0); -} -x_177 = lean_ctor_get(x_173, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_173, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_173, 3); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 4); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 5); -lean_inc(x_181); -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); - lean_ctor_release(x_173, 5); - x_182 = x_173; -} else { - lean_dec_ref(x_173); - x_182 = lean_box(0); -} -x_183 = lean_ctor_get(x_174, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_174, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_174, 3); -lean_inc(x_185); -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_186 = x_174; -} else { - lean_dec_ref(x_174); - x_186 = lean_box(0); -} -if (lean_is_scalar(x_186)) { - x_187 = lean_alloc_ctor(0, 4, 0); -} else { - x_187 = x_186; -} -lean_ctor_set(x_187, 0, x_183); -lean_ctor_set(x_187, 1, x_184); -lean_ctor_set(x_187, 2, x_142); -lean_ctor_set(x_187, 3, x_185); -if (lean_is_scalar(x_182)) { - x_188 = lean_alloc_ctor(0, 6, 0); -} else { - x_188 = x_182; -} -lean_ctor_set(x_188, 0, x_177); -lean_ctor_set(x_188, 1, x_178); -lean_ctor_set(x_188, 2, x_187); -lean_ctor_set(x_188, 3, x_179); -lean_ctor_set(x_188, 4, x_180); -lean_ctor_set(x_188, 5, x_181); -if (lean_is_scalar(x_176)) { - x_189 = lean_alloc_ctor(1, 2, 0); -} else { - x_189 = x_176; -} -lean_ctor_set(x_189, 0, x_175); -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; 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; -x_190 = lean_ctor_get(x_10, 0); -x_191 = lean_ctor_get(x_10, 1); -x_192 = lean_ctor_get(x_10, 3); -x_193 = lean_ctor_get(x_10, 4); -x_194 = lean_ctor_get(x_10, 5); -lean_inc(x_194); -lean_inc(x_193); -lean_inc(x_192); -lean_inc(x_191); -lean_inc(x_190); +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_inc(x_152); +lean_inc(x_151); lean_dec(x_10); -x_195 = lean_ctor_get(x_11, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_11, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_11, 2); +x_156 = lean_ctor_get(x_12, 0); +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_inc(x_159); +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; +} else { + lean_dec_ref(x_12); + x_160 = 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); +} else { + x_195 = x_160; +} +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_11, 3); +x_198 = lean_ctor_get(x_4, 1); lean_inc(x_198); -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); - x_199 = x_11; -} else { - lean_dec_ref(x_11); - x_199 = lean_box(0); -} -x_200 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_199)) { - x_201 = lean_alloc_ctor(0, 4, 0); -} else { - x_201 = x_199; -} -lean_ctor_set(x_201, 0, x_195); -lean_ctor_set(x_201, 1, x_196); -lean_ctor_set(x_201, 2, x_200); -lean_ctor_set(x_201, 3, x_198); -x_202 = lean_alloc_ctor(0, 6, 0); -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); -x_203 = lean_ctor_get(x_4, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_4, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_4, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_4, 3); -lean_inc(x_206); -x_207 = lean_ctor_get(x_4, 4); -lean_inc(x_207); +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); 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_208 = x_4; + x_202 = x_4; } else { lean_dec_ref(x_4); - x_208 = lean_box(0); + x_202 = lean_box(0); } lean_inc(x_1); -x_209 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_209, 0, x_12); -lean_ctor_set(x_209, 1, x_1); -x_210 = lean_array_push(x_205, x_209); -if (lean_is_scalar(x_208)) { - x_211 = lean_alloc_ctor(0, 5, 0); +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); } else { - x_211 = x_208; + x_205 = x_202; } -lean_ctor_set(x_211, 0, x_203); -lean_ctor_set(x_211, 1, x_204); -lean_ctor_set(x_211, 2, x_210); -lean_ctor_set(x_211, 3, x_206); -lean_ctor_set(x_211, 4, x_207); -x_212 = lean_apply_3(x_3, x_1, x_211, x_202); -if (lean_obj_tag(x_212) == 0) +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_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; -x_213 = lean_ctor_get(x_212, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_213, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_212, 0); -lean_inc(x_215); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - x_216 = x_212; -} else { - lean_dec_ref(x_212); - x_216 = lean_box(0); -} -x_217 = lean_ctor_get(x_213, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_213, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_213, 3); -lean_inc(x_219); -x_220 = lean_ctor_get(x_213, 4); -lean_inc(x_220); -x_221 = lean_ctor_get(x_213, 5); -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); -} -x_223 = lean_ctor_get(x_214, 0); -lean_inc(x_223); -x_224 = lean_ctor_get(x_214, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_214, 3); -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); - 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, 4, 0); -} else { - x_227 = x_226; -} -lean_ctor_set(x_227, 0, x_223); -lean_ctor_set(x_227, 1, x_224); -lean_ctor_set(x_227, 2, x_197); -lean_ctor_set(x_227, 3, x_225); -if (lean_is_scalar(x_222)) { - x_228 = lean_alloc_ctor(0, 6, 0); -} else { - x_228 = x_222; -} -lean_ctor_set(x_228, 0, x_217); -lean_ctor_set(x_228, 1, x_218); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_219); -lean_ctor_set(x_228, 4, x_220); -lean_ctor_set(x_228, 5, x_221); -if (lean_is_scalar(x_216)) { - x_229 = lean_alloc_ctor(0, 2, 0); -} else { - x_229 = x_216; -} -lean_ctor_set(x_229, 0, x_215); -lean_ctor_set(x_229, 1, x_228); -return x_229; +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; } else { -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; -x_230 = lean_ctor_get(x_212, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_212, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - x_233 = x_212; -} else { - lean_dec_ref(x_212); - x_233 = lean_box(0); +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; } -x_234 = lean_ctor_get(x_230, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_230, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_230, 4); -lean_inc(x_237); -x_238 = lean_ctor_get(x_230, 5); -lean_inc(x_238); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - lean_ctor_release(x_230, 4); - lean_ctor_release(x_230, 5); - x_239 = x_230; +block_193: +{ +if (lean_obj_tag(x_161) == 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_230); - x_239 = lean_box(0); + lean_dec_ref(x_162); + x_170 = lean_box(0); } -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_231, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_231, 3); -lean_inc(x_242); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - x_243 = x_231; +x_171 = lean_ctor_get(x_163, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_163, 1); +lean_inc(x_172); +x_173 = lean_ctor_get(x_163, 3); +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; } else { - lean_dec_ref(x_231); - x_243 = lean_box(0); + lean_dec_ref(x_163); + x_174 = lean_box(0); } -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_174)) { + x_175 = lean_alloc_ctor(0, 4, 0); } else { - x_244 = x_243; + x_175 = x_174; } -lean_ctor_set(x_244, 0, x_240); -lean_ctor_set(x_244, 1, x_241); -lean_ctor_set(x_244, 2, x_197); -lean_ctor_set(x_244, 3, x_242); -if (lean_is_scalar(x_239)) { - x_245 = lean_alloc_ctor(0, 6, 0); +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_245 = x_239; + x_176 = x_170; } -lean_ctor_set(x_245, 0, x_234); -lean_ctor_set(x_245, 1, x_235); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_236); -lean_ctor_set(x_245, 4, x_237); -lean_ctor_set(x_245, 5, x_238); -if (lean_is_scalar(x_233)) { - x_246 = lean_alloc_ctor(1, 2, 0); +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_246 = x_233; + 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); +lean_inc(x_179); +lean_dec(x_161); +x_180 = lean_ctor_get(x_162, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_162, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_162, 3); +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; +} else { + lean_dec_ref(x_162); + x_185 = 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; +} else { + lean_dec_ref(x_178); + x_189 = lean_box(0); +} +if (lean_is_scalar(x_189)) { + x_190 = lean_alloc_ctor(0, 4, 0); +} else { + x_190 = x_189; +} +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); +if (lean_is_scalar(x_11)) { + x_192 = lean_alloc_ctor(0, 2, 0); +} else { + x_192 = x_11; +} +lean_ctor_set(x_192, 0, x_179); +lean_ctor_set(x_192, 1, x_191); +return x_192; } -lean_ctor_set(x_246, 0, x_232); -lean_ctor_set(x_246, 1, x_245); -return x_246; } } } } else { -uint8_t x_247; +uint8_t x_213; lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_247 = !lean_is_exclusive(x_6); -if (x_247 == 0) +x_213 = !lean_is_exclusive(x_6); +if (x_213 == 0) { return x_6; } else { -lean_object* x_248; lean_object* x_249; lean_object* x_250; -x_248 = lean_ctor_get(x_6, 0); -x_249 = lean_ctor_get(x_6, 1); -lean_inc(x_249); -lean_inc(x_248); +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_dec(x_6); -x_250 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_250, 0, x_248); -lean_ctor_set(x_250, 1, x_249); -return x_250; +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; } } } @@ -45757,812 +40191,771 @@ return x_21; } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint8_t x_25; +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_dec(x_5); x_22 = lean_ctor_get(x_18, 1); lean_inc(x_22); -lean_dec(x_18); -x_23 = lean_ctor_get(x_22, 2); -lean_inc(x_23); -x_24 = lean_ctor_get(x_19, 0); +if (lean_is_exclusive(x_18)) { + lean_ctor_release(x_18, 0); + lean_ctor_release(x_18, 1); + x_23 = x_18; +} else { + lean_dec_ref(x_18); + x_23 = lean_box(0); +} +x_24 = lean_ctor_get(x_22, 2); lean_inc(x_24); +x_25 = lean_ctor_get(x_19, 0); +lean_inc(x_25); lean_dec(x_19); -x_25 = !lean_is_exclusive(x_22); -if (x_25 == 0) +x_26 = !lean_is_exclusive(x_22); +if (x_26 == 0) { -lean_object* x_26; uint8_t x_27; -x_26 = lean_ctor_get(x_22, 2); -lean_dec(x_26); -x_27 = !lean_is_exclusive(x_23); -if (x_27 == 0) +lean_object* x_27; uint8_t x_28; +x_27 = lean_ctor_get(x_22, 2); +lean_dec(x_27); +x_28 = !lean_is_exclusive(x_24); +if (x_28 == 0) { -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_23, 2); -x_29 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_23, 2, x_29); +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; +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); lean_inc(x_17); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_24); -lean_ctor_set(x_30, 1, x_17); -x_31 = lean_array_push(x_13, x_30); -x_32 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_32, 0, x_11); -lean_ctor_set(x_32, 1, x_16); -lean_ctor_set(x_32, 2, x_31); -lean_ctor_set(x_32, 3, x_14); -lean_ctor_set(x_32, 4, x_15); -x_33 = lean_apply_3(x_4, x_17, x_32, x_22); -if (lean_obj_tag(x_33) == 0) +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) { -lean_object* x_34; lean_object* x_35; uint8_t x_36; -x_34 = lean_ctor_get(x_33, 1); -lean_inc(x_34); -x_35 = lean_ctor_get(x_34, 2); -lean_inc(x_35); -x_36 = !lean_is_exclusive(x_33); +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; +} +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; +} +block_80: +{ +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_32 = lean_ctor_get(x_31, 2); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 0); +lean_inc(x_33); +lean_dec(x_30); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_31, 2); +lean_dec(x_35); +x_36 = !lean_is_exclusive(x_32); if (x_36 == 0) { -lean_object* x_37; uint8_t x_38; -x_37 = lean_ctor_get(x_33, 1); +lean_object* x_37; lean_object* x_38; +x_37 = lean_ctor_get(x_32, 2); lean_dec(x_37); -x_38 = !lean_is_exclusive(x_34); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -x_39 = lean_ctor_get(x_34, 2); -lean_dec(x_39); -x_40 = !lean_is_exclusive(x_35); -if (x_40 == 0) -{ -lean_object* x_41; -x_41 = lean_ctor_get(x_35, 2); -lean_dec(x_41); -lean_ctor_set(x_35, 2, x_28); -return x_33; +lean_ctor_set(x_32, 2, x_29); +if (lean_is_scalar(x_23)) { + x_38 = lean_alloc_ctor(1, 2, 0); +} else { + x_38 = x_23; + lean_ctor_set_tag(x_38, 1); +} +lean_ctor_set(x_38, 0, x_33); +lean_ctor_set(x_38, 1, x_31); +return x_38; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_35, 0); -x_43 = lean_ctor_get(x_35, 1); -x_44 = lean_ctor_get(x_35, 3); -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_28); -lean_ctor_set(x_45, 3, x_44); -lean_ctor_set(x_34, 2, x_45); -return x_33; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_39 = lean_ctor_get(x_32, 0); +x_40 = lean_ctor_get(x_32, 1); +x_41 = lean_ctor_get(x_32, 3); +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); +if (lean_is_scalar(x_23)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_23; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_33); +lean_ctor_set(x_43, 1, x_31); +return x_43; } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_46 = lean_ctor_get(x_34, 0); -x_47 = lean_ctor_get(x_34, 1); -x_48 = lean_ctor_get(x_34, 3); -x_49 = lean_ctor_get(x_34, 4); -x_50 = lean_ctor_get(x_34, 5); -lean_inc(x_50); -lean_inc(x_49); +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_inc(x_48); lean_inc(x_47); lean_inc(x_46); -lean_dec(x_34); -x_51 = lean_ctor_get(x_35, 0); +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); +lean_inc(x_50); +x_51 = lean_ctor_get(x_32, 3); lean_inc(x_51); -x_52 = lean_ctor_get(x_35, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_35, 3); -lean_inc(x_53); -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_54 = x_35; +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; } else { - lean_dec_ref(x_35); - x_54 = lean_box(0); + lean_dec_ref(x_32); + x_52 = lean_box(0); } -if (lean_is_scalar(x_54)) { - x_55 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(0, 4, 0); } else { - x_55 = x_54; + x_53 = x_52; } -lean_ctor_set(x_55, 0, x_51); -lean_ctor_set(x_55, 1, x_52); -lean_ctor_set(x_55, 2, x_28); -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); -lean_ctor_set(x_33, 1, x_56); -return x_33; +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); +if (lean_is_scalar(x_23)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_23; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_33); +lean_ctor_set(x_55, 1, x_54); +return x_55; } } 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; -x_57 = lean_ctor_get(x_33, 0); +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_dec(x_33); -x_58 = lean_ctor_get(x_34, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_34, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_34, 3); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 4); -lean_inc(x_61); -x_62 = lean_ctor_get(x_34, 5); -lean_inc(x_62); -if (lean_is_exclusive(x_34)) { - lean_ctor_release(x_34, 0); - lean_ctor_release(x_34, 1); - lean_ctor_release(x_34, 2); - lean_ctor_release(x_34, 3); - lean_ctor_release(x_34, 4); - lean_ctor_release(x_34, 5); - x_63 = x_34; +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); +if (x_60 == 0) +{ +lean_object* x_61; lean_object* x_62; +x_61 = lean_ctor_get(x_56, 2); +lean_dec(x_61); +lean_ctor_set(x_56, 2, x_29); +if (lean_is_scalar(x_23)) { + x_62 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_34); - x_63 = lean_box(0); + x_62 = x_23; } -x_64 = lean_ctor_get(x_35, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_35, 1); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_31); +return x_62; +} +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_inc(x_65); -x_66 = lean_ctor_get(x_35, 3); -lean_inc(x_66); -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_67 = x_35; +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); +if (lean_is_scalar(x_23)) { + x_67 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_35); - x_67 = lean_box(0); + x_67 = x_23; } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 4, 0); -} else { - x_68 = x_67; -} -lean_ctor_set(x_68, 0, x_64); -lean_ctor_set(x_68, 1, x_65); -lean_ctor_set(x_68, 2, x_28); -lean_ctor_set(x_68, 3, x_66); -if (lean_is_scalar(x_63)) { - x_69 = lean_alloc_ctor(0, 6, 0); -} else { - x_69 = x_63; -} -lean_ctor_set(x_69, 0, x_58); -lean_ctor_set(x_69, 1, x_59); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_60); -lean_ctor_set(x_69, 4, x_61); -lean_ctor_set(x_69, 5, x_62); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_57); -lean_ctor_set(x_70, 1, x_69); -return x_70; +lean_ctor_set(x_67, 0, x_57); +lean_ctor_set(x_67, 1, x_31); +return x_67; } } else { -lean_object* x_71; lean_object* x_72; uint8_t x_73; -x_71 = lean_ctor_get(x_33, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_71, 2); +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_inc(x_72); -x_73 = !lean_is_exclusive(x_33); -if (x_73 == 0) -{ -lean_object* x_74; uint8_t x_75; -x_74 = lean_ctor_get(x_33, 1); -lean_dec(x_74); -x_75 = !lean_is_exclusive(x_71); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_71, 2); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_72); -if (x_77 == 0) -{ -lean_object* x_78; -x_78 = lean_ctor_get(x_72, 2); -lean_dec(x_78); -lean_ctor_set(x_72, 2, x_28); -return x_33; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_79 = lean_ctor_get(x_72, 0); -x_80 = lean_ctor_get(x_72, 1); -x_81 = lean_ctor_get(x_72, 3); -lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_72); -x_82 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_82, 0, x_79); -lean_ctor_set(x_82, 1, x_80); -lean_ctor_set(x_82, 2, x_28); -lean_ctor_set(x_82, 3, x_81); -lean_ctor_set(x_71, 2, x_82); -return x_33; -} -} -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; -x_83 = lean_ctor_get(x_71, 0); -x_84 = lean_ctor_get(x_71, 1); -x_85 = lean_ctor_get(x_71, 3); -x_86 = lean_ctor_get(x_71, 4); -x_87 = lean_ctor_get(x_71, 5); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_71); -x_88 = lean_ctor_get(x_72, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_72, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_72, 3); -lean_inc(x_90); -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); - x_91 = 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; } else { - lean_dec_ref(x_72); - x_91 = lean_box(0); + lean_dec_ref(x_56); + x_76 = lean_box(0); } -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 4, 0); } else { - x_92 = x_91; + x_77 = x_76; +} +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); +if (lean_is_scalar(x_23)) { + x_79 = lean_alloc_ctor(0, 2, 0); +} else { + x_79 = 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_92, 0, x_88); -lean_ctor_set(x_92, 1, x_89); -lean_ctor_set(x_92, 2, x_28); -lean_ctor_set(x_92, 3, x_90); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_83); -lean_ctor_set(x_93, 1, x_84); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_85); -lean_ctor_set(x_93, 4, x_86); -lean_ctor_set(x_93, 5, x_87); -lean_ctor_set(x_33, 1, x_93); -return x_33; } } 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; -x_94 = lean_ctor_get(x_33, 0); -lean_inc(x_94); -lean_dec(x_33); -x_95 = lean_ctor_get(x_71, 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_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); -x_96 = lean_ctor_get(x_71, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_71, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_71, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_71, 5); -lean_inc(x_99); -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); - lean_ctor_release(x_71, 4); - lean_ctor_release(x_71, 5); - x_100 = x_71; -} else { - lean_dec_ref(x_71); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_72, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_72, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_72, 3); -lean_inc(x_103); -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); - x_104 = x_72; -} else { - lean_dec_ref(x_72); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_28); -lean_ctor_set(x_105, 3, x_103); -if (lean_is_scalar(x_100)) { - x_106 = lean_alloc_ctor(0, 6, 0); -} else { - x_106 = x_100; -} -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(1, 2, 0); -lean_ctor_set(x_107, 0, x_94); -lean_ctor_set(x_107, 1, x_106); -return x_107; -} -} -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_108 = lean_ctor_get(x_23, 0); -x_109 = lean_ctor_get(x_23, 1); -x_110 = lean_ctor_get(x_23, 2); -x_111 = lean_ctor_get(x_23, 3); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_23); -x_112 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_113 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_113, 0, x_108); -lean_ctor_set(x_113, 1, x_109); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_111); -lean_ctor_set(x_22, 2, x_113); +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_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_24); -lean_ctor_set(x_114, 1, x_17); -x_115 = lean_array_push(x_13, x_114); -x_116 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_116, 0, x_11); -lean_ctor_set(x_116, 1, x_16); -lean_ctor_set(x_116, 2, x_115); -lean_ctor_set(x_116, 3, x_14); -lean_ctor_set(x_116, 4, x_15); -x_117 = lean_apply_3(x_4, x_17, x_116, x_22); -if (lean_obj_tag(x_117) == 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; lean_object* x_133; lean_object* x_134; -x_118 = lean_ctor_get(x_117, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_118, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_117, 0); -lean_inc(x_120); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_121 = x_117; -} else { - lean_dec_ref(x_117); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_118, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 3); -lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 4); -lean_inc(x_125); -x_126 = lean_ctor_get(x_118, 5); -lean_inc(x_126); -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_127 = x_118; -} else { - lean_dec_ref(x_118); - x_127 = lean_box(0); -} -x_128 = lean_ctor_get(x_119, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_119, 3); -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); - 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, 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_110); -lean_ctor_set(x_132, 3, x_130); -if (lean_is_scalar(x_127)) { - x_133 = lean_alloc_ctor(0, 6, 0); -} else { - x_133 = x_127; -} -lean_ctor_set(x_133, 0, x_122); -lean_ctor_set(x_133, 1, x_123); +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_124); -lean_ctor_set(x_133, 4, x_125); -lean_ctor_set(x_133, 5, x_126); -if (lean_is_scalar(x_121)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_121; -} -lean_ctor_set(x_134, 0, x_120); -lean_ctor_set(x_134, 1, x_133); -return x_134; -} -else +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; 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_135 = lean_ctor_get(x_117, 1); +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_135, 2); +x_136 = lean_ctor_get(x_134, 1); lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 0); -lean_inc(x_137); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_138 = x_117; -} else { - lean_dec_ref(x_117); - x_138 = lean_box(0); +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; } -x_139 = lean_ctor_get(x_135, 0); +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); -x_140 = lean_ctor_get(x_135, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); -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); +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; } -x_145 = lean_ctor_get(x_136, 0); +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_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_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); -x_146 = lean_ctor_get(x_136, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 3); -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); - 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, 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_110); -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_138)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_138; -} -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; lean_object* x_168; -x_152 = lean_ctor_get(x_22, 0); -x_153 = lean_ctor_get(x_22, 1); -x_154 = lean_ctor_get(x_22, 3); -x_155 = lean_ctor_get(x_22, 4); -x_156 = lean_ctor_get(x_22, 5); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); +lean_inc(x_144); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); lean_dec(x_22); -x_157 = lean_ctor_get(x_23, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_23, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_23, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_23, 3); -lean_inc(x_160); -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); - x_161 = x_23; +x_146 = lean_ctor_get(x_24, 0); +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_inc(x_149); +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; } else { - lean_dec_ref(x_23); - x_161 = lean_box(0); + lean_dec_ref(x_24); + x_150 = lean_box(0); } -x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_161)) { - x_163 = lean_alloc_ctor(0, 4, 0); +x_184 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_150)) { + x_185 = lean_alloc_ctor(0, 4, 0); } else { - x_163 = x_161; + x_185 = x_150; } -lean_ctor_set(x_163, 0, x_157); -lean_ctor_set(x_163, 1, x_158); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_160); -x_164 = lean_alloc_ctor(0, 6, 0); -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); +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_inc(x_17); -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_24); -lean_ctor_set(x_165, 1, x_17); -x_166 = lean_array_push(x_13, x_165); -x_167 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_167, 0, x_11); -lean_ctor_set(x_167, 1, x_16); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_14); -lean_ctor_set(x_167, 4, x_15); -x_168 = lean_apply_3(x_4, x_17, x_167, x_164); -if (lean_obj_tag(x_168) == 0) +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) { -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; -x_169 = lean_ctor_get(x_168, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_169, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_168, 0); -lean_inc(x_171); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_172 = x_168; -} else { - lean_dec_ref(x_168); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_169, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_169, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_169, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_169, 4); -lean_inc(x_176); -x_177 = lean_ctor_get(x_169, 5); -lean_inc(x_177); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - lean_ctor_release(x_169, 4); - lean_ctor_release(x_169, 5); - x_178 = x_169; -} else { - lean_dec_ref(x_169); - x_178 = lean_box(0); -} -x_179 = lean_ctor_get(x_170, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_170, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_170, 3); -lean_inc(x_181); -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); - x_182 = x_170; -} else { - lean_dec_ref(x_170); - x_182 = lean_box(0); -} -if (lean_is_scalar(x_182)) { - x_183 = lean_alloc_ctor(0, 4, 0); -} else { - x_183 = x_182; -} -lean_ctor_set(x_183, 0, x_179); -lean_ctor_set(x_183, 1, x_180); -lean_ctor_set(x_183, 2, x_159); -lean_ctor_set(x_183, 3, x_181); -if (lean_is_scalar(x_178)) { - x_184 = lean_alloc_ctor(0, 6, 0); -} else { - x_184 = x_178; -} -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); -if (lean_is_scalar(x_172)) { - x_185 = lean_alloc_ctor(0, 2, 0); -} else { - x_185 = x_172; -} -lean_ctor_set(x_185, 0, x_171); -lean_ctor_set(x_185, 1, x_184); -return x_185; -} -else -{ -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; lean_object* x_201; lean_object* x_202; -x_186 = lean_ctor_get(x_168, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_186, 2); -lean_inc(x_187); -x_188 = lean_ctor_get(x_168, 0); -lean_inc(x_188); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_189 = x_168; -} else { - lean_dec_ref(x_168); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_186, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_186, 1); +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_186, 3); +x_192 = lean_ctor_get(x_190, 1); lean_inc(x_192); -x_193 = lean_ctor_get(x_186, 4); -lean_inc(x_193); -x_194 = lean_ctor_get(x_186, 5); +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; +} +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); -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_195 = x_186; -} else { - lean_dec_ref(x_186); - x_195 = lean_box(0); +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; } -x_196 = lean_ctor_get(x_187, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_187, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_187, 3); -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); - x_199 = x_187; +block_183: +{ +if (lean_obj_tag(x_151) == 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_187); - x_199 = lean_box(0); + lean_dec_ref(x_152); + x_160 = lean_box(0); } -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 4, 0); +x_161 = lean_ctor_get(x_153, 0); +lean_inc(x_161); +x_162 = lean_ctor_get(x_153, 1); +lean_inc(x_162); +x_163 = lean_ctor_get(x_153, 3); +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; } else { - x_200 = x_199; + lean_dec_ref(x_153); + x_164 = lean_box(0); } -lean_ctor_set(x_200, 0, x_196); -lean_ctor_set(x_200, 1, x_197); -lean_ctor_set(x_200, 2, x_159); -lean_ctor_set(x_200, 3, x_198); -if (lean_is_scalar(x_195)) { - x_201 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 4, 0); } else { - x_201 = x_195; + x_165 = x_164; } -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_189)) { - x_202 = lean_alloc_ctor(1, 2, 0); +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_202 = x_189; + 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); +lean_inc(x_169); +lean_dec(x_151); +x_170 = lean_ctor_get(x_152, 0); +lean_inc(x_170); +x_171 = lean_ctor_get(x_152, 1); +lean_inc(x_171); +x_172 = lean_ctor_get(x_152, 3); +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; +} else { + lean_dec_ref(x_152); + x_175 = 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; +} else { + lean_dec_ref(x_168); + x_179 = lean_box(0); +} +if (lean_is_scalar(x_179)) { + x_180 = lean_alloc_ctor(0, 4, 0); +} else { + x_180 = x_179; +} +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); +if (lean_is_scalar(x_23)) { + x_182 = lean_alloc_ctor(0, 2, 0); +} else { + x_182 = x_23; +} +lean_ctor_set(x_182, 0, x_169); +lean_ctor_set(x_182, 1, x_181); +return x_182; } -lean_ctor_set(x_202, 0, x_188); -lean_ctor_set(x_202, 1, x_201); -return x_202; } } } } else { -uint8_t x_203; +uint8_t x_197; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -46571,352 +40964,373 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_203 = !lean_is_exclusive(x_18); -if (x_203 == 0) +x_197 = !lean_is_exclusive(x_18); +if (x_197 == 0) { return x_18; } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; -x_204 = lean_ctor_get(x_18, 0); -x_205 = lean_ctor_get(x_18, 1); -lean_inc(x_205); -lean_inc(x_204); +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_dec(x_18); -x_206 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_206, 0, x_204); -lean_ctor_set(x_206, 1, x_205); -return x_206; +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; } } } 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; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_207 = lean_ctor_get(x_5, 0); -x_208 = lean_ctor_get(x_5, 1); -x_209 = lean_ctor_get(x_5, 2); -x_210 = lean_ctor_get(x_5, 3); -x_211 = lean_ctor_get(x_5, 4); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_208); -lean_inc(x_207); +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_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_212 = lean_local_ctx_mk_local_decl(x_208, x_8, x_1, x_2, x_3); -x_213 = l_Lean_mkFVar(x_8); -lean_inc(x_211); +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); -lean_inc(x_209); -lean_inc(x_212); -lean_inc(x_207); -x_214 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_214, 0, x_207); -lean_ctor_set(x_214, 1, x_212); -lean_ctor_set(x_214, 2, x_209); -lean_ctor_set(x_214, 3, x_210); -lean_ctor_set(x_214, 4, x_211); -lean_inc(x_214); -x_215 = l_Lean_Meta_isClass(x_2, x_214, x_9); -if (lean_obj_tag(x_215) == 0) +if (lean_obj_tag(x_210) == 0) { -lean_object* x_216; -x_216 = lean_ctor_get(x_215, 0); -lean_inc(x_216); -if (lean_obj_tag(x_216) == 0) -{ -lean_object* x_217; lean_object* x_218; -lean_dec(x_212); -lean_dec(x_211); -lean_dec(x_210); +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); -lean_dec(x_207); -x_217 = lean_ctor_get(x_215, 1); -lean_inc(x_217); -lean_dec(x_215); -x_218 = lean_apply_3(x_4, x_213, x_214, x_217); -return x_218; +x_212 = lean_apply_3(x_4, x_207, x_208, x_211); +return x_212; } 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; 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_dec(x_214); -x_219 = lean_ctor_get(x_215, 1); -lean_inc(x_219); -lean_dec(x_215); -x_220 = lean_ctor_get(x_219, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_216, 0); -lean_inc(x_221); -lean_dec(x_216); -x_222 = lean_ctor_get(x_219, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_219, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_219, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_219, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_219, 5); -lean_inc(x_226); -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); - lean_ctor_release(x_219, 5); - x_227 = x_219; +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_219); + lean_dec_ref(x_209); + x_214 = lean_box(0); +} +x_215 = lean_ctor_get(x_213, 2); +lean_inc(x_215); +x_216 = lean_ctor_get(x_210, 0); +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_218); +x_219 = lean_ctor_get(x_213, 3); +lean_inc(x_219); +x_220 = lean_ctor_get(x_213, 4); +lean_inc(x_220); +x_221 = lean_ctor_get(x_213, 5); +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); +} +x_223 = lean_ctor_get(x_215, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_215, 1); +lean_inc(x_224); +x_225 = lean_ctor_get(x_215, 2); +lean_inc(x_225); +x_226 = lean_ctor_get(x_215, 3); +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_228 = lean_ctor_get(x_220, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_220, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_220, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_220, 3); -lean_inc(x_231); -if (lean_is_exclusive(x_220)) { - lean_ctor_release(x_220, 0); - lean_ctor_release(x_220, 1); - lean_ctor_release(x_220, 2); - lean_ctor_release(x_220, 3); - x_232 = x_220; -} else { - lean_dec_ref(x_220); - x_232 = lean_box(0); -} -x_233 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_232)) { - x_234 = lean_alloc_ctor(0, 4, 0); -} else { - x_234 = x_232; -} -lean_ctor_set(x_234, 0, x_228); -lean_ctor_set(x_234, 1, x_229); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_231); +x_261 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_227)) { - x_235 = lean_alloc_ctor(0, 6, 0); + x_262 = lean_alloc_ctor(0, 4, 0); } else { - x_235 = x_227; + x_262 = x_227; } -lean_ctor_set(x_235, 0, x_222); -lean_ctor_set(x_235, 1, x_223); -lean_ctor_set(x_235, 2, x_234); -lean_ctor_set(x_235, 3, x_224); -lean_ctor_set(x_235, 4, x_225); -lean_ctor_set(x_235, 5, x_226); -lean_inc(x_213); -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_221); -lean_ctor_set(x_236, 1, x_213); -x_237 = lean_array_push(x_209, x_236); -x_238 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_238, 0, x_207); -lean_ctor_set(x_238, 1, x_212); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_210); -lean_ctor_set(x_238, 4, x_211); -x_239 = lean_apply_3(x_4, x_213, x_238, x_235); -if (lean_obj_tag(x_239) == 0) +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_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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_230); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -lean_ctor_set(x_256, 0, x_242); -lean_ctor_set(x_256, 1, x_255); -return x_256; +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_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); +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; } -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; +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_inc(x_230); +x_231 = lean_ctor_get(x_228, 0); +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); +lean_inc(x_233); +x_234 = lean_ctor_get(x_229, 3); +lean_inc(x_234); +x_235 = lean_ctor_get(x_229, 4); +lean_inc(x_235); +x_236 = lean_ctor_get(x_229, 5); +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; } else { - lean_dec_ref(x_257); - x_266 = lean_box(0); + lean_dec_ref(x_229); + x_237 = lean_box(0); } -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; +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; } else { - lean_dec_ref(x_258); - x_270 = lean_box(0); + lean_dec_ref(x_230); + x_241 = lean_box(0); } -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_241)) { + x_242 = lean_alloc_ctor(0, 4, 0); } else { - x_271 = x_270; + x_242 = x_241; } -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_230); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); +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_272 = x_266; + x_243 = x_237; } -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(1, 2, 0); +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_273 = x_260; + 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; +} +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_inc(x_245); +x_246 = lean_ctor_get(x_228, 0); +lean_inc(x_246); +lean_dec(x_228); +x_247 = lean_ctor_get(x_229, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_229, 1); +lean_inc(x_248); +x_249 = lean_ctor_get(x_229, 3); +lean_inc(x_249); +x_250 = lean_ctor_get(x_229, 4); +lean_inc(x_250); +x_251 = lean_ctor_get(x_229, 5); +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; +} else { + lean_dec_ref(x_229); + 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); +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; +} else { + lean_dec_ref(x_245); + x_256 = lean_box(0); +} +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 4, 0); +} else { + x_257 = x_256; +} +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); +} else { + x_258 = x_252; +} +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); +} else { + x_259 = x_214; +} +lean_ctor_set(x_259, 0, x_246); +lean_ctor_set(x_259, 1, x_258); +return x_259; } -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } else { lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -lean_dec(x_214); -lean_dec(x_213); -lean_dec(x_212); -lean_dec(x_211); -lean_dec(x_210); -lean_dec(x_209); +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_dec(x_4); -x_274 = lean_ctor_get(x_215, 0); +x_274 = lean_ctor_get(x_209, 0); lean_inc(x_274); -x_275 = lean_ctor_get(x_215, 1); +x_275 = lean_ctor_get(x_209, 1); lean_inc(x_275); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - x_276 = x_215; +if (lean_is_exclusive(x_209)) { + lean_ctor_release(x_209, 0); + lean_ctor_release(x_209, 1); + x_276 = x_209; } else { - lean_dec_ref(x_215); + lean_dec_ref(x_209); x_276 = lean_box(0); } if (lean_is_scalar(x_276)) { @@ -47018,812 +41432,771 @@ return x_21; } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint8_t x_25; +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_dec(x_5); x_22 = lean_ctor_get(x_18, 1); lean_inc(x_22); -lean_dec(x_18); -x_23 = lean_ctor_get(x_22, 2); -lean_inc(x_23); -x_24 = lean_ctor_get(x_19, 0); +if (lean_is_exclusive(x_18)) { + lean_ctor_release(x_18, 0); + lean_ctor_release(x_18, 1); + x_23 = x_18; +} else { + lean_dec_ref(x_18); + x_23 = lean_box(0); +} +x_24 = lean_ctor_get(x_22, 2); lean_inc(x_24); +x_25 = lean_ctor_get(x_19, 0); +lean_inc(x_25); lean_dec(x_19); -x_25 = !lean_is_exclusive(x_22); -if (x_25 == 0) +x_26 = !lean_is_exclusive(x_22); +if (x_26 == 0) { -lean_object* x_26; uint8_t x_27; -x_26 = lean_ctor_get(x_22, 2); -lean_dec(x_26); -x_27 = !lean_is_exclusive(x_23); -if (x_27 == 0) +lean_object* x_27; uint8_t x_28; +x_27 = lean_ctor_get(x_22, 2); +lean_dec(x_27); +x_28 = !lean_is_exclusive(x_24); +if (x_28 == 0) { -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_23, 2); -x_29 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_23, 2, x_29); +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; +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); lean_inc(x_17); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_24); -lean_ctor_set(x_30, 1, x_17); -x_31 = lean_array_push(x_13, x_30); -x_32 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_32, 0, x_11); -lean_ctor_set(x_32, 1, x_16); -lean_ctor_set(x_32, 2, x_31); -lean_ctor_set(x_32, 3, x_14); -lean_ctor_set(x_32, 4, x_15); -x_33 = lean_apply_3(x_4, x_17, x_32, x_22); -if (lean_obj_tag(x_33) == 0) +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) { -lean_object* x_34; lean_object* x_35; uint8_t x_36; -x_34 = lean_ctor_get(x_33, 1); -lean_inc(x_34); -x_35 = lean_ctor_get(x_34, 2); -lean_inc(x_35); -x_36 = !lean_is_exclusive(x_33); +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; +} +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; +} +block_80: +{ +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_32 = lean_ctor_get(x_31, 2); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 0); +lean_inc(x_33); +lean_dec(x_30); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_31, 2); +lean_dec(x_35); +x_36 = !lean_is_exclusive(x_32); if (x_36 == 0) { -lean_object* x_37; uint8_t x_38; -x_37 = lean_ctor_get(x_33, 1); +lean_object* x_37; lean_object* x_38; +x_37 = lean_ctor_get(x_32, 2); lean_dec(x_37); -x_38 = !lean_is_exclusive(x_34); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -x_39 = lean_ctor_get(x_34, 2); -lean_dec(x_39); -x_40 = !lean_is_exclusive(x_35); -if (x_40 == 0) -{ -lean_object* x_41; -x_41 = lean_ctor_get(x_35, 2); -lean_dec(x_41); -lean_ctor_set(x_35, 2, x_28); -return x_33; +lean_ctor_set(x_32, 2, x_29); +if (lean_is_scalar(x_23)) { + x_38 = lean_alloc_ctor(1, 2, 0); +} else { + x_38 = x_23; + lean_ctor_set_tag(x_38, 1); +} +lean_ctor_set(x_38, 0, x_33); +lean_ctor_set(x_38, 1, x_31); +return x_38; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_35, 0); -x_43 = lean_ctor_get(x_35, 1); -x_44 = lean_ctor_get(x_35, 3); -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_28); -lean_ctor_set(x_45, 3, x_44); -lean_ctor_set(x_34, 2, x_45); -return x_33; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_39 = lean_ctor_get(x_32, 0); +x_40 = lean_ctor_get(x_32, 1); +x_41 = lean_ctor_get(x_32, 3); +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); +if (lean_is_scalar(x_23)) { + x_43 = lean_alloc_ctor(1, 2, 0); +} else { + x_43 = x_23; + lean_ctor_set_tag(x_43, 1); +} +lean_ctor_set(x_43, 0, x_33); +lean_ctor_set(x_43, 1, x_31); +return x_43; } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_46 = lean_ctor_get(x_34, 0); -x_47 = lean_ctor_get(x_34, 1); -x_48 = lean_ctor_get(x_34, 3); -x_49 = lean_ctor_get(x_34, 4); -x_50 = lean_ctor_get(x_34, 5); -lean_inc(x_50); -lean_inc(x_49); +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_inc(x_48); lean_inc(x_47); lean_inc(x_46); -lean_dec(x_34); -x_51 = lean_ctor_get(x_35, 0); +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); +lean_inc(x_50); +x_51 = lean_ctor_get(x_32, 3); lean_inc(x_51); -x_52 = lean_ctor_get(x_35, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_35, 3); -lean_inc(x_53); -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_54 = x_35; +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; } else { - lean_dec_ref(x_35); - x_54 = lean_box(0); + lean_dec_ref(x_32); + x_52 = lean_box(0); } -if (lean_is_scalar(x_54)) { - x_55 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(0, 4, 0); } else { - x_55 = x_54; + x_53 = x_52; } -lean_ctor_set(x_55, 0, x_51); -lean_ctor_set(x_55, 1, x_52); -lean_ctor_set(x_55, 2, x_28); -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); -lean_ctor_set(x_33, 1, x_56); -return x_33; +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); +if (lean_is_scalar(x_23)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_23; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_33); +lean_ctor_set(x_55, 1, x_54); +return x_55; } } 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; -x_57 = lean_ctor_get(x_33, 0); +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_dec(x_33); -x_58 = lean_ctor_get(x_34, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_34, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_34, 3); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 4); -lean_inc(x_61); -x_62 = lean_ctor_get(x_34, 5); -lean_inc(x_62); -if (lean_is_exclusive(x_34)) { - lean_ctor_release(x_34, 0); - lean_ctor_release(x_34, 1); - lean_ctor_release(x_34, 2); - lean_ctor_release(x_34, 3); - lean_ctor_release(x_34, 4); - lean_ctor_release(x_34, 5); - x_63 = x_34; +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); +if (x_60 == 0) +{ +lean_object* x_61; lean_object* x_62; +x_61 = lean_ctor_get(x_56, 2); +lean_dec(x_61); +lean_ctor_set(x_56, 2, x_29); +if (lean_is_scalar(x_23)) { + x_62 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_34); - x_63 = lean_box(0); + x_62 = x_23; } -x_64 = lean_ctor_get(x_35, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_35, 1); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_31); +return x_62; +} +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_inc(x_65); -x_66 = lean_ctor_get(x_35, 3); -lean_inc(x_66); -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_67 = x_35; +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); +if (lean_is_scalar(x_23)) { + x_67 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_35); - x_67 = lean_box(0); + x_67 = x_23; } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 4, 0); -} else { - x_68 = x_67; -} -lean_ctor_set(x_68, 0, x_64); -lean_ctor_set(x_68, 1, x_65); -lean_ctor_set(x_68, 2, x_28); -lean_ctor_set(x_68, 3, x_66); -if (lean_is_scalar(x_63)) { - x_69 = lean_alloc_ctor(0, 6, 0); -} else { - x_69 = x_63; -} -lean_ctor_set(x_69, 0, x_58); -lean_ctor_set(x_69, 1, x_59); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_60); -lean_ctor_set(x_69, 4, x_61); -lean_ctor_set(x_69, 5, x_62); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_57); -lean_ctor_set(x_70, 1, x_69); -return x_70; +lean_ctor_set(x_67, 0, x_57); +lean_ctor_set(x_67, 1, x_31); +return x_67; } } else { -lean_object* x_71; lean_object* x_72; uint8_t x_73; -x_71 = lean_ctor_get(x_33, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_71, 2); +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_inc(x_72); -x_73 = !lean_is_exclusive(x_33); -if (x_73 == 0) -{ -lean_object* x_74; uint8_t x_75; -x_74 = lean_ctor_get(x_33, 1); -lean_dec(x_74); -x_75 = !lean_is_exclusive(x_71); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_71, 2); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_72); -if (x_77 == 0) -{ -lean_object* x_78; -x_78 = lean_ctor_get(x_72, 2); -lean_dec(x_78); -lean_ctor_set(x_72, 2, x_28); -return x_33; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_79 = lean_ctor_get(x_72, 0); -x_80 = lean_ctor_get(x_72, 1); -x_81 = lean_ctor_get(x_72, 3); -lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_72); -x_82 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_82, 0, x_79); -lean_ctor_set(x_82, 1, x_80); -lean_ctor_set(x_82, 2, x_28); -lean_ctor_set(x_82, 3, x_81); -lean_ctor_set(x_71, 2, x_82); -return x_33; -} -} -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; -x_83 = lean_ctor_get(x_71, 0); -x_84 = lean_ctor_get(x_71, 1); -x_85 = lean_ctor_get(x_71, 3); -x_86 = lean_ctor_get(x_71, 4); -x_87 = lean_ctor_get(x_71, 5); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_71); -x_88 = lean_ctor_get(x_72, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_72, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_72, 3); -lean_inc(x_90); -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); - x_91 = 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; } else { - lean_dec_ref(x_72); - x_91 = lean_box(0); + lean_dec_ref(x_56); + x_76 = lean_box(0); } -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 4, 0); } else { - x_92 = x_91; + x_77 = x_76; +} +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); +if (lean_is_scalar(x_23)) { + x_79 = lean_alloc_ctor(0, 2, 0); +} else { + x_79 = 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_92, 0, x_88); -lean_ctor_set(x_92, 1, x_89); -lean_ctor_set(x_92, 2, x_28); -lean_ctor_set(x_92, 3, x_90); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_83); -lean_ctor_set(x_93, 1, x_84); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_85); -lean_ctor_set(x_93, 4, x_86); -lean_ctor_set(x_93, 5, x_87); -lean_ctor_set(x_33, 1, x_93); -return x_33; } } 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; -x_94 = lean_ctor_get(x_33, 0); -lean_inc(x_94); -lean_dec(x_33); -x_95 = lean_ctor_get(x_71, 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_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); -x_96 = lean_ctor_get(x_71, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_71, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_71, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_71, 5); -lean_inc(x_99); -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); - lean_ctor_release(x_71, 4); - lean_ctor_release(x_71, 5); - x_100 = x_71; -} else { - lean_dec_ref(x_71); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_72, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_72, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_72, 3); -lean_inc(x_103); -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); - x_104 = x_72; -} else { - lean_dec_ref(x_72); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_28); -lean_ctor_set(x_105, 3, x_103); -if (lean_is_scalar(x_100)) { - x_106 = lean_alloc_ctor(0, 6, 0); -} else { - x_106 = x_100; -} -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(1, 2, 0); -lean_ctor_set(x_107, 0, x_94); -lean_ctor_set(x_107, 1, x_106); -return x_107; -} -} -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_108 = lean_ctor_get(x_23, 0); -x_109 = lean_ctor_get(x_23, 1); -x_110 = lean_ctor_get(x_23, 2); -x_111 = lean_ctor_get(x_23, 3); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_23); -x_112 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_113 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_113, 0, x_108); -lean_ctor_set(x_113, 1, x_109); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_111); -lean_ctor_set(x_22, 2, x_113); +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_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_24); -lean_ctor_set(x_114, 1, x_17); -x_115 = lean_array_push(x_13, x_114); -x_116 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_116, 0, x_11); -lean_ctor_set(x_116, 1, x_16); -lean_ctor_set(x_116, 2, x_115); -lean_ctor_set(x_116, 3, x_14); -lean_ctor_set(x_116, 4, x_15); -x_117 = lean_apply_3(x_4, x_17, x_116, x_22); -if (lean_obj_tag(x_117) == 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; lean_object* x_133; lean_object* x_134; -x_118 = lean_ctor_get(x_117, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_118, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_117, 0); -lean_inc(x_120); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_121 = x_117; -} else { - lean_dec_ref(x_117); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_118, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 3); -lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 4); -lean_inc(x_125); -x_126 = lean_ctor_get(x_118, 5); -lean_inc(x_126); -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_127 = x_118; -} else { - lean_dec_ref(x_118); - x_127 = lean_box(0); -} -x_128 = lean_ctor_get(x_119, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_119, 3); -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); - 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, 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_110); -lean_ctor_set(x_132, 3, x_130); -if (lean_is_scalar(x_127)) { - x_133 = lean_alloc_ctor(0, 6, 0); -} else { - x_133 = x_127; -} -lean_ctor_set(x_133, 0, x_122); -lean_ctor_set(x_133, 1, x_123); +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_124); -lean_ctor_set(x_133, 4, x_125); -lean_ctor_set(x_133, 5, x_126); -if (lean_is_scalar(x_121)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_121; -} -lean_ctor_set(x_134, 0, x_120); -lean_ctor_set(x_134, 1, x_133); -return x_134; -} -else +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; 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_135 = lean_ctor_get(x_117, 1); +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_135, 2); +x_136 = lean_ctor_get(x_134, 1); lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 0); -lean_inc(x_137); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - x_138 = x_117; -} else { - lean_dec_ref(x_117); - x_138 = lean_box(0); +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; } -x_139 = lean_ctor_get(x_135, 0); +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); -x_140 = lean_ctor_get(x_135, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); -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); +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; } -x_145 = lean_ctor_get(x_136, 0); +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_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_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); -x_146 = lean_ctor_get(x_136, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 3); -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); - 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, 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_110); -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_138)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_138; -} -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; lean_object* x_168; -x_152 = lean_ctor_get(x_22, 0); -x_153 = lean_ctor_get(x_22, 1); -x_154 = lean_ctor_get(x_22, 3); -x_155 = lean_ctor_get(x_22, 4); -x_156 = lean_ctor_get(x_22, 5); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); +lean_inc(x_144); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); lean_dec(x_22); -x_157 = lean_ctor_get(x_23, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_23, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_23, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_23, 3); -lean_inc(x_160); -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); - x_161 = x_23; +x_146 = lean_ctor_get(x_24, 0); +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_inc(x_149); +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; } else { - lean_dec_ref(x_23); - x_161 = lean_box(0); + lean_dec_ref(x_24); + x_150 = lean_box(0); } -x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_161)) { - x_163 = lean_alloc_ctor(0, 4, 0); +x_184 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_150)) { + x_185 = lean_alloc_ctor(0, 4, 0); } else { - x_163 = x_161; + x_185 = x_150; } -lean_ctor_set(x_163, 0, x_157); -lean_ctor_set(x_163, 1, x_158); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_160); -x_164 = lean_alloc_ctor(0, 6, 0); -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); +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_inc(x_17); -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_24); -lean_ctor_set(x_165, 1, x_17); -x_166 = lean_array_push(x_13, x_165); -x_167 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_167, 0, x_11); -lean_ctor_set(x_167, 1, x_16); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_14); -lean_ctor_set(x_167, 4, x_15); -x_168 = lean_apply_3(x_4, x_17, x_167, x_164); -if (lean_obj_tag(x_168) == 0) +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) { -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; -x_169 = lean_ctor_get(x_168, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_169, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_168, 0); -lean_inc(x_171); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_172 = x_168; -} else { - lean_dec_ref(x_168); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_169, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_169, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_169, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_169, 4); -lean_inc(x_176); -x_177 = lean_ctor_get(x_169, 5); -lean_inc(x_177); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - lean_ctor_release(x_169, 4); - lean_ctor_release(x_169, 5); - x_178 = x_169; -} else { - lean_dec_ref(x_169); - x_178 = lean_box(0); -} -x_179 = lean_ctor_get(x_170, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_170, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_170, 3); -lean_inc(x_181); -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); - x_182 = x_170; -} else { - lean_dec_ref(x_170); - x_182 = lean_box(0); -} -if (lean_is_scalar(x_182)) { - x_183 = lean_alloc_ctor(0, 4, 0); -} else { - x_183 = x_182; -} -lean_ctor_set(x_183, 0, x_179); -lean_ctor_set(x_183, 1, x_180); -lean_ctor_set(x_183, 2, x_159); -lean_ctor_set(x_183, 3, x_181); -if (lean_is_scalar(x_178)) { - x_184 = lean_alloc_ctor(0, 6, 0); -} else { - x_184 = x_178; -} -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); -if (lean_is_scalar(x_172)) { - x_185 = lean_alloc_ctor(0, 2, 0); -} else { - x_185 = x_172; -} -lean_ctor_set(x_185, 0, x_171); -lean_ctor_set(x_185, 1, x_184); -return x_185; -} -else -{ -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; lean_object* x_201; lean_object* x_202; -x_186 = lean_ctor_get(x_168, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_186, 2); -lean_inc(x_187); -x_188 = lean_ctor_get(x_168, 0); -lean_inc(x_188); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_189 = x_168; -} else { - lean_dec_ref(x_168); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_186, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_186, 1); +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_186, 3); +x_192 = lean_ctor_get(x_190, 1); lean_inc(x_192); -x_193 = lean_ctor_get(x_186, 4); -lean_inc(x_193); -x_194 = lean_ctor_get(x_186, 5); +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; +} +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); -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_195 = x_186; -} else { - lean_dec_ref(x_186); - x_195 = lean_box(0); +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; } -x_196 = lean_ctor_get(x_187, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_187, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_187, 3); -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); - x_199 = x_187; +block_183: +{ +if (lean_obj_tag(x_151) == 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_187); - x_199 = lean_box(0); + lean_dec_ref(x_152); + x_160 = lean_box(0); } -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 4, 0); +x_161 = lean_ctor_get(x_153, 0); +lean_inc(x_161); +x_162 = lean_ctor_get(x_153, 1); +lean_inc(x_162); +x_163 = lean_ctor_get(x_153, 3); +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; } else { - x_200 = x_199; + lean_dec_ref(x_153); + x_164 = lean_box(0); } -lean_ctor_set(x_200, 0, x_196); -lean_ctor_set(x_200, 1, x_197); -lean_ctor_set(x_200, 2, x_159); -lean_ctor_set(x_200, 3, x_198); -if (lean_is_scalar(x_195)) { - x_201 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 4, 0); } else { - x_201 = x_195; + x_165 = x_164; } -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_189)) { - x_202 = lean_alloc_ctor(1, 2, 0); +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_202 = x_189; + 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); +lean_inc(x_169); +lean_dec(x_151); +x_170 = lean_ctor_get(x_152, 0); +lean_inc(x_170); +x_171 = lean_ctor_get(x_152, 1); +lean_inc(x_171); +x_172 = lean_ctor_get(x_152, 3); +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; +} else { + lean_dec_ref(x_152); + x_175 = 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; +} else { + lean_dec_ref(x_168); + x_179 = lean_box(0); +} +if (lean_is_scalar(x_179)) { + x_180 = lean_alloc_ctor(0, 4, 0); +} else { + x_180 = x_179; +} +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); +if (lean_is_scalar(x_23)) { + x_182 = lean_alloc_ctor(0, 2, 0); +} else { + x_182 = x_23; +} +lean_ctor_set(x_182, 0, x_169); +lean_ctor_set(x_182, 1, x_181); +return x_182; } -lean_ctor_set(x_202, 0, x_188); -lean_ctor_set(x_202, 1, x_201); -return x_202; } } } } else { -uint8_t x_203; +uint8_t x_197; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -47832,352 +42205,373 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_203 = !lean_is_exclusive(x_18); -if (x_203 == 0) +x_197 = !lean_is_exclusive(x_18); +if (x_197 == 0) { return x_18; } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; -x_204 = lean_ctor_get(x_18, 0); -x_205 = lean_ctor_get(x_18, 1); -lean_inc(x_205); -lean_inc(x_204); +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_dec(x_18); -x_206 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_206, 0, x_204); -lean_ctor_set(x_206, 1, x_205); -return x_206; +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; } } } 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; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_207 = lean_ctor_get(x_5, 0); -x_208 = lean_ctor_get(x_5, 1); -x_209 = lean_ctor_get(x_5, 2); -x_210 = lean_ctor_get(x_5, 3); -x_211 = lean_ctor_get(x_5, 4); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_208); -lean_inc(x_207); +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_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_212 = lean_local_ctx_mk_let_decl(x_208, x_8, x_1, x_2, x_3); -x_213 = l_Lean_mkFVar(x_8); -lean_inc(x_211); +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); -lean_inc(x_209); -lean_inc(x_212); -lean_inc(x_207); -x_214 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_214, 0, x_207); -lean_ctor_set(x_214, 1, x_212); -lean_ctor_set(x_214, 2, x_209); -lean_ctor_set(x_214, 3, x_210); -lean_ctor_set(x_214, 4, x_211); -lean_inc(x_214); -x_215 = l_Lean_Meta_isClass(x_2, x_214, x_9); -if (lean_obj_tag(x_215) == 0) +if (lean_obj_tag(x_210) == 0) { -lean_object* x_216; -x_216 = lean_ctor_get(x_215, 0); -lean_inc(x_216); -if (lean_obj_tag(x_216) == 0) -{ -lean_object* x_217; lean_object* x_218; -lean_dec(x_212); -lean_dec(x_211); -lean_dec(x_210); +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); -lean_dec(x_207); -x_217 = lean_ctor_get(x_215, 1); -lean_inc(x_217); -lean_dec(x_215); -x_218 = lean_apply_3(x_4, x_213, x_214, x_217); -return x_218; +x_212 = lean_apply_3(x_4, x_207, x_208, x_211); +return x_212; } 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; 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_dec(x_214); -x_219 = lean_ctor_get(x_215, 1); -lean_inc(x_219); -lean_dec(x_215); -x_220 = lean_ctor_get(x_219, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_216, 0); -lean_inc(x_221); -lean_dec(x_216); -x_222 = lean_ctor_get(x_219, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_219, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_219, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_219, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_219, 5); -lean_inc(x_226); -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); - lean_ctor_release(x_219, 5); - x_227 = x_219; +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_219); + lean_dec_ref(x_209); + x_214 = lean_box(0); +} +x_215 = lean_ctor_get(x_213, 2); +lean_inc(x_215); +x_216 = lean_ctor_get(x_210, 0); +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_218); +x_219 = lean_ctor_get(x_213, 3); +lean_inc(x_219); +x_220 = lean_ctor_get(x_213, 4); +lean_inc(x_220); +x_221 = lean_ctor_get(x_213, 5); +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); +} +x_223 = lean_ctor_get(x_215, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_215, 1); +lean_inc(x_224); +x_225 = lean_ctor_get(x_215, 2); +lean_inc(x_225); +x_226 = lean_ctor_get(x_215, 3); +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_228 = lean_ctor_get(x_220, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_220, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_220, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_220, 3); -lean_inc(x_231); -if (lean_is_exclusive(x_220)) { - lean_ctor_release(x_220, 0); - lean_ctor_release(x_220, 1); - lean_ctor_release(x_220, 2); - lean_ctor_release(x_220, 3); - x_232 = x_220; -} else { - lean_dec_ref(x_220); - x_232 = lean_box(0); -} -x_233 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_232)) { - x_234 = lean_alloc_ctor(0, 4, 0); -} else { - x_234 = x_232; -} -lean_ctor_set(x_234, 0, x_228); -lean_ctor_set(x_234, 1, x_229); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_231); +x_261 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_227)) { - x_235 = lean_alloc_ctor(0, 6, 0); + x_262 = lean_alloc_ctor(0, 4, 0); } else { - x_235 = x_227; + x_262 = x_227; } -lean_ctor_set(x_235, 0, x_222); -lean_ctor_set(x_235, 1, x_223); -lean_ctor_set(x_235, 2, x_234); -lean_ctor_set(x_235, 3, x_224); -lean_ctor_set(x_235, 4, x_225); -lean_ctor_set(x_235, 5, x_226); -lean_inc(x_213); -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_221); -lean_ctor_set(x_236, 1, x_213); -x_237 = lean_array_push(x_209, x_236); -x_238 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_238, 0, x_207); -lean_ctor_set(x_238, 1, x_212); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_210); -lean_ctor_set(x_238, 4, x_211); -x_239 = lean_apply_3(x_4, x_213, x_238, x_235); -if (lean_obj_tag(x_239) == 0) +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_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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_230); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -lean_ctor_set(x_256, 0, x_242); -lean_ctor_set(x_256, 1, x_255); -return x_256; +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_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); +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; } -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; +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_inc(x_230); +x_231 = lean_ctor_get(x_228, 0); +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); +lean_inc(x_233); +x_234 = lean_ctor_get(x_229, 3); +lean_inc(x_234); +x_235 = lean_ctor_get(x_229, 4); +lean_inc(x_235); +x_236 = lean_ctor_get(x_229, 5); +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; } else { - lean_dec_ref(x_257); - x_266 = lean_box(0); + lean_dec_ref(x_229); + x_237 = lean_box(0); } -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; +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; } else { - lean_dec_ref(x_258); - x_270 = lean_box(0); + lean_dec_ref(x_230); + x_241 = lean_box(0); } -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_241)) { + x_242 = lean_alloc_ctor(0, 4, 0); } else { - x_271 = x_270; + x_242 = x_241; } -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_230); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); +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_272 = x_266; + x_243 = x_237; } -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(1, 2, 0); +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_273 = x_260; + 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; +} +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_inc(x_245); +x_246 = lean_ctor_get(x_228, 0); +lean_inc(x_246); +lean_dec(x_228); +x_247 = lean_ctor_get(x_229, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_229, 1); +lean_inc(x_248); +x_249 = lean_ctor_get(x_229, 3); +lean_inc(x_249); +x_250 = lean_ctor_get(x_229, 4); +lean_inc(x_250); +x_251 = lean_ctor_get(x_229, 5); +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; +} else { + lean_dec_ref(x_229); + 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); +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; +} else { + lean_dec_ref(x_245); + x_256 = lean_box(0); +} +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 4, 0); +} else { + x_257 = x_256; +} +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); +} else { + x_258 = x_252; +} +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); +} else { + x_259 = x_214; +} +lean_ctor_set(x_259, 0, x_246); +lean_ctor_set(x_259, 1, x_258); +return x_259; } -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } else { lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -lean_dec(x_214); -lean_dec(x_213); -lean_dec(x_212); -lean_dec(x_211); -lean_dec(x_210); -lean_dec(x_209); +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_dec(x_4); -x_274 = lean_ctor_get(x_215, 0); +x_274 = lean_ctor_get(x_209, 0); lean_inc(x_274); -x_275 = lean_ctor_get(x_215, 1); +x_275 = lean_ctor_get(x_209, 1); lean_inc(x_275); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - x_276 = x_215; +if (lean_is_exclusive(x_209)) { + lean_ctor_release(x_209, 0); + lean_ctor_release(x_209, 1); + x_276 = x_209; } else { - lean_dec_ref(x_215); + lean_dec_ref(x_209); x_276 = lean_box(0); } if (lean_is_scalar(x_276)) { @@ -48610,33 +43004,33 @@ lean_ctor_set(x_13, 3, x_8); lean_ctor_set(x_13, 4, x_9); if (x_12 == 0) { -lean_object* x_186; +lean_object* x_179; lean_dec(x_2); -x_186 = lean_box(0); -x_14 = x_186; -goto block_185; +x_179 = lean_box(0); +x_14 = x_179; +goto block_178; } else { -lean_object* x_187; uint8_t x_188; -x_187 = lean_unsigned_to_nat(0u); -x_188 = l_Array_isEqvAux___main___at_Lean_Meta_withLocalContext___spec__1(x_2, x_4, lean_box(0), x_2, x_7, x_187); +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_dec(x_2); -if (x_188 == 0) +if (x_181 == 0) { -lean_object* x_189; -x_189 = lean_box(0); -x_14 = x_189; -goto block_185; +lean_object* x_182; +x_182 = lean_box(0); +x_14 = x_182; +goto block_178; } else { -lean_object* x_190; -x_190 = lean_apply_2(x_3, x_13, x_5); -return x_190; +lean_object* x_183; +x_183 = lean_apply_2(x_3, x_13, x_5); +return x_183; } } -block_185: +block_178: { uint8_t x_15; lean_dec(x_14); @@ -48648,86 +43042,117 @@ 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_18; lean_object* x_19; lean_object* x_20; lean_object* x_70; lean_object* x_71; x_18 = lean_ctor_get(x_16, 2); -x_19 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_16, 2, x_19); -x_20 = lean_apply_2(x_3, x_13, x_5); -if (lean_obj_tag(x_20) == 0) +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) +{ +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; +} +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; +} +block_69: +{ +if (lean_obj_tag(x_19) == 0) { lean_object* x_21; lean_object* x_22; uint8_t x_23; -x_21 = lean_ctor_get(x_20, 1); +x_21 = lean_ctor_get(x_20, 2); lean_inc(x_21); -x_22 = lean_ctor_get(x_21, 2); +x_22 = lean_ctor_get(x_19, 0); lean_inc(x_22); +lean_dec(x_19); x_23 = !lean_is_exclusive(x_20); if (x_23 == 0) { lean_object* x_24; uint8_t x_25; -x_24 = lean_ctor_get(x_20, 1); +x_24 = lean_ctor_get(x_20, 2); lean_dec(x_24); x_25 = !lean_is_exclusive(x_21); if (x_25 == 0) { -lean_object* x_26; uint8_t x_27; +lean_object* x_26; lean_object* x_27; x_26 = lean_ctor_get(x_21, 2); lean_dec(x_26); -x_27 = !lean_is_exclusive(x_22); -if (x_27 == 0) -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_22, 2); -lean_dec(x_28); -lean_ctor_set(x_22, 2, x_18); -return x_20; +lean_ctor_set(x_21, 2, x_18); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_20); +return x_27; } else { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_22, 0); -x_30 = lean_ctor_get(x_22, 1); -x_31 = lean_ctor_get(x_22, 3); -lean_inc(x_31); +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_28 = lean_ctor_get(x_21, 0); +x_29 = lean_ctor_get(x_21, 1); +x_30 = lean_ctor_get(x_21, 3); lean_inc(x_30); lean_inc(x_29); -lean_dec(x_22); -x_32 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_32, 0, x_29); -lean_ctor_set(x_32, 1, x_30); -lean_ctor_set(x_32, 2, x_18); -lean_ctor_set(x_32, 3, x_31); -lean_ctor_set(x_21, 2, x_32); -return x_20; +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; } } 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; -x_33 = lean_ctor_get(x_21, 0); -x_34 = lean_ctor_get(x_21, 1); -x_35 = lean_ctor_get(x_21, 3); -x_36 = lean_ctor_get(x_21, 4); -x_37 = lean_ctor_get(x_21, 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; +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_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); -lean_dec(x_21); -x_38 = lean_ctor_get(x_22, 0); +lean_dec(x_20); +x_38 = lean_ctor_get(x_21, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_22, 1); +x_39 = lean_ctor_get(x_21, 1); lean_inc(x_39); -x_40 = lean_ctor_get(x_22, 3); +x_40 = lean_ctor_get(x_21, 3); lean_inc(x_40); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - lean_ctor_release(x_22, 1); - lean_ctor_release(x_22, 2); - lean_ctor_release(x_22, 3); - x_41 = x_22; +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; } else { - lean_dec_ref(x_22); + lean_dec_ref(x_21); x_41 = lean_box(0); } if (lean_is_scalar(x_41)) { @@ -48746,657 +43171,533 @@ 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); -lean_ctor_set(x_20, 1, x_43); -return x_20; +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; } } 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; -x_44 = lean_ctor_get(x_20, 0); -lean_inc(x_44); -lean_dec(x_20); -x_45 = lean_ctor_get(x_21, 0); +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_21, 1); +x_46 = lean_ctor_get(x_19, 0); lean_inc(x_46); -x_47 = lean_ctor_get(x_21, 3); -lean_inc(x_47); -x_48 = lean_ctor_get(x_21, 4); -lean_inc(x_48); -x_49 = lean_ctor_get(x_21, 5); -lean_inc(x_49); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_50 = x_21; -} else { - lean_dec_ref(x_21); - x_50 = lean_box(0); +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); +if (x_49 == 0) +{ +lean_object* x_50; lean_object* x_51; +x_50 = lean_ctor_get(x_45, 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_ctor_get(x_22, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_22, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_22, 3); +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_inc(x_54); lean_inc(x_53); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - lean_ctor_release(x_22, 1); - lean_ctor_release(x_22, 2); - lean_ctor_release(x_22, 3); - x_54 = x_22; -} else { - lean_dec_ref(x_22); - x_54 = lean_box(0); -} -if (lean_is_scalar(x_54)) { - x_55 = lean_alloc_ctor(0, 4, 0); -} else { - x_55 = x_54; -} -lean_ctor_set(x_55, 0, x_51); -lean_ctor_set(x_55, 1, x_52); +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_53); -if (lean_is_scalar(x_50)) { - x_56 = lean_alloc_ctor(0, 6, 0); -} else { - x_56 = x_50; -} -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, 2, 0); -lean_ctor_set(x_57, 0, x_44); -lean_ctor_set(x_57, 1, x_56); -return x_57; +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; } } else { -lean_object* x_58; lean_object* x_59; uint8_t x_60; +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); -lean_inc(x_58); -x_59 = lean_ctor_get(x_58, 2); +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_inc(x_61); +lean_inc(x_60); lean_inc(x_59); -x_60 = !lean_is_exclusive(x_20); -if (x_60 == 0) -{ -lean_object* x_61; uint8_t x_62; -x_61 = lean_ctor_get(x_20, 1); -lean_dec(x_61); -x_62 = !lean_is_exclusive(x_58); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_58, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_59); -if (x_64 == 0) -{ -lean_object* x_65; -x_65 = lean_ctor_get(x_59, 2); -lean_dec(x_65); -lean_ctor_set(x_59, 2, x_18); -return x_20; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -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_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_18); -lean_ctor_set(x_69, 3, x_68); -lean_ctor_set(x_58, 2, x_69); -return x_20; -} -} -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; -x_70 = lean_ctor_get(x_58, 0); -x_71 = lean_ctor_get(x_58, 1); -x_72 = lean_ctor_get(x_58, 3); -x_73 = lean_ctor_get(x_58, 4); -x_74 = lean_ctor_get(x_58, 5); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_58); -x_75 = lean_ctor_get(x_59, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_59, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_59, 3); -lean_inc(x_77); -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_78 = x_59; -} else { - lean_dec_ref(x_59); - 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_18); -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_20, 1, x_80); -return x_20; -} -} -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; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_81 = lean_ctor_get(x_20, 0); -lean_inc(x_81); +lean_inc(x_58); +lean_inc(x_57); lean_dec(x_20); -x_82 = lean_ctor_get(x_58, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_58, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_58, 3); -lean_inc(x_84); -x_85 = lean_ctor_get(x_58, 4); -lean_inc(x_85); -x_86 = lean_ctor_get(x_58, 5); -lean_inc(x_86); -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_87 = x_58; +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; } else { - lean_dec_ref(x_58); - x_87 = lean_box(0); + lean_dec_ref(x_45); + x_65 = lean_box(0); } -x_88 = lean_ctor_get(x_59, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_59, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_59, 3); -lean_inc(x_90); -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_91 = x_59; +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_59); + x_66 = x_65; +} +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; +} +} +} +} +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_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_92 = lean_alloc_ctor(0, 4, 0); + x_97 = lean_alloc_ctor(0, 6, 0); } else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_88); -lean_ctor_set(x_92, 1, x_89); -lean_ctor_set(x_92, 2, x_18); -lean_ctor_set(x_92, 3, x_90); -if (lean_is_scalar(x_87)) { - x_93 = lean_alloc_ctor(0, 6, 0); -} else { - x_93 = x_87; -} -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); -x_94 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_94, 0, x_81); -lean_ctor_set(x_94, 1, x_93); -return x_94; -} + 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_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_95 = lean_ctor_get(x_16, 0); -x_96 = lean_ctor_get(x_16, 1); -x_97 = lean_ctor_get(x_16, 2); -x_98 = lean_ctor_get(x_16, 3); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_dec(x_16); -x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_100 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_100, 0, x_95); -lean_ctor_set(x_100, 1, x_96); -lean_ctor_set(x_100, 2, x_99); -lean_ctor_set(x_100, 3, x_98); -lean_ctor_set(x_5, 2, x_100); -x_101 = lean_apply_2(x_3, x_13, x_5); -if (lean_obj_tag(x_101) == 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; lean_object* x_117; lean_object* x_118; -x_102 = lean_ctor_get(x_101, 1); +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_102, 2); +x_103 = lean_ctor_get(x_83, 3); lean_inc(x_103); -x_104 = lean_ctor_get(x_101, 0); +x_104 = lean_ctor_get(x_83, 4); lean_inc(x_104); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - x_105 = x_101; +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_101); - x_105 = lean_box(0); + lean_dec_ref(x_83); + x_106 = lean_box(0); } -x_106 = lean_ctor_get(x_102, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_102, 1); +x_107 = lean_ctor_get(x_99, 0); lean_inc(x_107); -x_108 = lean_ctor_get(x_102, 3); +x_108 = lean_ctor_get(x_99, 1); lean_inc(x_108); -x_109 = lean_ctor_get(x_102, 4); +x_109 = lean_ctor_get(x_99, 3); lean_inc(x_109); -x_110 = lean_ctor_get(x_102, 5); -lean_inc(x_110); -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_111 = x_102; +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_102); - x_111 = lean_box(0); + lean_dec_ref(x_99); + x_110 = lean_box(0); } -x_112 = lean_ctor_get(x_103, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_103, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_103, 3); -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); - x_115 = x_103; +if (lean_is_scalar(x_110)) { + x_111 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_103); - x_115 = lean_box(0); + x_111 = x_110; } -if (lean_is_scalar(x_115)) { - x_116 = lean_alloc_ctor(0, 4, 0); +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_116 = x_115; + 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; } -lean_ctor_set(x_116, 0, x_112); -lean_ctor_set(x_116, 1, x_113); -lean_ctor_set(x_116, 2, x_97); -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_105)) { - x_118 = lean_alloc_ctor(0, 2, 0); -} else { - x_118 = x_105; } -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; lean_object* x_135; -x_119 = lean_ctor_get(x_101, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_119, 2); -lean_inc(x_120); -x_121 = lean_ctor_get(x_101, 0); -lean_inc(x_121); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - x_122 = x_101; -} else { - lean_dec_ref(x_101); - x_122 = lean_box(0); -} -x_123 = lean_ctor_get(x_119, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_119, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_119, 3); -lean_inc(x_125); -x_126 = lean_ctor_get(x_119, 4); -lean_inc(x_126); -x_127 = lean_ctor_get(x_119, 5); -lean_inc(x_127); -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); - lean_ctor_release(x_119, 5); - x_128 = x_119; -} else { - lean_dec_ref(x_119); - x_128 = lean_box(0); -} -x_129 = lean_ctor_get(x_120, 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_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); -x_130 = lean_ctor_get(x_120, 1); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_124); +lean_inc(x_126); +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_120, 3); +x_131 = lean_ctor_get(x_124, 1); lean_inc(x_131); -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); - x_132 = x_120; +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_120); - x_132 = lean_box(0); + lean_dec_ref(x_124); + x_134 = lean_box(0); } -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 4, 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_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_97); -lean_ctor_set(x_133, 3, x_131); -if (lean_is_scalar(x_128)) { - x_134 = lean_alloc_ctor(0, 6, 0); -} else { - x_134 = x_128; -} -lean_ctor_set(x_134, 0, x_123); -lean_ctor_set(x_134, 1, x_124); -lean_ctor_set(x_134, 2, x_133); -lean_ctor_set(x_134, 3, x_125); -lean_ctor_set(x_134, 4, x_126); -lean_ctor_set(x_134, 5, x_127); -if (lean_is_scalar(x_122)) { - x_135 = lean_alloc_ctor(1, 2, 0); -} else { - x_135 = x_122; -} -lean_ctor_set(x_135, 0, x_121); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} + 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_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_136 = lean_ctor_get(x_5, 2); -x_137 = lean_ctor_get(x_5, 0); -x_138 = lean_ctor_get(x_5, 1); -x_139 = lean_ctor_get(x_5, 3); -x_140 = lean_ctor_get(x_5, 4); -x_141 = lean_ctor_get(x_5, 5); -lean_inc(x_141); -lean_inc(x_140); -lean_inc(x_139); -lean_inc(x_136); -lean_inc(x_138); +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_137); -lean_dec(x_5); -x_142 = lean_ctor_get(x_136, 0); +x_138 = lean_ctor_get(x_135, 0); +lean_inc(x_138); +lean_dec(x_135); +x_139 = lean_ctor_get(x_136, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_136, 1); +lean_inc(x_140); +x_141 = lean_ctor_get(x_136, 3); +lean_inc(x_141); +x_142 = lean_ctor_get(x_136, 4); lean_inc(x_142); -x_143 = lean_ctor_get(x_136, 1); +x_143 = lean_ctor_get(x_136, 5); lean_inc(x_143); -x_144 = lean_ctor_get(x_136, 2); -lean_inc(x_144); -x_145 = lean_ctor_get(x_136, 3); -lean_inc(x_145); 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_146 = x_136; + lean_ctor_release(x_136, 4); + lean_ctor_release(x_136, 5); + x_144 = x_136; } else { lean_dec_ref(x_136); - x_146 = lean_box(0); + x_144 = lean_box(0); } -x_147 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_146)) { - x_148 = lean_alloc_ctor(0, 4, 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 { - x_148 = x_146; + lean_dec_ref(x_137); + x_148 = lean_box(0); } -lean_ctor_set(x_148, 0, x_142); -lean_ctor_set(x_148, 1, x_143); -lean_ctor_set(x_148, 2, x_147); -lean_ctor_set(x_148, 3, x_145); -x_149 = lean_alloc_ctor(0, 6, 0); -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); -x_150 = lean_apply_2(x_3, x_13, x_149); -if (lean_obj_tag(x_150) == 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_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; +} +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_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_151 = lean_ctor_get(x_150, 1); -lean_inc(x_151); -x_152 = lean_ctor_get(x_151, 2); +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_150, 0); +x_153 = lean_ctor_get(x_135, 0); lean_inc(x_153); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - x_154 = x_150; -} else { - lean_dec_ref(x_150); - x_154 = lean_box(0); -} -x_155 = lean_ctor_get(x_151, 0); +lean_dec(x_135); +x_154 = lean_ctor_get(x_136, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_136, 1); lean_inc(x_155); -x_156 = lean_ctor_get(x_151, 1); +x_156 = lean_ctor_get(x_136, 3); lean_inc(x_156); -x_157 = lean_ctor_get(x_151, 3); +x_157 = lean_ctor_get(x_136, 4); lean_inc(x_157); -x_158 = lean_ctor_get(x_151, 4); +x_158 = lean_ctor_get(x_136, 5); lean_inc(x_158); -x_159 = lean_ctor_get(x_151, 5); -lean_inc(x_159); -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); - lean_ctor_release(x_151, 5); - x_160 = x_151; +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; } else { - lean_dec_ref(x_151); - x_160 = lean_box(0); + lean_dec_ref(x_136); + x_159 = lean_box(0); } -x_161 = lean_ctor_get(x_152, 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, 1); +x_162 = lean_ctor_get(x_152, 3); lean_inc(x_162); -x_163 = lean_ctor_get(x_152, 3); -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); - x_164 = x_152; + x_163 = x_152; } else { lean_dec_ref(x_152); - x_164 = lean_box(0); + x_163 = lean_box(0); } -if (lean_is_scalar(x_164)) { - x_165 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_163)) { + x_164 = lean_alloc_ctor(0, 4, 0); } else { - x_165 = x_164; + x_164 = x_163; } -lean_ctor_set(x_165, 0, x_161); -lean_ctor_set(x_165, 1, x_162); -lean_ctor_set(x_165, 2, x_144); -lean_ctor_set(x_165, 3, x_163); -if (lean_is_scalar(x_160)) { - x_166 = lean_alloc_ctor(0, 6, 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); } else { - x_166 = x_160; + x_165 = x_159; } -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_154)) { - x_167 = lean_alloc_ctor(0, 2, 0); -} else { - x_167 = x_154; +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_167, 0, x_153); -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; lean_object* x_183; lean_object* x_184; -x_168 = lean_ctor_get(x_150, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_168, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_150, 0); -lean_inc(x_170); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - x_171 = x_150; -} else { - lean_dec_ref(x_150); - x_171 = lean_box(0); -} -x_172 = lean_ctor_get(x_168, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_168, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_168, 3); -lean_inc(x_174); -x_175 = lean_ctor_get(x_168, 4); -lean_inc(x_175); -x_176 = lean_ctor_get(x_168, 5); -lean_inc(x_176); -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); - lean_ctor_release(x_168, 4); - lean_ctor_release(x_168, 5); - x_177 = x_168; -} else { - lean_dec_ref(x_168); - x_177 = lean_box(0); -} -x_178 = lean_ctor_get(x_169, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_169, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_169, 3); -lean_inc(x_180); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - x_181 = x_169; -} else { - lean_dec_ref(x_169); - x_181 = lean_box(0); -} -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 4, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_178); -lean_ctor_set(x_182, 1, x_179); -lean_ctor_set(x_182, 2, x_144); -lean_ctor_set(x_182, 3, x_180); -if (lean_is_scalar(x_177)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_177; -} -lean_ctor_set(x_183, 0, x_172); -lean_ctor_set(x_183, 1, x_173); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_174); -lean_ctor_set(x_183, 4, x_175); -lean_ctor_set(x_183, 5, x_176); -if (lean_is_scalar(x_171)) { - x_184 = lean_alloc_ctor(1, 2, 0); -} else { - x_184 = x_171; -} -lean_ctor_set(x_184, 0, x_170); -lean_ctor_set(x_184, 1, x_183); -return x_184; } } } @@ -49986,7 +44287,177 @@ return x_13; } } } -lean_object* _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1() { +lean_object* _init_l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid instantiateForall, too many parameters"); +return x_1; +} +} +lean_object* _init_l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1; +x_2 = lean_alloc_ctor(22, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_1); +x_7 = lean_nat_dec_lt(x_2, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; +lean_dec(x_4); +lean_dec(x_2); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_3); +lean_ctor_set(x_8, 1, x_5); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_array_fget(x_1, x_2); +lean_inc(x_4); +x_10 = l_Lean_Meta_whnf(x_3, x_4, x_5); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +if (lean_obj_tag(x_11) == 7) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_ctor_get(x_11, 2); +lean_inc(x_13); +lean_dec(x_11); +x_14 = lean_unsigned_to_nat(1u); +x_15 = lean_nat_add(x_2, x_14); +lean_dec(x_2); +x_16 = lean_expr_instantiate1(x_13, x_9); +lean_dec(x_9); +lean_dec(x_13); +x_2 = x_15; +x_3 = x_16; +x_5 = x_12; +goto _start; +} +else +{ +uint8_t x_18; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_4); +lean_dec(x_2); +x_18 = !lean_is_exclusive(x_10); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_10, 0); +lean_dec(x_19); +x_20 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2; +lean_ctor_set_tag(x_10, 1); +lean_ctor_set(x_10, 0, x_20); +return x_10; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_10, 1); +lean_inc(x_21); +lean_dec(x_10); +x_22 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2; +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_21); +return x_23; +} +} +} +else +{ +uint8_t x_24; +lean_dec(x_9); +lean_dec(x_4); +lean_dec(x_2); +x_24 = !lean_is_exclusive(x_10); +if (x_24 == 0) +{ +return x_10; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_10, 0); +x_26 = lean_ctor_get(x_10, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_10); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +} +} +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main(x_1, x_2, x_3, x_4, x_5); +return x_6; +} +} +lean_object* l___private_Lean_Meta_Basic_10__instantiateForallAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Lean_Meta_Basic_10__instantiateForallAux(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_Meta_instantiateForall(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; +x_5 = lean_unsigned_to_nat(0u); +x_6 = l___private_Lean_Meta_Basic_10__instantiateForallAux___main(x_2, x_5, x_1, x_3, x_4); +return x_6; +} +} +lean_object* l_Lean_Meta_instantiateForall___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_instantiateForall(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1() { _start: { lean_object* x_1; @@ -49994,17 +44465,17 @@ x_1 = lean_mk_string("Meta"); return x_1; } } -lean_object* _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2() { +lean_object* _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1; +x_2 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3() { +lean_object* _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3() { _start: { lean_object* x_1; @@ -50012,21 +44483,21 @@ x_1 = lean_mk_string("debug"); return x_1; } } -lean_object* _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4() { +lean_object* _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; -x_2 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; +x_2 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses(lean_object* x_1) { +lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_2 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_3 = l_Lean_registerTraceClass(x_2, x_1); if (lean_obj_tag(x_3) == 0) { @@ -50034,7 +44505,7 @@ lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = lean_ctor_get(x_3, 1); lean_inc(x_4); lean_dec(x_3); -x_5 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4; +x_5 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4; x_6 = l_Lean_registerTraceClass(x_5, x_4); return x_6; } @@ -51039,15 +45510,19 @@ l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1 = _init_l_Lean_Meta_r lean_mark_persistent(l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1); l_Lean_Meta_getParamNames___closed__1 = _init_l_Lean_Meta_getParamNames___closed__1(); lean_mark_persistent(l_Lean_Meta_getParamNames___closed__1); -l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1 = _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1(); -lean_mark_persistent(l___private_Lean_Meta_Basic_10__regTraceClasses___closed__1); -l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2 = _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2(); -lean_mark_persistent(l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2); -l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3 = _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3(); -lean_mark_persistent(l___private_Lean_Meta_Basic_10__regTraceClasses___closed__3); -l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4 = _init_l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4(); -lean_mark_persistent(l___private_Lean_Meta_Basic_10__regTraceClasses___closed__4); -res = l___private_Lean_Meta_Basic_10__regTraceClasses(lean_io_mk_world()); +l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1 = _init_l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1(); +lean_mark_persistent(l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__1); +l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2 = _init_l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2(); +lean_mark_persistent(l___private_Lean_Meta_Basic_10__instantiateForallAux___main___closed__2); +l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1 = _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1(); +lean_mark_persistent(l___private_Lean_Meta_Basic_11__regTraceClasses___closed__1); +l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2 = _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2(); +lean_mark_persistent(l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2); +l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3 = _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3(); +lean_mark_persistent(l___private_Lean_Meta_Basic_11__regTraceClasses___closed__3); +l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4 = _init_l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4(); +lean_mark_persistent(l___private_Lean_Meta_Basic_11__regTraceClasses___closed__4); +res = l___private_Lean_Meta_Basic_11__regTraceClasses(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l_Std_PersistentHashMap_empty___at_Lean_Meta_run___spec__1___closed__1 = _init_l_Std_PersistentHashMap_empty___at_Lean_Meta_run___spec__1___closed__1(); diff --git a/stage0/stdlib/Lean/Meta/Check.c b/stage0/stdlib/Lean/Meta/Check.c index 1c477707cf..f575e1ff0d 100644 --- a/stage0/stdlib/Lean/Meta/Check.c +++ b/stage0/stdlib/Lean/Meta/Check.c @@ -26,6 +26,7 @@ lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object* uint8_t l_Lean_checkTraceOption(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_forMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* lean_array_get_size(lean_object*); lean_object* l___private_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_forallTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*); @@ -77,7 +78,6 @@ lean_object* l___private_Lean_Meta_Check_7__regTraceClasses(lean_object*); lean_object* l___private_Lean_Meta_Check_3__checkForall___at___private_Lean_Meta_Check_6__checkAux___main___spec__4___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Check_2__checkLambdaLet___at___private_Lean_Meta_Check_6__checkAux___main___spec__2___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_Exception_toTraceMessageData(lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_check___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Check_3__checkForall___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_MetavarContext_MkBinding_mkBinding___closed__1; @@ -2682,7 +2682,7 @@ lean_object* _init_l_Lean_Meta_check___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_check___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; @@ -4291,7 +4291,7 @@ lean_object* _init_l_Lean_Meta_isTypeCorrect___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_isTypeCorrect___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; diff --git a/stage0/stdlib/Lean/Meta/ExprDefEq.c b/stage0/stdlib/Lean/Meta/ExprDefEq.c index cebac21b8a..94da1f729d 100644 --- a/stage0/stdlib/Lean/Meta/ExprDefEq.c +++ b/stage0/stdlib/Lean/Meta/ExprDefEq.c @@ -3640,1132 +3640,951 @@ goto _start; } else { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; x_31 = lean_ctor_get(x_25, 1); lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_32 = x_25; +} else { + lean_dec_ref(x_25); + x_32 = lean_box(0); +} +x_33 = lean_ctor_get(x_26, 0); +lean_inc(x_33); lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_3, x_33); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_3, x_34); lean_dec(x_3); -x_35 = !lean_is_exclusive(x_31); -if (x_35 == 0) +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_31, 2); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_31, 2); +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) { -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_36, 2); -x_39 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_39); -x_40 = !lean_is_exclusive(x_5); -if (x_40 == 0) +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +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) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_5, 2); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_32); -lean_ctor_set(x_42, 1, x_10); -x_43 = lean_array_push(x_41, x_42); -lean_ctor_set(x_5, 2, x_43); -x_44 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_5, x_31); -if (lean_obj_tag(x_44) == 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_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_44, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_45, 2); -lean_inc(x_46); -x_47 = !lean_is_exclusive(x_44); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_44, 1); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_45); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_45, 2); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_46); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_46, 2); -lean_dec(x_52); -lean_ctor_set(x_46, 2, x_38); -return x_44; +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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_53 = lean_ctor_get(x_46, 0); -x_54 = lean_ctor_get(x_46, 1); -x_55 = lean_ctor_get(x_46, 3); -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_38); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); -return x_44; +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_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; } } 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; -x_57 = lean_ctor_get(x_45, 0); -x_58 = lean_ctor_get(x_45, 1); -x_59 = lean_ctor_get(x_45, 3); -x_60 = lean_ctor_get(x_45, 4); -x_61 = lean_ctor_get(x_45, 5); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); +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_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; +} +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_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; +} +} +block_90: +{ +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 2); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 0); +lean_inc(x_43); +lean_dec(x_40); +x_44 = !lean_is_exclusive(x_41); +if (x_44 == 0) +{ +lean_object* x_45; uint8_t x_46; +x_45 = lean_ctor_get(x_41, 2); +lean_dec(x_45); +x_46 = !lean_is_exclusive(x_42); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_42, 2); +lean_dec(x_47); +lean_ctor_set(x_42, 2, x_39); +if (lean_is_scalar(x_32)) { + x_48 = lean_alloc_ctor(1, 2, 0); +} else { + x_48 = x_32; + lean_ctor_set_tag(x_48, 1); +} +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_41); +return x_48; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_49 = lean_ctor_get(x_42, 0); +x_50 = lean_ctor_get(x_42, 1); +x_51 = lean_ctor_get(x_42, 3); +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); +if (lean_is_scalar(x_32)) { + x_53 = lean_alloc_ctor(1, 2, 0); +} else { + x_53 = x_32; + lean_ctor_set_tag(x_53, 1); +} +lean_ctor_set(x_53, 0, x_43); +lean_ctor_set(x_53, 1, x_41); +return x_53; +} +} +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_inc(x_58); lean_inc(x_57); -lean_dec(x_45); -x_62 = lean_ctor_get(x_46, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_46, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 3); -lean_inc(x_64); -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_65 = x_46; +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); +lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 3); +lean_inc(x_61); +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; } else { - lean_dec_ref(x_46); - x_65 = lean_box(0); + lean_dec_ref(x_42); + x_62 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_63 = x_62; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_38); -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); -lean_ctor_set(x_44, 1, x_67); -return x_44; +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); +if (lean_is_scalar(x_32)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_32; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_43); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } 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; lean_object* x_80; lean_object* x_81; -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -lean_dec(x_44); -x_69 = lean_ctor_get(x_45, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_45, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 5); -lean_inc(x_73); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_74 = x_45; +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_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); +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_39); +if (lean_is_scalar(x_32)) { + x_72 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_74 = lean_box(0); + x_72 = x_32; } -x_75 = lean_ctor_get(x_46, 0); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_41); +return x_72; +} +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_inc(x_75); -x_76 = lean_ctor_get(x_46, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_46, 3); -lean_inc(x_77); -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_78 = x_46; +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); +if (lean_is_scalar(x_32)) { + x_77 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_46); - x_78 = lean_box(0); + x_77 = x_32; } -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_38); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); -} else { - x_80 = x_74; -} -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, 2, 0); -lean_ctor_set(x_81, 0, x_68); -lean_ctor_set(x_81, 1, x_80); -return x_81; +lean_ctor_set(x_77, 0, x_67); +lean_ctor_set(x_77, 1, x_41); +return x_77; } } else { -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_44, 1); +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_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); +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_is_exclusive(x_44); -if (x_84 == 0) -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_44, 1); -lean_dec(x_85); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_82, 2); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) -{ -lean_object* x_89; -x_89 = lean_ctor_get(x_83, 2); -lean_dec(x_89); -lean_ctor_set(x_83, 2, x_38); -return x_44; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_90 = lean_ctor_get(x_83, 0); -x_91 = lean_ctor_get(x_83, 1); -x_92 = lean_ctor_get(x_83, 3); -lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_83); -x_93 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_93, 0, x_90); -lean_ctor_set(x_93, 1, x_91); -lean_ctor_set(x_93, 2, x_38); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set(x_82, 2, x_93); -return x_44; -} -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_94 = lean_ctor_get(x_82, 0); -x_95 = lean_ctor_get(x_82, 1); -x_96 = lean_ctor_get(x_82, 3); -x_97 = lean_ctor_get(x_82, 4); -x_98 = lean_ctor_get(x_82, 5); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_82); -x_99 = lean_ctor_get(x_83, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_83, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_83, 3); -lean_inc(x_101); -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_102 = 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; } else { - lean_dec_ref(x_83); - x_102 = lean_box(0); + lean_dec_ref(x_66); + x_86 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); } else { - x_103 = x_102; + x_87 = x_86; } -lean_ctor_set(x_103, 0, x_99); -lean_ctor_set(x_103, 1, x_100); -lean_ctor_set(x_103, 2, x_38); -lean_ctor_set(x_103, 3, x_101); -x_104 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_104, 0, x_94); -lean_ctor_set(x_104, 1, x_95); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_96); -lean_ctor_set(x_104, 4, x_97); -lean_ctor_set(x_104, 5, x_98); -lean_ctor_set(x_44, 1, x_104); -return x_44; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_105 = lean_ctor_get(x_44, 0); -lean_inc(x_105); -lean_dec(x_44); -x_106 = lean_ctor_get(x_82, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_82, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_82, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 5); -lean_inc(x_110); -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_111 = x_82; +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); +if (lean_is_scalar(x_32)) { + x_89 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + x_89 = x_32; } -x_112 = lean_ctor_get(x_83, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_83, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_83, 3); -lean_inc(x_114); -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_115 = x_83; -} else { - lean_dec_ref(x_83); - x_115 = lean_box(0); +lean_ctor_set(x_89, 0, x_67); +lean_ctor_set(x_89, 1, x_88); +return x_89; } -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_38); -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); -x_118 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_118, 0, x_105); -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; -x_119 = lean_ctor_get(x_5, 0); -x_120 = lean_ctor_get(x_5, 1); -x_121 = lean_ctor_get(x_5, 2); -x_122 = lean_ctor_get(x_5, 3); -x_123 = lean_ctor_get(x_5, 4); -lean_inc(x_123); -lean_inc(x_122); +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_dec(x_5); -x_124 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_124, 0, x_32); -lean_ctor_set(x_124, 1, x_10); -x_125 = lean_array_push(x_121, x_124); -x_126 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_126, 0, x_119); -lean_ctor_set(x_126, 1, x_120); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_122); -lean_ctor_set(x_126, 4, x_123); -x_127 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_126, x_31); -if (lean_obj_tag(x_127) == 0) -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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_128 = lean_ctor_get(x_127, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_127, 0); -lean_inc(x_130); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_131 = x_127; +lean_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_127); + 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_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_128, 0); +x_132 = lean_ctor_get(x_124, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_128, 1); +x_133 = lean_ctor_get(x_124, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_128, 3); +x_134 = lean_ctor_get(x_124, 3); lean_inc(x_134); -x_135 = lean_ctor_get(x_128, 4); -lean_inc(x_135); -x_136 = lean_ctor_get(x_128, 5); -lean_inc(x_136); -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_137 = x_128; +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_128); - x_137 = lean_box(0); + lean_dec_ref(x_124); + x_135 = lean_box(0); } -x_138 = lean_ctor_get(x_129, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_129, 1); -lean_inc(x_139); -x_140 = lean_ctor_get(x_129, 3); -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); - x_141 = x_129; +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_129); - x_141 = lean_box(0); + x_136 = x_135; } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 4, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_138); -lean_ctor_set(x_142, 1, x_139); -lean_ctor_set(x_142, 2, x_38); -lean_ctor_set(x_142, 3, x_140); -if (lean_is_scalar(x_137)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_137; -} -lean_ctor_set(x_143, 0, x_132); -lean_ctor_set(x_143, 1, x_133); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_134); -lean_ctor_set(x_143, 4, x_135); -lean_ctor_set(x_143, 5, x_136); +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_144 = lean_alloc_ctor(0, 2, 0); + x_137 = lean_alloc_ctor(0, 6, 0); } else { - x_144 = x_131; + x_137 = x_131; } -lean_ctor_set(x_144, 0, x_130); -lean_ctor_set(x_144, 1, x_143); -return x_144; +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_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_145 = lean_ctor_get(x_127, 1); +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); -x_146 = lean_ctor_get(x_145, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 0); +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); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_148 = x_127; -} else { - lean_dec_ref(x_127); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_145, 0); +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_145, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_145, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_145, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_145, 5); -lean_inc(x_153); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - lean_ctor_release(x_145, 3); - lean_ctor_release(x_145, 4); - lean_ctor_release(x_145, 5); - x_154 = x_145; +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_145); - x_154 = lean_box(0); + lean_dec_ref(x_139); + x_150 = lean_box(0); } -x_155 = lean_ctor_get(x_146, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_146, 3); -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); - x_158 = x_146; +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_146); - x_158 = lean_box(0); + x_151 = x_150; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 4, 0); +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_159 = x_158; + x_152 = x_146; } -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_38); -lean_ctor_set(x_159, 3, x_157); -if (lean_is_scalar(x_154)) { - x_160 = lean_alloc_ctor(0, 6, 0); +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_160 = x_154; + x_153 = x_32; } -lean_ctor_set(x_160, 0, x_149); -lean_ctor_set(x_160, 1, x_150); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_151); -lean_ctor_set(x_160, 4, x_152); -lean_ctor_set(x_160, 5, x_153); -if (lean_is_scalar(x_148)) { - x_161 = lean_alloc_ctor(1, 2, 0); -} else { - x_161 = x_148; +lean_ctor_set(x_153, 0, x_140); +lean_ctor_set(x_153, 1, x_152); +return x_153; } -lean_ctor_set(x_161, 0, x_147); -lean_ctor_set(x_161, 1, x_160); -return x_161; } } } else { -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; -x_162 = lean_ctor_get(x_36, 0); -x_163 = lean_ctor_get(x_36, 1); -x_164 = lean_ctor_get(x_36, 2); -x_165 = lean_ctor_get(x_36, 3); -lean_inc(x_165); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_36); -x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_167 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_167, 0, x_162); -lean_ctor_set(x_167, 1, x_163); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_165); -lean_ctor_set(x_31, 2, x_167); -x_168 = lean_ctor_get(x_5, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_5, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_5, 2); -lean_inc(x_170); -x_171 = lean_ctor_get(x_5, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_5, 4); -lean_inc(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_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); 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_173 = x_5; + x_225 = x_5; } else { lean_dec_ref(x_5); - x_173 = lean_box(0); + x_225 = lean_box(0); } -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_32); -lean_ctor_set(x_174, 1, x_10); -x_175 = lean_array_push(x_170, x_174); -if (lean_is_scalar(x_173)) { - x_176 = lean_alloc_ctor(0, 5, 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_228 = lean_alloc_ctor(0, 5, 0); } else { - x_176 = x_173; + x_228 = x_225; } -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(x_1, x_2, x_34, x_4, x_176, x_31); -if (lean_obj_tag(x_177) == 0) +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_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_228, x_219); +if (lean_obj_tag(x_229) == 0) { -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_178 = lean_ctor_get(x_177, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_178, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 0); -lean_inc(x_180); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_181 = x_177; -} else { - lean_dec_ref(x_177); - x_181 = lean_box(0); -} -x_182 = lean_ctor_get(x_178, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 5); -lean_inc(x_186); -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_187 = x_178; -} else { - lean_dec_ref(x_178); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_179, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_179, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_179, 3); -lean_inc(x_190); -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_191 = x_179; -} else { - lean_dec_ref(x_179); - 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_164); -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_181)) { - x_194 = lean_alloc_ctor(0, 2, 0); -} else { - x_194 = x_181; -} -lean_ctor_set(x_194, 0, x_180); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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_184 = x_232; +x_185 = x_231; +goto block_216; } 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; lean_object* x_210; lean_object* x_211; -x_195 = lean_ctor_get(x_177, 1); +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_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; +} 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_195, 2); +x_196 = lean_ctor_get(x_186, 3); lean_inc(x_196); -x_197 = lean_ctor_get(x_177, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_198 = x_177; +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_177); - x_198 = lean_box(0); + lean_dec_ref(x_186); + x_197 = lean_box(0); } -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_195, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_195, 3); +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_195, 4); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 5); +lean_dec(x_184); +x_203 = lean_ctor_get(x_185, 0); lean_inc(x_203); -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_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = lean_ctor_get(x_196, 0); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_185, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 1); +x_206 = lean_ctor_get(x_185, 4); lean_inc(x_206); -x_207 = lean_ctor_get(x_196, 3); +x_207 = lean_ctor_get(x_185, 5); lean_inc(x_207); -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_208 = x_196; +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; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_185); x_208 = 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; +} else { + lean_dec_ref(x_201); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); +} else { + x_213 = x_212; +} +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_209 = lean_alloc_ctor(0, 4, 0); + x_214 = lean_alloc_ctor(0, 6, 0); } else { - x_209 = x_208; + x_214 = x_208; } -lean_ctor_set(x_209, 0, x_205); -lean_ctor_set(x_209, 1, x_206); -lean_ctor_set(x_209, 2, x_164); -lean_ctor_set(x_209, 3, x_207); -if (lean_is_scalar(x_204)) { - x_210 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_32)) { + x_215 = lean_alloc_ctor(0, 2, 0); } else { - x_210 = x_204; + x_215 = x_32; } -lean_ctor_set(x_210, 0, x_199); -lean_ctor_set(x_210, 1, x_200); -lean_ctor_set(x_210, 2, x_209); -lean_ctor_set(x_210, 3, x_201); -lean_ctor_set(x_210, 4, x_202); -lean_ctor_set(x_210, 5, x_203); -if (lean_is_scalar(x_198)) { - x_211 = lean_alloc_ctor(1, 2, 0); -} else { - x_211 = x_198; +lean_ctor_set(x_215, 0, x_202); +lean_ctor_set(x_215, 1, x_214); +return x_215; } -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; 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; -x_212 = lean_ctor_get(x_31, 2); -x_213 = lean_ctor_get(x_31, 0); -x_214 = lean_ctor_get(x_31, 1); -x_215 = lean_ctor_get(x_31, 3); -x_216 = lean_ctor_get(x_31, 4); -x_217 = lean_ctor_get(x_31, 5); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_212); -lean_inc(x_214); -lean_inc(x_213); -lean_dec(x_31); -x_218 = lean_ctor_get(x_212, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_212, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_212, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_212, 3); -lean_inc(x_221); -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); - x_222 = x_212; -} else { - lean_dec_ref(x_212); - x_222 = lean_box(0); -} -x_223 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 4, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_218); -lean_ctor_set(x_224, 1, x_219); -lean_ctor_set(x_224, 2, x_223); -lean_ctor_set(x_224, 3, x_221); -x_225 = lean_alloc_ctor(0, 6, 0); -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); -x_226 = lean_ctor_get(x_5, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_5, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_5, 2); -lean_inc(x_228); -x_229 = lean_ctor_get(x_5, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_5, 4); -lean_inc(x_230); -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_231 = x_5; -} else { - lean_dec_ref(x_5); - x_231 = lean_box(0); -} -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_32); -lean_ctor_set(x_232, 1, x_10); -x_233 = lean_array_push(x_228, x_232); -if (lean_is_scalar(x_231)) { - x_234 = lean_alloc_ctor(0, 5, 0); -} else { - x_234 = x_231; -} -lean_ctor_set(x_234, 0, x_226); -lean_ctor_set(x_234, 1, x_227); -lean_ctor_set(x_234, 2, x_233); -lean_ctor_set(x_234, 3, x_229); -lean_ctor_set(x_234, 4, x_230); -x_235 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_234, x_225); -if (lean_obj_tag(x_235) == 0) -{ -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; lean_object* x_252; -x_236 = lean_ctor_get(x_235, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_236, 2); -lean_inc(x_237); -x_238 = lean_ctor_get(x_235, 0); -lean_inc(x_238); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_239 = x_235; -} else { - lean_dec_ref(x_235); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_236, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 3); -lean_inc(x_242); -x_243 = lean_ctor_get(x_236, 4); -lean_inc(x_243); -x_244 = lean_ctor_get(x_236, 5); -lean_inc(x_244); -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); -x_247 = lean_ctor_get(x_237, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_237, 3); -lean_inc(x_248); -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); - x_249 = x_237; -} else { - lean_dec_ref(x_237); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_246); -lean_ctor_set(x_250, 1, x_247); -lean_ctor_set(x_250, 2, x_220); -lean_ctor_set(x_250, 3, x_248); -if (lean_is_scalar(x_245)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_245; -} -lean_ctor_set(x_251, 0, x_240); -lean_ctor_set(x_251, 1, x_241); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_242); -lean_ctor_set(x_251, 4, x_243); -lean_ctor_set(x_251, 5, x_244); -if (lean_is_scalar(x_239)) { - x_252 = lean_alloc_ctor(0, 2, 0); -} else { - x_252 = x_239; -} -lean_ctor_set(x_252, 0, x_238); -lean_ctor_set(x_252, 1, x_251); -return x_252; -} -else -{ -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; -x_253 = lean_ctor_get(x_235, 1); -lean_inc(x_253); -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_235, 0); -lean_inc(x_255); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_256 = x_235; -} else { - lean_dec_ref(x_235); - x_256 = lean_box(0); -} -x_257 = lean_ctor_get(x_253, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_253, 1); -lean_inc(x_258); -x_259 = lean_ctor_get(x_253, 3); -lean_inc(x_259); -x_260 = lean_ctor_get(x_253, 4); -lean_inc(x_260); -x_261 = lean_ctor_get(x_253, 5); -lean_inc(x_261); -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); - lean_ctor_release(x_253, 4); - lean_ctor_release(x_253, 5); - x_262 = x_253; -} else { - lean_dec_ref(x_253); - x_262 = lean_box(0); -} -x_263 = lean_ctor_get(x_254, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_254, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_254, 3); -lean_inc(x_265); -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_266 = x_254; -} else { - lean_dec_ref(x_254); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(0, 4, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_263); -lean_ctor_set(x_267, 1, x_264); -lean_ctor_set(x_267, 2, x_220); -lean_ctor_set(x_267, 3, x_265); -if (lean_is_scalar(x_262)) { - x_268 = lean_alloc_ctor(0, 6, 0); -} else { - x_268 = x_262; -} -lean_ctor_set(x_268, 0, x_257); -lean_ctor_set(x_268, 1, x_258); -lean_ctor_set(x_268, 2, x_267); -lean_ctor_set(x_268, 3, x_259); -lean_ctor_set(x_268, 4, x_260); -lean_ctor_set(x_268, 5, x_261); -if (lean_is_scalar(x_256)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_256; -} -lean_ctor_set(x_269, 0, x_255); -lean_ctor_set(x_269, 1, x_268); -return x_269; } } } } else { -uint8_t x_270; +uint8_t x_236; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_270 = !lean_is_exclusive(x_25); -if (x_270 == 0) +x_236 = !lean_is_exclusive(x_25); +if (x_236 == 0) { return x_25; } else { -lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_271 = lean_ctor_get(x_25, 0); -x_272 = lean_ctor_get(x_25, 1); -lean_inc(x_272); -lean_inc(x_271); +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_dec(x_25); -x_273 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_273, 0, x_271); -lean_ctor_set(x_273, 1, x_272); -return x_273; +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; } } } } else { -uint8_t x_274; +uint8_t x_240; lean_dec(x_14); lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_274 = !lean_is_exclusive(x_17); -if (x_274 == 0) +x_240 = !lean_is_exclusive(x_17); +if (x_240 == 0) { return x_17; } else { -lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_275 = lean_ctor_get(x_17, 0); -x_276 = lean_ctor_get(x_17, 1); -lean_inc(x_276); -lean_inc(x_275); +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_dec(x_17); -x_277 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_277, 0, x_275); -lean_ctor_set(x_277, 1, x_276); -return x_277; +x_243 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_243, 0, x_241); +lean_ctor_set(x_243, 1, x_242); +return x_243; } } } else { -uint8_t x_278; +uint8_t x_244; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_278 = !lean_is_exclusive(x_11); -if (x_278 == 0) +x_244 = !lean_is_exclusive(x_11); +if (x_244 == 0) { return x_11; } else { -lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_11, 0); -x_280 = lean_ctor_get(x_11, 1); -lean_inc(x_280); -lean_inc(x_279); +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_dec(x_11); -x_281 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -return x_281; +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; } } } @@ -4901,1129 +4720,948 @@ goto _start; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; x_35 = lean_ctor_get(x_29, 1); lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_ctor_get(x_30, 0); -lean_inc(x_36); +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + x_36 = x_29; +} else { + lean_dec_ref(x_29); + x_36 = lean_box(0); +} +x_37 = lean_ctor_get(x_30, 0); +lean_inc(x_37); lean_dec(x_30); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_add(x_6, x_37); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_add(x_6, x_38); lean_dec(x_6); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) +x_40 = !lean_is_exclusive(x_35); +if (x_40 == 0) { -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 2); +x_42 = !lean_is_exclusive(x_41); +if (x_42 == 0) { -lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_42 = lean_ctor_get(x_40, 2); -x_43 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_40, 2, x_43); -x_44 = !lean_is_exclusive(x_7); -if (x_44 == 0) +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +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) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = lean_ctor_get(x_7, 2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_14); -x_47 = lean_array_push(x_45, x_46); -lean_ctor_set(x_7, 2, x_47); -x_48 = 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_38, x_7, x_35); -if (lean_obj_tag(x_48) == 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_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_49, 2); -lean_inc(x_50); -x_51 = !lean_is_exclusive(x_48); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_48, 1); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_49, 2); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_50); -if (x_55 == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_50, 2); -lean_dec(x_56); -lean_ctor_set(x_50, 2, x_42); -return x_48; +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_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_50, 0); -x_58 = lean_ctor_get(x_50, 1); -x_59 = lean_ctor_get(x_50, 3); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_50); -x_60 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_42); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_49, 2, x_60); -return x_48; +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_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; } } 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; -x_61 = lean_ctor_get(x_49, 0); -x_62 = lean_ctor_get(x_49, 1); -x_63 = lean_ctor_get(x_49, 3); -x_64 = lean_ctor_get(x_49, 4); -x_65 = lean_ctor_get(x_49, 5); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); +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_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; +} +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_44 = x_121; +x_45 = x_120; +goto block_94; +} +} +block_94: +{ +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 0); +lean_inc(x_47); +lean_dec(x_44); +x_48 = !lean_is_exclusive(x_45); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_45, 2); +lean_dec(x_49); +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_43); +if (lean_is_scalar(x_36)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_36; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +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); +if (lean_is_scalar(x_36)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_36; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_47); +lean_ctor_set(x_57, 1, x_45); +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_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_inc(x_62); lean_inc(x_61); -lean_dec(x_49); -x_66 = lean_ctor_get(x_50, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_50, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_50, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_69 = x_50; +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); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 3); +lean_inc(x_65); +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; } else { - lean_dec_ref(x_50); - x_69 = lean_box(0); + lean_dec_ref(x_46); + x_66 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_67 = x_66; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_42); -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_48, 1, x_71); -return x_48; +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); +if (lean_is_scalar(x_36)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_36; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_47); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } 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; lean_object* x_84; lean_object* x_85; -x_72 = lean_ctor_get(x_48, 0); -lean_inc(x_72); -lean_dec(x_48); -x_73 = lean_ctor_get(x_49, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 3); -lean_inc(x_75); -x_76 = lean_ctor_get(x_49, 4); -lean_inc(x_76); -x_77 = lean_ctor_get(x_49, 5); -lean_inc(x_77); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_78 = x_49; +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_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); +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_43); +if (lean_is_scalar(x_36)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_49); - x_78 = lean_box(0); + x_76 = x_36; } -x_79 = lean_ctor_get(x_50, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_45); +return x_76; +} +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_inc(x_79); -x_80 = lean_ctor_get(x_50, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_50, 3); -lean_inc(x_81); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_82 = x_50; +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); +if (lean_is_scalar(x_36)) { + x_81 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_50); - x_82 = lean_box(0); + x_81 = x_36; } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 4, 0); -} else { - x_83 = x_82; -} -lean_ctor_set(x_83, 0, x_79); -lean_ctor_set(x_83, 1, x_80); -lean_ctor_set(x_83, 2, x_42); -lean_ctor_set(x_83, 3, x_81); -if (lean_is_scalar(x_78)) { - x_84 = lean_alloc_ctor(0, 6, 0); -} else { - x_84 = x_78; -} -lean_ctor_set(x_84, 0, x_73); -lean_ctor_set(x_84, 1, x_74); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_75); -lean_ctor_set(x_84, 4, x_76); -lean_ctor_set(x_84, 5, x_77); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_72); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_81, 0, x_71); +lean_ctor_set(x_81, 1, x_45); +return x_81; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_48, 1); +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_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); +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_is_exclusive(x_48); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_48, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_86, 2); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_42); -return x_48; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -x_96 = lean_ctor_get(x_87, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -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_42); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_86, 2, x_97); -return x_48; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 0); -x_99 = lean_ctor_get(x_86, 1); -x_100 = lean_ctor_get(x_86, 3); -x_101 = lean_ctor_get(x_86, 4); -x_102 = lean_ctor_get(x_86, 5); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_86); -x_103 = lean_ctor_get(x_87, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 3); -lean_inc(x_105); -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_106 = 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; } else { - lean_dec_ref(x_87); - x_106 = lean_box(0); + lean_dec_ref(x_70); + x_90 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_107 = x_106; + x_91 = x_90; } -lean_ctor_set(x_107, 0, x_103); -lean_ctor_set(x_107, 1, x_104); -lean_ctor_set(x_107, 2, x_42); -lean_ctor_set(x_107, 3, x_105); -x_108 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_108, 0, x_98); -lean_ctor_set(x_108, 1, x_99); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_100); -lean_ctor_set(x_108, 4, x_101); -lean_ctor_set(x_108, 5, x_102); -lean_ctor_set(x_48, 1, x_108); -return x_48; -} -} -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; -x_109 = lean_ctor_get(x_48, 0); -lean_inc(x_109); -lean_dec(x_48); -x_110 = lean_ctor_get(x_86, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 3); -lean_inc(x_112); -x_113 = lean_ctor_get(x_86, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_86, 5); -lean_inc(x_114); -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_115 = x_86; +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); +if (lean_is_scalar(x_36)) { + x_93 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_86); - x_115 = lean_box(0); + x_93 = x_36; } -x_116 = lean_ctor_get(x_87, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_87, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 3); -lean_inc(x_118); -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_119 = x_87; -} else { - lean_dec_ref(x_87); - x_119 = lean_box(0); +lean_ctor_set(x_93, 0, x_71); +lean_ctor_set(x_93, 1, x_92); +return x_93; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_42); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_109); -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; -x_123 = lean_ctor_get(x_7, 0); -x_124 = lean_ctor_get(x_7, 1); -x_125 = lean_ctor_get(x_7, 2); -x_126 = lean_ctor_get(x_7, 3); -x_127 = lean_ctor_get(x_7, 4); -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; 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_dec(x_7); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_36); -lean_ctor_set(x_128, 1, x_14); -x_129 = lean_array_push(x_125, x_128); -x_130 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_130, 0, x_123); -lean_ctor_set(x_130, 1, x_124); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_126); -lean_ctor_set(x_130, 4, x_127); -x_131 = 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_38, x_130, x_35); -if (lean_obj_tag(x_131) == 0) -{ -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; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_135 = x_131; +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_131); + 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_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_132, 0); +x_136 = lean_ctor_get(x_128, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); +x_137 = lean_ctor_get(x_128, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 3); +x_138 = lean_ctor_get(x_128, 3); lean_inc(x_138); -x_139 = lean_ctor_get(x_132, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_132, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_141 = x_132; +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_132); - x_141 = lean_box(0); + lean_dec_ref(x_128); + x_139 = lean_box(0); } -x_142 = lean_ctor_get(x_133, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_133, 3); -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); - x_145 = x_133; +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_145 = lean_box(0); + x_140 = x_139; } -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_42); -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); +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_148 = lean_alloc_ctor(0, 2, 0); + x_141 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_135; + x_141 = x_135; } -lean_ctor_set(x_148, 0, x_134); -lean_ctor_set(x_148, 1, x_147); -return x_148; +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_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_131, 1); +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); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_131, 0); +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); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_152 = x_131; -} else { - lean_dec_ref(x_131); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); +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_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; +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_149); - x_158 = lean_box(0); + lean_dec_ref(x_143); + x_154 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_150); - x_162 = lean_box(0); + x_155 = x_154; } -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); +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_163 = x_162; + x_156 = x_150; } -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_42); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); +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_164 = x_158; + x_157 = x_36; } -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(1, 2, 0); -} else { - x_165 = x_152; +lean_ctor_set(x_157, 0, x_144); +lean_ctor_set(x_157, 1, x_156); +return x_157; } -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; } } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_166 = lean_ctor_get(x_40, 0); -x_167 = lean_ctor_get(x_40, 1); -x_168 = lean_ctor_get(x_40, 2); -x_169 = lean_ctor_get(x_40, 3); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_40); -x_170 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_171 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_171, 0, x_166); -lean_ctor_set(x_171, 1, x_167); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_169); -lean_ctor_set(x_35, 2, x_171); -x_172 = lean_ctor_get(x_7, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_7, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_7, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_7, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_7, 4); -lean_inc(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_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); 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_177 = x_7; + x_229 = x_7; } else { lean_dec_ref(x_7); - x_177 = lean_box(0); + x_229 = lean_box(0); } -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_36); -lean_ctor_set(x_178, 1, x_14); -x_179 = lean_array_push(x_174, x_178); -if (lean_is_scalar(x_177)) { - x_180 = lean_alloc_ctor(0, 5, 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_232 = lean_alloc_ctor(0, 5, 0); } else { - x_180 = x_177; + x_232 = x_229; } -lean_ctor_set(x_180, 0, x_172); -lean_ctor_set(x_180, 1, x_173); -lean_ctor_set(x_180, 2, x_179); -lean_ctor_set(x_180, 3, x_175); -lean_ctor_set(x_180, 4, x_176); -x_181 = 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_38, x_180, x_35); -if (lean_obj_tag(x_181) == 0) +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_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_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_196; lean_object* x_197; lean_object* x_198; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_182, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_182, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_182, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_182, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_182, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - lean_ctor_release(x_182, 2); - lean_ctor_release(x_182, 3); - lean_ctor_release(x_182, 4); - lean_ctor_release(x_182, 5); - x_191 = x_182; -} else { - lean_dec_ref(x_182); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_183, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_183, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_183, 3); -lean_inc(x_194); -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); - x_195 = x_183; -} else { - lean_dec_ref(x_183); - 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_168); -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_185)) { - x_198 = lean_alloc_ctor(0, 2, 0); -} else { - x_198 = x_185; -} -lean_ctor_set(x_198, 0, x_184); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_188 = x_236; +x_189 = x_235; +goto block_220; } 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; lean_object* x_214; lean_object* x_215; -x_199 = lean_ctor_get(x_181, 1); +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_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; +} 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_199, 2); +x_200 = lean_ctor_get(x_190, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_181, 0); -lean_inc(x_201); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_202 = x_181; +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_181); - x_202 = lean_box(0); + lean_dec_ref(x_190); + x_201 = lean_box(0); } -x_203 = lean_ctor_get(x_199, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_199, 3); +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_199, 4); +x_206 = lean_ctor_get(x_188, 0); lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 5); +lean_dec(x_188); +x_207 = lean_ctor_get(x_189, 0); lean_inc(x_207); -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); - lean_ctor_release(x_199, 4); - lean_ctor_release(x_199, 5); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = lean_ctor_get(x_200, 0); +x_208 = lean_ctor_get(x_189, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_189, 3); lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 1); +x_210 = lean_ctor_get(x_189, 4); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 3); +x_211 = lean_ctor_get(x_189, 5); 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); - x_212 = x_200; +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; } else { - lean_dec_ref(x_200); + lean_dec_ref(x_189); 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); +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; +} else { + lean_dec_ref(x_205); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 4, 0); +} else { + x_217 = x_216; +} +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_213 = lean_alloc_ctor(0, 4, 0); + x_218 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_218 = x_212; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_168); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_36)) { + x_219 = lean_alloc_ctor(0, 2, 0); } else { - x_214 = x_208; + x_219 = x_36; } -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); -if (lean_is_scalar(x_202)) { - x_215 = lean_alloc_ctor(1, 2, 0); -} else { - x_215 = x_202; +lean_ctor_set(x_219, 0, x_206); +lean_ctor_set(x_219, 1, x_218); +return x_219; } -lean_ctor_set(x_215, 0, x_201); -lean_ctor_set(x_215, 1, x_214); -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_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; -x_216 = lean_ctor_get(x_35, 2); -x_217 = lean_ctor_get(x_35, 0); -x_218 = lean_ctor_get(x_35, 1); -x_219 = lean_ctor_get(x_35, 3); -x_220 = lean_ctor_get(x_35, 4); -x_221 = lean_ctor_get(x_35, 5); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); -lean_inc(x_216); -lean_inc(x_218); -lean_inc(x_217); -lean_dec(x_35); -x_222 = lean_ctor_get(x_216, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_216, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_216, 3); -lean_inc(x_225); -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_226 = x_216; -} else { - lean_dec_ref(x_216); - x_226 = lean_box(0); -} -x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 4, 0); -} else { - x_228 = x_226; -} -lean_ctor_set(x_228, 0, x_222); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_225); -x_229 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_229, 0, x_217); -lean_ctor_set(x_229, 1, x_218); -lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_219); -lean_ctor_set(x_229, 4, x_220); -lean_ctor_set(x_229, 5, x_221); -x_230 = lean_ctor_get(x_7, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_7, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_7, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_7, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_7, 4); -lean_inc(x_234); -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_235 = x_7; -} else { - lean_dec_ref(x_7); - x_235 = lean_box(0); -} -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_36); -lean_ctor_set(x_236, 1, x_14); -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___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_38, x_238, x_229); -if (lean_obj_tag(x_239) == 0) -{ -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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_224); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -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; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; -} else { - lean_dec_ref(x_257); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; -} else { - lean_dec_ref(x_258); - x_270 = lean_box(0); -} -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); -} else { - x_271 = x_270; -} -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_224); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); -} else { - x_272 = x_266; -} -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(1, 2, 0); -} else { - x_273 = x_260; -} -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } } else { -uint8_t x_274; +uint8_t x_240; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_274 = !lean_is_exclusive(x_29); -if (x_274 == 0) +x_240 = !lean_is_exclusive(x_29); +if (x_240 == 0) { return x_29; } else { -lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_275 = lean_ctor_get(x_29, 0); -x_276 = lean_ctor_get(x_29, 1); -lean_inc(x_276); -lean_inc(x_275); +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_dec(x_29); -x_277 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_277, 0, x_275); -lean_ctor_set(x_277, 1, x_276); -return x_277; +x_243 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_243, 0, x_241); +lean_ctor_set(x_243, 1, x_242); +return x_243; } } } } else { -uint8_t x_278; +uint8_t x_244; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_278 = !lean_is_exclusive(x_21); -if (x_278 == 0) +x_244 = !lean_is_exclusive(x_21); +if (x_244 == 0) { return x_21; } else { -lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_21, 0); -x_280 = lean_ctor_get(x_21, 1); -lean_inc(x_280); -lean_inc(x_279); +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_dec(x_21); -x_281 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -return x_281; +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; } } } else { -uint8_t x_282; +uint8_t x_248; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_282 = !lean_is_exclusive(x_15); -if (x_282 == 0) +x_248 = !lean_is_exclusive(x_15); +if (x_248 == 0) { return x_15; } else { -lean_object* x_283; lean_object* x_284; lean_object* x_285; -x_283 = lean_ctor_get(x_15, 0); -x_284 = lean_ctor_get(x_15, 1); -lean_inc(x_284); -lean_inc(x_283); +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_dec(x_15); -x_285 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_285, 0, x_283); -lean_ctor_set(x_285, 1, x_284); -return x_285; +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; } } } @@ -10349,2153 +9987,1791 @@ goto _start; } case 1: { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; lean_dec(x_28); x_35 = lean_ctor_get(x_29, 1); lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_ctor_get(x_30, 0); -lean_inc(x_36); +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + x_36 = x_29; +} else { + lean_dec_ref(x_29); + x_36 = lean_box(0); +} +x_37 = lean_ctor_get(x_30, 0); +lean_inc(x_37); lean_dec(x_30); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_add(x_7, x_37); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_add(x_7, x_38); lean_dec(x_7); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) +x_40 = !lean_is_exclusive(x_35); +if (x_40 == 0) { -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 2); +x_42 = !lean_is_exclusive(x_41); +if (x_42 == 0) { -lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_42 = lean_ctor_get(x_40, 2); -x_43 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_40, 2, x_43); -x_44 = !lean_is_exclusive(x_8); -if (x_44 == 0) +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +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) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = lean_ctor_get(x_8, 2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_24); -x_47 = lean_array_push(x_45, x_46); -lean_ctor_set(x_8, 2, x_47); -x_48 = 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_38, x_8, x_35); -if (lean_obj_tag(x_48) == 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_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_49, 2); -lean_inc(x_50); -x_51 = !lean_is_exclusive(x_48); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_48, 1); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_49, 2); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_50); -if (x_55 == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_50, 2); -lean_dec(x_56); -lean_ctor_set(x_50, 2, x_42); -return x_48; +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_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_50, 0); -x_58 = lean_ctor_get(x_50, 1); -x_59 = lean_ctor_get(x_50, 3); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_50); -x_60 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_42); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_49, 2, x_60); -return x_48; +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_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; } } 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; -x_61 = lean_ctor_get(x_49, 0); -x_62 = lean_ctor_get(x_49, 1); -x_63 = lean_ctor_get(x_49, 3); -x_64 = lean_ctor_get(x_49, 4); -x_65 = lean_ctor_get(x_49, 5); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); +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_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; +} +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_44 = x_121; +x_45 = x_120; +goto block_94; +} +} +block_94: +{ +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 0); +lean_inc(x_47); +lean_dec(x_44); +x_48 = !lean_is_exclusive(x_45); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_45, 2); +lean_dec(x_49); +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_43); +if (lean_is_scalar(x_36)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_36; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +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); +if (lean_is_scalar(x_36)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_36; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_47); +lean_ctor_set(x_57, 1, x_45); +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_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_inc(x_62); lean_inc(x_61); -lean_dec(x_49); -x_66 = lean_ctor_get(x_50, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_50, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_50, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_69 = x_50; +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); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 3); +lean_inc(x_65); +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; } else { - lean_dec_ref(x_50); - x_69 = lean_box(0); + lean_dec_ref(x_46); + x_66 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_67 = x_66; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_42); -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_48, 1, x_71); -return x_48; +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); +if (lean_is_scalar(x_36)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_36; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_47); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } 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; lean_object* x_84; lean_object* x_85; -x_72 = lean_ctor_get(x_48, 0); -lean_inc(x_72); -lean_dec(x_48); -x_73 = lean_ctor_get(x_49, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 3); -lean_inc(x_75); -x_76 = lean_ctor_get(x_49, 4); -lean_inc(x_76); -x_77 = lean_ctor_get(x_49, 5); -lean_inc(x_77); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_78 = x_49; +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_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); +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_43); +if (lean_is_scalar(x_36)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_49); - x_78 = lean_box(0); + x_76 = x_36; } -x_79 = lean_ctor_get(x_50, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_45); +return x_76; +} +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_inc(x_79); -x_80 = lean_ctor_get(x_50, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_50, 3); -lean_inc(x_81); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_82 = x_50; +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); +if (lean_is_scalar(x_36)) { + x_81 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_50); - x_82 = lean_box(0); + x_81 = x_36; } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 4, 0); -} else { - x_83 = x_82; -} -lean_ctor_set(x_83, 0, x_79); -lean_ctor_set(x_83, 1, x_80); -lean_ctor_set(x_83, 2, x_42); -lean_ctor_set(x_83, 3, x_81); -if (lean_is_scalar(x_78)) { - x_84 = lean_alloc_ctor(0, 6, 0); -} else { - x_84 = x_78; -} -lean_ctor_set(x_84, 0, x_73); -lean_ctor_set(x_84, 1, x_74); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_75); -lean_ctor_set(x_84, 4, x_76); -lean_ctor_set(x_84, 5, x_77); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_72); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_81, 0, x_71); +lean_ctor_set(x_81, 1, x_45); +return x_81; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_48, 1); +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_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); +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_is_exclusive(x_48); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_48, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_86, 2); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_42); -return x_48; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -x_96 = lean_ctor_get(x_87, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -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_42); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_86, 2, x_97); -return x_48; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 0); -x_99 = lean_ctor_get(x_86, 1); -x_100 = lean_ctor_get(x_86, 3); -x_101 = lean_ctor_get(x_86, 4); -x_102 = lean_ctor_get(x_86, 5); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_86); -x_103 = lean_ctor_get(x_87, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 3); -lean_inc(x_105); -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_106 = 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; } else { - lean_dec_ref(x_87); - x_106 = lean_box(0); + lean_dec_ref(x_70); + x_90 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_107 = x_106; + x_91 = x_90; } -lean_ctor_set(x_107, 0, x_103); -lean_ctor_set(x_107, 1, x_104); -lean_ctor_set(x_107, 2, x_42); -lean_ctor_set(x_107, 3, x_105); -x_108 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_108, 0, x_98); -lean_ctor_set(x_108, 1, x_99); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_100); -lean_ctor_set(x_108, 4, x_101); -lean_ctor_set(x_108, 5, x_102); -lean_ctor_set(x_48, 1, x_108); -return x_48; -} -} -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; -x_109 = lean_ctor_get(x_48, 0); -lean_inc(x_109); -lean_dec(x_48); -x_110 = lean_ctor_get(x_86, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 3); -lean_inc(x_112); -x_113 = lean_ctor_get(x_86, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_86, 5); -lean_inc(x_114); -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_115 = x_86; +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); +if (lean_is_scalar(x_36)) { + x_93 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_86); - x_115 = lean_box(0); + x_93 = x_36; } -x_116 = lean_ctor_get(x_87, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_87, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 3); -lean_inc(x_118); -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_119 = x_87; -} else { - lean_dec_ref(x_87); - x_119 = lean_box(0); +lean_ctor_set(x_93, 0, x_71); +lean_ctor_set(x_93, 1, x_92); +return x_93; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_42); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_109); -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; -x_123 = lean_ctor_get(x_8, 0); -x_124 = lean_ctor_get(x_8, 1); -x_125 = lean_ctor_get(x_8, 2); -x_126 = lean_ctor_get(x_8, 3); -x_127 = lean_ctor_get(x_8, 4); -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; 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_dec(x_8); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_36); -lean_ctor_set(x_128, 1, x_24); -x_129 = lean_array_push(x_125, x_128); -x_130 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_130, 0, x_123); -lean_ctor_set(x_130, 1, x_124); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_126); -lean_ctor_set(x_130, 4, x_127); -x_131 = 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_38, x_130, x_35); -if (lean_obj_tag(x_131) == 0) -{ -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; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_135 = x_131; +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_131); + 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_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_132, 0); +x_136 = lean_ctor_get(x_128, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); +x_137 = lean_ctor_get(x_128, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 3); +x_138 = lean_ctor_get(x_128, 3); lean_inc(x_138); -x_139 = lean_ctor_get(x_132, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_132, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_141 = x_132; +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_132); - x_141 = lean_box(0); + lean_dec_ref(x_128); + x_139 = lean_box(0); } -x_142 = lean_ctor_get(x_133, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_133, 3); -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); - x_145 = x_133; +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_145 = lean_box(0); + x_140 = x_139; } -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_42); -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); +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_148 = lean_alloc_ctor(0, 2, 0); + x_141 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_135; + x_141 = x_135; } -lean_ctor_set(x_148, 0, x_134); -lean_ctor_set(x_148, 1, x_147); -return x_148; +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_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_131, 1); +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); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_131, 0); +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); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_152 = x_131; -} else { - lean_dec_ref(x_131); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); +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_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; +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_149); - x_158 = lean_box(0); + lean_dec_ref(x_143); + x_154 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_150); - x_162 = lean_box(0); + x_155 = x_154; } -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); +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_163 = x_162; + x_156 = x_150; } -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_42); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); +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_164 = x_158; + x_157 = x_36; } -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(1, 2, 0); -} else { - x_165 = x_152; +lean_ctor_set(x_157, 0, x_144); +lean_ctor_set(x_157, 1, x_156); +return x_157; } -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; } } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_166 = lean_ctor_get(x_40, 0); -x_167 = lean_ctor_get(x_40, 1); -x_168 = lean_ctor_get(x_40, 2); -x_169 = lean_ctor_get(x_40, 3); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_40); -x_170 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_171 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_171, 0, x_166); -lean_ctor_set(x_171, 1, x_167); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_169); -lean_ctor_set(x_35, 2, x_171); -x_172 = lean_ctor_get(x_8, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_8, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_8, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_8, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_8, 4); -lean_inc(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_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); 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_177 = x_8; + x_229 = x_8; } else { lean_dec_ref(x_8); - x_177 = lean_box(0); + x_229 = lean_box(0); } -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_36); -lean_ctor_set(x_178, 1, x_24); -x_179 = lean_array_push(x_174, x_178); -if (lean_is_scalar(x_177)) { - x_180 = lean_alloc_ctor(0, 5, 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_232 = lean_alloc_ctor(0, 5, 0); } else { - x_180 = x_177; + x_232 = x_229; } -lean_ctor_set(x_180, 0, x_172); -lean_ctor_set(x_180, 1, x_173); -lean_ctor_set(x_180, 2, x_179); -lean_ctor_set(x_180, 3, x_175); -lean_ctor_set(x_180, 4, x_176); -x_181 = 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_38, x_180, x_35); -if (lean_obj_tag(x_181) == 0) +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_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_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_196; lean_object* x_197; lean_object* x_198; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_182, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_182, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_182, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_182, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_182, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - lean_ctor_release(x_182, 2); - lean_ctor_release(x_182, 3); - lean_ctor_release(x_182, 4); - lean_ctor_release(x_182, 5); - x_191 = x_182; -} else { - lean_dec_ref(x_182); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_183, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_183, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_183, 3); -lean_inc(x_194); -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); - x_195 = x_183; -} else { - lean_dec_ref(x_183); - 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_168); -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_185)) { - x_198 = lean_alloc_ctor(0, 2, 0); -} else { - x_198 = x_185; -} -lean_ctor_set(x_198, 0, x_184); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_188 = x_236; +x_189 = x_235; +goto block_220; } 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; lean_object* x_214; lean_object* x_215; -x_199 = lean_ctor_get(x_181, 1); +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_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; +} 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_199, 2); +x_200 = lean_ctor_get(x_190, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_181, 0); -lean_inc(x_201); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_202 = x_181; +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_181); - x_202 = lean_box(0); + lean_dec_ref(x_190); + x_201 = lean_box(0); } -x_203 = lean_ctor_get(x_199, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_199, 3); +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_199, 4); +x_206 = lean_ctor_get(x_188, 0); lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 5); +lean_dec(x_188); +x_207 = lean_ctor_get(x_189, 0); lean_inc(x_207); -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); - lean_ctor_release(x_199, 4); - lean_ctor_release(x_199, 5); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = lean_ctor_get(x_200, 0); +x_208 = lean_ctor_get(x_189, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_189, 3); lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 1); +x_210 = lean_ctor_get(x_189, 4); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 3); +x_211 = lean_ctor_get(x_189, 5); 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); - x_212 = x_200; +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; } else { - lean_dec_ref(x_200); + lean_dec_ref(x_189); 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); +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; +} else { + lean_dec_ref(x_205); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 4, 0); +} else { + x_217 = x_216; +} +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_213 = lean_alloc_ctor(0, 4, 0); + x_218 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_218 = x_212; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_168); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_36)) { + x_219 = lean_alloc_ctor(0, 2, 0); } else { - x_214 = x_208; + x_219 = x_36; } -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); -if (lean_is_scalar(x_202)) { - x_215 = lean_alloc_ctor(1, 2, 0); -} else { - x_215 = x_202; +lean_ctor_set(x_219, 0, x_206); +lean_ctor_set(x_219, 1, x_218); +return x_219; } -lean_ctor_set(x_215, 0, x_201); -lean_ctor_set(x_215, 1, x_214); -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_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; -x_216 = lean_ctor_get(x_35, 2); -x_217 = lean_ctor_get(x_35, 0); -x_218 = lean_ctor_get(x_35, 1); -x_219 = lean_ctor_get(x_35, 3); -x_220 = lean_ctor_get(x_35, 4); -x_221 = lean_ctor_get(x_35, 5); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); -lean_inc(x_216); -lean_inc(x_218); -lean_inc(x_217); -lean_dec(x_35); -x_222 = lean_ctor_get(x_216, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_216, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_216, 3); -lean_inc(x_225); -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_226 = x_216; -} else { - lean_dec_ref(x_216); - x_226 = lean_box(0); -} -x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 4, 0); -} else { - x_228 = x_226; -} -lean_ctor_set(x_228, 0, x_222); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_225); -x_229 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_229, 0, x_217); -lean_ctor_set(x_229, 1, x_218); -lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_219); -lean_ctor_set(x_229, 4, x_220); -lean_ctor_set(x_229, 5, x_221); -x_230 = lean_ctor_get(x_8, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_8, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_8, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_8, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_8, 4); -lean_inc(x_234); -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_235 = x_8; -} else { - lean_dec_ref(x_8); - x_235 = lean_box(0); -} -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_36); -lean_ctor_set(x_236, 1, x_24); -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_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_238, x_229); -if (lean_obj_tag(x_239) == 0) -{ -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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_224); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -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; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; -} else { - lean_dec_ref(x_257); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; -} else { - lean_dec_ref(x_258); - x_270 = lean_box(0); -} -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); -} else { - x_271 = x_270; -} -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_224); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); -} else { - x_272 = x_266; -} -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(1, 2, 0); -} else { - x_273 = x_260; -} -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } default: { -lean_object* x_274; lean_object* x_275; -x_274 = lean_ctor_get(x_29, 1); -lean_inc(x_274); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_29, 1); +lean_inc(x_240); lean_dec(x_29); lean_inc(x_8); -x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); -if (lean_obj_tag(x_275) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_276; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -if (lean_obj_tag(x_276) == 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_277; lean_object* x_278; lean_object* x_279; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_24); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_7, x_278); +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); lean_dec(x_7); -x_7 = x_279; -x_9 = x_277; +x_7 = x_245; +x_9 = x_243; goto _start; } else { -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; uint8_t x_285; -x_281 = lean_ctor_get(x_275, 1); -lean_inc(x_281); -lean_dec(x_275); -x_282 = lean_ctor_get(x_276, 0); -lean_inc(x_282); -lean_dec(x_276); -x_283 = lean_unsigned_to_nat(1u); -x_284 = lean_nat_add(x_7, x_283); +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_241); + x_248 = 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_285 = !lean_is_exclusive(x_281); -if (x_285 == 0) +x_252 = !lean_is_exclusive(x_247); +if (x_252 == 0) { -lean_object* x_286; uint8_t x_287; -x_286 = lean_ctor_get(x_281, 2); -x_287 = !lean_is_exclusive(x_286); -if (x_287 == 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_288; lean_object* x_289; uint8_t x_290; -x_288 = lean_ctor_get(x_286, 2); -x_289 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_286, 2, x_289); -x_290 = !lean_is_exclusive(x_8); -if (x_290 == 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_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_291 = lean_ctor_get(x_8, 2); -x_292 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_292, 0, x_282); -lean_ctor_set(x_292, 1, x_24); -x_293 = lean_array_push(x_291, x_292); -lean_ctor_set(x_8, 2, x_293); -x_294 = 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_284, x_8, x_281); -if (lean_obj_tag(x_294) == 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_295; lean_object* x_296; uint8_t x_297; -x_295 = lean_ctor_get(x_294, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_295, 2); -lean_inc(x_296); -x_297 = !lean_is_exclusive(x_294); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_294, 1); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_295); -if (x_299 == 0) -{ -lean_object* x_300; uint8_t x_301; -x_300 = lean_ctor_get(x_295, 2); -lean_dec(x_300); -x_301 = !lean_is_exclusive(x_296); -if (x_301 == 0) -{ -lean_object* x_302; -x_302 = lean_ctor_get(x_296, 2); -lean_dec(x_302); -lean_ctor_set(x_296, 2, x_288); -return x_294; -} -else -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_296, 0); -x_304 = lean_ctor_get(x_296, 1); -x_305 = lean_ctor_get(x_296, 3); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_296); -x_306 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_288); -lean_ctor_set(x_306, 3, x_305); -lean_ctor_set(x_295, 2, x_306); -return x_294; -} -} -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; -x_307 = lean_ctor_get(x_295, 0); -x_308 = lean_ctor_get(x_295, 1); -x_309 = lean_ctor_get(x_295, 3); -x_310 = lean_ctor_get(x_295, 4); -x_311 = lean_ctor_get(x_295, 5); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_dec(x_295); -x_312 = lean_ctor_get(x_296, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_296, 1); +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_296, 3); +x_314 = lean_ctor_get(x_312, 1); lean_inc(x_314); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_315 = x_296; -} else { - lean_dec_ref(x_296); - x_315 = lean_box(0); +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; } -if (lean_is_scalar(x_315)) { - x_316 = lean_alloc_ctor(0, 4, 0); -} else { - x_316 = x_315; -} -lean_ctor_set(x_316, 0, x_312); -lean_ctor_set(x_316, 1, x_313); -lean_ctor_set(x_316, 2, x_288); -lean_ctor_set(x_316, 3, x_314); -x_317 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_317, 0, x_307); -lean_ctor_set(x_317, 1, x_308); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_309); -lean_ctor_set(x_317, 4, x_310); -lean_ctor_set(x_317, 5, x_311); -lean_ctor_set(x_294, 1, x_317); -return x_294; +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_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_318 = lean_ctor_get(x_294, 0); -lean_inc(x_318); -lean_dec(x_294); -x_319 = lean_ctor_get(x_295, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_295, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_295, 3); -lean_inc(x_321); -x_322 = lean_ctor_get(x_295, 4); -lean_inc(x_322); -x_323 = lean_ctor_get(x_295, 5); +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); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - lean_ctor_release(x_295, 2); - lean_ctor_release(x_295, 3); - lean_ctor_release(x_295, 4); - lean_ctor_release(x_295, 5); - x_324 = x_295; -} else { - lean_dec_ref(x_295); - x_324 = lean_box(0); -} -x_325 = lean_ctor_get(x_296, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_296, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_296, 3); -lean_inc(x_327); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_328 = x_296; -} else { - lean_dec_ref(x_296); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 4, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_325); -lean_ctor_set(x_329, 1, x_326); -lean_ctor_set(x_329, 2, x_288); -lean_ctor_set(x_329, 3, x_327); -if (lean_is_scalar(x_324)) { - x_330 = lean_alloc_ctor(0, 6, 0); -} else { - x_330 = x_324; -} -lean_ctor_set(x_330, 0, x_319); -lean_ctor_set(x_330, 1, x_320); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_321); -lean_ctor_set(x_330, 4, x_322); -lean_ctor_set(x_330, 5, x_323); -x_331 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_331, 0, x_318); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} -} -else -{ -lean_object* x_332; lean_object* x_333; uint8_t x_334; -x_332 = lean_ctor_get(x_294, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_332, 2); -lean_inc(x_333); -x_334 = !lean_is_exclusive(x_294); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_294, 1); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_332); -if (x_336 == 0) -{ -lean_object* x_337; uint8_t x_338; -x_337 = lean_ctor_get(x_332, 2); -lean_dec(x_337); -x_338 = !lean_is_exclusive(x_333); -if (x_338 == 0) -{ -lean_object* x_339; -x_339 = lean_ctor_get(x_333, 2); -lean_dec(x_339); -lean_ctor_set(x_333, 2, x_288); -return x_294; -} -else -{ -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_340 = lean_ctor_get(x_333, 0); -x_341 = lean_ctor_get(x_333, 1); -x_342 = lean_ctor_get(x_333, 3); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_333); -x_343 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_343, 0, x_340); -lean_ctor_set(x_343, 1, x_341); -lean_ctor_set(x_343, 2, x_288); -lean_ctor_set(x_343, 3, x_342); -lean_ctor_set(x_332, 2, x_343); -return x_294; -} -} -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; -x_344 = lean_ctor_get(x_332, 0); -x_345 = lean_ctor_get(x_332, 1); -x_346 = lean_ctor_get(x_332, 3); -x_347 = lean_ctor_get(x_332, 4); -x_348 = lean_ctor_get(x_332, 5); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_dec(x_332); -x_349 = lean_ctor_get(x_333, 0); -lean_inc(x_349); -x_350 = lean_ctor_get(x_333, 1); -lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 3); -lean_inc(x_351); -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); - x_352 = x_333; -} else { - lean_dec_ref(x_333); - x_352 = lean_box(0); -} -if (lean_is_scalar(x_352)) { - x_353 = lean_alloc_ctor(0, 4, 0); -} else { - x_353 = x_352; -} -lean_ctor_set(x_353, 0, x_349); -lean_ctor_set(x_353, 1, x_350); -lean_ctor_set(x_353, 2, x_288); -lean_ctor_set(x_353, 3, x_351); -x_354 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_354, 0, x_344); -lean_ctor_set(x_354, 1, x_345); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_346); -lean_ctor_set(x_354, 4, x_347); -lean_ctor_set(x_354, 5, x_348); -lean_ctor_set(x_294, 1, x_354); -return x_294; -} -} -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; -x_355 = lean_ctor_get(x_294, 0); -lean_inc(x_355); -lean_dec(x_294); -x_356 = lean_ctor_get(x_332, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_332, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_332, 3); -lean_inc(x_358); -x_359 = lean_ctor_get(x_332, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_332, 5); -lean_inc(x_360); -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); - lean_ctor_release(x_332, 5); - x_361 = x_332; -} else { - lean_dec_ref(x_332); - x_361 = lean_box(0); -} -x_362 = lean_ctor_get(x_333, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_333, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_333, 3); -lean_inc(x_364); -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); - x_365 = x_333; -} else { - lean_dec_ref(x_333); - x_365 = lean_box(0); -} -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 4, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_362); -lean_ctor_set(x_366, 1, x_363); -lean_ctor_set(x_366, 2, x_288); -lean_ctor_set(x_366, 3, x_364); -if (lean_is_scalar(x_361)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_361; -} -lean_ctor_set(x_367, 0, x_356); -lean_ctor_set(x_367, 1, x_357); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_358); -lean_ctor_set(x_367, 4, x_359); -lean_ctor_set(x_367, 5, x_360); -x_368 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_368, 0, x_355); -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; -x_369 = lean_ctor_get(x_8, 0); -x_370 = lean_ctor_get(x_8, 1); -x_371 = lean_ctor_get(x_8, 2); -x_372 = lean_ctor_get(x_8, 3); -x_373 = lean_ctor_get(x_8, 4); -lean_inc(x_373); -lean_inc(x_372); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); +lean_inc(x_322); +lean_inc(x_321); +lean_inc(x_320); +lean_inc(x_319); lean_dec(x_8); -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_282); -lean_ctor_set(x_374, 1, x_24); -x_375 = lean_array_push(x_371, x_374); -x_376 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_376, 0, x_369); -lean_ctor_set(x_376, 1, x_370); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_372); -lean_ctor_set(x_376, 4, x_373); -x_377 = 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_284, x_376, x_281); -if (lean_obj_tag(x_377) == 0) +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_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_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; -x_378 = lean_ctor_get(x_377, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_378, 2); -lean_inc(x_379); -x_380 = lean_ctor_get(x_377, 0); -lean_inc(x_380); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_381 = x_377; -} else { - lean_dec_ref(x_377); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 4); -lean_inc(x_385); -x_386 = lean_ctor_get(x_378, 5); -lean_inc(x_386); -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); - lean_ctor_release(x_378, 4); - lean_ctor_release(x_378, 5); - x_387 = x_378; -} else { - lean_dec_ref(x_378); - x_387 = lean_box(0); -} -x_388 = lean_ctor_get(x_379, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_379, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_379, 3); -lean_inc(x_390); -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_391 = x_379; -} else { - lean_dec_ref(x_379); - x_391 = lean_box(0); -} -if (lean_is_scalar(x_391)) { - x_392 = lean_alloc_ctor(0, 4, 0); -} else { - x_392 = x_391; -} -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_288); -lean_ctor_set(x_392, 3, x_390); -if (lean_is_scalar(x_387)) { - x_393 = lean_alloc_ctor(0, 6, 0); -} else { - x_393 = x_387; -} -lean_ctor_set(x_393, 0, x_382); -lean_ctor_set(x_393, 1, x_383); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_384); -lean_ctor_set(x_393, 4, x_385); -lean_ctor_set(x_393, 5, x_386); -if (lean_is_scalar(x_381)) { - x_394 = lean_alloc_ctor(0, 2, 0); -} else { - x_394 = x_381; -} -lean_ctor_set(x_394, 0, x_380); -lean_ctor_set(x_394, 1, x_393); -return x_394; +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_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_409; lean_object* x_410; lean_object* x_411; -x_395 = lean_ctor_get(x_377, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_377, 0); -lean_inc(x_397); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_398 = x_377; -} else { - lean_dec_ref(x_377); - x_398 = lean_box(0); +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; } -x_399 = lean_ctor_get(x_395, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_395, 5); -lean_inc(x_403); -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_404 = x_395; -} else { - lean_dec_ref(x_395); - x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_396, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_396, 3); -lean_inc(x_407); -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_408 = x_396; +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); +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 { - lean_dec_ref(x_396); - x_408 = lean_box(0); + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); } -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); +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; +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_409 = x_408; + x_269 = x_248; + lean_ctor_set_tag(x_269, 1); } -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_288); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_269, 0, x_259); +lean_ctor_set(x_269, 1, x_257); +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; 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_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 { - x_410 = x_404; + lean_dec_ref(x_258); + x_278 = lean_box(0); } -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_398)) { - x_411 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_278)) { + x_279 = lean_alloc_ctor(0, 4, 0); } else { - x_411 = x_398; + x_279 = x_278; +} +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, 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); +} else { + x_281 = x_248; + lean_ctor_set_tag(x_281, 1); +} +lean_ctor_set(x_281, 0, x_259); +lean_ctor_set(x_281, 1, x_280); +return x_281; +} +} +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_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_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); +} else { + x_293 = x_248; +} +lean_ctor_set(x_293, 0, x_283); +lean_ctor_set(x_293, 1, x_257); +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_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); +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; +} else { + lean_dec_ref(x_282); + x_302 = lean_box(0); +} +if (lean_is_scalar(x_302)) { + x_303 = lean_alloc_ctor(0, 4, 0); +} else { + x_303 = x_302; +} +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); +} else { + x_305 = x_248; +} +lean_ctor_set(x_305, 0, x_283); +lean_ctor_set(x_305, 1, x_304); +return x_305; } -lean_ctor_set(x_411, 0, x_397); -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; lean_object* x_427; -x_412 = lean_ctor_get(x_286, 0); -x_413 = lean_ctor_get(x_286, 1); -x_414 = lean_ctor_get(x_286, 2); -x_415 = lean_ctor_get(x_286, 3); -lean_inc(x_415); -lean_inc(x_414); -lean_inc(x_413); -lean_inc(x_412); -lean_dec(x_286); -x_416 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_417 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_417, 0, x_412); -lean_ctor_set(x_417, 1, x_413); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_415); -lean_ctor_set(x_281, 2, x_417); -x_418 = lean_ctor_get(x_8, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_8, 1); -lean_inc(x_419); -x_420 = lean_ctor_get(x_8, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_8, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_8, 4); -lean_inc(x_422); +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); 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_423 = x_8; + x_378 = x_8; } else { lean_dec_ref(x_8); - x_423 = lean_box(0); + x_378 = lean_box(0); } -x_424 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_424, 0, x_282); -lean_ctor_set(x_424, 1, x_24); -x_425 = lean_array_push(x_420, x_424); -if (lean_is_scalar(x_423)) { - x_426 = lean_alloc_ctor(0, 5, 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); } else { - x_426 = x_423; + x_381 = x_378; } -lean_ctor_set(x_426, 0, x_418); -lean_ctor_set(x_426, 1, x_419); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_421); -lean_ctor_set(x_426, 4, x_422); -x_427 = 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_284, x_426, x_281); -if (lean_obj_tag(x_427) == 0) +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_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_428 = lean_ctor_get(x_427, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_428, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_427, 0); -lean_inc(x_430); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_431 = x_427; -} else { - lean_dec_ref(x_427); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_428, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_428, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_428, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_428, 4); -lean_inc(x_435); -x_436 = lean_ctor_get(x_428, 5); -lean_inc(x_436); -if (lean_is_exclusive(x_428)) { - lean_ctor_release(x_428, 0); - lean_ctor_release(x_428, 1); - lean_ctor_release(x_428, 2); - lean_ctor_release(x_428, 3); - lean_ctor_release(x_428, 4); - lean_ctor_release(x_428, 5); - x_437 = x_428; -} else { - lean_dec_ref(x_428); - x_437 = lean_box(0); -} -x_438 = lean_ctor_get(x_429, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_429, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_429, 3); -lean_inc(x_440); -if (lean_is_exclusive(x_429)) { - lean_ctor_release(x_429, 0); - lean_ctor_release(x_429, 1); - lean_ctor_release(x_429, 2); - lean_ctor_release(x_429, 3); - x_441 = x_429; -} else { - lean_dec_ref(x_429); - x_441 = lean_box(0); -} -if (lean_is_scalar(x_441)) { - x_442 = lean_alloc_ctor(0, 4, 0); -} else { - x_442 = x_441; -} -lean_ctor_set(x_442, 0, x_438); -lean_ctor_set(x_442, 1, x_439); -lean_ctor_set(x_442, 2, x_414); -lean_ctor_set(x_442, 3, x_440); -if (lean_is_scalar(x_437)) { - x_443 = lean_alloc_ctor(0, 6, 0); -} else { - x_443 = x_437; -} -lean_ctor_set(x_443, 0, x_432); -lean_ctor_set(x_443, 1, x_433); -lean_ctor_set(x_443, 2, x_442); -lean_ctor_set(x_443, 3, x_434); -lean_ctor_set(x_443, 4, x_435); -lean_ctor_set(x_443, 5, x_436); -if (lean_is_scalar(x_431)) { - x_444 = lean_alloc_ctor(0, 2, 0); -} else { - x_444 = x_431; -} -lean_ctor_set(x_444, 0, x_430); -lean_ctor_set(x_444, 1, x_443); -return x_444; +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; } else { -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_445 = lean_ctor_get(x_427, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_445, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_427, 0); -lean_inc(x_447); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_448 = x_427; -} else { - lean_dec_ref(x_427); - x_448 = lean_box(0); +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; } +block_370: +{ +if (lean_obj_tag(x_338) == 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_inc(x_355); +x_356 = lean_ctor_get(x_338, 0); +lean_inc(x_356); +lean_dec(x_338); +x_357 = lean_ctor_get(x_339, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_339, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_339, 3); +lean_inc(x_359); +x_360 = lean_ctor_get(x_339, 4); +lean_inc(x_360); +x_361 = lean_ctor_get(x_339, 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; +} else { + lean_dec_ref(x_339); + x_362 = lean_box(0); +} +x_363 = lean_ctor_get(x_355, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_355, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_355, 3); +lean_inc(x_365); +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; +} else { + lean_dec_ref(x_355); + x_366 = lean_box(0); +} +if (lean_is_scalar(x_366)) { + x_367 = lean_alloc_ctor(0, 4, 0); +} else { + x_367 = x_366; +} +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); +if (lean_is_scalar(x_362)) { + x_368 = lean_alloc_ctor(0, 6, 0); +} else { + x_368 = 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); +} else { + x_369 = x_248; +} +lean_ctor_set(x_369, 0, x_356); +lean_ctor_set(x_369, 1, x_368); +return x_369; +} +} +} +} +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; +} else { + lean_dec_ref(x_389); + x_399 = 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); +} else { + x_434 = x_399; +} +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); +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; +} else { + lean_dec_ref(x_8); + x_441 = 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); +} else { + x_444 = x_441; +} +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_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; +} +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); -x_451 = lean_ctor_get(x_445, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_445, 4); -lean_inc(x_452); -x_453 = lean_ctor_get(x_445, 5); -lean_inc(x_453); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - lean_ctor_release(x_445, 2); - lean_ctor_release(x_445, 3); - lean_ctor_release(x_445, 4); - lean_ctor_release(x_445, 5); - x_454 = x_445; +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; +} +block_432: +{ +if (lean_obj_tag(x_400) == 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_445); - x_454 = lean_box(0); + lean_dec_ref(x_401); + x_409 = lean_box(0); } -x_455 = lean_ctor_get(x_446, 0); -lean_inc(x_455); -x_456 = lean_ctor_get(x_446, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_446, 3); -lean_inc(x_457); -if (lean_is_exclusive(x_446)) { - lean_ctor_release(x_446, 0); - lean_ctor_release(x_446, 1); - lean_ctor_release(x_446, 2); - lean_ctor_release(x_446, 3); - x_458 = x_446; +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_446); - x_458 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_413)) { + x_414 = lean_alloc_ctor(0, 4, 0); } else { - x_459 = x_458; + x_414 = x_413; } -lean_ctor_set(x_459, 0, x_455); -lean_ctor_set(x_459, 1, x_456); -lean_ctor_set(x_459, 2, x_414); -lean_ctor_set(x_459, 3, x_457); -if (lean_is_scalar(x_454)) { - x_460 = lean_alloc_ctor(0, 6, 0); +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_460 = x_454; + x_415 = x_409; } -lean_ctor_set(x_460, 0, x_449); -lean_ctor_set(x_460, 1, x_450); -lean_ctor_set(x_460, 2, x_459); -lean_ctor_set(x_460, 3, x_451); -lean_ctor_set(x_460, 4, x_452); -lean_ctor_set(x_460, 5, x_453); -if (lean_is_scalar(x_448)) { - x_461 = lean_alloc_ctor(1, 2, 0); +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_461 = x_448; -} -lean_ctor_set(x_461, 0, x_447); -lean_ctor_set(x_461, 1, x_460); -return x_461; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_462 = lean_ctor_get(x_281, 2); -x_463 = lean_ctor_get(x_281, 0); -x_464 = lean_ctor_get(x_281, 1); -x_465 = lean_ctor_get(x_281, 3); -x_466 = lean_ctor_get(x_281, 4); -x_467 = lean_ctor_get(x_281, 5); -lean_inc(x_467); -lean_inc(x_466); -lean_inc(x_465); -lean_inc(x_462); -lean_inc(x_464); -lean_inc(x_463); -lean_dec(x_281); -x_468 = lean_ctor_get(x_462, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_462, 1); -lean_inc(x_469); -x_470 = lean_ctor_get(x_462, 2); -lean_inc(x_470); -x_471 = lean_ctor_get(x_462, 3); -lean_inc(x_471); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - lean_ctor_release(x_462, 2); - lean_ctor_release(x_462, 3); - x_472 = x_462; +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_inc(x_420); +x_421 = lean_ctor_get(x_401, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_401, 4); +lean_inc(x_422); +x_423 = lean_ctor_get(x_401, 5); +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_462); - x_472 = lean_box(0); + lean_dec_ref(x_401); + x_424 = lean_box(0); } -x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_472)) { - x_474 = 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); +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; } else { - x_474 = x_472; + lean_dec_ref(x_417); + x_428 = lean_box(0); } -lean_ctor_set(x_474, 0, x_468); -lean_ctor_set(x_474, 1, x_469); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_471); -x_475 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_475, 0, x_463); -lean_ctor_set(x_475, 1, x_464); -lean_ctor_set(x_475, 2, x_474); -lean_ctor_set(x_475, 3, x_465); -lean_ctor_set(x_475, 4, x_466); -lean_ctor_set(x_475, 5, x_467); -x_476 = lean_ctor_get(x_8, 0); -lean_inc(x_476); -x_477 = lean_ctor_get(x_8, 1); -lean_inc(x_477); -x_478 = lean_ctor_get(x_8, 2); -lean_inc(x_478); -x_479 = lean_ctor_get(x_8, 3); -lean_inc(x_479); -x_480 = lean_ctor_get(x_8, 4); -lean_inc(x_480); -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_481 = x_8; +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_8); - x_481 = lean_box(0); + x_429 = x_428; } -x_482 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_482, 0, x_282); -lean_ctor_set(x_482, 1, x_24); -x_483 = lean_array_push(x_478, x_482); -if (lean_is_scalar(x_481)) { - x_484 = lean_alloc_ctor(0, 5, 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); } else { - x_484 = x_481; + x_430 = x_424; } -lean_ctor_set(x_484, 0, x_476); -lean_ctor_set(x_484, 1, x_477); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_479); -lean_ctor_set(x_484, 4, x_480); -x_485 = 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_284, x_484, x_475); -if (lean_obj_tag(x_485) == 0) -{ -lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_486 = lean_ctor_get(x_485, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_486, 2); -lean_inc(x_487); -x_488 = lean_ctor_get(x_485, 0); -lean_inc(x_488); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_489 = x_485; +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); } else { - lean_dec_ref(x_485); - x_489 = lean_box(0); + x_431 = x_248; } -x_490 = lean_ctor_get(x_486, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_486, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_486, 3); -lean_inc(x_492); -x_493 = lean_ctor_get(x_486, 4); -lean_inc(x_493); -x_494 = lean_ctor_get(x_486, 5); -lean_inc(x_494); -if (lean_is_exclusive(x_486)) { - lean_ctor_release(x_486, 0); - lean_ctor_release(x_486, 1); - lean_ctor_release(x_486, 2); - lean_ctor_release(x_486, 3); - lean_ctor_release(x_486, 4); - lean_ctor_release(x_486, 5); - x_495 = x_486; -} else { - lean_dec_ref(x_486); - x_495 = lean_box(0); +lean_ctor_set(x_431, 0, x_418); +lean_ctor_set(x_431, 1, x_430); +return x_431; } -x_496 = lean_ctor_get(x_487, 0); -lean_inc(x_496); -x_497 = lean_ctor_get(x_487, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_487, 3); -lean_inc(x_498); -if (lean_is_exclusive(x_487)) { - lean_ctor_release(x_487, 0); - lean_ctor_release(x_487, 1); - lean_ctor_release(x_487, 2); - lean_ctor_release(x_487, 3); - x_499 = x_487; -} else { - lean_dec_ref(x_487); - x_499 = lean_box(0); -} -if (lean_is_scalar(x_499)) { - x_500 = lean_alloc_ctor(0, 4, 0); -} else { - x_500 = x_499; -} -lean_ctor_set(x_500, 0, x_496); -lean_ctor_set(x_500, 1, x_497); -lean_ctor_set(x_500, 2, x_470); -lean_ctor_set(x_500, 3, x_498); -if (lean_is_scalar(x_495)) { - x_501 = lean_alloc_ctor(0, 6, 0); -} else { - x_501 = x_495; -} -lean_ctor_set(x_501, 0, x_490); -lean_ctor_set(x_501, 1, x_491); -lean_ctor_set(x_501, 2, x_500); -lean_ctor_set(x_501, 3, x_492); -lean_ctor_set(x_501, 4, x_493); -lean_ctor_set(x_501, 5, x_494); -if (lean_is_scalar(x_489)) { - x_502 = lean_alloc_ctor(0, 2, 0); -} else { - x_502 = x_489; -} -lean_ctor_set(x_502, 0, x_488); -lean_ctor_set(x_502, 1, x_501); -return x_502; -} -else -{ -lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_503 = lean_ctor_get(x_485, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_503, 2); -lean_inc(x_504); -x_505 = lean_ctor_get(x_485, 0); -lean_inc(x_505); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_506 = x_485; -} else { - lean_dec_ref(x_485); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_503, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_503, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_503, 3); -lean_inc(x_509); -x_510 = lean_ctor_get(x_503, 4); -lean_inc(x_510); -x_511 = lean_ctor_get(x_503, 5); -lean_inc(x_511); -if (lean_is_exclusive(x_503)) { - lean_ctor_release(x_503, 0); - lean_ctor_release(x_503, 1); - lean_ctor_release(x_503, 2); - lean_ctor_release(x_503, 3); - lean_ctor_release(x_503, 4); - lean_ctor_release(x_503, 5); - x_512 = x_503; -} else { - lean_dec_ref(x_503); - x_512 = lean_box(0); -} -x_513 = lean_ctor_get(x_504, 0); -lean_inc(x_513); -x_514 = lean_ctor_get(x_504, 1); -lean_inc(x_514); -x_515 = lean_ctor_get(x_504, 3); -lean_inc(x_515); -if (lean_is_exclusive(x_504)) { - lean_ctor_release(x_504, 0); - lean_ctor_release(x_504, 1); - lean_ctor_release(x_504, 2); - lean_ctor_release(x_504, 3); - x_516 = x_504; -} else { - lean_dec_ref(x_504); - x_516 = lean_box(0); -} -if (lean_is_scalar(x_516)) { - x_517 = lean_alloc_ctor(0, 4, 0); -} else { - x_517 = x_516; -} -lean_ctor_set(x_517, 0, x_513); -lean_ctor_set(x_517, 1, x_514); -lean_ctor_set(x_517, 2, x_470); -lean_ctor_set(x_517, 3, x_515); -if (lean_is_scalar(x_512)) { - x_518 = lean_alloc_ctor(0, 6, 0); -} else { - x_518 = x_512; -} -lean_ctor_set(x_518, 0, x_507); -lean_ctor_set(x_518, 1, x_508); -lean_ctor_set(x_518, 2, x_517); -lean_ctor_set(x_518, 3, x_509); -lean_ctor_set(x_518, 4, x_510); -lean_ctor_set(x_518, 5, x_511); -if (lean_is_scalar(x_506)) { - x_519 = lean_alloc_ctor(1, 2, 0); -} else { - x_519 = x_506; -} -lean_ctor_set(x_519, 0, x_505); -lean_ctor_set(x_519, 1, x_518); -return x_519; } } } } else { -uint8_t x_520; +uint8_t x_452; 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_520 = !lean_is_exclusive(x_275); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_241); +if (x_452 == 0) { -return x_275; +return x_241; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_275, 0); -x_522 = lean_ctor_get(x_275, 1); -lean_inc(x_522); -lean_inc(x_521); -lean_dec(x_275); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } @@ -12503,7 +11779,7 @@ return x_523; } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -12511,52 +11787,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_29); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_29); +if (x_456 == 0) { return x_29; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_29, 0); -x_526 = lean_ctor_get(x_29, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_29); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } else { -uint8_t x_528; +uint8_t x_460; 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_528 = !lean_is_exclusive(x_25); -if (x_528 == 0) +x_460 = !lean_is_exclusive(x_25); +if (x_460 == 0) { return x_25; } else { -lean_object* x_529; lean_object* x_530; lean_object* x_531; -x_529 = lean_ctor_get(x_25, 0); -x_530 = lean_ctor_get(x_25, 1); -lean_inc(x_530); -lean_inc(x_529); +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_dec(x_25); -x_531 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_531, 0, x_529); -lean_ctor_set(x_531, 1, x_530); -return x_531; +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; } } } @@ -12725,2130 +12001,1768 @@ goto _start; } case 1: { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_dec(x_26); x_33 = lean_ctor_get(x_27, 1); lean_inc(x_33); -lean_dec(x_27); -x_34 = lean_ctor_get(x_28, 0); -lean_inc(x_34); +if (lean_is_exclusive(x_27)) { + lean_ctor_release(x_27, 0); + lean_ctor_release(x_27, 1); + x_34 = x_27; +} else { + lean_dec_ref(x_27); + x_34 = lean_box(0); +} +x_35 = lean_ctor_get(x_28, 0); +lean_inc(x_35); lean_dec(x_28); -x_35 = lean_unsigned_to_nat(1u); -x_36 = lean_nat_add(x_12, x_35); +x_36 = lean_unsigned_to_nat(1u); +x_37 = lean_nat_add(x_12, x_36); lean_dec(x_12); -x_37 = !lean_is_exclusive(x_33); -if (x_37 == 0) +x_38 = !lean_is_exclusive(x_33); +if (x_38 == 0) { -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_33, 2); -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_33, 2); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) { -lean_object* x_40; lean_object* x_41; uint8_t x_42; -x_40 = lean_ctor_get(x_38, 2); -x_41 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_38, 2, x_41); -x_42 = !lean_is_exclusive(x_13); -if (x_42 == 0) +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_93; uint8_t x_94; +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) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_13, 2); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_34); -lean_ctor_set(x_44, 1, x_22); -x_45 = lean_array_push(x_43, x_44); -lean_ctor_set(x_13, 2, x_45); -x_46 = 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_36, x_13, x_33); -if (lean_obj_tag(x_46) == 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_47; lean_object* x_48; uint8_t x_49; -x_47 = lean_ctor_get(x_46, 1); -lean_inc(x_47); -x_48 = lean_ctor_get(x_47, 2); -lean_inc(x_48); -x_49 = !lean_is_exclusive(x_46); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_46, 1); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_47); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_47, 2); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_48); -if (x_53 == 0) -{ -lean_object* x_54; -x_54 = lean_ctor_get(x_48, 2); -lean_dec(x_54); -lean_ctor_set(x_48, 2, x_40); -return x_46; +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_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = lean_ctor_get(x_48, 0); -x_56 = lean_ctor_get(x_48, 1); -x_57 = lean_ctor_get(x_48, 3); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_48); -x_58 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_40); -lean_ctor_set(x_58, 3, x_57); -lean_ctor_set(x_47, 2, x_58); -return x_46; +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_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; } } 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; -x_59 = lean_ctor_get(x_47, 0); -x_60 = lean_ctor_get(x_47, 1); -x_61 = lean_ctor_get(x_47, 3); -x_62 = lean_ctor_get(x_47, 4); -x_63 = lean_ctor_get(x_47, 5); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); +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_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; +} +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_42 = x_119; +x_43 = x_118; +goto block_92; +} +} +block_92: +{ +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_44; lean_object* x_45; uint8_t x_46; +x_44 = lean_ctor_get(x_43, 2); +lean_inc(x_44); +x_45 = lean_ctor_get(x_42, 0); +lean_inc(x_45); +lean_dec(x_42); +x_46 = !lean_is_exclusive(x_43); +if (x_46 == 0) +{ +lean_object* x_47; uint8_t x_48; +x_47 = lean_ctor_get(x_43, 2); +lean_dec(x_47); +x_48 = !lean_is_exclusive(x_44); +if (x_48 == 0) +{ +lean_object* x_49; lean_object* x_50; +x_49 = lean_ctor_get(x_44, 2); +lean_dec(x_49); +lean_ctor_set(x_44, 2, x_41); +if (lean_is_scalar(x_34)) { + x_50 = lean_alloc_ctor(1, 2, 0); +} else { + x_50 = x_34; + lean_ctor_set_tag(x_50, 1); +} +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_43); +return x_50; +} +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_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); +if (lean_is_scalar(x_34)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_34; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_45); +lean_ctor_set(x_55, 1, x_43); +return x_55; +} +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; 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_inc(x_60); lean_inc(x_59); -lean_dec(x_47); -x_64 = lean_ctor_get(x_48, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_48, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_48, 3); -lean_inc(x_66); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_67 = x_48; +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); +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; } else { - lean_dec_ref(x_48); - x_67 = lean_box(0); + lean_dec_ref(x_44); + x_64 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_65 = x_64; } -lean_ctor_set(x_68, 0, x_64); -lean_ctor_set(x_68, 1, x_65); -lean_ctor_set(x_68, 2, x_40); -lean_ctor_set(x_68, 3, x_66); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_59); -lean_ctor_set(x_69, 1, x_60); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_61); -lean_ctor_set(x_69, 4, x_62); -lean_ctor_set(x_69, 5, x_63); -lean_ctor_set(x_46, 1, x_69); -return x_46; +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); +if (lean_is_scalar(x_34)) { + x_67 = lean_alloc_ctor(1, 2, 0); +} else { + x_67 = x_34; + lean_ctor_set_tag(x_67, 1); +} +lean_ctor_set(x_67, 0, x_45); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } 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; lean_object* x_82; lean_object* x_83; -x_70 = lean_ctor_get(x_46, 0); -lean_inc(x_70); -lean_dec(x_46); -x_71 = lean_ctor_get(x_47, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_47, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_47, 3); -lean_inc(x_73); -x_74 = lean_ctor_get(x_47, 4); -lean_inc(x_74); -x_75 = lean_ctor_get(x_47, 5); -lean_inc(x_75); -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); - lean_ctor_release(x_47, 5); - x_76 = x_47; +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_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); +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_41); +if (lean_is_scalar(x_34)) { + x_74 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_47); - x_76 = lean_box(0); + x_74 = x_34; } -x_77 = lean_ctor_get(x_48, 0); +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_43); +return x_74; +} +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_inc(x_77); -x_78 = lean_ctor_get(x_48, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_48, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_80 = x_48; +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); +if (lean_is_scalar(x_34)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_48); - x_80 = lean_box(0); + x_79 = x_34; } -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_40); -lean_ctor_set(x_81, 3, x_79); -if (lean_is_scalar(x_76)) { - x_82 = lean_alloc_ctor(0, 6, 0); -} else { - x_82 = x_76; -} -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); -x_83 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_83, 0, x_70); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_79, 0, x_69); +lean_ctor_set(x_79, 1, x_43); +return x_79; } } else { -lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_84 = lean_ctor_get(x_46, 1); +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_inc(x_84); -x_85 = lean_ctor_get(x_84, 2); +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_is_exclusive(x_46); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_46, 1); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_84); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_84, 2); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_85); -if (x_90 == 0) -{ -lean_object* x_91; -x_91 = lean_ctor_get(x_85, 2); -lean_dec(x_91); -lean_ctor_set(x_85, 2, x_40); -return x_46; -} -else -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_85, 0); -x_93 = lean_ctor_get(x_85, 1); -x_94 = lean_ctor_get(x_85, 3); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_85); -x_95 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_95, 0, x_92); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_95, 2, x_40); -lean_ctor_set(x_95, 3, x_94); -lean_ctor_set(x_84, 2, x_95); -return x_46; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_96 = lean_ctor_get(x_84, 0); -x_97 = lean_ctor_get(x_84, 1); -x_98 = lean_ctor_get(x_84, 3); -x_99 = lean_ctor_get(x_84, 4); -x_100 = lean_ctor_get(x_84, 5); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_84); -x_101 = lean_ctor_get(x_85, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_85, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_85, 3); -lean_inc(x_103); -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_104 = 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; } else { - lean_dec_ref(x_85); - x_104 = lean_box(0); + lean_dec_ref(x_68); + x_88 = lean_box(0); } -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_104; + x_89 = x_88; } -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_40); -lean_ctor_set(x_105, 3, x_103); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_96); -lean_ctor_set(x_106, 1, x_97); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_98); -lean_ctor_set(x_106, 4, x_99); -lean_ctor_set(x_106, 5, x_100); -lean_ctor_set(x_46, 1, x_106); -return x_46; -} -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_107 = lean_ctor_get(x_46, 0); -lean_inc(x_107); -lean_dec(x_46); -x_108 = lean_ctor_get(x_84, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_84, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_84, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_84, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_84, 5); -lean_inc(x_112); -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_113 = x_84; +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); +if (lean_is_scalar(x_34)) { + x_91 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + x_91 = x_34; } -x_114 = lean_ctor_get(x_85, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_85, 1); -lean_inc(x_115); -x_116 = lean_ctor_get(x_85, 3); -lean_inc(x_116); -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_117 = x_85; -} else { - lean_dec_ref(x_85); - x_117 = lean_box(0); +lean_ctor_set(x_91, 0, x_69); +lean_ctor_set(x_91, 1, x_90); +return x_91; } -if (lean_is_scalar(x_117)) { - x_118 = lean_alloc_ctor(0, 4, 0); -} else { - x_118 = x_117; -} -lean_ctor_set(x_118, 0, x_114); -lean_ctor_set(x_118, 1, x_115); -lean_ctor_set(x_118, 2, x_40); -lean_ctor_set(x_118, 3, x_116); -if (lean_is_scalar(x_113)) { - x_119 = lean_alloc_ctor(0, 6, 0); -} else { - x_119 = x_113; -} -lean_ctor_set(x_119, 0, x_108); -lean_ctor_set(x_119, 1, x_109); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_110); -lean_ctor_set(x_119, 4, x_111); -lean_ctor_set(x_119, 5, x_112); -x_120 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_120, 0, x_107); -lean_ctor_set(x_120, 1, x_119); -return x_120; } } } 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; -x_121 = lean_ctor_get(x_13, 0); -x_122 = lean_ctor_get(x_13, 1); -x_123 = lean_ctor_get(x_13, 2); -x_124 = lean_ctor_get(x_13, 3); -x_125 = lean_ctor_get(x_13, 4); -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; 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_dec(x_13); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_34); -lean_ctor_set(x_126, 1, x_22); -x_127 = lean_array_push(x_123, x_126); -x_128 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_128, 0, x_121); -lean_ctor_set(x_128, 1, x_122); -lean_ctor_set(x_128, 2, x_127); -lean_ctor_set(x_128, 3, x_124); -lean_ctor_set(x_128, 4, x_125); -x_129 = 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_36, x_128, x_33); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; 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_130 = lean_ctor_get(x_129, 1); -lean_inc(x_130); -x_131 = lean_ctor_get(x_130, 2); -lean_inc(x_131); -x_132 = lean_ctor_get(x_129, 0); -lean_inc(x_132); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_133 = x_129; +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_129); + 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_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_130, 0); +x_134 = lean_ctor_get(x_126, 0); lean_inc(x_134); -x_135 = lean_ctor_get(x_130, 1); +x_135 = lean_ctor_get(x_126, 1); lean_inc(x_135); -x_136 = lean_ctor_get(x_130, 3); +x_136 = lean_ctor_get(x_126, 3); lean_inc(x_136); -x_137 = lean_ctor_get(x_130, 4); -lean_inc(x_137); -x_138 = lean_ctor_get(x_130, 5); -lean_inc(x_138); -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_139 = x_130; +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_130); - x_139 = lean_box(0); + lean_dec_ref(x_126); + x_137 = lean_box(0); } -x_140 = lean_ctor_get(x_131, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_131, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_131, 3); -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); - x_143 = x_131; +if (lean_is_scalar(x_137)) { + x_138 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_131); - x_143 = lean_box(0); + x_138 = x_137; } -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_40); -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); +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_146 = lean_alloc_ctor(0, 2, 0); + x_139 = lean_alloc_ctor(0, 6, 0); } else { - x_146 = x_133; + x_139 = x_133; } -lean_ctor_set(x_146, 0, x_132); -lean_ctor_set(x_146, 1, x_145); -return x_146; +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_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; -x_147 = lean_ctor_get(x_129, 1); +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); -x_148 = lean_ctor_get(x_147, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_129, 0); +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); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_150 = x_129; -} else { - lean_dec_ref(x_129); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_147, 0); +x_150 = lean_ctor_get(x_141, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_141, 3); lean_inc(x_151); -x_152 = lean_ctor_get(x_147, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_147, 3); -lean_inc(x_153); -x_154 = lean_ctor_get(x_147, 4); -lean_inc(x_154); -x_155 = lean_ctor_get(x_147, 5); -lean_inc(x_155); -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; +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_147); - x_156 = lean_box(0); + lean_dec_ref(x_141); + x_152 = lean_box(0); } -x_157 = lean_ctor_get(x_148, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_148, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_148, 3); -lean_inc(x_159); -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); - x_160 = x_148; +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_148); - x_160 = lean_box(0); + x_153 = x_152; } -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(0, 4, 0); +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_161 = x_160; + x_154 = x_148; } -lean_ctor_set(x_161, 0, x_157); -lean_ctor_set(x_161, 1, x_158); -lean_ctor_set(x_161, 2, x_40); -lean_ctor_set(x_161, 3, x_159); -if (lean_is_scalar(x_156)) { - x_162 = lean_alloc_ctor(0, 6, 0); +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_162 = x_156; + x_155 = x_34; } -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(1, 2, 0); -} else { - x_163 = x_150; +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_149); -lean_ctor_set(x_163, 1, x_162); -return x_163; } } } else { -lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_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_38, 0); -x_165 = lean_ctor_get(x_38, 1); -x_166 = lean_ctor_get(x_38, 2); -x_167 = lean_ctor_get(x_38, 3); -lean_inc(x_167); -lean_inc(x_166); -lean_inc(x_165); -lean_inc(x_164); -lean_dec(x_38); -x_168 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_169 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_169, 0, x_164); -lean_ctor_set(x_169, 1, x_165); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_167); -lean_ctor_set(x_33, 2, x_169); -x_170 = lean_ctor_get(x_13, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_13, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_13, 2); -lean_inc(x_172); -x_173 = lean_ctor_get(x_13, 3); -lean_inc(x_173); -x_174 = lean_ctor_get(x_13, 4); -lean_inc(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_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); 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_175 = x_13; + x_227 = x_13; } else { lean_dec_ref(x_13); - x_175 = lean_box(0); + x_227 = lean_box(0); } -x_176 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_176, 0, x_34); -lean_ctor_set(x_176, 1, x_22); -x_177 = lean_array_push(x_172, x_176); -if (lean_is_scalar(x_175)) { - x_178 = lean_alloc_ctor(0, 5, 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_230 = lean_alloc_ctor(0, 5, 0); } else { - x_178 = x_175; + x_230 = x_227; } -lean_ctor_set(x_178, 0, x_170); -lean_ctor_set(x_178, 1, x_171); -lean_ctor_set(x_178, 2, x_177); -lean_ctor_set(x_178, 3, x_173); -lean_ctor_set(x_178, 4, x_174); -x_179 = 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_36, x_178, x_33); -if (lean_obj_tag(x_179) == 0) +lean_ctor_set(x_230, 0, x_222); +lean_ctor_set(x_230, 1, x_223); +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_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; lean_object* x_196; -x_180 = lean_ctor_get(x_179, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_180, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - x_183 = x_179; -} else { - lean_dec_ref(x_179); - x_183 = lean_box(0); -} -x_184 = lean_ctor_get(x_180, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_180, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_180, 3); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 4); -lean_inc(x_187); -x_188 = lean_ctor_get(x_180, 5); -lean_inc(x_188); -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_189 = x_180; -} else { - lean_dec_ref(x_180); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_181, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_181, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_181, 3); -lean_inc(x_192); -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_193 = x_181; -} else { - lean_dec_ref(x_181); - x_193 = lean_box(0); -} -if (lean_is_scalar(x_193)) { - x_194 = lean_alloc_ctor(0, 4, 0); -} else { - x_194 = x_193; -} -lean_ctor_set(x_194, 0, x_190); -lean_ctor_set(x_194, 1, x_191); -lean_ctor_set(x_194, 2, x_166); -lean_ctor_set(x_194, 3, x_192); -if (lean_is_scalar(x_189)) { - x_195 = lean_alloc_ctor(0, 6, 0); -} else { - x_195 = x_189; -} -lean_ctor_set(x_195, 0, x_184); -lean_ctor_set(x_195, 1, x_185); -lean_ctor_set(x_195, 2, x_194); -lean_ctor_set(x_195, 3, x_186); -lean_ctor_set(x_195, 4, x_187); -lean_ctor_set(x_195, 5, x_188); -if (lean_is_scalar(x_183)) { - x_196 = lean_alloc_ctor(0, 2, 0); -} else { - x_196 = x_183; -} -lean_ctor_set(x_196, 0, x_182); -lean_ctor_set(x_196, 1, x_195); -return x_196; +lean_object* x_232; lean_object* x_233; lean_object* x_234; +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_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_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; -x_197 = lean_ctor_get(x_179, 1); +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_231, 0); +lean_inc(x_235); +x_236 = lean_ctor_get(x_231, 1); +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; +} +block_218: +{ +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_197, 2); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 0); -lean_inc(x_199); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - x_200 = 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); + x_199 = x_188; } else { - lean_dec_ref(x_179); - x_200 = lean_box(0); + lean_dec_ref(x_188); + x_199 = lean_box(0); } -x_201 = lean_ctor_get(x_197, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_197, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_197, 3); +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; +} +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_197, 4); +x_204 = lean_ctor_get(x_186, 0); lean_inc(x_204); -x_205 = lean_ctor_get(x_197, 5); +lean_dec(x_186); +x_205 = lean_ctor_get(x_187, 0); lean_inc(x_205); -if (lean_is_exclusive(x_197)) { - lean_ctor_release(x_197, 0); - lean_ctor_release(x_197, 1); - lean_ctor_release(x_197, 2); - lean_ctor_release(x_197, 3); - lean_ctor_release(x_197, 4); - lean_ctor_release(x_197, 5); - x_206 = x_197; -} else { - lean_dec_ref(x_197); - x_206 = lean_box(0); -} -x_207 = lean_ctor_get(x_198, 0); +x_206 = lean_ctor_get(x_187, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 3); lean_inc(x_207); -x_208 = lean_ctor_get(x_198, 1); +x_208 = lean_ctor_get(x_187, 4); lean_inc(x_208); -x_209 = lean_ctor_get(x_198, 3); +x_209 = lean_ctor_get(x_187, 5); lean_inc(x_209); -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); - x_210 = 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); + lean_ctor_release(x_187, 5); + x_210 = x_187; } else { - lean_dec_ref(x_198); + lean_dec_ref(x_187); 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); +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; +} else { + lean_dec_ref(x_203); + x_214 = lean_box(0); +} +if (lean_is_scalar(x_214)) { + x_215 = lean_alloc_ctor(0, 4, 0); +} else { + x_215 = x_214; +} +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_211 = lean_alloc_ctor(0, 4, 0); + x_216 = lean_alloc_ctor(0, 6, 0); } else { - x_211 = x_210; + x_216 = x_210; } -lean_ctor_set(x_211, 0, x_207); -lean_ctor_set(x_211, 1, x_208); -lean_ctor_set(x_211, 2, x_166); -lean_ctor_set(x_211, 3, x_209); -if (lean_is_scalar(x_206)) { - x_212 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_34)) { + x_217 = lean_alloc_ctor(0, 2, 0); } else { - x_212 = x_206; + x_217 = x_34; } -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); -if (lean_is_scalar(x_200)) { - x_213 = lean_alloc_ctor(1, 2, 0); -} else { - x_213 = x_200; +lean_ctor_set(x_217, 0, x_204); +lean_ctor_set(x_217, 1, x_216); +return x_217; } -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; 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_214 = lean_ctor_get(x_33, 2); -x_215 = lean_ctor_get(x_33, 0); -x_216 = lean_ctor_get(x_33, 1); -x_217 = lean_ctor_get(x_33, 3); -x_218 = lean_ctor_get(x_33, 4); -x_219 = lean_ctor_get(x_33, 5); -lean_inc(x_219); -lean_inc(x_218); -lean_inc(x_217); -lean_inc(x_214); -lean_inc(x_216); -lean_inc(x_215); -lean_dec(x_33); -x_220 = lean_ctor_get(x_214, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_214, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_214, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_214, 3); -lean_inc(x_223); -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); - x_224 = x_214; -} else { - lean_dec_ref(x_214); - x_224 = lean_box(0); -} -x_225 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_224)) { - x_226 = lean_alloc_ctor(0, 4, 0); -} else { - x_226 = x_224; -} -lean_ctor_set(x_226, 0, x_220); -lean_ctor_set(x_226, 1, x_221); -lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_223); -x_227 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_227, 0, x_215); -lean_ctor_set(x_227, 1, x_216); -lean_ctor_set(x_227, 2, x_226); -lean_ctor_set(x_227, 3, x_217); -lean_ctor_set(x_227, 4, x_218); -lean_ctor_set(x_227, 5, x_219); -x_228 = lean_ctor_get(x_13, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_13, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_13, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_13, 3); -lean_inc(x_231); -x_232 = lean_ctor_get(x_13, 4); -lean_inc(x_232); -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_233 = x_13; -} else { - lean_dec_ref(x_13); - x_233 = lean_box(0); -} -x_234 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_234, 0, x_34); -lean_ctor_set(x_234, 1, x_22); -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_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_36, x_236, x_227); -if (lean_obj_tag(x_237) == 0) -{ -lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; -x_238 = lean_ctor_get(x_237, 1); -lean_inc(x_238); -x_239 = lean_ctor_get(x_238, 2); -lean_inc(x_239); -x_240 = lean_ctor_get(x_237, 0); -lean_inc(x_240); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_241 = x_237; -} else { - lean_dec_ref(x_237); - x_241 = lean_box(0); -} -x_242 = lean_ctor_get(x_238, 0); -lean_inc(x_242); -x_243 = lean_ctor_get(x_238, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_238, 3); -lean_inc(x_244); -x_245 = lean_ctor_get(x_238, 4); -lean_inc(x_245); -x_246 = lean_ctor_get(x_238, 5); -lean_inc(x_246); -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); - lean_ctor_release(x_238, 5); - x_247 = x_238; -} else { - lean_dec_ref(x_238); - x_247 = lean_box(0); -} -x_248 = lean_ctor_get(x_239, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_239, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_239, 3); -lean_inc(x_250); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - lean_ctor_release(x_239, 2); - lean_ctor_release(x_239, 3); - x_251 = x_239; -} else { - lean_dec_ref(x_239); - x_251 = lean_box(0); -} -if (lean_is_scalar(x_251)) { - x_252 = lean_alloc_ctor(0, 4, 0); -} else { - x_252 = x_251; -} -lean_ctor_set(x_252, 0, x_248); -lean_ctor_set(x_252, 1, x_249); -lean_ctor_set(x_252, 2, x_222); -lean_ctor_set(x_252, 3, x_250); -if (lean_is_scalar(x_247)) { - x_253 = lean_alloc_ctor(0, 6, 0); -} else { - x_253 = x_247; -} -lean_ctor_set(x_253, 0, x_242); -lean_ctor_set(x_253, 1, x_243); -lean_ctor_set(x_253, 2, x_252); -lean_ctor_set(x_253, 3, x_244); -lean_ctor_set(x_253, 4, x_245); -lean_ctor_set(x_253, 5, x_246); -if (lean_is_scalar(x_241)) { - x_254 = lean_alloc_ctor(0, 2, 0); -} else { - x_254 = x_241; -} -lean_ctor_set(x_254, 0, x_240); -lean_ctor_set(x_254, 1, x_253); -return x_254; -} -else -{ -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; -x_255 = lean_ctor_get(x_237, 1); -lean_inc(x_255); -x_256 = lean_ctor_get(x_255, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_237, 0); -lean_inc(x_257); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_258 = x_237; -} else { - lean_dec_ref(x_237); - x_258 = lean_box(0); -} -x_259 = lean_ctor_get(x_255, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_255, 1); -lean_inc(x_260); -x_261 = lean_ctor_get(x_255, 3); -lean_inc(x_261); -x_262 = lean_ctor_get(x_255, 4); -lean_inc(x_262); -x_263 = lean_ctor_get(x_255, 5); -lean_inc(x_263); -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); - lean_ctor_release(x_255, 4); - lean_ctor_release(x_255, 5); - x_264 = x_255; -} else { - lean_dec_ref(x_255); - x_264 = lean_box(0); -} -x_265 = lean_ctor_get(x_256, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_256, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_256, 3); -lean_inc(x_267); -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_268 = x_256; -} else { - lean_dec_ref(x_256); - 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_ctor_set(x_269, 0, x_265); -lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_222); -lean_ctor_set(x_269, 3, x_267); -if (lean_is_scalar(x_264)) { - x_270 = lean_alloc_ctor(0, 6, 0); -} else { - x_270 = x_264; -} -lean_ctor_set(x_270, 0, x_259); -lean_ctor_set(x_270, 1, x_260); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_261); -lean_ctor_set(x_270, 4, x_262); -lean_ctor_set(x_270, 5, x_263); -if (lean_is_scalar(x_258)) { - x_271 = lean_alloc_ctor(1, 2, 0); -} else { - x_271 = x_258; -} -lean_ctor_set(x_271, 0, x_257); -lean_ctor_set(x_271, 1, x_270); -return x_271; } } } default: { -lean_object* x_272; lean_object* x_273; -x_272 = lean_ctor_get(x_27, 1); -lean_inc(x_272); +lean_object* x_238; lean_object* x_239; +x_238 = lean_ctor_get(x_27, 1); +lean_inc(x_238); lean_dec(x_27); lean_inc(x_13); -x_273 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_272); -if (lean_obj_tag(x_273) == 0) +x_239 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_238); +if (lean_obj_tag(x_239) == 0) { -lean_object* x_274; -x_274 = lean_ctor_get(x_273, 0); -lean_inc(x_274); -if (lean_obj_tag(x_274) == 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_275; lean_object* x_276; lean_object* x_277; +lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_dec(x_22); -x_275 = lean_ctor_get(x_273, 1); -lean_inc(x_275); -lean_dec(x_273); -x_276 = lean_unsigned_to_nat(1u); -x_277 = lean_nat_add(x_12, x_276); +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); lean_dec(x_12); -x_12 = x_277; -x_14 = x_275; +x_12 = x_243; +x_14 = x_241; goto _start; } else { -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_279 = lean_ctor_get(x_273, 1); -lean_inc(x_279); -lean_dec(x_273); -x_280 = lean_ctor_get(x_274, 0); -lean_inc(x_280); -lean_dec(x_274); -x_281 = lean_unsigned_to_nat(1u); -x_282 = lean_nat_add(x_12, x_281); +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; +} else { + lean_dec_ref(x_239); + x_246 = 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_283 = !lean_is_exclusive(x_279); -if (x_283 == 0) +x_250 = !lean_is_exclusive(x_245); +if (x_250 == 0) { -lean_object* x_284; uint8_t x_285; -x_284 = lean_ctor_get(x_279, 2); -x_285 = !lean_is_exclusive(x_284); -if (x_285 == 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_286; lean_object* x_287; uint8_t x_288; -x_286 = lean_ctor_get(x_284, 2); -x_287 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_284, 2, x_287); -x_288 = !lean_is_exclusive(x_13); -if (x_288 == 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_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; -x_289 = lean_ctor_get(x_13, 2); -x_290 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_290, 0, x_280); -lean_ctor_set(x_290, 1, x_22); -x_291 = lean_array_push(x_289, x_290); -lean_ctor_set(x_13, 2, x_291); -x_292 = 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_282, x_13, x_279); -if (lean_obj_tag(x_292) == 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_293; lean_object* x_294; uint8_t x_295; -x_293 = lean_ctor_get(x_292, 1); -lean_inc(x_293); -x_294 = lean_ctor_get(x_293, 2); -lean_inc(x_294); -x_295 = !lean_is_exclusive(x_292); -if (x_295 == 0) -{ -lean_object* x_296; uint8_t x_297; -x_296 = lean_ctor_get(x_292, 1); -lean_dec(x_296); -x_297 = !lean_is_exclusive(x_293); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_293, 2); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_294); -if (x_299 == 0) -{ -lean_object* x_300; -x_300 = lean_ctor_get(x_294, 2); -lean_dec(x_300); -lean_ctor_set(x_294, 2, x_286); -return x_292; -} -else -{ -lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_301 = lean_ctor_get(x_294, 0); -x_302 = lean_ctor_get(x_294, 1); -x_303 = lean_ctor_get(x_294, 3); -lean_inc(x_303); -lean_inc(x_302); -lean_inc(x_301); -lean_dec(x_294); -x_304 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_304, 0, x_301); -lean_ctor_set(x_304, 1, x_302); -lean_ctor_set(x_304, 2, x_286); -lean_ctor_set(x_304, 3, x_303); -lean_ctor_set(x_293, 2, x_304); -return x_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; lean_object* x_314; lean_object* x_315; -x_305 = lean_ctor_get(x_293, 0); -x_306 = lean_ctor_get(x_293, 1); -x_307 = lean_ctor_get(x_293, 3); -x_308 = lean_ctor_get(x_293, 4); -x_309 = lean_ctor_get(x_293, 5); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_dec(x_293); -x_310 = lean_ctor_get(x_294, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_294, 1); +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_294, 3); +x_312 = lean_ctor_get(x_310, 1); lean_inc(x_312); -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); - x_313 = x_294; -} else { - lean_dec_ref(x_294); - x_313 = lean_box(0); +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; } -if (lean_is_scalar(x_313)) { - x_314 = lean_alloc_ctor(0, 4, 0); -} else { - x_314 = x_313; -} -lean_ctor_set(x_314, 0, x_310); -lean_ctor_set(x_314, 1, x_311); -lean_ctor_set(x_314, 2, x_286); -lean_ctor_set(x_314, 3, x_312); -x_315 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_315, 0, x_305); -lean_ctor_set(x_315, 1, x_306); -lean_ctor_set(x_315, 2, x_314); -lean_ctor_set(x_315, 3, x_307); -lean_ctor_set(x_315, 4, x_308); -lean_ctor_set(x_315, 5, x_309); -lean_ctor_set(x_292, 1, x_315); -return x_292; +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_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_316 = lean_ctor_get(x_292, 0); -lean_inc(x_316); -lean_dec(x_292); -x_317 = lean_ctor_get(x_293, 0); -lean_inc(x_317); -x_318 = lean_ctor_get(x_293, 1); -lean_inc(x_318); -x_319 = lean_ctor_get(x_293, 3); -lean_inc(x_319); -x_320 = lean_ctor_get(x_293, 4); -lean_inc(x_320); -x_321 = lean_ctor_get(x_293, 5); +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); -if (lean_is_exclusive(x_293)) { - lean_ctor_release(x_293, 0); - lean_ctor_release(x_293, 1); - lean_ctor_release(x_293, 2); - lean_ctor_release(x_293, 3); - lean_ctor_release(x_293, 4); - lean_ctor_release(x_293, 5); - x_322 = x_293; -} else { - lean_dec_ref(x_293); - x_322 = lean_box(0); -} -x_323 = lean_ctor_get(x_294, 0); -lean_inc(x_323); -x_324 = lean_ctor_get(x_294, 1); -lean_inc(x_324); -x_325 = lean_ctor_get(x_294, 3); -lean_inc(x_325); -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); - x_326 = x_294; -} else { - lean_dec_ref(x_294); - x_326 = lean_box(0); -} -if (lean_is_scalar(x_326)) { - x_327 = lean_alloc_ctor(0, 4, 0); -} else { - x_327 = x_326; -} -lean_ctor_set(x_327, 0, x_323); -lean_ctor_set(x_327, 1, x_324); -lean_ctor_set(x_327, 2, x_286); -lean_ctor_set(x_327, 3, x_325); -if (lean_is_scalar(x_322)) { - x_328 = lean_alloc_ctor(0, 6, 0); -} else { - x_328 = x_322; -} -lean_ctor_set(x_328, 0, x_317); -lean_ctor_set(x_328, 1, x_318); -lean_ctor_set(x_328, 2, x_327); -lean_ctor_set(x_328, 3, x_319); -lean_ctor_set(x_328, 4, x_320); -lean_ctor_set(x_328, 5, x_321); -x_329 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_329, 0, x_316); -lean_ctor_set(x_329, 1, x_328); -return x_329; -} -} -else -{ -lean_object* x_330; lean_object* x_331; uint8_t x_332; -x_330 = lean_ctor_get(x_292, 1); -lean_inc(x_330); -x_331 = lean_ctor_get(x_330, 2); -lean_inc(x_331); -x_332 = !lean_is_exclusive(x_292); -if (x_332 == 0) -{ -lean_object* x_333; uint8_t x_334; -x_333 = lean_ctor_get(x_292, 1); -lean_dec(x_333); -x_334 = !lean_is_exclusive(x_330); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_330, 2); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_331); -if (x_336 == 0) -{ -lean_object* x_337; -x_337 = lean_ctor_get(x_331, 2); -lean_dec(x_337); -lean_ctor_set(x_331, 2, x_286); -return x_292; -} -else -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; -x_338 = lean_ctor_get(x_331, 0); -x_339 = lean_ctor_get(x_331, 1); -x_340 = lean_ctor_get(x_331, 3); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_dec(x_331); -x_341 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_341, 0, x_338); -lean_ctor_set(x_341, 1, x_339); -lean_ctor_set(x_341, 2, x_286); -lean_ctor_set(x_341, 3, x_340); -lean_ctor_set(x_330, 2, x_341); -return x_292; -} -} -else -{ -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_342 = lean_ctor_get(x_330, 0); -x_343 = lean_ctor_get(x_330, 1); -x_344 = lean_ctor_get(x_330, 3); -x_345 = lean_ctor_get(x_330, 4); -x_346 = lean_ctor_get(x_330, 5); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_dec(x_330); -x_347 = lean_ctor_get(x_331, 0); -lean_inc(x_347); -x_348 = lean_ctor_get(x_331, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_331, 3); -lean_inc(x_349); -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_350 = x_331; -} else { - lean_dec_ref(x_331); - x_350 = lean_box(0); -} -if (lean_is_scalar(x_350)) { - x_351 = lean_alloc_ctor(0, 4, 0); -} else { - x_351 = x_350; -} -lean_ctor_set(x_351, 0, x_347); -lean_ctor_set(x_351, 1, x_348); -lean_ctor_set(x_351, 2, x_286); -lean_ctor_set(x_351, 3, x_349); -x_352 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_352, 0, x_342); -lean_ctor_set(x_352, 1, x_343); -lean_ctor_set(x_352, 2, x_351); -lean_ctor_set(x_352, 3, x_344); -lean_ctor_set(x_352, 4, x_345); -lean_ctor_set(x_352, 5, x_346); -lean_ctor_set(x_292, 1, x_352); -return x_292; -} -} -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; -x_353 = lean_ctor_get(x_292, 0); -lean_inc(x_353); -lean_dec(x_292); -x_354 = lean_ctor_get(x_330, 0); -lean_inc(x_354); -x_355 = lean_ctor_get(x_330, 1); -lean_inc(x_355); -x_356 = lean_ctor_get(x_330, 3); -lean_inc(x_356); -x_357 = lean_ctor_get(x_330, 4); -lean_inc(x_357); -x_358 = lean_ctor_get(x_330, 5); -lean_inc(x_358); -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_359 = x_330; -} else { - lean_dec_ref(x_330); - x_359 = lean_box(0); -} -x_360 = lean_ctor_get(x_331, 0); -lean_inc(x_360); -x_361 = lean_ctor_get(x_331, 1); -lean_inc(x_361); -x_362 = lean_ctor_get(x_331, 3); -lean_inc(x_362); -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_363 = x_331; -} else { - lean_dec_ref(x_331); - x_363 = lean_box(0); -} -if (lean_is_scalar(x_363)) { - x_364 = lean_alloc_ctor(0, 4, 0); -} else { - x_364 = x_363; -} -lean_ctor_set(x_364, 0, x_360); -lean_ctor_set(x_364, 1, x_361); -lean_ctor_set(x_364, 2, x_286); -lean_ctor_set(x_364, 3, x_362); -if (lean_is_scalar(x_359)) { - x_365 = lean_alloc_ctor(0, 6, 0); -} else { - x_365 = 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); -x_366 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_366, 0, x_353); -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; -x_367 = lean_ctor_get(x_13, 0); -x_368 = lean_ctor_get(x_13, 1); -x_369 = lean_ctor_get(x_13, 2); -x_370 = lean_ctor_get(x_13, 3); -x_371 = lean_ctor_get(x_13, 4); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); +lean_inc(x_320); +lean_inc(x_319); +lean_inc(x_318); +lean_inc(x_317); lean_dec(x_13); -x_372 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_372, 0, x_280); -lean_ctor_set(x_372, 1, x_22); -x_373 = lean_array_push(x_369, x_372); -x_374 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_374, 0, x_367); -lean_ctor_set(x_374, 1, x_368); -lean_ctor_set(x_374, 2, x_373); -lean_ctor_set(x_374, 3, x_370); -lean_ctor_set(x_374, 4, x_371); -x_375 = 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_282, x_374, x_279); -if (lean_obj_tag(x_375) == 0) +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_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; -x_376 = lean_ctor_get(x_375, 1); -lean_inc(x_376); -x_377 = lean_ctor_get(x_376, 2); -lean_inc(x_377); -x_378 = lean_ctor_get(x_375, 0); -lean_inc(x_378); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_379 = x_375; -} else { - lean_dec_ref(x_375); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_376, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_376, 1); -lean_inc(x_381); -x_382 = lean_ctor_get(x_376, 3); -lean_inc(x_382); -x_383 = lean_ctor_get(x_376, 4); -lean_inc(x_383); -x_384 = lean_ctor_get(x_376, 5); -lean_inc(x_384); -if (lean_is_exclusive(x_376)) { - lean_ctor_release(x_376, 0); - lean_ctor_release(x_376, 1); - lean_ctor_release(x_376, 2); - lean_ctor_release(x_376, 3); - lean_ctor_release(x_376, 4); - lean_ctor_release(x_376, 5); - x_385 = x_376; -} else { - lean_dec_ref(x_376); - x_385 = lean_box(0); -} -x_386 = lean_ctor_get(x_377, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_377, 1); -lean_inc(x_387); -x_388 = lean_ctor_get(x_377, 3); -lean_inc(x_388); -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); - x_389 = x_377; -} else { - lean_dec_ref(x_377); - x_389 = lean_box(0); -} -if (lean_is_scalar(x_389)) { - x_390 = lean_alloc_ctor(0, 4, 0); -} else { - x_390 = x_389; -} -lean_ctor_set(x_390, 0, x_386); -lean_ctor_set(x_390, 1, x_387); -lean_ctor_set(x_390, 2, x_286); -lean_ctor_set(x_390, 3, x_388); -if (lean_is_scalar(x_385)) { - x_391 = lean_alloc_ctor(0, 6, 0); -} else { - x_391 = x_385; -} -lean_ctor_set(x_391, 0, x_380); -lean_ctor_set(x_391, 1, x_381); -lean_ctor_set(x_391, 2, x_390); -lean_ctor_set(x_391, 3, x_382); -lean_ctor_set(x_391, 4, x_383); -lean_ctor_set(x_391, 5, x_384); -if (lean_is_scalar(x_379)) { - x_392 = lean_alloc_ctor(0, 2, 0); -} else { - x_392 = x_379; -} -lean_ctor_set(x_392, 0, x_378); -lean_ctor_set(x_392, 1, x_391); -return x_392; +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_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; lean_object* x_408; lean_object* x_409; -x_393 = lean_ctor_get(x_375, 1); -lean_inc(x_393); -x_394 = lean_ctor_get(x_393, 2); -lean_inc(x_394); -x_395 = lean_ctor_get(x_375, 0); -lean_inc(x_395); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_396 = x_375; -} else { - lean_dec_ref(x_375); - x_396 = lean_box(0); +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; } -x_397 = lean_ctor_get(x_393, 0); -lean_inc(x_397); -x_398 = lean_ctor_get(x_393, 1); -lean_inc(x_398); -x_399 = lean_ctor_get(x_393, 3); -lean_inc(x_399); -x_400 = lean_ctor_get(x_393, 4); -lean_inc(x_400); -x_401 = lean_ctor_get(x_393, 5); -lean_inc(x_401); -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); - lean_ctor_release(x_393, 4); - lean_ctor_release(x_393, 5); - x_402 = x_393; -} else { - lean_dec_ref(x_393); - x_402 = lean_box(0); } -x_403 = lean_ctor_get(x_394, 0); -lean_inc(x_403); -x_404 = lean_ctor_get(x_394, 1); -lean_inc(x_404); -x_405 = lean_ctor_get(x_394, 3); -lean_inc(x_405); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - lean_ctor_release(x_394, 2); - lean_ctor_release(x_394, 3); - x_406 = x_394; +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); +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); +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 { - lean_dec_ref(x_394); - x_406 = lean_box(0); + x_262 = x_246; + lean_ctor_set_tag(x_262, 1); } -if (lean_is_scalar(x_406)) { - x_407 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_262, 0, x_257); +lean_ctor_set(x_262, 1, x_255); +return x_262; +} +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_407 = x_406; + x_267 = x_246; + lean_ctor_set_tag(x_267, 1); } -lean_ctor_set(x_407, 0, x_403); -lean_ctor_set(x_407, 1, x_404); -lean_ctor_set(x_407, 2, x_286); -lean_ctor_set(x_407, 3, x_405); -if (lean_is_scalar(x_402)) { - x_408 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_267, 0, x_257); +lean_ctor_set(x_267, 1, x_255); +return x_267; +} +} +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_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 { - x_408 = x_402; + lean_dec_ref(x_256); + x_276 = lean_box(0); } -lean_ctor_set(x_408, 0, x_397); -lean_ctor_set(x_408, 1, x_398); -lean_ctor_set(x_408, 2, x_407); -lean_ctor_set(x_408, 3, x_399); -lean_ctor_set(x_408, 4, x_400); -lean_ctor_set(x_408, 5, x_401); -if (lean_is_scalar(x_396)) { - x_409 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(0, 4, 0); } else { - x_409 = x_396; + x_277 = x_276; +} +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, 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); +} else { + x_279 = x_246; + lean_ctor_set_tag(x_279, 1); +} +lean_ctor_set(x_279, 0, x_257); +lean_ctor_set(x_279, 1, x_278); +return x_279; +} +} +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_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_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); +} else { + x_291 = x_246; +} +lean_ctor_set(x_291, 0, x_281); +lean_ctor_set(x_291, 1, x_255); +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_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); +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; +} else { + lean_dec_ref(x_280); + x_300 = lean_box(0); +} +if (lean_is_scalar(x_300)) { + x_301 = lean_alloc_ctor(0, 4, 0); +} else { + x_301 = x_300; +} +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); +} else { + x_303 = x_246; +} +lean_ctor_set(x_303, 0, x_281); +lean_ctor_set(x_303, 1, x_302); +return x_303; } -lean_ctor_set(x_409, 0, x_395); -lean_ctor_set(x_409, 1, x_408); -return x_409; } } } else { -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_284, 0); -x_411 = lean_ctor_get(x_284, 1); -x_412 = lean_ctor_get(x_284, 2); -x_413 = lean_ctor_get(x_284, 3); -lean_inc(x_413); -lean_inc(x_412); -lean_inc(x_411); -lean_inc(x_410); -lean_dec(x_284); -x_414 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_415 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_415, 0, x_410); -lean_ctor_set(x_415, 1, x_411); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_413); -lean_ctor_set(x_279, 2, x_415); -x_416 = lean_ctor_get(x_13, 0); -lean_inc(x_416); -x_417 = lean_ctor_get(x_13, 1); -lean_inc(x_417); -x_418 = lean_ctor_get(x_13, 2); -lean_inc(x_418); -x_419 = lean_ctor_get(x_13, 3); -lean_inc(x_419); -x_420 = lean_ctor_get(x_13, 4); -lean_inc(x_420); +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); 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_421 = x_13; + x_376 = x_13; } else { lean_dec_ref(x_13); - x_421 = lean_box(0); + x_376 = lean_box(0); } -x_422 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_422, 0, x_280); -lean_ctor_set(x_422, 1, x_22); -x_423 = lean_array_push(x_418, x_422); -if (lean_is_scalar(x_421)) { - x_424 = lean_alloc_ctor(0, 5, 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); } else { - x_424 = x_421; + x_379 = x_376; } -lean_ctor_set(x_424, 0, x_416); -lean_ctor_set(x_424, 1, x_417); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_419); -lean_ctor_set(x_424, 4, x_420); -x_425 = 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_282, x_424, x_279); -if (lean_obj_tag(x_425) == 0) +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_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; lean_object* x_442; -x_426 = lean_ctor_get(x_425, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_426, 2); -lean_inc(x_427); -x_428 = lean_ctor_get(x_425, 0); -lean_inc(x_428); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - x_429 = x_425; -} else { - lean_dec_ref(x_425); - x_429 = lean_box(0); -} -x_430 = lean_ctor_get(x_426, 0); -lean_inc(x_430); -x_431 = lean_ctor_get(x_426, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_426, 3); -lean_inc(x_432); -x_433 = lean_ctor_get(x_426, 4); -lean_inc(x_433); -x_434 = lean_ctor_get(x_426, 5); -lean_inc(x_434); -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); - lean_ctor_release(x_426, 5); - x_435 = x_426; -} else { - lean_dec_ref(x_426); - x_435 = lean_box(0); -} -x_436 = lean_ctor_get(x_427, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_427, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_427, 3); -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); - 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, 4, 0); -} else { - x_440 = x_439; -} -lean_ctor_set(x_440, 0, x_436); -lean_ctor_set(x_440, 1, x_437); -lean_ctor_set(x_440, 2, x_412); -lean_ctor_set(x_440, 3, x_438); -if (lean_is_scalar(x_435)) { - x_441 = lean_alloc_ctor(0, 6, 0); -} else { - x_441 = x_435; -} -lean_ctor_set(x_441, 0, x_430); -lean_ctor_set(x_441, 1, x_431); -lean_ctor_set(x_441, 2, x_440); -lean_ctor_set(x_441, 3, x_432); -lean_ctor_set(x_441, 4, x_433); -lean_ctor_set(x_441, 5, x_434); -if (lean_is_scalar(x_429)) { - x_442 = lean_alloc_ctor(0, 2, 0); -} else { - x_442 = x_429; -} -lean_ctor_set(x_442, 0, x_428); -lean_ctor_set(x_442, 1, x_441); -return x_442; +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; } else { -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; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_443 = lean_ctor_get(x_425, 1); -lean_inc(x_443); -x_444 = lean_ctor_get(x_443, 2); -lean_inc(x_444); -x_445 = lean_ctor_get(x_425, 0); -lean_inc(x_445); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - x_446 = x_425; -} else { - lean_dec_ref(x_425); - x_446 = lean_box(0); +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; } +block_368: +{ +if (lean_obj_tag(x_336) == 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_inc(x_353); +x_354 = lean_ctor_get(x_336, 0); +lean_inc(x_354); +lean_dec(x_336); +x_355 = lean_ctor_get(x_337, 0); +lean_inc(x_355); +x_356 = lean_ctor_get(x_337, 1); +lean_inc(x_356); +x_357 = lean_ctor_get(x_337, 3); +lean_inc(x_357); +x_358 = lean_ctor_get(x_337, 4); +lean_inc(x_358); +x_359 = lean_ctor_get(x_337, 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; +} else { + lean_dec_ref(x_337); + x_360 = lean_box(0); +} +x_361 = lean_ctor_get(x_353, 0); +lean_inc(x_361); +x_362 = lean_ctor_get(x_353, 1); +lean_inc(x_362); +x_363 = lean_ctor_get(x_353, 3); +lean_inc(x_363); +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; +} else { + lean_dec_ref(x_353); + x_364 = lean_box(0); +} +if (lean_is_scalar(x_364)) { + x_365 = lean_alloc_ctor(0, 4, 0); +} else { + x_365 = x_364; +} +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); +if (lean_is_scalar(x_360)) { + x_366 = lean_alloc_ctor(0, 6, 0); +} else { + x_366 = 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); +} else { + x_367 = x_246; +} +lean_ctor_set(x_367, 0, x_354); +lean_ctor_set(x_367, 1, x_366); +return x_367; +} +} +} +} +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; +} else { + lean_dec_ref(x_387); + x_397 = 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); +} else { + x_432 = x_397; +} +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); +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; +} else { + lean_dec_ref(x_13); + x_439 = 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); +} else { + x_442 = x_439; +} +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_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; +} +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); -x_449 = lean_ctor_get(x_443, 3); -lean_inc(x_449); -x_450 = lean_ctor_get(x_443, 4); -lean_inc(x_450); -x_451 = lean_ctor_get(x_443, 5); -lean_inc(x_451); -if (lean_is_exclusive(x_443)) { - lean_ctor_release(x_443, 0); - lean_ctor_release(x_443, 1); - lean_ctor_release(x_443, 2); - lean_ctor_release(x_443, 3); - lean_ctor_release(x_443, 4); - lean_ctor_release(x_443, 5); - x_452 = x_443; +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; +} +block_430: +{ +if (lean_obj_tag(x_398) == 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_443); - x_452 = lean_box(0); + lean_dec_ref(x_399); + x_407 = lean_box(0); } -x_453 = lean_ctor_get(x_444, 0); -lean_inc(x_453); -x_454 = lean_ctor_get(x_444, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_444, 3); -lean_inc(x_455); -if (lean_is_exclusive(x_444)) { - lean_ctor_release(x_444, 0); - lean_ctor_release(x_444, 1); - lean_ctor_release(x_444, 2); - lean_ctor_release(x_444, 3); - x_456 = x_444; +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_444); - x_456 = lean_box(0); + lean_dec_ref(x_400); + x_411 = lean_box(0); } -if (lean_is_scalar(x_456)) { - x_457 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_411)) { + x_412 = lean_alloc_ctor(0, 4, 0); } else { - x_457 = x_456; + x_412 = x_411; } -lean_ctor_set(x_457, 0, x_453); -lean_ctor_set(x_457, 1, x_454); -lean_ctor_set(x_457, 2, x_412); -lean_ctor_set(x_457, 3, x_455); -if (lean_is_scalar(x_452)) { - x_458 = lean_alloc_ctor(0, 6, 0); +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_458 = x_452; + x_413 = x_407; } -lean_ctor_set(x_458, 0, x_447); -lean_ctor_set(x_458, 1, x_448); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_449); -lean_ctor_set(x_458, 4, x_450); -lean_ctor_set(x_458, 5, x_451); -if (lean_is_scalar(x_446)) { - x_459 = lean_alloc_ctor(1, 2, 0); +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_459 = x_446; -} -lean_ctor_set(x_459, 0, x_445); -lean_ctor_set(x_459, 1, x_458); -return x_459; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; -x_460 = lean_ctor_get(x_279, 2); -x_461 = lean_ctor_get(x_279, 0); -x_462 = lean_ctor_get(x_279, 1); -x_463 = lean_ctor_get(x_279, 3); -x_464 = lean_ctor_get(x_279, 4); -x_465 = lean_ctor_get(x_279, 5); -lean_inc(x_465); -lean_inc(x_464); -lean_inc(x_463); -lean_inc(x_460); -lean_inc(x_462); -lean_inc(x_461); -lean_dec(x_279); -x_466 = lean_ctor_get(x_460, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_460, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_460, 3); -lean_inc(x_469); -if (lean_is_exclusive(x_460)) { - lean_ctor_release(x_460, 0); - lean_ctor_release(x_460, 1); - lean_ctor_release(x_460, 2); - lean_ctor_release(x_460, 3); - x_470 = x_460; +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_inc(x_418); +x_419 = lean_ctor_get(x_399, 3); +lean_inc(x_419); +x_420 = lean_ctor_get(x_399, 4); +lean_inc(x_420); +x_421 = lean_ctor_get(x_399, 5); +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_460); - x_470 = lean_box(0); + lean_dec_ref(x_399); + x_422 = lean_box(0); } -x_471 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_470)) { - x_472 = 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); +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; } else { - x_472 = x_470; + lean_dec_ref(x_415); + x_426 = lean_box(0); } -lean_ctor_set(x_472, 0, x_466); -lean_ctor_set(x_472, 1, x_467); -lean_ctor_set(x_472, 2, x_471); -lean_ctor_set(x_472, 3, x_469); -x_473 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_473, 0, x_461); -lean_ctor_set(x_473, 1, x_462); -lean_ctor_set(x_473, 2, x_472); -lean_ctor_set(x_473, 3, x_463); -lean_ctor_set(x_473, 4, x_464); -lean_ctor_set(x_473, 5, x_465); -x_474 = lean_ctor_get(x_13, 0); -lean_inc(x_474); -x_475 = lean_ctor_get(x_13, 1); -lean_inc(x_475); -x_476 = lean_ctor_get(x_13, 2); -lean_inc(x_476); -x_477 = lean_ctor_get(x_13, 3); -lean_inc(x_477); -x_478 = lean_ctor_get(x_13, 4); -lean_inc(x_478); -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_479 = x_13; +if (lean_is_scalar(x_426)) { + x_427 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_13); - x_479 = lean_box(0); + x_427 = x_426; } -x_480 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_480, 0, x_280); -lean_ctor_set(x_480, 1, x_22); -x_481 = lean_array_push(x_476, x_480); -if (lean_is_scalar(x_479)) { - x_482 = lean_alloc_ctor(0, 5, 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); } else { - x_482 = x_479; + x_428 = x_422; } -lean_ctor_set(x_482, 0, x_474); -lean_ctor_set(x_482, 1, x_475); -lean_ctor_set(x_482, 2, x_481); -lean_ctor_set(x_482, 3, x_477); -lean_ctor_set(x_482, 4, x_478); -x_483 = 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_282, x_482, x_473); -if (lean_obj_tag(x_483) == 0) -{ -lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; -x_484 = lean_ctor_get(x_483, 1); -lean_inc(x_484); -x_485 = lean_ctor_get(x_484, 2); -lean_inc(x_485); -x_486 = lean_ctor_get(x_483, 0); -lean_inc(x_486); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - x_487 = x_483; +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); } else { - lean_dec_ref(x_483); - x_487 = lean_box(0); + x_429 = x_246; } -x_488 = lean_ctor_get(x_484, 0); -lean_inc(x_488); -x_489 = lean_ctor_get(x_484, 1); -lean_inc(x_489); -x_490 = lean_ctor_get(x_484, 3); -lean_inc(x_490); -x_491 = lean_ctor_get(x_484, 4); -lean_inc(x_491); -x_492 = lean_ctor_get(x_484, 5); -lean_inc(x_492); -if (lean_is_exclusive(x_484)) { - lean_ctor_release(x_484, 0); - lean_ctor_release(x_484, 1); - lean_ctor_release(x_484, 2); - lean_ctor_release(x_484, 3); - lean_ctor_release(x_484, 4); - lean_ctor_release(x_484, 5); - x_493 = x_484; -} else { - lean_dec_ref(x_484); - x_493 = lean_box(0); +lean_ctor_set(x_429, 0, x_416); +lean_ctor_set(x_429, 1, x_428); +return x_429; } -x_494 = lean_ctor_get(x_485, 0); -lean_inc(x_494); -x_495 = lean_ctor_get(x_485, 1); -lean_inc(x_495); -x_496 = lean_ctor_get(x_485, 3); -lean_inc(x_496); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - lean_ctor_release(x_485, 2); - lean_ctor_release(x_485, 3); - x_497 = x_485; -} else { - lean_dec_ref(x_485); - x_497 = lean_box(0); -} -if (lean_is_scalar(x_497)) { - x_498 = lean_alloc_ctor(0, 4, 0); -} else { - x_498 = x_497; -} -lean_ctor_set(x_498, 0, x_494); -lean_ctor_set(x_498, 1, x_495); -lean_ctor_set(x_498, 2, x_468); -lean_ctor_set(x_498, 3, x_496); -if (lean_is_scalar(x_493)) { - x_499 = lean_alloc_ctor(0, 6, 0); -} else { - x_499 = x_493; -} -lean_ctor_set(x_499, 0, x_488); -lean_ctor_set(x_499, 1, x_489); -lean_ctor_set(x_499, 2, x_498); -lean_ctor_set(x_499, 3, x_490); -lean_ctor_set(x_499, 4, x_491); -lean_ctor_set(x_499, 5, x_492); -if (lean_is_scalar(x_487)) { - x_500 = lean_alloc_ctor(0, 2, 0); -} else { - x_500 = x_487; -} -lean_ctor_set(x_500, 0, x_486); -lean_ctor_set(x_500, 1, x_499); -return x_500; -} -else -{ -lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_501 = lean_ctor_get(x_483, 1); -lean_inc(x_501); -x_502 = lean_ctor_get(x_501, 2); -lean_inc(x_502); -x_503 = lean_ctor_get(x_483, 0); -lean_inc(x_503); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - x_504 = x_483; -} else { - lean_dec_ref(x_483); - x_504 = lean_box(0); -} -x_505 = lean_ctor_get(x_501, 0); -lean_inc(x_505); -x_506 = lean_ctor_get(x_501, 1); -lean_inc(x_506); -x_507 = lean_ctor_get(x_501, 3); -lean_inc(x_507); -x_508 = lean_ctor_get(x_501, 4); -lean_inc(x_508); -x_509 = lean_ctor_get(x_501, 5); -lean_inc(x_509); -if (lean_is_exclusive(x_501)) { - lean_ctor_release(x_501, 0); - lean_ctor_release(x_501, 1); - lean_ctor_release(x_501, 2); - lean_ctor_release(x_501, 3); - lean_ctor_release(x_501, 4); - lean_ctor_release(x_501, 5); - x_510 = x_501; -} else { - lean_dec_ref(x_501); - x_510 = lean_box(0); -} -x_511 = lean_ctor_get(x_502, 0); -lean_inc(x_511); -x_512 = lean_ctor_get(x_502, 1); -lean_inc(x_512); -x_513 = lean_ctor_get(x_502, 3); -lean_inc(x_513); -if (lean_is_exclusive(x_502)) { - lean_ctor_release(x_502, 0); - lean_ctor_release(x_502, 1); - lean_ctor_release(x_502, 2); - lean_ctor_release(x_502, 3); - x_514 = x_502; -} else { - lean_dec_ref(x_502); - x_514 = lean_box(0); -} -if (lean_is_scalar(x_514)) { - x_515 = lean_alloc_ctor(0, 4, 0); -} else { - x_515 = x_514; -} -lean_ctor_set(x_515, 0, x_511); -lean_ctor_set(x_515, 1, x_512); -lean_ctor_set(x_515, 2, x_468); -lean_ctor_set(x_515, 3, x_513); -if (lean_is_scalar(x_510)) { - x_516 = lean_alloc_ctor(0, 6, 0); -} else { - x_516 = x_510; -} -lean_ctor_set(x_516, 0, x_505); -lean_ctor_set(x_516, 1, x_506); -lean_ctor_set(x_516, 2, x_515); -lean_ctor_set(x_516, 3, x_507); -lean_ctor_set(x_516, 4, x_508); -lean_ctor_set(x_516, 5, x_509); -if (lean_is_scalar(x_504)) { - x_517 = lean_alloc_ctor(1, 2, 0); -} else { - x_517 = x_504; -} -lean_ctor_set(x_517, 0, x_503); -lean_ctor_set(x_517, 1, x_516); -return x_517; } } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -14859,23 +13773,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_273); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_239); +if (x_450 == 0) { -return x_273; +return x_239; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_273, 0); -x_520 = lean_ctor_get(x_273, 1); -lean_inc(x_520); -lean_inc(x_519); -lean_dec(x_273); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -14883,7 +13797,7 @@ return x_521; } else { -uint8_t x_522; +uint8_t x_454; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -14895,29 +13809,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_522 = !lean_is_exclusive(x_27); -if (x_522 == 0) +x_454 = !lean_is_exclusive(x_27); +if (x_454 == 0) { return x_27; } else { -lean_object* x_523; lean_object* x_524; lean_object* x_525; -x_523 = lean_ctor_get(x_27, 0); -x_524 = lean_ctor_get(x_27, 1); -lean_inc(x_524); -lean_inc(x_523); +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_dec(x_27); -x_525 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_525, 0, x_523); -lean_ctor_set(x_525, 1, x_524); -return x_525; +x_457 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_457, 0, x_455); +lean_ctor_set(x_457, 1, x_456); +return x_457; } } } else { -uint8_t x_526; +uint8_t x_458; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -14928,23 +13842,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_526 = !lean_is_exclusive(x_23); -if (x_526 == 0) +x_458 = !lean_is_exclusive(x_23); +if (x_458 == 0) { return x_23; } else { -lean_object* x_527; lean_object* x_528; lean_object* x_529; -x_527 = lean_ctor_get(x_23, 0); -x_528 = lean_ctor_get(x_23, 1); -lean_inc(x_528); -lean_inc(x_527); +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_dec(x_23); -x_529 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_529, 0, x_527); -lean_ctor_set(x_529, 1, x_528); -return x_529; +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; } } } @@ -15060,2153 +13974,1791 @@ goto _start; } case 1: { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; lean_dec(x_28); x_35 = lean_ctor_get(x_29, 1); lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_ctor_get(x_30, 0); -lean_inc(x_36); +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + x_36 = x_29; +} else { + lean_dec_ref(x_29); + x_36 = lean_box(0); +} +x_37 = lean_ctor_get(x_30, 0); +lean_inc(x_37); lean_dec(x_30); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_add(x_7, x_37); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_add(x_7, x_38); lean_dec(x_7); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) +x_40 = !lean_is_exclusive(x_35); +if (x_40 == 0) { -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 2); +x_42 = !lean_is_exclusive(x_41); +if (x_42 == 0) { -lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_42 = lean_ctor_get(x_40, 2); -x_43 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_40, 2, x_43); -x_44 = !lean_is_exclusive(x_8); -if (x_44 == 0) +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +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) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = lean_ctor_get(x_8, 2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_24); -x_47 = lean_array_push(x_45, x_46); -lean_ctor_set(x_8, 2, x_47); -x_48 = 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_38, x_8, x_35); -if (lean_obj_tag(x_48) == 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_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_49, 2); -lean_inc(x_50); -x_51 = !lean_is_exclusive(x_48); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_48, 1); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_49, 2); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_50); -if (x_55 == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_50, 2); -lean_dec(x_56); -lean_ctor_set(x_50, 2, x_42); -return x_48; +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_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_50, 0); -x_58 = lean_ctor_get(x_50, 1); -x_59 = lean_ctor_get(x_50, 3); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_50); -x_60 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_42); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_49, 2, x_60); -return x_48; +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_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; } } 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; -x_61 = lean_ctor_get(x_49, 0); -x_62 = lean_ctor_get(x_49, 1); -x_63 = lean_ctor_get(x_49, 3); -x_64 = lean_ctor_get(x_49, 4); -x_65 = lean_ctor_get(x_49, 5); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); +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_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; +} +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_44 = x_121; +x_45 = x_120; +goto block_94; +} +} +block_94: +{ +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 0); +lean_inc(x_47); +lean_dec(x_44); +x_48 = !lean_is_exclusive(x_45); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_45, 2); +lean_dec(x_49); +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_43); +if (lean_is_scalar(x_36)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_36; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +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); +if (lean_is_scalar(x_36)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_36; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_47); +lean_ctor_set(x_57, 1, x_45); +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_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_inc(x_62); lean_inc(x_61); -lean_dec(x_49); -x_66 = lean_ctor_get(x_50, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_50, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_50, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_69 = x_50; +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); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 3); +lean_inc(x_65); +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; } else { - lean_dec_ref(x_50); - x_69 = lean_box(0); + lean_dec_ref(x_46); + x_66 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_67 = x_66; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_42); -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_48, 1, x_71); -return x_48; +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); +if (lean_is_scalar(x_36)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_36; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_47); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } 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; lean_object* x_84; lean_object* x_85; -x_72 = lean_ctor_get(x_48, 0); -lean_inc(x_72); -lean_dec(x_48); -x_73 = lean_ctor_get(x_49, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 3); -lean_inc(x_75); -x_76 = lean_ctor_get(x_49, 4); -lean_inc(x_76); -x_77 = lean_ctor_get(x_49, 5); -lean_inc(x_77); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_78 = x_49; +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_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); +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_43); +if (lean_is_scalar(x_36)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_49); - x_78 = lean_box(0); + x_76 = x_36; } -x_79 = lean_ctor_get(x_50, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_45); +return x_76; +} +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_inc(x_79); -x_80 = lean_ctor_get(x_50, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_50, 3); -lean_inc(x_81); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_82 = x_50; +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); +if (lean_is_scalar(x_36)) { + x_81 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_50); - x_82 = lean_box(0); + x_81 = x_36; } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 4, 0); -} else { - x_83 = x_82; -} -lean_ctor_set(x_83, 0, x_79); -lean_ctor_set(x_83, 1, x_80); -lean_ctor_set(x_83, 2, x_42); -lean_ctor_set(x_83, 3, x_81); -if (lean_is_scalar(x_78)) { - x_84 = lean_alloc_ctor(0, 6, 0); -} else { - x_84 = x_78; -} -lean_ctor_set(x_84, 0, x_73); -lean_ctor_set(x_84, 1, x_74); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_75); -lean_ctor_set(x_84, 4, x_76); -lean_ctor_set(x_84, 5, x_77); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_72); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_81, 0, x_71); +lean_ctor_set(x_81, 1, x_45); +return x_81; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_48, 1); +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_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); +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_is_exclusive(x_48); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_48, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_86, 2); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_42); -return x_48; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -x_96 = lean_ctor_get(x_87, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -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_42); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_86, 2, x_97); -return x_48; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 0); -x_99 = lean_ctor_get(x_86, 1); -x_100 = lean_ctor_get(x_86, 3); -x_101 = lean_ctor_get(x_86, 4); -x_102 = lean_ctor_get(x_86, 5); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_86); -x_103 = lean_ctor_get(x_87, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 3); -lean_inc(x_105); -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_106 = 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; } else { - lean_dec_ref(x_87); - x_106 = lean_box(0); + lean_dec_ref(x_70); + x_90 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_107 = x_106; + x_91 = x_90; } -lean_ctor_set(x_107, 0, x_103); -lean_ctor_set(x_107, 1, x_104); -lean_ctor_set(x_107, 2, x_42); -lean_ctor_set(x_107, 3, x_105); -x_108 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_108, 0, x_98); -lean_ctor_set(x_108, 1, x_99); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_100); -lean_ctor_set(x_108, 4, x_101); -lean_ctor_set(x_108, 5, x_102); -lean_ctor_set(x_48, 1, x_108); -return x_48; -} -} -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; -x_109 = lean_ctor_get(x_48, 0); -lean_inc(x_109); -lean_dec(x_48); -x_110 = lean_ctor_get(x_86, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 3); -lean_inc(x_112); -x_113 = lean_ctor_get(x_86, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_86, 5); -lean_inc(x_114); -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_115 = x_86; +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); +if (lean_is_scalar(x_36)) { + x_93 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_86); - x_115 = lean_box(0); + x_93 = x_36; } -x_116 = lean_ctor_get(x_87, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_87, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 3); -lean_inc(x_118); -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_119 = x_87; -} else { - lean_dec_ref(x_87); - x_119 = lean_box(0); +lean_ctor_set(x_93, 0, x_71); +lean_ctor_set(x_93, 1, x_92); +return x_93; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_42); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_109); -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; -x_123 = lean_ctor_get(x_8, 0); -x_124 = lean_ctor_get(x_8, 1); -x_125 = lean_ctor_get(x_8, 2); -x_126 = lean_ctor_get(x_8, 3); -x_127 = lean_ctor_get(x_8, 4); -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; 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_dec(x_8); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_36); -lean_ctor_set(x_128, 1, x_24); -x_129 = lean_array_push(x_125, x_128); -x_130 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_130, 0, x_123); -lean_ctor_set(x_130, 1, x_124); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_126); -lean_ctor_set(x_130, 4, x_127); -x_131 = 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_38, x_130, x_35); -if (lean_obj_tag(x_131) == 0) -{ -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; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_135 = x_131; +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_131); + 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_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_132, 0); +x_136 = lean_ctor_get(x_128, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); +x_137 = lean_ctor_get(x_128, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 3); +x_138 = lean_ctor_get(x_128, 3); lean_inc(x_138); -x_139 = lean_ctor_get(x_132, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_132, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_141 = x_132; +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_132); - x_141 = lean_box(0); + lean_dec_ref(x_128); + x_139 = lean_box(0); } -x_142 = lean_ctor_get(x_133, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_133, 3); -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); - x_145 = x_133; +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_145 = lean_box(0); + x_140 = x_139; } -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_42); -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); +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_148 = lean_alloc_ctor(0, 2, 0); + x_141 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_135; + x_141 = x_135; } -lean_ctor_set(x_148, 0, x_134); -lean_ctor_set(x_148, 1, x_147); -return x_148; +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_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_131, 1); +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); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_131, 0); +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); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_152 = x_131; -} else { - lean_dec_ref(x_131); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); +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_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; +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_149); - x_158 = lean_box(0); + lean_dec_ref(x_143); + x_154 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_150); - x_162 = lean_box(0); + x_155 = x_154; } -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); +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_163 = x_162; + x_156 = x_150; } -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_42); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); +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_164 = x_158; + x_157 = x_36; } -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(1, 2, 0); -} else { - x_165 = x_152; +lean_ctor_set(x_157, 0, x_144); +lean_ctor_set(x_157, 1, x_156); +return x_157; } -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; } } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_166 = lean_ctor_get(x_40, 0); -x_167 = lean_ctor_get(x_40, 1); -x_168 = lean_ctor_get(x_40, 2); -x_169 = lean_ctor_get(x_40, 3); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_40); -x_170 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_171 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_171, 0, x_166); -lean_ctor_set(x_171, 1, x_167); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_169); -lean_ctor_set(x_35, 2, x_171); -x_172 = lean_ctor_get(x_8, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_8, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_8, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_8, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_8, 4); -lean_inc(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_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); 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_177 = x_8; + x_229 = x_8; } else { lean_dec_ref(x_8); - x_177 = lean_box(0); + x_229 = lean_box(0); } -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_36); -lean_ctor_set(x_178, 1, x_24); -x_179 = lean_array_push(x_174, x_178); -if (lean_is_scalar(x_177)) { - x_180 = lean_alloc_ctor(0, 5, 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_232 = lean_alloc_ctor(0, 5, 0); } else { - x_180 = x_177; + x_232 = x_229; } -lean_ctor_set(x_180, 0, x_172); -lean_ctor_set(x_180, 1, x_173); -lean_ctor_set(x_180, 2, x_179); -lean_ctor_set(x_180, 3, x_175); -lean_ctor_set(x_180, 4, x_176); -x_181 = 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_38, x_180, x_35); -if (lean_obj_tag(x_181) == 0) +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_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_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_196; lean_object* x_197; lean_object* x_198; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_182, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_182, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_182, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_182, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_182, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - lean_ctor_release(x_182, 2); - lean_ctor_release(x_182, 3); - lean_ctor_release(x_182, 4); - lean_ctor_release(x_182, 5); - x_191 = x_182; -} else { - lean_dec_ref(x_182); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_183, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_183, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_183, 3); -lean_inc(x_194); -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); - x_195 = x_183; -} else { - lean_dec_ref(x_183); - 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_168); -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_185)) { - x_198 = lean_alloc_ctor(0, 2, 0); -} else { - x_198 = x_185; -} -lean_ctor_set(x_198, 0, x_184); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_188 = x_236; +x_189 = x_235; +goto block_220; } 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; lean_object* x_214; lean_object* x_215; -x_199 = lean_ctor_get(x_181, 1); +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_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; +} 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_199, 2); +x_200 = lean_ctor_get(x_190, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_181, 0); -lean_inc(x_201); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_202 = x_181; +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_181); - x_202 = lean_box(0); + lean_dec_ref(x_190); + x_201 = lean_box(0); } -x_203 = lean_ctor_get(x_199, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_199, 3); +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_199, 4); +x_206 = lean_ctor_get(x_188, 0); lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 5); +lean_dec(x_188); +x_207 = lean_ctor_get(x_189, 0); lean_inc(x_207); -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); - lean_ctor_release(x_199, 4); - lean_ctor_release(x_199, 5); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = lean_ctor_get(x_200, 0); +x_208 = lean_ctor_get(x_189, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_189, 3); lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 1); +x_210 = lean_ctor_get(x_189, 4); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 3); +x_211 = lean_ctor_get(x_189, 5); 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); - x_212 = x_200; +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; } else { - lean_dec_ref(x_200); + lean_dec_ref(x_189); 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); +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; +} else { + lean_dec_ref(x_205); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 4, 0); +} else { + x_217 = x_216; +} +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_213 = lean_alloc_ctor(0, 4, 0); + x_218 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_218 = x_212; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_168); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_36)) { + x_219 = lean_alloc_ctor(0, 2, 0); } else { - x_214 = x_208; + x_219 = x_36; } -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); -if (lean_is_scalar(x_202)) { - x_215 = lean_alloc_ctor(1, 2, 0); -} else { - x_215 = x_202; +lean_ctor_set(x_219, 0, x_206); +lean_ctor_set(x_219, 1, x_218); +return x_219; } -lean_ctor_set(x_215, 0, x_201); -lean_ctor_set(x_215, 1, x_214); -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_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; -x_216 = lean_ctor_get(x_35, 2); -x_217 = lean_ctor_get(x_35, 0); -x_218 = lean_ctor_get(x_35, 1); -x_219 = lean_ctor_get(x_35, 3); -x_220 = lean_ctor_get(x_35, 4); -x_221 = lean_ctor_get(x_35, 5); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); -lean_inc(x_216); -lean_inc(x_218); -lean_inc(x_217); -lean_dec(x_35); -x_222 = lean_ctor_get(x_216, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_216, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_216, 3); -lean_inc(x_225); -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_226 = x_216; -} else { - lean_dec_ref(x_216); - x_226 = lean_box(0); -} -x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 4, 0); -} else { - x_228 = x_226; -} -lean_ctor_set(x_228, 0, x_222); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_225); -x_229 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_229, 0, x_217); -lean_ctor_set(x_229, 1, x_218); -lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_219); -lean_ctor_set(x_229, 4, x_220); -lean_ctor_set(x_229, 5, x_221); -x_230 = lean_ctor_get(x_8, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_8, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_8, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_8, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_8, 4); -lean_inc(x_234); -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_235 = x_8; -} else { - lean_dec_ref(x_8); - x_235 = lean_box(0); -} -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_36); -lean_ctor_set(x_236, 1, x_24); -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_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_238, x_229); -if (lean_obj_tag(x_239) == 0) -{ -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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_224); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -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; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; -} else { - lean_dec_ref(x_257); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; -} else { - lean_dec_ref(x_258); - x_270 = lean_box(0); -} -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); -} else { - x_271 = x_270; -} -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_224); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); -} else { - x_272 = x_266; -} -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(1, 2, 0); -} else { - x_273 = x_260; -} -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } default: { -lean_object* x_274; lean_object* x_275; -x_274 = lean_ctor_get(x_29, 1); -lean_inc(x_274); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_29, 1); +lean_inc(x_240); lean_dec(x_29); lean_inc(x_8); -x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); -if (lean_obj_tag(x_275) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_276; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -if (lean_obj_tag(x_276) == 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_277; lean_object* x_278; lean_object* x_279; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_24); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_7, x_278); +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); lean_dec(x_7); -x_7 = x_279; -x_9 = x_277; +x_7 = x_245; +x_9 = x_243; goto _start; } else { -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; uint8_t x_285; -x_281 = lean_ctor_get(x_275, 1); -lean_inc(x_281); -lean_dec(x_275); -x_282 = lean_ctor_get(x_276, 0); -lean_inc(x_282); -lean_dec(x_276); -x_283 = lean_unsigned_to_nat(1u); -x_284 = lean_nat_add(x_7, x_283); +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_241); + x_248 = 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_285 = !lean_is_exclusive(x_281); -if (x_285 == 0) +x_252 = !lean_is_exclusive(x_247); +if (x_252 == 0) { -lean_object* x_286; uint8_t x_287; -x_286 = lean_ctor_get(x_281, 2); -x_287 = !lean_is_exclusive(x_286); -if (x_287 == 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_288; lean_object* x_289; uint8_t x_290; -x_288 = lean_ctor_get(x_286, 2); -x_289 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_286, 2, x_289); -x_290 = !lean_is_exclusive(x_8); -if (x_290 == 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_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_291 = lean_ctor_get(x_8, 2); -x_292 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_292, 0, x_282); -lean_ctor_set(x_292, 1, x_24); -x_293 = lean_array_push(x_291, x_292); -lean_ctor_set(x_8, 2, x_293); -x_294 = 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_284, x_8, x_281); -if (lean_obj_tag(x_294) == 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_295; lean_object* x_296; uint8_t x_297; -x_295 = lean_ctor_get(x_294, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_295, 2); -lean_inc(x_296); -x_297 = !lean_is_exclusive(x_294); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_294, 1); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_295); -if (x_299 == 0) -{ -lean_object* x_300; uint8_t x_301; -x_300 = lean_ctor_get(x_295, 2); -lean_dec(x_300); -x_301 = !lean_is_exclusive(x_296); -if (x_301 == 0) -{ -lean_object* x_302; -x_302 = lean_ctor_get(x_296, 2); -lean_dec(x_302); -lean_ctor_set(x_296, 2, x_288); -return x_294; -} -else -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_296, 0); -x_304 = lean_ctor_get(x_296, 1); -x_305 = lean_ctor_get(x_296, 3); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_296); -x_306 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_288); -lean_ctor_set(x_306, 3, x_305); -lean_ctor_set(x_295, 2, x_306); -return x_294; -} -} -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; -x_307 = lean_ctor_get(x_295, 0); -x_308 = lean_ctor_get(x_295, 1); -x_309 = lean_ctor_get(x_295, 3); -x_310 = lean_ctor_get(x_295, 4); -x_311 = lean_ctor_get(x_295, 5); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_dec(x_295); -x_312 = lean_ctor_get(x_296, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_296, 1); +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_296, 3); +x_314 = lean_ctor_get(x_312, 1); lean_inc(x_314); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_315 = x_296; -} else { - lean_dec_ref(x_296); - x_315 = lean_box(0); +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; } -if (lean_is_scalar(x_315)) { - x_316 = lean_alloc_ctor(0, 4, 0); -} else { - x_316 = x_315; -} -lean_ctor_set(x_316, 0, x_312); -lean_ctor_set(x_316, 1, x_313); -lean_ctor_set(x_316, 2, x_288); -lean_ctor_set(x_316, 3, x_314); -x_317 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_317, 0, x_307); -lean_ctor_set(x_317, 1, x_308); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_309); -lean_ctor_set(x_317, 4, x_310); -lean_ctor_set(x_317, 5, x_311); -lean_ctor_set(x_294, 1, x_317); -return x_294; +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_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_318 = lean_ctor_get(x_294, 0); -lean_inc(x_318); -lean_dec(x_294); -x_319 = lean_ctor_get(x_295, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_295, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_295, 3); -lean_inc(x_321); -x_322 = lean_ctor_get(x_295, 4); -lean_inc(x_322); -x_323 = lean_ctor_get(x_295, 5); +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); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - lean_ctor_release(x_295, 2); - lean_ctor_release(x_295, 3); - lean_ctor_release(x_295, 4); - lean_ctor_release(x_295, 5); - x_324 = x_295; -} else { - lean_dec_ref(x_295); - x_324 = lean_box(0); -} -x_325 = lean_ctor_get(x_296, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_296, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_296, 3); -lean_inc(x_327); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_328 = x_296; -} else { - lean_dec_ref(x_296); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 4, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_325); -lean_ctor_set(x_329, 1, x_326); -lean_ctor_set(x_329, 2, x_288); -lean_ctor_set(x_329, 3, x_327); -if (lean_is_scalar(x_324)) { - x_330 = lean_alloc_ctor(0, 6, 0); -} else { - x_330 = x_324; -} -lean_ctor_set(x_330, 0, x_319); -lean_ctor_set(x_330, 1, x_320); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_321); -lean_ctor_set(x_330, 4, x_322); -lean_ctor_set(x_330, 5, x_323); -x_331 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_331, 0, x_318); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} -} -else -{ -lean_object* x_332; lean_object* x_333; uint8_t x_334; -x_332 = lean_ctor_get(x_294, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_332, 2); -lean_inc(x_333); -x_334 = !lean_is_exclusive(x_294); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_294, 1); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_332); -if (x_336 == 0) -{ -lean_object* x_337; uint8_t x_338; -x_337 = lean_ctor_get(x_332, 2); -lean_dec(x_337); -x_338 = !lean_is_exclusive(x_333); -if (x_338 == 0) -{ -lean_object* x_339; -x_339 = lean_ctor_get(x_333, 2); -lean_dec(x_339); -lean_ctor_set(x_333, 2, x_288); -return x_294; -} -else -{ -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_340 = lean_ctor_get(x_333, 0); -x_341 = lean_ctor_get(x_333, 1); -x_342 = lean_ctor_get(x_333, 3); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_333); -x_343 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_343, 0, x_340); -lean_ctor_set(x_343, 1, x_341); -lean_ctor_set(x_343, 2, x_288); -lean_ctor_set(x_343, 3, x_342); -lean_ctor_set(x_332, 2, x_343); -return x_294; -} -} -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; -x_344 = lean_ctor_get(x_332, 0); -x_345 = lean_ctor_get(x_332, 1); -x_346 = lean_ctor_get(x_332, 3); -x_347 = lean_ctor_get(x_332, 4); -x_348 = lean_ctor_get(x_332, 5); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_dec(x_332); -x_349 = lean_ctor_get(x_333, 0); -lean_inc(x_349); -x_350 = lean_ctor_get(x_333, 1); -lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 3); -lean_inc(x_351); -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); - x_352 = x_333; -} else { - lean_dec_ref(x_333); - x_352 = lean_box(0); -} -if (lean_is_scalar(x_352)) { - x_353 = lean_alloc_ctor(0, 4, 0); -} else { - x_353 = x_352; -} -lean_ctor_set(x_353, 0, x_349); -lean_ctor_set(x_353, 1, x_350); -lean_ctor_set(x_353, 2, x_288); -lean_ctor_set(x_353, 3, x_351); -x_354 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_354, 0, x_344); -lean_ctor_set(x_354, 1, x_345); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_346); -lean_ctor_set(x_354, 4, x_347); -lean_ctor_set(x_354, 5, x_348); -lean_ctor_set(x_294, 1, x_354); -return x_294; -} -} -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; -x_355 = lean_ctor_get(x_294, 0); -lean_inc(x_355); -lean_dec(x_294); -x_356 = lean_ctor_get(x_332, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_332, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_332, 3); -lean_inc(x_358); -x_359 = lean_ctor_get(x_332, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_332, 5); -lean_inc(x_360); -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); - lean_ctor_release(x_332, 5); - x_361 = x_332; -} else { - lean_dec_ref(x_332); - x_361 = lean_box(0); -} -x_362 = lean_ctor_get(x_333, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_333, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_333, 3); -lean_inc(x_364); -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); - x_365 = x_333; -} else { - lean_dec_ref(x_333); - x_365 = lean_box(0); -} -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 4, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_362); -lean_ctor_set(x_366, 1, x_363); -lean_ctor_set(x_366, 2, x_288); -lean_ctor_set(x_366, 3, x_364); -if (lean_is_scalar(x_361)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_361; -} -lean_ctor_set(x_367, 0, x_356); -lean_ctor_set(x_367, 1, x_357); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_358); -lean_ctor_set(x_367, 4, x_359); -lean_ctor_set(x_367, 5, x_360); -x_368 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_368, 0, x_355); -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; -x_369 = lean_ctor_get(x_8, 0); -x_370 = lean_ctor_get(x_8, 1); -x_371 = lean_ctor_get(x_8, 2); -x_372 = lean_ctor_get(x_8, 3); -x_373 = lean_ctor_get(x_8, 4); -lean_inc(x_373); -lean_inc(x_372); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); +lean_inc(x_322); +lean_inc(x_321); +lean_inc(x_320); +lean_inc(x_319); lean_dec(x_8); -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_282); -lean_ctor_set(x_374, 1, x_24); -x_375 = lean_array_push(x_371, x_374); -x_376 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_376, 0, x_369); -lean_ctor_set(x_376, 1, x_370); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_372); -lean_ctor_set(x_376, 4, x_373); -x_377 = 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_284, x_376, x_281); -if (lean_obj_tag(x_377) == 0) +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_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_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; -x_378 = lean_ctor_get(x_377, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_378, 2); -lean_inc(x_379); -x_380 = lean_ctor_get(x_377, 0); -lean_inc(x_380); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_381 = x_377; -} else { - lean_dec_ref(x_377); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 4); -lean_inc(x_385); -x_386 = lean_ctor_get(x_378, 5); -lean_inc(x_386); -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); - lean_ctor_release(x_378, 4); - lean_ctor_release(x_378, 5); - x_387 = x_378; -} else { - lean_dec_ref(x_378); - x_387 = lean_box(0); -} -x_388 = lean_ctor_get(x_379, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_379, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_379, 3); -lean_inc(x_390); -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_391 = x_379; -} else { - lean_dec_ref(x_379); - x_391 = lean_box(0); -} -if (lean_is_scalar(x_391)) { - x_392 = lean_alloc_ctor(0, 4, 0); -} else { - x_392 = x_391; -} -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_288); -lean_ctor_set(x_392, 3, x_390); -if (lean_is_scalar(x_387)) { - x_393 = lean_alloc_ctor(0, 6, 0); -} else { - x_393 = x_387; -} -lean_ctor_set(x_393, 0, x_382); -lean_ctor_set(x_393, 1, x_383); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_384); -lean_ctor_set(x_393, 4, x_385); -lean_ctor_set(x_393, 5, x_386); -if (lean_is_scalar(x_381)) { - x_394 = lean_alloc_ctor(0, 2, 0); -} else { - x_394 = x_381; -} -lean_ctor_set(x_394, 0, x_380); -lean_ctor_set(x_394, 1, x_393); -return x_394; +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_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_409; lean_object* x_410; lean_object* x_411; -x_395 = lean_ctor_get(x_377, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_377, 0); -lean_inc(x_397); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_398 = x_377; -} else { - lean_dec_ref(x_377); - x_398 = lean_box(0); +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; } -x_399 = lean_ctor_get(x_395, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_395, 5); -lean_inc(x_403); -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_404 = x_395; -} else { - lean_dec_ref(x_395); - x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_396, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_396, 3); -lean_inc(x_407); -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_408 = x_396; +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); +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 { - lean_dec_ref(x_396); - x_408 = lean_box(0); + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); } -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); +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; +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_409 = x_408; + x_269 = x_248; + lean_ctor_set_tag(x_269, 1); } -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_288); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_269, 0, x_259); +lean_ctor_set(x_269, 1, x_257); +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; 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_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 { - x_410 = x_404; + lean_dec_ref(x_258); + x_278 = lean_box(0); } -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_398)) { - x_411 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_278)) { + x_279 = lean_alloc_ctor(0, 4, 0); } else { - x_411 = x_398; + x_279 = x_278; +} +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, 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); +} else { + x_281 = x_248; + lean_ctor_set_tag(x_281, 1); +} +lean_ctor_set(x_281, 0, x_259); +lean_ctor_set(x_281, 1, x_280); +return x_281; +} +} +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_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_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); +} else { + x_293 = x_248; +} +lean_ctor_set(x_293, 0, x_283); +lean_ctor_set(x_293, 1, x_257); +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_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); +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; +} else { + lean_dec_ref(x_282); + x_302 = lean_box(0); +} +if (lean_is_scalar(x_302)) { + x_303 = lean_alloc_ctor(0, 4, 0); +} else { + x_303 = x_302; +} +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); +} else { + x_305 = x_248; +} +lean_ctor_set(x_305, 0, x_283); +lean_ctor_set(x_305, 1, x_304); +return x_305; } -lean_ctor_set(x_411, 0, x_397); -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; lean_object* x_427; -x_412 = lean_ctor_get(x_286, 0); -x_413 = lean_ctor_get(x_286, 1); -x_414 = lean_ctor_get(x_286, 2); -x_415 = lean_ctor_get(x_286, 3); -lean_inc(x_415); -lean_inc(x_414); -lean_inc(x_413); -lean_inc(x_412); -lean_dec(x_286); -x_416 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_417 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_417, 0, x_412); -lean_ctor_set(x_417, 1, x_413); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_415); -lean_ctor_set(x_281, 2, x_417); -x_418 = lean_ctor_get(x_8, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_8, 1); -lean_inc(x_419); -x_420 = lean_ctor_get(x_8, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_8, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_8, 4); -lean_inc(x_422); +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); 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_423 = x_8; + x_378 = x_8; } else { lean_dec_ref(x_8); - x_423 = lean_box(0); + x_378 = lean_box(0); } -x_424 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_424, 0, x_282); -lean_ctor_set(x_424, 1, x_24); -x_425 = lean_array_push(x_420, x_424); -if (lean_is_scalar(x_423)) { - x_426 = lean_alloc_ctor(0, 5, 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); } else { - x_426 = x_423; + x_381 = x_378; } -lean_ctor_set(x_426, 0, x_418); -lean_ctor_set(x_426, 1, x_419); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_421); -lean_ctor_set(x_426, 4, x_422); -x_427 = 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_284, x_426, x_281); -if (lean_obj_tag(x_427) == 0) +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_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_428 = lean_ctor_get(x_427, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_428, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_427, 0); -lean_inc(x_430); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_431 = x_427; -} else { - lean_dec_ref(x_427); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_428, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_428, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_428, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_428, 4); -lean_inc(x_435); -x_436 = lean_ctor_get(x_428, 5); -lean_inc(x_436); -if (lean_is_exclusive(x_428)) { - lean_ctor_release(x_428, 0); - lean_ctor_release(x_428, 1); - lean_ctor_release(x_428, 2); - lean_ctor_release(x_428, 3); - lean_ctor_release(x_428, 4); - lean_ctor_release(x_428, 5); - x_437 = x_428; -} else { - lean_dec_ref(x_428); - x_437 = lean_box(0); -} -x_438 = lean_ctor_get(x_429, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_429, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_429, 3); -lean_inc(x_440); -if (lean_is_exclusive(x_429)) { - lean_ctor_release(x_429, 0); - lean_ctor_release(x_429, 1); - lean_ctor_release(x_429, 2); - lean_ctor_release(x_429, 3); - x_441 = x_429; -} else { - lean_dec_ref(x_429); - x_441 = lean_box(0); -} -if (lean_is_scalar(x_441)) { - x_442 = lean_alloc_ctor(0, 4, 0); -} else { - x_442 = x_441; -} -lean_ctor_set(x_442, 0, x_438); -lean_ctor_set(x_442, 1, x_439); -lean_ctor_set(x_442, 2, x_414); -lean_ctor_set(x_442, 3, x_440); -if (lean_is_scalar(x_437)) { - x_443 = lean_alloc_ctor(0, 6, 0); -} else { - x_443 = x_437; -} -lean_ctor_set(x_443, 0, x_432); -lean_ctor_set(x_443, 1, x_433); -lean_ctor_set(x_443, 2, x_442); -lean_ctor_set(x_443, 3, x_434); -lean_ctor_set(x_443, 4, x_435); -lean_ctor_set(x_443, 5, x_436); -if (lean_is_scalar(x_431)) { - x_444 = lean_alloc_ctor(0, 2, 0); -} else { - x_444 = x_431; -} -lean_ctor_set(x_444, 0, x_430); -lean_ctor_set(x_444, 1, x_443); -return x_444; +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; } else { -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_445 = lean_ctor_get(x_427, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_445, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_427, 0); -lean_inc(x_447); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_448 = x_427; -} else { - lean_dec_ref(x_427); - x_448 = lean_box(0); +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; } +block_370: +{ +if (lean_obj_tag(x_338) == 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_inc(x_355); +x_356 = lean_ctor_get(x_338, 0); +lean_inc(x_356); +lean_dec(x_338); +x_357 = lean_ctor_get(x_339, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_339, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_339, 3); +lean_inc(x_359); +x_360 = lean_ctor_get(x_339, 4); +lean_inc(x_360); +x_361 = lean_ctor_get(x_339, 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; +} else { + lean_dec_ref(x_339); + x_362 = lean_box(0); +} +x_363 = lean_ctor_get(x_355, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_355, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_355, 3); +lean_inc(x_365); +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; +} else { + lean_dec_ref(x_355); + x_366 = lean_box(0); +} +if (lean_is_scalar(x_366)) { + x_367 = lean_alloc_ctor(0, 4, 0); +} else { + x_367 = x_366; +} +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); +if (lean_is_scalar(x_362)) { + x_368 = lean_alloc_ctor(0, 6, 0); +} else { + x_368 = 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); +} else { + x_369 = x_248; +} +lean_ctor_set(x_369, 0, x_356); +lean_ctor_set(x_369, 1, x_368); +return x_369; +} +} +} +} +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; +} else { + lean_dec_ref(x_389); + x_399 = 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); +} else { + x_434 = x_399; +} +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); +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; +} else { + lean_dec_ref(x_8); + x_441 = 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); +} else { + x_444 = x_441; +} +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_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; +} +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); -x_451 = lean_ctor_get(x_445, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_445, 4); -lean_inc(x_452); -x_453 = lean_ctor_get(x_445, 5); -lean_inc(x_453); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - lean_ctor_release(x_445, 2); - lean_ctor_release(x_445, 3); - lean_ctor_release(x_445, 4); - lean_ctor_release(x_445, 5); - x_454 = x_445; +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; +} +block_432: +{ +if (lean_obj_tag(x_400) == 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_445); - x_454 = lean_box(0); + lean_dec_ref(x_401); + x_409 = lean_box(0); } -x_455 = lean_ctor_get(x_446, 0); -lean_inc(x_455); -x_456 = lean_ctor_get(x_446, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_446, 3); -lean_inc(x_457); -if (lean_is_exclusive(x_446)) { - lean_ctor_release(x_446, 0); - lean_ctor_release(x_446, 1); - lean_ctor_release(x_446, 2); - lean_ctor_release(x_446, 3); - x_458 = x_446; +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_446); - x_458 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_413)) { + x_414 = lean_alloc_ctor(0, 4, 0); } else { - x_459 = x_458; + x_414 = x_413; } -lean_ctor_set(x_459, 0, x_455); -lean_ctor_set(x_459, 1, x_456); -lean_ctor_set(x_459, 2, x_414); -lean_ctor_set(x_459, 3, x_457); -if (lean_is_scalar(x_454)) { - x_460 = lean_alloc_ctor(0, 6, 0); +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_460 = x_454; + x_415 = x_409; } -lean_ctor_set(x_460, 0, x_449); -lean_ctor_set(x_460, 1, x_450); -lean_ctor_set(x_460, 2, x_459); -lean_ctor_set(x_460, 3, x_451); -lean_ctor_set(x_460, 4, x_452); -lean_ctor_set(x_460, 5, x_453); -if (lean_is_scalar(x_448)) { - x_461 = lean_alloc_ctor(1, 2, 0); +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_461 = x_448; -} -lean_ctor_set(x_461, 0, x_447); -lean_ctor_set(x_461, 1, x_460); -return x_461; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_462 = lean_ctor_get(x_281, 2); -x_463 = lean_ctor_get(x_281, 0); -x_464 = lean_ctor_get(x_281, 1); -x_465 = lean_ctor_get(x_281, 3); -x_466 = lean_ctor_get(x_281, 4); -x_467 = lean_ctor_get(x_281, 5); -lean_inc(x_467); -lean_inc(x_466); -lean_inc(x_465); -lean_inc(x_462); -lean_inc(x_464); -lean_inc(x_463); -lean_dec(x_281); -x_468 = lean_ctor_get(x_462, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_462, 1); -lean_inc(x_469); -x_470 = lean_ctor_get(x_462, 2); -lean_inc(x_470); -x_471 = lean_ctor_get(x_462, 3); -lean_inc(x_471); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - lean_ctor_release(x_462, 2); - lean_ctor_release(x_462, 3); - x_472 = x_462; +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_inc(x_420); +x_421 = lean_ctor_get(x_401, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_401, 4); +lean_inc(x_422); +x_423 = lean_ctor_get(x_401, 5); +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_462); - x_472 = lean_box(0); + lean_dec_ref(x_401); + x_424 = lean_box(0); } -x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_472)) { - x_474 = 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); +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; } else { - x_474 = x_472; + lean_dec_ref(x_417); + x_428 = lean_box(0); } -lean_ctor_set(x_474, 0, x_468); -lean_ctor_set(x_474, 1, x_469); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_471); -x_475 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_475, 0, x_463); -lean_ctor_set(x_475, 1, x_464); -lean_ctor_set(x_475, 2, x_474); -lean_ctor_set(x_475, 3, x_465); -lean_ctor_set(x_475, 4, x_466); -lean_ctor_set(x_475, 5, x_467); -x_476 = lean_ctor_get(x_8, 0); -lean_inc(x_476); -x_477 = lean_ctor_get(x_8, 1); -lean_inc(x_477); -x_478 = lean_ctor_get(x_8, 2); -lean_inc(x_478); -x_479 = lean_ctor_get(x_8, 3); -lean_inc(x_479); -x_480 = lean_ctor_get(x_8, 4); -lean_inc(x_480); -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_481 = x_8; +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_8); - x_481 = lean_box(0); + x_429 = x_428; } -x_482 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_482, 0, x_282); -lean_ctor_set(x_482, 1, x_24); -x_483 = lean_array_push(x_478, x_482); -if (lean_is_scalar(x_481)) { - x_484 = lean_alloc_ctor(0, 5, 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); } else { - x_484 = x_481; + x_430 = x_424; } -lean_ctor_set(x_484, 0, x_476); -lean_ctor_set(x_484, 1, x_477); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_479); -lean_ctor_set(x_484, 4, x_480); -x_485 = 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_284, x_484, x_475); -if (lean_obj_tag(x_485) == 0) -{ -lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_486 = lean_ctor_get(x_485, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_486, 2); -lean_inc(x_487); -x_488 = lean_ctor_get(x_485, 0); -lean_inc(x_488); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_489 = x_485; +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); } else { - lean_dec_ref(x_485); - x_489 = lean_box(0); + x_431 = x_248; } -x_490 = lean_ctor_get(x_486, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_486, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_486, 3); -lean_inc(x_492); -x_493 = lean_ctor_get(x_486, 4); -lean_inc(x_493); -x_494 = lean_ctor_get(x_486, 5); -lean_inc(x_494); -if (lean_is_exclusive(x_486)) { - lean_ctor_release(x_486, 0); - lean_ctor_release(x_486, 1); - lean_ctor_release(x_486, 2); - lean_ctor_release(x_486, 3); - lean_ctor_release(x_486, 4); - lean_ctor_release(x_486, 5); - x_495 = x_486; -} else { - lean_dec_ref(x_486); - x_495 = lean_box(0); +lean_ctor_set(x_431, 0, x_418); +lean_ctor_set(x_431, 1, x_430); +return x_431; } -x_496 = lean_ctor_get(x_487, 0); -lean_inc(x_496); -x_497 = lean_ctor_get(x_487, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_487, 3); -lean_inc(x_498); -if (lean_is_exclusive(x_487)) { - lean_ctor_release(x_487, 0); - lean_ctor_release(x_487, 1); - lean_ctor_release(x_487, 2); - lean_ctor_release(x_487, 3); - x_499 = x_487; -} else { - lean_dec_ref(x_487); - x_499 = lean_box(0); -} -if (lean_is_scalar(x_499)) { - x_500 = lean_alloc_ctor(0, 4, 0); -} else { - x_500 = x_499; -} -lean_ctor_set(x_500, 0, x_496); -lean_ctor_set(x_500, 1, x_497); -lean_ctor_set(x_500, 2, x_470); -lean_ctor_set(x_500, 3, x_498); -if (lean_is_scalar(x_495)) { - x_501 = lean_alloc_ctor(0, 6, 0); -} else { - x_501 = x_495; -} -lean_ctor_set(x_501, 0, x_490); -lean_ctor_set(x_501, 1, x_491); -lean_ctor_set(x_501, 2, x_500); -lean_ctor_set(x_501, 3, x_492); -lean_ctor_set(x_501, 4, x_493); -lean_ctor_set(x_501, 5, x_494); -if (lean_is_scalar(x_489)) { - x_502 = lean_alloc_ctor(0, 2, 0); -} else { - x_502 = x_489; -} -lean_ctor_set(x_502, 0, x_488); -lean_ctor_set(x_502, 1, x_501); -return x_502; -} -else -{ -lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_503 = lean_ctor_get(x_485, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_503, 2); -lean_inc(x_504); -x_505 = lean_ctor_get(x_485, 0); -lean_inc(x_505); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_506 = x_485; -} else { - lean_dec_ref(x_485); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_503, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_503, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_503, 3); -lean_inc(x_509); -x_510 = lean_ctor_get(x_503, 4); -lean_inc(x_510); -x_511 = lean_ctor_get(x_503, 5); -lean_inc(x_511); -if (lean_is_exclusive(x_503)) { - lean_ctor_release(x_503, 0); - lean_ctor_release(x_503, 1); - lean_ctor_release(x_503, 2); - lean_ctor_release(x_503, 3); - lean_ctor_release(x_503, 4); - lean_ctor_release(x_503, 5); - x_512 = x_503; -} else { - lean_dec_ref(x_503); - x_512 = lean_box(0); -} -x_513 = lean_ctor_get(x_504, 0); -lean_inc(x_513); -x_514 = lean_ctor_get(x_504, 1); -lean_inc(x_514); -x_515 = lean_ctor_get(x_504, 3); -lean_inc(x_515); -if (lean_is_exclusive(x_504)) { - lean_ctor_release(x_504, 0); - lean_ctor_release(x_504, 1); - lean_ctor_release(x_504, 2); - lean_ctor_release(x_504, 3); - x_516 = x_504; -} else { - lean_dec_ref(x_504); - x_516 = lean_box(0); -} -if (lean_is_scalar(x_516)) { - x_517 = lean_alloc_ctor(0, 4, 0); -} else { - x_517 = x_516; -} -lean_ctor_set(x_517, 0, x_513); -lean_ctor_set(x_517, 1, x_514); -lean_ctor_set(x_517, 2, x_470); -lean_ctor_set(x_517, 3, x_515); -if (lean_is_scalar(x_512)) { - x_518 = lean_alloc_ctor(0, 6, 0); -} else { - x_518 = x_512; -} -lean_ctor_set(x_518, 0, x_507); -lean_ctor_set(x_518, 1, x_508); -lean_ctor_set(x_518, 2, x_517); -lean_ctor_set(x_518, 3, x_509); -lean_ctor_set(x_518, 4, x_510); -lean_ctor_set(x_518, 5, x_511); -if (lean_is_scalar(x_506)) { - x_519 = lean_alloc_ctor(1, 2, 0); -} else { - x_519 = x_506; -} -lean_ctor_set(x_519, 0, x_505); -lean_ctor_set(x_519, 1, x_518); -return x_519; } } } } else { -uint8_t x_520; +uint8_t x_452; 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_520 = !lean_is_exclusive(x_275); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_241); +if (x_452 == 0) { -return x_275; +return x_241; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_275, 0); -x_522 = lean_ctor_get(x_275, 1); -lean_inc(x_522); -lean_inc(x_521); -lean_dec(x_275); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } @@ -17214,7 +15766,7 @@ return x_523; } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -17222,52 +15774,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_29); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_29); +if (x_456 == 0) { return x_29; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_29, 0); -x_526 = lean_ctor_get(x_29, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_29); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } else { -uint8_t x_528; +uint8_t x_460; 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_528 = !lean_is_exclusive(x_25); -if (x_528 == 0) +x_460 = !lean_is_exclusive(x_25); +if (x_460 == 0) { return x_25; } else { -lean_object* x_529; lean_object* x_530; lean_object* x_531; -x_529 = lean_ctor_get(x_25, 0); -x_530 = lean_ctor_get(x_25, 1); -lean_inc(x_530); -lean_inc(x_529); +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_dec(x_25); -x_531 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_531, 0, x_529); -lean_ctor_set(x_531, 1, x_530); -return x_531; +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; } } } @@ -31598,2153 +30150,1791 @@ goto _start; } case 1: { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; lean_dec(x_28); x_35 = lean_ctor_get(x_29, 1); lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_ctor_get(x_30, 0); -lean_inc(x_36); +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + x_36 = x_29; +} else { + lean_dec_ref(x_29); + x_36 = lean_box(0); +} +x_37 = lean_ctor_get(x_30, 0); +lean_inc(x_37); lean_dec(x_30); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_add(x_7, x_37); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_add(x_7, x_38); lean_dec(x_7); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) +x_40 = !lean_is_exclusive(x_35); +if (x_40 == 0) { -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 2); +x_42 = !lean_is_exclusive(x_41); +if (x_42 == 0) { -lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_42 = lean_ctor_get(x_40, 2); -x_43 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_40, 2, x_43); -x_44 = !lean_is_exclusive(x_8); -if (x_44 == 0) +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +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) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = lean_ctor_get(x_8, 2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_24); -x_47 = lean_array_push(x_45, x_46); -lean_ctor_set(x_8, 2, x_47); -x_48 = 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_38, x_8, x_35); -if (lean_obj_tag(x_48) == 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_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_49, 2); -lean_inc(x_50); -x_51 = !lean_is_exclusive(x_48); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_48, 1); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_49, 2); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_50); -if (x_55 == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_50, 2); -lean_dec(x_56); -lean_ctor_set(x_50, 2, x_42); -return x_48; +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_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_50, 0); -x_58 = lean_ctor_get(x_50, 1); -x_59 = lean_ctor_get(x_50, 3); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_50); -x_60 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_42); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_49, 2, x_60); -return x_48; +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_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; } } 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; -x_61 = lean_ctor_get(x_49, 0); -x_62 = lean_ctor_get(x_49, 1); -x_63 = lean_ctor_get(x_49, 3); -x_64 = lean_ctor_get(x_49, 4); -x_65 = lean_ctor_get(x_49, 5); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); +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_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; +} +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_44 = x_121; +x_45 = x_120; +goto block_94; +} +} +block_94: +{ +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 0); +lean_inc(x_47); +lean_dec(x_44); +x_48 = !lean_is_exclusive(x_45); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_45, 2); +lean_dec(x_49); +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_43); +if (lean_is_scalar(x_36)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_36; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +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); +if (lean_is_scalar(x_36)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_36; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_47); +lean_ctor_set(x_57, 1, x_45); +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_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_inc(x_62); lean_inc(x_61); -lean_dec(x_49); -x_66 = lean_ctor_get(x_50, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_50, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_50, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_69 = x_50; +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); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 3); +lean_inc(x_65); +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; } else { - lean_dec_ref(x_50); - x_69 = lean_box(0); + lean_dec_ref(x_46); + x_66 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_67 = x_66; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_42); -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_48, 1, x_71); -return x_48; +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); +if (lean_is_scalar(x_36)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_36; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_47); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } 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; lean_object* x_84; lean_object* x_85; -x_72 = lean_ctor_get(x_48, 0); -lean_inc(x_72); -lean_dec(x_48); -x_73 = lean_ctor_get(x_49, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 3); -lean_inc(x_75); -x_76 = lean_ctor_get(x_49, 4); -lean_inc(x_76); -x_77 = lean_ctor_get(x_49, 5); -lean_inc(x_77); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_78 = x_49; +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_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); +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_43); +if (lean_is_scalar(x_36)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_49); - x_78 = lean_box(0); + x_76 = x_36; } -x_79 = lean_ctor_get(x_50, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_45); +return x_76; +} +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_inc(x_79); -x_80 = lean_ctor_get(x_50, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_50, 3); -lean_inc(x_81); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_82 = x_50; +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); +if (lean_is_scalar(x_36)) { + x_81 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_50); - x_82 = lean_box(0); + x_81 = x_36; } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 4, 0); -} else { - x_83 = x_82; -} -lean_ctor_set(x_83, 0, x_79); -lean_ctor_set(x_83, 1, x_80); -lean_ctor_set(x_83, 2, x_42); -lean_ctor_set(x_83, 3, x_81); -if (lean_is_scalar(x_78)) { - x_84 = lean_alloc_ctor(0, 6, 0); -} else { - x_84 = x_78; -} -lean_ctor_set(x_84, 0, x_73); -lean_ctor_set(x_84, 1, x_74); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_75); -lean_ctor_set(x_84, 4, x_76); -lean_ctor_set(x_84, 5, x_77); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_72); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_81, 0, x_71); +lean_ctor_set(x_81, 1, x_45); +return x_81; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_48, 1); +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_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); +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_is_exclusive(x_48); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_48, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_86, 2); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_42); -return x_48; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -x_96 = lean_ctor_get(x_87, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -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_42); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_86, 2, x_97); -return x_48; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 0); -x_99 = lean_ctor_get(x_86, 1); -x_100 = lean_ctor_get(x_86, 3); -x_101 = lean_ctor_get(x_86, 4); -x_102 = lean_ctor_get(x_86, 5); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_86); -x_103 = lean_ctor_get(x_87, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 3); -lean_inc(x_105); -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_106 = 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; } else { - lean_dec_ref(x_87); - x_106 = lean_box(0); + lean_dec_ref(x_70); + x_90 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_107 = x_106; + x_91 = x_90; } -lean_ctor_set(x_107, 0, x_103); -lean_ctor_set(x_107, 1, x_104); -lean_ctor_set(x_107, 2, x_42); -lean_ctor_set(x_107, 3, x_105); -x_108 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_108, 0, x_98); -lean_ctor_set(x_108, 1, x_99); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_100); -lean_ctor_set(x_108, 4, x_101); -lean_ctor_set(x_108, 5, x_102); -lean_ctor_set(x_48, 1, x_108); -return x_48; -} -} -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; -x_109 = lean_ctor_get(x_48, 0); -lean_inc(x_109); -lean_dec(x_48); -x_110 = lean_ctor_get(x_86, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 3); -lean_inc(x_112); -x_113 = lean_ctor_get(x_86, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_86, 5); -lean_inc(x_114); -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_115 = x_86; +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); +if (lean_is_scalar(x_36)) { + x_93 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_86); - x_115 = lean_box(0); + x_93 = x_36; } -x_116 = lean_ctor_get(x_87, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_87, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 3); -lean_inc(x_118); -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_119 = x_87; -} else { - lean_dec_ref(x_87); - x_119 = lean_box(0); +lean_ctor_set(x_93, 0, x_71); +lean_ctor_set(x_93, 1, x_92); +return x_93; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_42); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_109); -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; -x_123 = lean_ctor_get(x_8, 0); -x_124 = lean_ctor_get(x_8, 1); -x_125 = lean_ctor_get(x_8, 2); -x_126 = lean_ctor_get(x_8, 3); -x_127 = lean_ctor_get(x_8, 4); -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; 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_dec(x_8); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_36); -lean_ctor_set(x_128, 1, x_24); -x_129 = lean_array_push(x_125, x_128); -x_130 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_130, 0, x_123); -lean_ctor_set(x_130, 1, x_124); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_126); -lean_ctor_set(x_130, 4, x_127); -x_131 = 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_38, x_130, x_35); -if (lean_obj_tag(x_131) == 0) -{ -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; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_135 = x_131; +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_131); + 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_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_132, 0); +x_136 = lean_ctor_get(x_128, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); +x_137 = lean_ctor_get(x_128, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 3); +x_138 = lean_ctor_get(x_128, 3); lean_inc(x_138); -x_139 = lean_ctor_get(x_132, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_132, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_141 = x_132; +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_132); - x_141 = lean_box(0); + lean_dec_ref(x_128); + x_139 = lean_box(0); } -x_142 = lean_ctor_get(x_133, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_133, 3); -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); - x_145 = x_133; +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_145 = lean_box(0); + x_140 = x_139; } -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_42); -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); +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_148 = lean_alloc_ctor(0, 2, 0); + x_141 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_135; + x_141 = x_135; } -lean_ctor_set(x_148, 0, x_134); -lean_ctor_set(x_148, 1, x_147); -return x_148; +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_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_131, 1); +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); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_131, 0); +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); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_152 = x_131; -} else { - lean_dec_ref(x_131); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); +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_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; +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_149); - x_158 = lean_box(0); + lean_dec_ref(x_143); + x_154 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_150); - x_162 = lean_box(0); + x_155 = x_154; } -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); +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_163 = x_162; + x_156 = x_150; } -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_42); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); +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_164 = x_158; + x_157 = x_36; } -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(1, 2, 0); -} else { - x_165 = x_152; +lean_ctor_set(x_157, 0, x_144); +lean_ctor_set(x_157, 1, x_156); +return x_157; } -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; } } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_166 = lean_ctor_get(x_40, 0); -x_167 = lean_ctor_get(x_40, 1); -x_168 = lean_ctor_get(x_40, 2); -x_169 = lean_ctor_get(x_40, 3); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_40); -x_170 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_171 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_171, 0, x_166); -lean_ctor_set(x_171, 1, x_167); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_169); -lean_ctor_set(x_35, 2, x_171); -x_172 = lean_ctor_get(x_8, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_8, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_8, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_8, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_8, 4); -lean_inc(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_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); 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_177 = x_8; + x_229 = x_8; } else { lean_dec_ref(x_8); - x_177 = lean_box(0); + x_229 = lean_box(0); } -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_36); -lean_ctor_set(x_178, 1, x_24); -x_179 = lean_array_push(x_174, x_178); -if (lean_is_scalar(x_177)) { - x_180 = lean_alloc_ctor(0, 5, 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_232 = lean_alloc_ctor(0, 5, 0); } else { - x_180 = x_177; + x_232 = x_229; } -lean_ctor_set(x_180, 0, x_172); -lean_ctor_set(x_180, 1, x_173); -lean_ctor_set(x_180, 2, x_179); -lean_ctor_set(x_180, 3, x_175); -lean_ctor_set(x_180, 4, x_176); -x_181 = 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_38, x_180, x_35); -if (lean_obj_tag(x_181) == 0) +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_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_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_196; lean_object* x_197; lean_object* x_198; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_182, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_182, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_182, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_182, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_182, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - lean_ctor_release(x_182, 2); - lean_ctor_release(x_182, 3); - lean_ctor_release(x_182, 4); - lean_ctor_release(x_182, 5); - x_191 = x_182; -} else { - lean_dec_ref(x_182); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_183, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_183, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_183, 3); -lean_inc(x_194); -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); - x_195 = x_183; -} else { - lean_dec_ref(x_183); - 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_168); -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_185)) { - x_198 = lean_alloc_ctor(0, 2, 0); -} else { - x_198 = x_185; -} -lean_ctor_set(x_198, 0, x_184); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_188 = x_236; +x_189 = x_235; +goto block_220; } 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; lean_object* x_214; lean_object* x_215; -x_199 = lean_ctor_get(x_181, 1); +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_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; +} 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_199, 2); +x_200 = lean_ctor_get(x_190, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_181, 0); -lean_inc(x_201); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_202 = x_181; +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_181); - x_202 = lean_box(0); + lean_dec_ref(x_190); + x_201 = lean_box(0); } -x_203 = lean_ctor_get(x_199, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_199, 3); +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_199, 4); +x_206 = lean_ctor_get(x_188, 0); lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 5); +lean_dec(x_188); +x_207 = lean_ctor_get(x_189, 0); lean_inc(x_207); -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); - lean_ctor_release(x_199, 4); - lean_ctor_release(x_199, 5); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = lean_ctor_get(x_200, 0); +x_208 = lean_ctor_get(x_189, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_189, 3); lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 1); +x_210 = lean_ctor_get(x_189, 4); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 3); +x_211 = lean_ctor_get(x_189, 5); 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); - x_212 = x_200; +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; } else { - lean_dec_ref(x_200); + lean_dec_ref(x_189); 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); +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; +} else { + lean_dec_ref(x_205); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 4, 0); +} else { + x_217 = x_216; +} +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_213 = lean_alloc_ctor(0, 4, 0); + x_218 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_218 = x_212; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_168); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_36)) { + x_219 = lean_alloc_ctor(0, 2, 0); } else { - x_214 = x_208; + x_219 = x_36; } -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); -if (lean_is_scalar(x_202)) { - x_215 = lean_alloc_ctor(1, 2, 0); -} else { - x_215 = x_202; +lean_ctor_set(x_219, 0, x_206); +lean_ctor_set(x_219, 1, x_218); +return x_219; } -lean_ctor_set(x_215, 0, x_201); -lean_ctor_set(x_215, 1, x_214); -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_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; -x_216 = lean_ctor_get(x_35, 2); -x_217 = lean_ctor_get(x_35, 0); -x_218 = lean_ctor_get(x_35, 1); -x_219 = lean_ctor_get(x_35, 3); -x_220 = lean_ctor_get(x_35, 4); -x_221 = lean_ctor_get(x_35, 5); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); -lean_inc(x_216); -lean_inc(x_218); -lean_inc(x_217); -lean_dec(x_35); -x_222 = lean_ctor_get(x_216, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_216, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_216, 3); -lean_inc(x_225); -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_226 = x_216; -} else { - lean_dec_ref(x_216); - x_226 = lean_box(0); -} -x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 4, 0); -} else { - x_228 = x_226; -} -lean_ctor_set(x_228, 0, x_222); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_225); -x_229 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_229, 0, x_217); -lean_ctor_set(x_229, 1, x_218); -lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_219); -lean_ctor_set(x_229, 4, x_220); -lean_ctor_set(x_229, 5, x_221); -x_230 = lean_ctor_get(x_8, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_8, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_8, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_8, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_8, 4); -lean_inc(x_234); -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_235 = x_8; -} else { - lean_dec_ref(x_8); - x_235 = lean_box(0); -} -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_36); -lean_ctor_set(x_236, 1, x_24); -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_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_238, x_229); -if (lean_obj_tag(x_239) == 0) -{ -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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_224); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -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; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; -} else { - lean_dec_ref(x_257); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; -} else { - lean_dec_ref(x_258); - x_270 = lean_box(0); -} -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); -} else { - x_271 = x_270; -} -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_224); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); -} else { - x_272 = x_266; -} -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(1, 2, 0); -} else { - x_273 = x_260; -} -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } default: { -lean_object* x_274; lean_object* x_275; -x_274 = lean_ctor_get(x_29, 1); -lean_inc(x_274); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_29, 1); +lean_inc(x_240); lean_dec(x_29); lean_inc(x_8); -x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); -if (lean_obj_tag(x_275) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_276; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -if (lean_obj_tag(x_276) == 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_277; lean_object* x_278; lean_object* x_279; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_24); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_7, x_278); +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); lean_dec(x_7); -x_7 = x_279; -x_9 = x_277; +x_7 = x_245; +x_9 = x_243; goto _start; } else { -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; uint8_t x_285; -x_281 = lean_ctor_get(x_275, 1); -lean_inc(x_281); -lean_dec(x_275); -x_282 = lean_ctor_get(x_276, 0); -lean_inc(x_282); -lean_dec(x_276); -x_283 = lean_unsigned_to_nat(1u); -x_284 = lean_nat_add(x_7, x_283); +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_241); + x_248 = 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_285 = !lean_is_exclusive(x_281); -if (x_285 == 0) +x_252 = !lean_is_exclusive(x_247); +if (x_252 == 0) { -lean_object* x_286; uint8_t x_287; -x_286 = lean_ctor_get(x_281, 2); -x_287 = !lean_is_exclusive(x_286); -if (x_287 == 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_288; lean_object* x_289; uint8_t x_290; -x_288 = lean_ctor_get(x_286, 2); -x_289 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_286, 2, x_289); -x_290 = !lean_is_exclusive(x_8); -if (x_290 == 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_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_291 = lean_ctor_get(x_8, 2); -x_292 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_292, 0, x_282); -lean_ctor_set(x_292, 1, x_24); -x_293 = lean_array_push(x_291, x_292); -lean_ctor_set(x_8, 2, x_293); -x_294 = 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_284, x_8, x_281); -if (lean_obj_tag(x_294) == 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_295; lean_object* x_296; uint8_t x_297; -x_295 = lean_ctor_get(x_294, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_295, 2); -lean_inc(x_296); -x_297 = !lean_is_exclusive(x_294); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_294, 1); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_295); -if (x_299 == 0) -{ -lean_object* x_300; uint8_t x_301; -x_300 = lean_ctor_get(x_295, 2); -lean_dec(x_300); -x_301 = !lean_is_exclusive(x_296); -if (x_301 == 0) -{ -lean_object* x_302; -x_302 = lean_ctor_get(x_296, 2); -lean_dec(x_302); -lean_ctor_set(x_296, 2, x_288); -return x_294; -} -else -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_296, 0); -x_304 = lean_ctor_get(x_296, 1); -x_305 = lean_ctor_get(x_296, 3); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_296); -x_306 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_288); -lean_ctor_set(x_306, 3, x_305); -lean_ctor_set(x_295, 2, x_306); -return x_294; -} -} -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; -x_307 = lean_ctor_get(x_295, 0); -x_308 = lean_ctor_get(x_295, 1); -x_309 = lean_ctor_get(x_295, 3); -x_310 = lean_ctor_get(x_295, 4); -x_311 = lean_ctor_get(x_295, 5); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_dec(x_295); -x_312 = lean_ctor_get(x_296, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_296, 1); +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_296, 3); +x_314 = lean_ctor_get(x_312, 1); lean_inc(x_314); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_315 = x_296; -} else { - lean_dec_ref(x_296); - x_315 = lean_box(0); +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; } -if (lean_is_scalar(x_315)) { - x_316 = lean_alloc_ctor(0, 4, 0); -} else { - x_316 = x_315; -} -lean_ctor_set(x_316, 0, x_312); -lean_ctor_set(x_316, 1, x_313); -lean_ctor_set(x_316, 2, x_288); -lean_ctor_set(x_316, 3, x_314); -x_317 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_317, 0, x_307); -lean_ctor_set(x_317, 1, x_308); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_309); -lean_ctor_set(x_317, 4, x_310); -lean_ctor_set(x_317, 5, x_311); -lean_ctor_set(x_294, 1, x_317); -return x_294; +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_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_318 = lean_ctor_get(x_294, 0); -lean_inc(x_318); -lean_dec(x_294); -x_319 = lean_ctor_get(x_295, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_295, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_295, 3); -lean_inc(x_321); -x_322 = lean_ctor_get(x_295, 4); -lean_inc(x_322); -x_323 = lean_ctor_get(x_295, 5); +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); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - lean_ctor_release(x_295, 2); - lean_ctor_release(x_295, 3); - lean_ctor_release(x_295, 4); - lean_ctor_release(x_295, 5); - x_324 = x_295; -} else { - lean_dec_ref(x_295); - x_324 = lean_box(0); -} -x_325 = lean_ctor_get(x_296, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_296, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_296, 3); -lean_inc(x_327); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_328 = x_296; -} else { - lean_dec_ref(x_296); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 4, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_325); -lean_ctor_set(x_329, 1, x_326); -lean_ctor_set(x_329, 2, x_288); -lean_ctor_set(x_329, 3, x_327); -if (lean_is_scalar(x_324)) { - x_330 = lean_alloc_ctor(0, 6, 0); -} else { - x_330 = x_324; -} -lean_ctor_set(x_330, 0, x_319); -lean_ctor_set(x_330, 1, x_320); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_321); -lean_ctor_set(x_330, 4, x_322); -lean_ctor_set(x_330, 5, x_323); -x_331 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_331, 0, x_318); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} -} -else -{ -lean_object* x_332; lean_object* x_333; uint8_t x_334; -x_332 = lean_ctor_get(x_294, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_332, 2); -lean_inc(x_333); -x_334 = !lean_is_exclusive(x_294); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_294, 1); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_332); -if (x_336 == 0) -{ -lean_object* x_337; uint8_t x_338; -x_337 = lean_ctor_get(x_332, 2); -lean_dec(x_337); -x_338 = !lean_is_exclusive(x_333); -if (x_338 == 0) -{ -lean_object* x_339; -x_339 = lean_ctor_get(x_333, 2); -lean_dec(x_339); -lean_ctor_set(x_333, 2, x_288); -return x_294; -} -else -{ -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_340 = lean_ctor_get(x_333, 0); -x_341 = lean_ctor_get(x_333, 1); -x_342 = lean_ctor_get(x_333, 3); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_333); -x_343 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_343, 0, x_340); -lean_ctor_set(x_343, 1, x_341); -lean_ctor_set(x_343, 2, x_288); -lean_ctor_set(x_343, 3, x_342); -lean_ctor_set(x_332, 2, x_343); -return x_294; -} -} -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; -x_344 = lean_ctor_get(x_332, 0); -x_345 = lean_ctor_get(x_332, 1); -x_346 = lean_ctor_get(x_332, 3); -x_347 = lean_ctor_get(x_332, 4); -x_348 = lean_ctor_get(x_332, 5); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_dec(x_332); -x_349 = lean_ctor_get(x_333, 0); -lean_inc(x_349); -x_350 = lean_ctor_get(x_333, 1); -lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 3); -lean_inc(x_351); -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); - x_352 = x_333; -} else { - lean_dec_ref(x_333); - x_352 = lean_box(0); -} -if (lean_is_scalar(x_352)) { - x_353 = lean_alloc_ctor(0, 4, 0); -} else { - x_353 = x_352; -} -lean_ctor_set(x_353, 0, x_349); -lean_ctor_set(x_353, 1, x_350); -lean_ctor_set(x_353, 2, x_288); -lean_ctor_set(x_353, 3, x_351); -x_354 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_354, 0, x_344); -lean_ctor_set(x_354, 1, x_345); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_346); -lean_ctor_set(x_354, 4, x_347); -lean_ctor_set(x_354, 5, x_348); -lean_ctor_set(x_294, 1, x_354); -return x_294; -} -} -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; -x_355 = lean_ctor_get(x_294, 0); -lean_inc(x_355); -lean_dec(x_294); -x_356 = lean_ctor_get(x_332, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_332, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_332, 3); -lean_inc(x_358); -x_359 = lean_ctor_get(x_332, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_332, 5); -lean_inc(x_360); -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); - lean_ctor_release(x_332, 5); - x_361 = x_332; -} else { - lean_dec_ref(x_332); - x_361 = lean_box(0); -} -x_362 = lean_ctor_get(x_333, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_333, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_333, 3); -lean_inc(x_364); -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); - x_365 = x_333; -} else { - lean_dec_ref(x_333); - x_365 = lean_box(0); -} -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 4, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_362); -lean_ctor_set(x_366, 1, x_363); -lean_ctor_set(x_366, 2, x_288); -lean_ctor_set(x_366, 3, x_364); -if (lean_is_scalar(x_361)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_361; -} -lean_ctor_set(x_367, 0, x_356); -lean_ctor_set(x_367, 1, x_357); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_358); -lean_ctor_set(x_367, 4, x_359); -lean_ctor_set(x_367, 5, x_360); -x_368 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_368, 0, x_355); -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; -x_369 = lean_ctor_get(x_8, 0); -x_370 = lean_ctor_get(x_8, 1); -x_371 = lean_ctor_get(x_8, 2); -x_372 = lean_ctor_get(x_8, 3); -x_373 = lean_ctor_get(x_8, 4); -lean_inc(x_373); -lean_inc(x_372); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); +lean_inc(x_322); +lean_inc(x_321); +lean_inc(x_320); +lean_inc(x_319); lean_dec(x_8); -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_282); -lean_ctor_set(x_374, 1, x_24); -x_375 = lean_array_push(x_371, x_374); -x_376 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_376, 0, x_369); -lean_ctor_set(x_376, 1, x_370); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_372); -lean_ctor_set(x_376, 4, x_373); -x_377 = 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_284, x_376, x_281); -if (lean_obj_tag(x_377) == 0) +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_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_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; -x_378 = lean_ctor_get(x_377, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_378, 2); -lean_inc(x_379); -x_380 = lean_ctor_get(x_377, 0); -lean_inc(x_380); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_381 = x_377; -} else { - lean_dec_ref(x_377); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 4); -lean_inc(x_385); -x_386 = lean_ctor_get(x_378, 5); -lean_inc(x_386); -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); - lean_ctor_release(x_378, 4); - lean_ctor_release(x_378, 5); - x_387 = x_378; -} else { - lean_dec_ref(x_378); - x_387 = lean_box(0); -} -x_388 = lean_ctor_get(x_379, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_379, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_379, 3); -lean_inc(x_390); -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_391 = x_379; -} else { - lean_dec_ref(x_379); - x_391 = lean_box(0); -} -if (lean_is_scalar(x_391)) { - x_392 = lean_alloc_ctor(0, 4, 0); -} else { - x_392 = x_391; -} -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_288); -lean_ctor_set(x_392, 3, x_390); -if (lean_is_scalar(x_387)) { - x_393 = lean_alloc_ctor(0, 6, 0); -} else { - x_393 = x_387; -} -lean_ctor_set(x_393, 0, x_382); -lean_ctor_set(x_393, 1, x_383); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_384); -lean_ctor_set(x_393, 4, x_385); -lean_ctor_set(x_393, 5, x_386); -if (lean_is_scalar(x_381)) { - x_394 = lean_alloc_ctor(0, 2, 0); -} else { - x_394 = x_381; -} -lean_ctor_set(x_394, 0, x_380); -lean_ctor_set(x_394, 1, x_393); -return x_394; +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_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_409; lean_object* x_410; lean_object* x_411; -x_395 = lean_ctor_get(x_377, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_377, 0); -lean_inc(x_397); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_398 = x_377; -} else { - lean_dec_ref(x_377); - x_398 = lean_box(0); +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; } -x_399 = lean_ctor_get(x_395, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_395, 5); -lean_inc(x_403); -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_404 = x_395; -} else { - lean_dec_ref(x_395); - x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_396, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_396, 3); -lean_inc(x_407); -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_408 = x_396; +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); +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 { - lean_dec_ref(x_396); - x_408 = lean_box(0); + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); } -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); +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; +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_409 = x_408; + x_269 = x_248; + lean_ctor_set_tag(x_269, 1); } -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_288); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_269, 0, x_259); +lean_ctor_set(x_269, 1, x_257); +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; 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_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 { - x_410 = x_404; + lean_dec_ref(x_258); + x_278 = lean_box(0); } -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_398)) { - x_411 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_278)) { + x_279 = lean_alloc_ctor(0, 4, 0); } else { - x_411 = x_398; + x_279 = x_278; +} +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, 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); +} else { + x_281 = x_248; + lean_ctor_set_tag(x_281, 1); +} +lean_ctor_set(x_281, 0, x_259); +lean_ctor_set(x_281, 1, x_280); +return x_281; +} +} +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_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_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); +} else { + x_293 = x_248; +} +lean_ctor_set(x_293, 0, x_283); +lean_ctor_set(x_293, 1, x_257); +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_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); +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; +} else { + lean_dec_ref(x_282); + x_302 = lean_box(0); +} +if (lean_is_scalar(x_302)) { + x_303 = lean_alloc_ctor(0, 4, 0); +} else { + x_303 = x_302; +} +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); +} else { + x_305 = x_248; +} +lean_ctor_set(x_305, 0, x_283); +lean_ctor_set(x_305, 1, x_304); +return x_305; } -lean_ctor_set(x_411, 0, x_397); -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; lean_object* x_427; -x_412 = lean_ctor_get(x_286, 0); -x_413 = lean_ctor_get(x_286, 1); -x_414 = lean_ctor_get(x_286, 2); -x_415 = lean_ctor_get(x_286, 3); -lean_inc(x_415); -lean_inc(x_414); -lean_inc(x_413); -lean_inc(x_412); -lean_dec(x_286); -x_416 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_417 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_417, 0, x_412); -lean_ctor_set(x_417, 1, x_413); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_415); -lean_ctor_set(x_281, 2, x_417); -x_418 = lean_ctor_get(x_8, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_8, 1); -lean_inc(x_419); -x_420 = lean_ctor_get(x_8, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_8, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_8, 4); -lean_inc(x_422); +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); 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_423 = x_8; + x_378 = x_8; } else { lean_dec_ref(x_8); - x_423 = lean_box(0); + x_378 = lean_box(0); } -x_424 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_424, 0, x_282); -lean_ctor_set(x_424, 1, x_24); -x_425 = lean_array_push(x_420, x_424); -if (lean_is_scalar(x_423)) { - x_426 = lean_alloc_ctor(0, 5, 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); } else { - x_426 = x_423; + x_381 = x_378; } -lean_ctor_set(x_426, 0, x_418); -lean_ctor_set(x_426, 1, x_419); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_421); -lean_ctor_set(x_426, 4, x_422); -x_427 = 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_284, x_426, x_281); -if (lean_obj_tag(x_427) == 0) +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_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_428 = lean_ctor_get(x_427, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_428, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_427, 0); -lean_inc(x_430); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_431 = x_427; -} else { - lean_dec_ref(x_427); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_428, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_428, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_428, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_428, 4); -lean_inc(x_435); -x_436 = lean_ctor_get(x_428, 5); -lean_inc(x_436); -if (lean_is_exclusive(x_428)) { - lean_ctor_release(x_428, 0); - lean_ctor_release(x_428, 1); - lean_ctor_release(x_428, 2); - lean_ctor_release(x_428, 3); - lean_ctor_release(x_428, 4); - lean_ctor_release(x_428, 5); - x_437 = x_428; -} else { - lean_dec_ref(x_428); - x_437 = lean_box(0); -} -x_438 = lean_ctor_get(x_429, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_429, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_429, 3); -lean_inc(x_440); -if (lean_is_exclusive(x_429)) { - lean_ctor_release(x_429, 0); - lean_ctor_release(x_429, 1); - lean_ctor_release(x_429, 2); - lean_ctor_release(x_429, 3); - x_441 = x_429; -} else { - lean_dec_ref(x_429); - x_441 = lean_box(0); -} -if (lean_is_scalar(x_441)) { - x_442 = lean_alloc_ctor(0, 4, 0); -} else { - x_442 = x_441; -} -lean_ctor_set(x_442, 0, x_438); -lean_ctor_set(x_442, 1, x_439); -lean_ctor_set(x_442, 2, x_414); -lean_ctor_set(x_442, 3, x_440); -if (lean_is_scalar(x_437)) { - x_443 = lean_alloc_ctor(0, 6, 0); -} else { - x_443 = x_437; -} -lean_ctor_set(x_443, 0, x_432); -lean_ctor_set(x_443, 1, x_433); -lean_ctor_set(x_443, 2, x_442); -lean_ctor_set(x_443, 3, x_434); -lean_ctor_set(x_443, 4, x_435); -lean_ctor_set(x_443, 5, x_436); -if (lean_is_scalar(x_431)) { - x_444 = lean_alloc_ctor(0, 2, 0); -} else { - x_444 = x_431; -} -lean_ctor_set(x_444, 0, x_430); -lean_ctor_set(x_444, 1, x_443); -return x_444; +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; } else { -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_445 = lean_ctor_get(x_427, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_445, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_427, 0); -lean_inc(x_447); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_448 = x_427; -} else { - lean_dec_ref(x_427); - x_448 = lean_box(0); +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; } +block_370: +{ +if (lean_obj_tag(x_338) == 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_inc(x_355); +x_356 = lean_ctor_get(x_338, 0); +lean_inc(x_356); +lean_dec(x_338); +x_357 = lean_ctor_get(x_339, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_339, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_339, 3); +lean_inc(x_359); +x_360 = lean_ctor_get(x_339, 4); +lean_inc(x_360); +x_361 = lean_ctor_get(x_339, 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; +} else { + lean_dec_ref(x_339); + x_362 = lean_box(0); +} +x_363 = lean_ctor_get(x_355, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_355, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_355, 3); +lean_inc(x_365); +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; +} else { + lean_dec_ref(x_355); + x_366 = lean_box(0); +} +if (lean_is_scalar(x_366)) { + x_367 = lean_alloc_ctor(0, 4, 0); +} else { + x_367 = x_366; +} +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); +if (lean_is_scalar(x_362)) { + x_368 = lean_alloc_ctor(0, 6, 0); +} else { + x_368 = 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); +} else { + x_369 = x_248; +} +lean_ctor_set(x_369, 0, x_356); +lean_ctor_set(x_369, 1, x_368); +return x_369; +} +} +} +} +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; +} else { + lean_dec_ref(x_389); + x_399 = 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); +} else { + x_434 = x_399; +} +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); +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; +} else { + lean_dec_ref(x_8); + x_441 = 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); +} else { + x_444 = x_441; +} +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_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; +} +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); -x_451 = lean_ctor_get(x_445, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_445, 4); -lean_inc(x_452); -x_453 = lean_ctor_get(x_445, 5); -lean_inc(x_453); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - lean_ctor_release(x_445, 2); - lean_ctor_release(x_445, 3); - lean_ctor_release(x_445, 4); - lean_ctor_release(x_445, 5); - x_454 = x_445; +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; +} +block_432: +{ +if (lean_obj_tag(x_400) == 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_445); - x_454 = lean_box(0); + lean_dec_ref(x_401); + x_409 = lean_box(0); } -x_455 = lean_ctor_get(x_446, 0); -lean_inc(x_455); -x_456 = lean_ctor_get(x_446, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_446, 3); -lean_inc(x_457); -if (lean_is_exclusive(x_446)) { - lean_ctor_release(x_446, 0); - lean_ctor_release(x_446, 1); - lean_ctor_release(x_446, 2); - lean_ctor_release(x_446, 3); - x_458 = x_446; +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_446); - x_458 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_413)) { + x_414 = lean_alloc_ctor(0, 4, 0); } else { - x_459 = x_458; + x_414 = x_413; } -lean_ctor_set(x_459, 0, x_455); -lean_ctor_set(x_459, 1, x_456); -lean_ctor_set(x_459, 2, x_414); -lean_ctor_set(x_459, 3, x_457); -if (lean_is_scalar(x_454)) { - x_460 = lean_alloc_ctor(0, 6, 0); +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_460 = x_454; + x_415 = x_409; } -lean_ctor_set(x_460, 0, x_449); -lean_ctor_set(x_460, 1, x_450); -lean_ctor_set(x_460, 2, x_459); -lean_ctor_set(x_460, 3, x_451); -lean_ctor_set(x_460, 4, x_452); -lean_ctor_set(x_460, 5, x_453); -if (lean_is_scalar(x_448)) { - x_461 = lean_alloc_ctor(1, 2, 0); +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_461 = x_448; -} -lean_ctor_set(x_461, 0, x_447); -lean_ctor_set(x_461, 1, x_460); -return x_461; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_462 = lean_ctor_get(x_281, 2); -x_463 = lean_ctor_get(x_281, 0); -x_464 = lean_ctor_get(x_281, 1); -x_465 = lean_ctor_get(x_281, 3); -x_466 = lean_ctor_get(x_281, 4); -x_467 = lean_ctor_get(x_281, 5); -lean_inc(x_467); -lean_inc(x_466); -lean_inc(x_465); -lean_inc(x_462); -lean_inc(x_464); -lean_inc(x_463); -lean_dec(x_281); -x_468 = lean_ctor_get(x_462, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_462, 1); -lean_inc(x_469); -x_470 = lean_ctor_get(x_462, 2); -lean_inc(x_470); -x_471 = lean_ctor_get(x_462, 3); -lean_inc(x_471); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - lean_ctor_release(x_462, 2); - lean_ctor_release(x_462, 3); - x_472 = x_462; +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_inc(x_420); +x_421 = lean_ctor_get(x_401, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_401, 4); +lean_inc(x_422); +x_423 = lean_ctor_get(x_401, 5); +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_462); - x_472 = lean_box(0); + lean_dec_ref(x_401); + x_424 = lean_box(0); } -x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_472)) { - x_474 = 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); +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; } else { - x_474 = x_472; + lean_dec_ref(x_417); + x_428 = lean_box(0); } -lean_ctor_set(x_474, 0, x_468); -lean_ctor_set(x_474, 1, x_469); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_471); -x_475 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_475, 0, x_463); -lean_ctor_set(x_475, 1, x_464); -lean_ctor_set(x_475, 2, x_474); -lean_ctor_set(x_475, 3, x_465); -lean_ctor_set(x_475, 4, x_466); -lean_ctor_set(x_475, 5, x_467); -x_476 = lean_ctor_get(x_8, 0); -lean_inc(x_476); -x_477 = lean_ctor_get(x_8, 1); -lean_inc(x_477); -x_478 = lean_ctor_get(x_8, 2); -lean_inc(x_478); -x_479 = lean_ctor_get(x_8, 3); -lean_inc(x_479); -x_480 = lean_ctor_get(x_8, 4); -lean_inc(x_480); -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_481 = x_8; +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_8); - x_481 = lean_box(0); + x_429 = x_428; } -x_482 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_482, 0, x_282); -lean_ctor_set(x_482, 1, x_24); -x_483 = lean_array_push(x_478, x_482); -if (lean_is_scalar(x_481)) { - x_484 = lean_alloc_ctor(0, 5, 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); } else { - x_484 = x_481; + x_430 = x_424; } -lean_ctor_set(x_484, 0, x_476); -lean_ctor_set(x_484, 1, x_477); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_479); -lean_ctor_set(x_484, 4, x_480); -x_485 = 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_284, x_484, x_475); -if (lean_obj_tag(x_485) == 0) -{ -lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_486 = lean_ctor_get(x_485, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_486, 2); -lean_inc(x_487); -x_488 = lean_ctor_get(x_485, 0); -lean_inc(x_488); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_489 = x_485; +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); } else { - lean_dec_ref(x_485); - x_489 = lean_box(0); + x_431 = x_248; } -x_490 = lean_ctor_get(x_486, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_486, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_486, 3); -lean_inc(x_492); -x_493 = lean_ctor_get(x_486, 4); -lean_inc(x_493); -x_494 = lean_ctor_get(x_486, 5); -lean_inc(x_494); -if (lean_is_exclusive(x_486)) { - lean_ctor_release(x_486, 0); - lean_ctor_release(x_486, 1); - lean_ctor_release(x_486, 2); - lean_ctor_release(x_486, 3); - lean_ctor_release(x_486, 4); - lean_ctor_release(x_486, 5); - x_495 = x_486; -} else { - lean_dec_ref(x_486); - x_495 = lean_box(0); +lean_ctor_set(x_431, 0, x_418); +lean_ctor_set(x_431, 1, x_430); +return x_431; } -x_496 = lean_ctor_get(x_487, 0); -lean_inc(x_496); -x_497 = lean_ctor_get(x_487, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_487, 3); -lean_inc(x_498); -if (lean_is_exclusive(x_487)) { - lean_ctor_release(x_487, 0); - lean_ctor_release(x_487, 1); - lean_ctor_release(x_487, 2); - lean_ctor_release(x_487, 3); - x_499 = x_487; -} else { - lean_dec_ref(x_487); - x_499 = lean_box(0); -} -if (lean_is_scalar(x_499)) { - x_500 = lean_alloc_ctor(0, 4, 0); -} else { - x_500 = x_499; -} -lean_ctor_set(x_500, 0, x_496); -lean_ctor_set(x_500, 1, x_497); -lean_ctor_set(x_500, 2, x_470); -lean_ctor_set(x_500, 3, x_498); -if (lean_is_scalar(x_495)) { - x_501 = lean_alloc_ctor(0, 6, 0); -} else { - x_501 = x_495; -} -lean_ctor_set(x_501, 0, x_490); -lean_ctor_set(x_501, 1, x_491); -lean_ctor_set(x_501, 2, x_500); -lean_ctor_set(x_501, 3, x_492); -lean_ctor_set(x_501, 4, x_493); -lean_ctor_set(x_501, 5, x_494); -if (lean_is_scalar(x_489)) { - x_502 = lean_alloc_ctor(0, 2, 0); -} else { - x_502 = x_489; -} -lean_ctor_set(x_502, 0, x_488); -lean_ctor_set(x_502, 1, x_501); -return x_502; -} -else -{ -lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_503 = lean_ctor_get(x_485, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_503, 2); -lean_inc(x_504); -x_505 = lean_ctor_get(x_485, 0); -lean_inc(x_505); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_506 = x_485; -} else { - lean_dec_ref(x_485); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_503, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_503, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_503, 3); -lean_inc(x_509); -x_510 = lean_ctor_get(x_503, 4); -lean_inc(x_510); -x_511 = lean_ctor_get(x_503, 5); -lean_inc(x_511); -if (lean_is_exclusive(x_503)) { - lean_ctor_release(x_503, 0); - lean_ctor_release(x_503, 1); - lean_ctor_release(x_503, 2); - lean_ctor_release(x_503, 3); - lean_ctor_release(x_503, 4); - lean_ctor_release(x_503, 5); - x_512 = x_503; -} else { - lean_dec_ref(x_503); - x_512 = lean_box(0); -} -x_513 = lean_ctor_get(x_504, 0); -lean_inc(x_513); -x_514 = lean_ctor_get(x_504, 1); -lean_inc(x_514); -x_515 = lean_ctor_get(x_504, 3); -lean_inc(x_515); -if (lean_is_exclusive(x_504)) { - lean_ctor_release(x_504, 0); - lean_ctor_release(x_504, 1); - lean_ctor_release(x_504, 2); - lean_ctor_release(x_504, 3); - x_516 = x_504; -} else { - lean_dec_ref(x_504); - x_516 = lean_box(0); -} -if (lean_is_scalar(x_516)) { - x_517 = lean_alloc_ctor(0, 4, 0); -} else { - x_517 = x_516; -} -lean_ctor_set(x_517, 0, x_513); -lean_ctor_set(x_517, 1, x_514); -lean_ctor_set(x_517, 2, x_470); -lean_ctor_set(x_517, 3, x_515); -if (lean_is_scalar(x_512)) { - x_518 = lean_alloc_ctor(0, 6, 0); -} else { - x_518 = x_512; -} -lean_ctor_set(x_518, 0, x_507); -lean_ctor_set(x_518, 1, x_508); -lean_ctor_set(x_518, 2, x_517); -lean_ctor_set(x_518, 3, x_509); -lean_ctor_set(x_518, 4, x_510); -lean_ctor_set(x_518, 5, x_511); -if (lean_is_scalar(x_506)) { - x_519 = lean_alloc_ctor(1, 2, 0); -} else { - x_519 = x_506; -} -lean_ctor_set(x_519, 0, x_505); -lean_ctor_set(x_519, 1, x_518); -return x_519; } } } } else { -uint8_t x_520; +uint8_t x_452; 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_520 = !lean_is_exclusive(x_275); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_241); +if (x_452 == 0) { -return x_275; +return x_241; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_275, 0); -x_522 = lean_ctor_get(x_275, 1); -lean_inc(x_522); -lean_inc(x_521); -lean_dec(x_275); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } @@ -33752,7 +31942,7 @@ return x_523; } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -33760,52 +31950,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_29); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_29); +if (x_456 == 0) { return x_29; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_29, 0); -x_526 = lean_ctor_get(x_29, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_29); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } else { -uint8_t x_528; +uint8_t x_460; 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_528 = !lean_is_exclusive(x_25); -if (x_528 == 0) +x_460 = !lean_is_exclusive(x_25); +if (x_460 == 0) { return x_25; } else { -lean_object* x_529; lean_object* x_530; lean_object* x_531; -x_529 = lean_ctor_get(x_25, 0); -x_530 = lean_ctor_get(x_25, 1); -lean_inc(x_530); -lean_inc(x_529); +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_dec(x_25); -x_531 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_531, 0, x_529); -lean_ctor_set(x_531, 1, x_530); -return x_531; +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; } } } @@ -33974,2130 +32164,1768 @@ goto _start; } case 1: { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_dec(x_26); x_33 = lean_ctor_get(x_27, 1); lean_inc(x_33); -lean_dec(x_27); -x_34 = lean_ctor_get(x_28, 0); -lean_inc(x_34); +if (lean_is_exclusive(x_27)) { + lean_ctor_release(x_27, 0); + lean_ctor_release(x_27, 1); + x_34 = x_27; +} else { + lean_dec_ref(x_27); + x_34 = lean_box(0); +} +x_35 = lean_ctor_get(x_28, 0); +lean_inc(x_35); lean_dec(x_28); -x_35 = lean_unsigned_to_nat(1u); -x_36 = lean_nat_add(x_12, x_35); +x_36 = lean_unsigned_to_nat(1u); +x_37 = lean_nat_add(x_12, x_36); lean_dec(x_12); -x_37 = !lean_is_exclusive(x_33); -if (x_37 == 0) +x_38 = !lean_is_exclusive(x_33); +if (x_38 == 0) { -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_33, 2); -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_33, 2); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) { -lean_object* x_40; lean_object* x_41; uint8_t x_42; -x_40 = lean_ctor_get(x_38, 2); -x_41 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_38, 2, x_41); -x_42 = !lean_is_exclusive(x_13); -if (x_42 == 0) +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_93; uint8_t x_94; +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) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_13, 2); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_34); -lean_ctor_set(x_44, 1, x_22); -x_45 = lean_array_push(x_43, x_44); -lean_ctor_set(x_13, 2, x_45); -x_46 = 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_36, x_13, x_33); -if (lean_obj_tag(x_46) == 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_47; lean_object* x_48; uint8_t x_49; -x_47 = lean_ctor_get(x_46, 1); -lean_inc(x_47); -x_48 = lean_ctor_get(x_47, 2); -lean_inc(x_48); -x_49 = !lean_is_exclusive(x_46); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_46, 1); -lean_dec(x_50); -x_51 = !lean_is_exclusive(x_47); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_47, 2); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_48); -if (x_53 == 0) -{ -lean_object* x_54; -x_54 = lean_ctor_get(x_48, 2); -lean_dec(x_54); -lean_ctor_set(x_48, 2, x_40); -return x_46; +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_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = lean_ctor_get(x_48, 0); -x_56 = lean_ctor_get(x_48, 1); -x_57 = lean_ctor_get(x_48, 3); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_48); -x_58 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_40); -lean_ctor_set(x_58, 3, x_57); -lean_ctor_set(x_47, 2, x_58); -return x_46; +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_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; } } 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; -x_59 = lean_ctor_get(x_47, 0); -x_60 = lean_ctor_get(x_47, 1); -x_61 = lean_ctor_get(x_47, 3); -x_62 = lean_ctor_get(x_47, 4); -x_63 = lean_ctor_get(x_47, 5); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); +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_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; +} +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_42 = x_119; +x_43 = x_118; +goto block_92; +} +} +block_92: +{ +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_44; lean_object* x_45; uint8_t x_46; +x_44 = lean_ctor_get(x_43, 2); +lean_inc(x_44); +x_45 = lean_ctor_get(x_42, 0); +lean_inc(x_45); +lean_dec(x_42); +x_46 = !lean_is_exclusive(x_43); +if (x_46 == 0) +{ +lean_object* x_47; uint8_t x_48; +x_47 = lean_ctor_get(x_43, 2); +lean_dec(x_47); +x_48 = !lean_is_exclusive(x_44); +if (x_48 == 0) +{ +lean_object* x_49; lean_object* x_50; +x_49 = lean_ctor_get(x_44, 2); +lean_dec(x_49); +lean_ctor_set(x_44, 2, x_41); +if (lean_is_scalar(x_34)) { + x_50 = lean_alloc_ctor(1, 2, 0); +} else { + x_50 = x_34; + lean_ctor_set_tag(x_50, 1); +} +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_43); +return x_50; +} +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_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); +if (lean_is_scalar(x_34)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_34; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_45); +lean_ctor_set(x_55, 1, x_43); +return x_55; +} +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; 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_inc(x_60); lean_inc(x_59); -lean_dec(x_47); -x_64 = lean_ctor_get(x_48, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_48, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_48, 3); -lean_inc(x_66); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_67 = x_48; +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); +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; } else { - lean_dec_ref(x_48); - x_67 = lean_box(0); + lean_dec_ref(x_44); + x_64 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_65 = x_64; } -lean_ctor_set(x_68, 0, x_64); -lean_ctor_set(x_68, 1, x_65); -lean_ctor_set(x_68, 2, x_40); -lean_ctor_set(x_68, 3, x_66); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_59); -lean_ctor_set(x_69, 1, x_60); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_61); -lean_ctor_set(x_69, 4, x_62); -lean_ctor_set(x_69, 5, x_63); -lean_ctor_set(x_46, 1, x_69); -return x_46; +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); +if (lean_is_scalar(x_34)) { + x_67 = lean_alloc_ctor(1, 2, 0); +} else { + x_67 = x_34; + lean_ctor_set_tag(x_67, 1); +} +lean_ctor_set(x_67, 0, x_45); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } 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; lean_object* x_82; lean_object* x_83; -x_70 = lean_ctor_get(x_46, 0); -lean_inc(x_70); -lean_dec(x_46); -x_71 = lean_ctor_get(x_47, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_47, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_47, 3); -lean_inc(x_73); -x_74 = lean_ctor_get(x_47, 4); -lean_inc(x_74); -x_75 = lean_ctor_get(x_47, 5); -lean_inc(x_75); -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); - lean_ctor_release(x_47, 5); - x_76 = x_47; +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_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); +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_41); +if (lean_is_scalar(x_34)) { + x_74 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_47); - x_76 = lean_box(0); + x_74 = x_34; } -x_77 = lean_ctor_get(x_48, 0); +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_43); +return x_74; +} +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_inc(x_77); -x_78 = lean_ctor_get(x_48, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_48, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_48)) { - lean_ctor_release(x_48, 0); - lean_ctor_release(x_48, 1); - lean_ctor_release(x_48, 2); - lean_ctor_release(x_48, 3); - x_80 = x_48; +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); +if (lean_is_scalar(x_34)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_48); - x_80 = lean_box(0); + x_79 = x_34; } -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_40); -lean_ctor_set(x_81, 3, x_79); -if (lean_is_scalar(x_76)) { - x_82 = lean_alloc_ctor(0, 6, 0); -} else { - x_82 = x_76; -} -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); -x_83 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_83, 0, x_70); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_79, 0, x_69); +lean_ctor_set(x_79, 1, x_43); +return x_79; } } else { -lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_84 = lean_ctor_get(x_46, 1); +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_inc(x_84); -x_85 = lean_ctor_get(x_84, 2); +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_is_exclusive(x_46); -if (x_86 == 0) -{ -lean_object* x_87; uint8_t x_88; -x_87 = lean_ctor_get(x_46, 1); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_84); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_84, 2); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_85); -if (x_90 == 0) -{ -lean_object* x_91; -x_91 = lean_ctor_get(x_85, 2); -lean_dec(x_91); -lean_ctor_set(x_85, 2, x_40); -return x_46; -} -else -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_85, 0); -x_93 = lean_ctor_get(x_85, 1); -x_94 = lean_ctor_get(x_85, 3); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_85); -x_95 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_95, 0, x_92); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_95, 2, x_40); -lean_ctor_set(x_95, 3, x_94); -lean_ctor_set(x_84, 2, x_95); -return x_46; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_96 = lean_ctor_get(x_84, 0); -x_97 = lean_ctor_get(x_84, 1); -x_98 = lean_ctor_get(x_84, 3); -x_99 = lean_ctor_get(x_84, 4); -x_100 = lean_ctor_get(x_84, 5); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_84); -x_101 = lean_ctor_get(x_85, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_85, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_85, 3); -lean_inc(x_103); -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_104 = 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; } else { - lean_dec_ref(x_85); - x_104 = lean_box(0); + lean_dec_ref(x_68); + x_88 = lean_box(0); } -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_104; + x_89 = x_88; } -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_40); -lean_ctor_set(x_105, 3, x_103); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_96); -lean_ctor_set(x_106, 1, x_97); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_98); -lean_ctor_set(x_106, 4, x_99); -lean_ctor_set(x_106, 5, x_100); -lean_ctor_set(x_46, 1, x_106); -return x_46; -} -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_107 = lean_ctor_get(x_46, 0); -lean_inc(x_107); -lean_dec(x_46); -x_108 = lean_ctor_get(x_84, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_84, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_84, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_84, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_84, 5); -lean_inc(x_112); -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_113 = x_84; +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); +if (lean_is_scalar(x_34)) { + x_91 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + x_91 = x_34; } -x_114 = lean_ctor_get(x_85, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_85, 1); -lean_inc(x_115); -x_116 = lean_ctor_get(x_85, 3); -lean_inc(x_116); -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_117 = x_85; -} else { - lean_dec_ref(x_85); - x_117 = lean_box(0); +lean_ctor_set(x_91, 0, x_69); +lean_ctor_set(x_91, 1, x_90); +return x_91; } -if (lean_is_scalar(x_117)) { - x_118 = lean_alloc_ctor(0, 4, 0); -} else { - x_118 = x_117; -} -lean_ctor_set(x_118, 0, x_114); -lean_ctor_set(x_118, 1, x_115); -lean_ctor_set(x_118, 2, x_40); -lean_ctor_set(x_118, 3, x_116); -if (lean_is_scalar(x_113)) { - x_119 = lean_alloc_ctor(0, 6, 0); -} else { - x_119 = x_113; -} -lean_ctor_set(x_119, 0, x_108); -lean_ctor_set(x_119, 1, x_109); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_110); -lean_ctor_set(x_119, 4, x_111); -lean_ctor_set(x_119, 5, x_112); -x_120 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_120, 0, x_107); -lean_ctor_set(x_120, 1, x_119); -return x_120; } } } 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; -x_121 = lean_ctor_get(x_13, 0); -x_122 = lean_ctor_get(x_13, 1); -x_123 = lean_ctor_get(x_13, 2); -x_124 = lean_ctor_get(x_13, 3); -x_125 = lean_ctor_get(x_13, 4); -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; 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_dec(x_13); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_34); -lean_ctor_set(x_126, 1, x_22); -x_127 = lean_array_push(x_123, x_126); -x_128 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_128, 0, x_121); -lean_ctor_set(x_128, 1, x_122); -lean_ctor_set(x_128, 2, x_127); -lean_ctor_set(x_128, 3, x_124); -lean_ctor_set(x_128, 4, x_125); -x_129 = 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_36, x_128, x_33); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; 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_130 = lean_ctor_get(x_129, 1); -lean_inc(x_130); -x_131 = lean_ctor_get(x_130, 2); -lean_inc(x_131); -x_132 = lean_ctor_get(x_129, 0); -lean_inc(x_132); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_133 = x_129; +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_129); + 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_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_130, 0); +x_134 = lean_ctor_get(x_126, 0); lean_inc(x_134); -x_135 = lean_ctor_get(x_130, 1); +x_135 = lean_ctor_get(x_126, 1); lean_inc(x_135); -x_136 = lean_ctor_get(x_130, 3); +x_136 = lean_ctor_get(x_126, 3); lean_inc(x_136); -x_137 = lean_ctor_get(x_130, 4); -lean_inc(x_137); -x_138 = lean_ctor_get(x_130, 5); -lean_inc(x_138); -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_139 = x_130; +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_130); - x_139 = lean_box(0); + lean_dec_ref(x_126); + x_137 = lean_box(0); } -x_140 = lean_ctor_get(x_131, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_131, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_131, 3); -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); - x_143 = x_131; +if (lean_is_scalar(x_137)) { + x_138 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_131); - x_143 = lean_box(0); + x_138 = x_137; } -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_40); -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); +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_146 = lean_alloc_ctor(0, 2, 0); + x_139 = lean_alloc_ctor(0, 6, 0); } else { - x_146 = x_133; + x_139 = x_133; } -lean_ctor_set(x_146, 0, x_132); -lean_ctor_set(x_146, 1, x_145); -return x_146; +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_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; -x_147 = lean_ctor_get(x_129, 1); +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); -x_148 = lean_ctor_get(x_147, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_129, 0); +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); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_150 = x_129; -} else { - lean_dec_ref(x_129); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_147, 0); +x_150 = lean_ctor_get(x_141, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_141, 3); lean_inc(x_151); -x_152 = lean_ctor_get(x_147, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_147, 3); -lean_inc(x_153); -x_154 = lean_ctor_get(x_147, 4); -lean_inc(x_154); -x_155 = lean_ctor_get(x_147, 5); -lean_inc(x_155); -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; +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_147); - x_156 = lean_box(0); + lean_dec_ref(x_141); + x_152 = lean_box(0); } -x_157 = lean_ctor_get(x_148, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_148, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_148, 3); -lean_inc(x_159); -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); - x_160 = x_148; +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_148); - x_160 = lean_box(0); + x_153 = x_152; } -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(0, 4, 0); +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_161 = x_160; + x_154 = x_148; } -lean_ctor_set(x_161, 0, x_157); -lean_ctor_set(x_161, 1, x_158); -lean_ctor_set(x_161, 2, x_40); -lean_ctor_set(x_161, 3, x_159); -if (lean_is_scalar(x_156)) { - x_162 = lean_alloc_ctor(0, 6, 0); +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_162 = x_156; + x_155 = x_34; } -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(1, 2, 0); -} else { - x_163 = x_150; +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_149); -lean_ctor_set(x_163, 1, x_162); -return x_163; } } } else { -lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_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_38, 0); -x_165 = lean_ctor_get(x_38, 1); -x_166 = lean_ctor_get(x_38, 2); -x_167 = lean_ctor_get(x_38, 3); -lean_inc(x_167); -lean_inc(x_166); -lean_inc(x_165); -lean_inc(x_164); -lean_dec(x_38); -x_168 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_169 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_169, 0, x_164); -lean_ctor_set(x_169, 1, x_165); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_167); -lean_ctor_set(x_33, 2, x_169); -x_170 = lean_ctor_get(x_13, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_13, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_13, 2); -lean_inc(x_172); -x_173 = lean_ctor_get(x_13, 3); -lean_inc(x_173); -x_174 = lean_ctor_get(x_13, 4); -lean_inc(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_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); 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_175 = x_13; + x_227 = x_13; } else { lean_dec_ref(x_13); - x_175 = lean_box(0); + x_227 = lean_box(0); } -x_176 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_176, 0, x_34); -lean_ctor_set(x_176, 1, x_22); -x_177 = lean_array_push(x_172, x_176); -if (lean_is_scalar(x_175)) { - x_178 = lean_alloc_ctor(0, 5, 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_230 = lean_alloc_ctor(0, 5, 0); } else { - x_178 = x_175; + x_230 = x_227; } -lean_ctor_set(x_178, 0, x_170); -lean_ctor_set(x_178, 1, x_171); -lean_ctor_set(x_178, 2, x_177); -lean_ctor_set(x_178, 3, x_173); -lean_ctor_set(x_178, 4, x_174); -x_179 = 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_36, x_178, x_33); -if (lean_obj_tag(x_179) == 0) +lean_ctor_set(x_230, 0, x_222); +lean_ctor_set(x_230, 1, x_223); +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_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; lean_object* x_196; -x_180 = lean_ctor_get(x_179, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_180, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - x_183 = x_179; -} else { - lean_dec_ref(x_179); - x_183 = lean_box(0); -} -x_184 = lean_ctor_get(x_180, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_180, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_180, 3); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 4); -lean_inc(x_187); -x_188 = lean_ctor_get(x_180, 5); -lean_inc(x_188); -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_189 = x_180; -} else { - lean_dec_ref(x_180); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_181, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_181, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_181, 3); -lean_inc(x_192); -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_193 = x_181; -} else { - lean_dec_ref(x_181); - x_193 = lean_box(0); -} -if (lean_is_scalar(x_193)) { - x_194 = lean_alloc_ctor(0, 4, 0); -} else { - x_194 = x_193; -} -lean_ctor_set(x_194, 0, x_190); -lean_ctor_set(x_194, 1, x_191); -lean_ctor_set(x_194, 2, x_166); -lean_ctor_set(x_194, 3, x_192); -if (lean_is_scalar(x_189)) { - x_195 = lean_alloc_ctor(0, 6, 0); -} else { - x_195 = x_189; -} -lean_ctor_set(x_195, 0, x_184); -lean_ctor_set(x_195, 1, x_185); -lean_ctor_set(x_195, 2, x_194); -lean_ctor_set(x_195, 3, x_186); -lean_ctor_set(x_195, 4, x_187); -lean_ctor_set(x_195, 5, x_188); -if (lean_is_scalar(x_183)) { - x_196 = lean_alloc_ctor(0, 2, 0); -} else { - x_196 = x_183; -} -lean_ctor_set(x_196, 0, x_182); -lean_ctor_set(x_196, 1, x_195); -return x_196; +lean_object* x_232; lean_object* x_233; lean_object* x_234; +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_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_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; -x_197 = lean_ctor_get(x_179, 1); +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_231, 0); +lean_inc(x_235); +x_236 = lean_ctor_get(x_231, 1); +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; +} +block_218: +{ +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_197, 2); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 0); -lean_inc(x_199); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - x_200 = 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); + x_199 = x_188; } else { - lean_dec_ref(x_179); - x_200 = lean_box(0); + lean_dec_ref(x_188); + x_199 = lean_box(0); } -x_201 = lean_ctor_get(x_197, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_197, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_197, 3); +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; +} +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_197, 4); +x_204 = lean_ctor_get(x_186, 0); lean_inc(x_204); -x_205 = lean_ctor_get(x_197, 5); +lean_dec(x_186); +x_205 = lean_ctor_get(x_187, 0); lean_inc(x_205); -if (lean_is_exclusive(x_197)) { - lean_ctor_release(x_197, 0); - lean_ctor_release(x_197, 1); - lean_ctor_release(x_197, 2); - lean_ctor_release(x_197, 3); - lean_ctor_release(x_197, 4); - lean_ctor_release(x_197, 5); - x_206 = x_197; -} else { - lean_dec_ref(x_197); - x_206 = lean_box(0); -} -x_207 = lean_ctor_get(x_198, 0); +x_206 = lean_ctor_get(x_187, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 3); lean_inc(x_207); -x_208 = lean_ctor_get(x_198, 1); +x_208 = lean_ctor_get(x_187, 4); lean_inc(x_208); -x_209 = lean_ctor_get(x_198, 3); +x_209 = lean_ctor_get(x_187, 5); lean_inc(x_209); -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); - x_210 = 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); + lean_ctor_release(x_187, 5); + x_210 = x_187; } else { - lean_dec_ref(x_198); + lean_dec_ref(x_187); 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); +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; +} else { + lean_dec_ref(x_203); + x_214 = lean_box(0); +} +if (lean_is_scalar(x_214)) { + x_215 = lean_alloc_ctor(0, 4, 0); +} else { + x_215 = x_214; +} +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_211 = lean_alloc_ctor(0, 4, 0); + x_216 = lean_alloc_ctor(0, 6, 0); } else { - x_211 = x_210; + x_216 = x_210; } -lean_ctor_set(x_211, 0, x_207); -lean_ctor_set(x_211, 1, x_208); -lean_ctor_set(x_211, 2, x_166); -lean_ctor_set(x_211, 3, x_209); -if (lean_is_scalar(x_206)) { - x_212 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_34)) { + x_217 = lean_alloc_ctor(0, 2, 0); } else { - x_212 = x_206; + x_217 = x_34; } -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); -if (lean_is_scalar(x_200)) { - x_213 = lean_alloc_ctor(1, 2, 0); -} else { - x_213 = x_200; +lean_ctor_set(x_217, 0, x_204); +lean_ctor_set(x_217, 1, x_216); +return x_217; } -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; 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_214 = lean_ctor_get(x_33, 2); -x_215 = lean_ctor_get(x_33, 0); -x_216 = lean_ctor_get(x_33, 1); -x_217 = lean_ctor_get(x_33, 3); -x_218 = lean_ctor_get(x_33, 4); -x_219 = lean_ctor_get(x_33, 5); -lean_inc(x_219); -lean_inc(x_218); -lean_inc(x_217); -lean_inc(x_214); -lean_inc(x_216); -lean_inc(x_215); -lean_dec(x_33); -x_220 = lean_ctor_get(x_214, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_214, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_214, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_214, 3); -lean_inc(x_223); -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); - x_224 = x_214; -} else { - lean_dec_ref(x_214); - x_224 = lean_box(0); -} -x_225 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_224)) { - x_226 = lean_alloc_ctor(0, 4, 0); -} else { - x_226 = x_224; -} -lean_ctor_set(x_226, 0, x_220); -lean_ctor_set(x_226, 1, x_221); -lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_223); -x_227 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_227, 0, x_215); -lean_ctor_set(x_227, 1, x_216); -lean_ctor_set(x_227, 2, x_226); -lean_ctor_set(x_227, 3, x_217); -lean_ctor_set(x_227, 4, x_218); -lean_ctor_set(x_227, 5, x_219); -x_228 = lean_ctor_get(x_13, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_13, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_13, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_13, 3); -lean_inc(x_231); -x_232 = lean_ctor_get(x_13, 4); -lean_inc(x_232); -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_233 = x_13; -} else { - lean_dec_ref(x_13); - x_233 = lean_box(0); -} -x_234 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_234, 0, x_34); -lean_ctor_set(x_234, 1, x_22); -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___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_36, x_236, x_227); -if (lean_obj_tag(x_237) == 0) -{ -lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; -x_238 = lean_ctor_get(x_237, 1); -lean_inc(x_238); -x_239 = lean_ctor_get(x_238, 2); -lean_inc(x_239); -x_240 = lean_ctor_get(x_237, 0); -lean_inc(x_240); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_241 = x_237; -} else { - lean_dec_ref(x_237); - x_241 = lean_box(0); -} -x_242 = lean_ctor_get(x_238, 0); -lean_inc(x_242); -x_243 = lean_ctor_get(x_238, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_238, 3); -lean_inc(x_244); -x_245 = lean_ctor_get(x_238, 4); -lean_inc(x_245); -x_246 = lean_ctor_get(x_238, 5); -lean_inc(x_246); -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); - lean_ctor_release(x_238, 5); - x_247 = x_238; -} else { - lean_dec_ref(x_238); - x_247 = lean_box(0); -} -x_248 = lean_ctor_get(x_239, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_239, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_239, 3); -lean_inc(x_250); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - lean_ctor_release(x_239, 2); - lean_ctor_release(x_239, 3); - x_251 = x_239; -} else { - lean_dec_ref(x_239); - x_251 = lean_box(0); -} -if (lean_is_scalar(x_251)) { - x_252 = lean_alloc_ctor(0, 4, 0); -} else { - x_252 = x_251; -} -lean_ctor_set(x_252, 0, x_248); -lean_ctor_set(x_252, 1, x_249); -lean_ctor_set(x_252, 2, x_222); -lean_ctor_set(x_252, 3, x_250); -if (lean_is_scalar(x_247)) { - x_253 = lean_alloc_ctor(0, 6, 0); -} else { - x_253 = x_247; -} -lean_ctor_set(x_253, 0, x_242); -lean_ctor_set(x_253, 1, x_243); -lean_ctor_set(x_253, 2, x_252); -lean_ctor_set(x_253, 3, x_244); -lean_ctor_set(x_253, 4, x_245); -lean_ctor_set(x_253, 5, x_246); -if (lean_is_scalar(x_241)) { - x_254 = lean_alloc_ctor(0, 2, 0); -} else { - x_254 = x_241; -} -lean_ctor_set(x_254, 0, x_240); -lean_ctor_set(x_254, 1, x_253); -return x_254; -} -else -{ -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; -x_255 = lean_ctor_get(x_237, 1); -lean_inc(x_255); -x_256 = lean_ctor_get(x_255, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_237, 0); -lean_inc(x_257); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_258 = x_237; -} else { - lean_dec_ref(x_237); - x_258 = lean_box(0); -} -x_259 = lean_ctor_get(x_255, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_255, 1); -lean_inc(x_260); -x_261 = lean_ctor_get(x_255, 3); -lean_inc(x_261); -x_262 = lean_ctor_get(x_255, 4); -lean_inc(x_262); -x_263 = lean_ctor_get(x_255, 5); -lean_inc(x_263); -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); - lean_ctor_release(x_255, 4); - lean_ctor_release(x_255, 5); - x_264 = x_255; -} else { - lean_dec_ref(x_255); - x_264 = lean_box(0); -} -x_265 = lean_ctor_get(x_256, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_256, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_256, 3); -lean_inc(x_267); -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_268 = x_256; -} else { - lean_dec_ref(x_256); - 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_ctor_set(x_269, 0, x_265); -lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_222); -lean_ctor_set(x_269, 3, x_267); -if (lean_is_scalar(x_264)) { - x_270 = lean_alloc_ctor(0, 6, 0); -} else { - x_270 = x_264; -} -lean_ctor_set(x_270, 0, x_259); -lean_ctor_set(x_270, 1, x_260); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_261); -lean_ctor_set(x_270, 4, x_262); -lean_ctor_set(x_270, 5, x_263); -if (lean_is_scalar(x_258)) { - x_271 = lean_alloc_ctor(1, 2, 0); -} else { - x_271 = x_258; -} -lean_ctor_set(x_271, 0, x_257); -lean_ctor_set(x_271, 1, x_270); -return x_271; } } } default: { -lean_object* x_272; lean_object* x_273; -x_272 = lean_ctor_get(x_27, 1); -lean_inc(x_272); +lean_object* x_238; lean_object* x_239; +x_238 = lean_ctor_get(x_27, 1); +lean_inc(x_238); lean_dec(x_27); lean_inc(x_13); -x_273 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_272); -if (lean_obj_tag(x_273) == 0) +x_239 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_238); +if (lean_obj_tag(x_239) == 0) { -lean_object* x_274; -x_274 = lean_ctor_get(x_273, 0); -lean_inc(x_274); -if (lean_obj_tag(x_274) == 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_275; lean_object* x_276; lean_object* x_277; +lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_dec(x_22); -x_275 = lean_ctor_get(x_273, 1); -lean_inc(x_275); -lean_dec(x_273); -x_276 = lean_unsigned_to_nat(1u); -x_277 = lean_nat_add(x_12, x_276); +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); lean_dec(x_12); -x_12 = x_277; -x_14 = x_275; +x_12 = x_243; +x_14 = x_241; goto _start; } else { -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_279 = lean_ctor_get(x_273, 1); -lean_inc(x_279); -lean_dec(x_273); -x_280 = lean_ctor_get(x_274, 0); -lean_inc(x_280); -lean_dec(x_274); -x_281 = lean_unsigned_to_nat(1u); -x_282 = lean_nat_add(x_12, x_281); +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; +} else { + lean_dec_ref(x_239); + x_246 = 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_283 = !lean_is_exclusive(x_279); -if (x_283 == 0) +x_250 = !lean_is_exclusive(x_245); +if (x_250 == 0) { -lean_object* x_284; uint8_t x_285; -x_284 = lean_ctor_get(x_279, 2); -x_285 = !lean_is_exclusive(x_284); -if (x_285 == 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_286; lean_object* x_287; uint8_t x_288; -x_286 = lean_ctor_get(x_284, 2); -x_287 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_284, 2, x_287); -x_288 = !lean_is_exclusive(x_13); -if (x_288 == 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_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; -x_289 = lean_ctor_get(x_13, 2); -x_290 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_290, 0, x_280); -lean_ctor_set(x_290, 1, x_22); -x_291 = lean_array_push(x_289, x_290); -lean_ctor_set(x_13, 2, x_291); -x_292 = 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_282, x_13, x_279); -if (lean_obj_tag(x_292) == 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_293; lean_object* x_294; uint8_t x_295; -x_293 = lean_ctor_get(x_292, 1); -lean_inc(x_293); -x_294 = lean_ctor_get(x_293, 2); -lean_inc(x_294); -x_295 = !lean_is_exclusive(x_292); -if (x_295 == 0) -{ -lean_object* x_296; uint8_t x_297; -x_296 = lean_ctor_get(x_292, 1); -lean_dec(x_296); -x_297 = !lean_is_exclusive(x_293); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_293, 2); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_294); -if (x_299 == 0) -{ -lean_object* x_300; -x_300 = lean_ctor_get(x_294, 2); -lean_dec(x_300); -lean_ctor_set(x_294, 2, x_286); -return x_292; -} -else -{ -lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_301 = lean_ctor_get(x_294, 0); -x_302 = lean_ctor_get(x_294, 1); -x_303 = lean_ctor_get(x_294, 3); -lean_inc(x_303); -lean_inc(x_302); -lean_inc(x_301); -lean_dec(x_294); -x_304 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_304, 0, x_301); -lean_ctor_set(x_304, 1, x_302); -lean_ctor_set(x_304, 2, x_286); -lean_ctor_set(x_304, 3, x_303); -lean_ctor_set(x_293, 2, x_304); -return x_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; lean_object* x_314; lean_object* x_315; -x_305 = lean_ctor_get(x_293, 0); -x_306 = lean_ctor_get(x_293, 1); -x_307 = lean_ctor_get(x_293, 3); -x_308 = lean_ctor_get(x_293, 4); -x_309 = lean_ctor_get(x_293, 5); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_dec(x_293); -x_310 = lean_ctor_get(x_294, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_294, 1); +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_294, 3); +x_312 = lean_ctor_get(x_310, 1); lean_inc(x_312); -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); - x_313 = x_294; -} else { - lean_dec_ref(x_294); - x_313 = lean_box(0); +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; } -if (lean_is_scalar(x_313)) { - x_314 = lean_alloc_ctor(0, 4, 0); -} else { - x_314 = x_313; -} -lean_ctor_set(x_314, 0, x_310); -lean_ctor_set(x_314, 1, x_311); -lean_ctor_set(x_314, 2, x_286); -lean_ctor_set(x_314, 3, x_312); -x_315 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_315, 0, x_305); -lean_ctor_set(x_315, 1, x_306); -lean_ctor_set(x_315, 2, x_314); -lean_ctor_set(x_315, 3, x_307); -lean_ctor_set(x_315, 4, x_308); -lean_ctor_set(x_315, 5, x_309); -lean_ctor_set(x_292, 1, x_315); -return x_292; +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_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_316 = lean_ctor_get(x_292, 0); -lean_inc(x_316); -lean_dec(x_292); -x_317 = lean_ctor_get(x_293, 0); -lean_inc(x_317); -x_318 = lean_ctor_get(x_293, 1); -lean_inc(x_318); -x_319 = lean_ctor_get(x_293, 3); -lean_inc(x_319); -x_320 = lean_ctor_get(x_293, 4); -lean_inc(x_320); -x_321 = lean_ctor_get(x_293, 5); +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); -if (lean_is_exclusive(x_293)) { - lean_ctor_release(x_293, 0); - lean_ctor_release(x_293, 1); - lean_ctor_release(x_293, 2); - lean_ctor_release(x_293, 3); - lean_ctor_release(x_293, 4); - lean_ctor_release(x_293, 5); - x_322 = x_293; -} else { - lean_dec_ref(x_293); - x_322 = lean_box(0); -} -x_323 = lean_ctor_get(x_294, 0); -lean_inc(x_323); -x_324 = lean_ctor_get(x_294, 1); -lean_inc(x_324); -x_325 = lean_ctor_get(x_294, 3); -lean_inc(x_325); -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); - x_326 = x_294; -} else { - lean_dec_ref(x_294); - x_326 = lean_box(0); -} -if (lean_is_scalar(x_326)) { - x_327 = lean_alloc_ctor(0, 4, 0); -} else { - x_327 = x_326; -} -lean_ctor_set(x_327, 0, x_323); -lean_ctor_set(x_327, 1, x_324); -lean_ctor_set(x_327, 2, x_286); -lean_ctor_set(x_327, 3, x_325); -if (lean_is_scalar(x_322)) { - x_328 = lean_alloc_ctor(0, 6, 0); -} else { - x_328 = x_322; -} -lean_ctor_set(x_328, 0, x_317); -lean_ctor_set(x_328, 1, x_318); -lean_ctor_set(x_328, 2, x_327); -lean_ctor_set(x_328, 3, x_319); -lean_ctor_set(x_328, 4, x_320); -lean_ctor_set(x_328, 5, x_321); -x_329 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_329, 0, x_316); -lean_ctor_set(x_329, 1, x_328); -return x_329; -} -} -else -{ -lean_object* x_330; lean_object* x_331; uint8_t x_332; -x_330 = lean_ctor_get(x_292, 1); -lean_inc(x_330); -x_331 = lean_ctor_get(x_330, 2); -lean_inc(x_331); -x_332 = !lean_is_exclusive(x_292); -if (x_332 == 0) -{ -lean_object* x_333; uint8_t x_334; -x_333 = lean_ctor_get(x_292, 1); -lean_dec(x_333); -x_334 = !lean_is_exclusive(x_330); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_330, 2); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_331); -if (x_336 == 0) -{ -lean_object* x_337; -x_337 = lean_ctor_get(x_331, 2); -lean_dec(x_337); -lean_ctor_set(x_331, 2, x_286); -return x_292; -} -else -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; -x_338 = lean_ctor_get(x_331, 0); -x_339 = lean_ctor_get(x_331, 1); -x_340 = lean_ctor_get(x_331, 3); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_dec(x_331); -x_341 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_341, 0, x_338); -lean_ctor_set(x_341, 1, x_339); -lean_ctor_set(x_341, 2, x_286); -lean_ctor_set(x_341, 3, x_340); -lean_ctor_set(x_330, 2, x_341); -return x_292; -} -} -else -{ -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_342 = lean_ctor_get(x_330, 0); -x_343 = lean_ctor_get(x_330, 1); -x_344 = lean_ctor_get(x_330, 3); -x_345 = lean_ctor_get(x_330, 4); -x_346 = lean_ctor_get(x_330, 5); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_dec(x_330); -x_347 = lean_ctor_get(x_331, 0); -lean_inc(x_347); -x_348 = lean_ctor_get(x_331, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_331, 3); -lean_inc(x_349); -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_350 = x_331; -} else { - lean_dec_ref(x_331); - x_350 = lean_box(0); -} -if (lean_is_scalar(x_350)) { - x_351 = lean_alloc_ctor(0, 4, 0); -} else { - x_351 = x_350; -} -lean_ctor_set(x_351, 0, x_347); -lean_ctor_set(x_351, 1, x_348); -lean_ctor_set(x_351, 2, x_286); -lean_ctor_set(x_351, 3, x_349); -x_352 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_352, 0, x_342); -lean_ctor_set(x_352, 1, x_343); -lean_ctor_set(x_352, 2, x_351); -lean_ctor_set(x_352, 3, x_344); -lean_ctor_set(x_352, 4, x_345); -lean_ctor_set(x_352, 5, x_346); -lean_ctor_set(x_292, 1, x_352); -return x_292; -} -} -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; -x_353 = lean_ctor_get(x_292, 0); -lean_inc(x_353); -lean_dec(x_292); -x_354 = lean_ctor_get(x_330, 0); -lean_inc(x_354); -x_355 = lean_ctor_get(x_330, 1); -lean_inc(x_355); -x_356 = lean_ctor_get(x_330, 3); -lean_inc(x_356); -x_357 = lean_ctor_get(x_330, 4); -lean_inc(x_357); -x_358 = lean_ctor_get(x_330, 5); -lean_inc(x_358); -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_359 = x_330; -} else { - lean_dec_ref(x_330); - x_359 = lean_box(0); -} -x_360 = lean_ctor_get(x_331, 0); -lean_inc(x_360); -x_361 = lean_ctor_get(x_331, 1); -lean_inc(x_361); -x_362 = lean_ctor_get(x_331, 3); -lean_inc(x_362); -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_363 = x_331; -} else { - lean_dec_ref(x_331); - x_363 = lean_box(0); -} -if (lean_is_scalar(x_363)) { - x_364 = lean_alloc_ctor(0, 4, 0); -} else { - x_364 = x_363; -} -lean_ctor_set(x_364, 0, x_360); -lean_ctor_set(x_364, 1, x_361); -lean_ctor_set(x_364, 2, x_286); -lean_ctor_set(x_364, 3, x_362); -if (lean_is_scalar(x_359)) { - x_365 = lean_alloc_ctor(0, 6, 0); -} else { - x_365 = 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); -x_366 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_366, 0, x_353); -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; -x_367 = lean_ctor_get(x_13, 0); -x_368 = lean_ctor_get(x_13, 1); -x_369 = lean_ctor_get(x_13, 2); -x_370 = lean_ctor_get(x_13, 3); -x_371 = lean_ctor_get(x_13, 4); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); +lean_inc(x_320); +lean_inc(x_319); +lean_inc(x_318); +lean_inc(x_317); lean_dec(x_13); -x_372 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_372, 0, x_280); -lean_ctor_set(x_372, 1, x_22); -x_373 = lean_array_push(x_369, x_372); -x_374 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_374, 0, x_367); -lean_ctor_set(x_374, 1, x_368); -lean_ctor_set(x_374, 2, x_373); -lean_ctor_set(x_374, 3, x_370); -lean_ctor_set(x_374, 4, x_371); -x_375 = 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_282, x_374, x_279); -if (lean_obj_tag(x_375) == 0) +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_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; -x_376 = lean_ctor_get(x_375, 1); -lean_inc(x_376); -x_377 = lean_ctor_get(x_376, 2); -lean_inc(x_377); -x_378 = lean_ctor_get(x_375, 0); -lean_inc(x_378); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_379 = x_375; -} else { - lean_dec_ref(x_375); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_376, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_376, 1); -lean_inc(x_381); -x_382 = lean_ctor_get(x_376, 3); -lean_inc(x_382); -x_383 = lean_ctor_get(x_376, 4); -lean_inc(x_383); -x_384 = lean_ctor_get(x_376, 5); -lean_inc(x_384); -if (lean_is_exclusive(x_376)) { - lean_ctor_release(x_376, 0); - lean_ctor_release(x_376, 1); - lean_ctor_release(x_376, 2); - lean_ctor_release(x_376, 3); - lean_ctor_release(x_376, 4); - lean_ctor_release(x_376, 5); - x_385 = x_376; -} else { - lean_dec_ref(x_376); - x_385 = lean_box(0); -} -x_386 = lean_ctor_get(x_377, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_377, 1); -lean_inc(x_387); -x_388 = lean_ctor_get(x_377, 3); -lean_inc(x_388); -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); - x_389 = x_377; -} else { - lean_dec_ref(x_377); - x_389 = lean_box(0); -} -if (lean_is_scalar(x_389)) { - x_390 = lean_alloc_ctor(0, 4, 0); -} else { - x_390 = x_389; -} -lean_ctor_set(x_390, 0, x_386); -lean_ctor_set(x_390, 1, x_387); -lean_ctor_set(x_390, 2, x_286); -lean_ctor_set(x_390, 3, x_388); -if (lean_is_scalar(x_385)) { - x_391 = lean_alloc_ctor(0, 6, 0); -} else { - x_391 = x_385; -} -lean_ctor_set(x_391, 0, x_380); -lean_ctor_set(x_391, 1, x_381); -lean_ctor_set(x_391, 2, x_390); -lean_ctor_set(x_391, 3, x_382); -lean_ctor_set(x_391, 4, x_383); -lean_ctor_set(x_391, 5, x_384); -if (lean_is_scalar(x_379)) { - x_392 = lean_alloc_ctor(0, 2, 0); -} else { - x_392 = x_379; -} -lean_ctor_set(x_392, 0, x_378); -lean_ctor_set(x_392, 1, x_391); -return x_392; +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_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; lean_object* x_408; lean_object* x_409; -x_393 = lean_ctor_get(x_375, 1); -lean_inc(x_393); -x_394 = lean_ctor_get(x_393, 2); -lean_inc(x_394); -x_395 = lean_ctor_get(x_375, 0); -lean_inc(x_395); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_396 = x_375; -} else { - lean_dec_ref(x_375); - x_396 = lean_box(0); +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; } -x_397 = lean_ctor_get(x_393, 0); -lean_inc(x_397); -x_398 = lean_ctor_get(x_393, 1); -lean_inc(x_398); -x_399 = lean_ctor_get(x_393, 3); -lean_inc(x_399); -x_400 = lean_ctor_get(x_393, 4); -lean_inc(x_400); -x_401 = lean_ctor_get(x_393, 5); -lean_inc(x_401); -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); - lean_ctor_release(x_393, 4); - lean_ctor_release(x_393, 5); - x_402 = x_393; -} else { - lean_dec_ref(x_393); - x_402 = lean_box(0); } -x_403 = lean_ctor_get(x_394, 0); -lean_inc(x_403); -x_404 = lean_ctor_get(x_394, 1); -lean_inc(x_404); -x_405 = lean_ctor_get(x_394, 3); -lean_inc(x_405); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - lean_ctor_release(x_394, 2); - lean_ctor_release(x_394, 3); - x_406 = x_394; +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); +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); +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 { - lean_dec_ref(x_394); - x_406 = lean_box(0); + x_262 = x_246; + lean_ctor_set_tag(x_262, 1); } -if (lean_is_scalar(x_406)) { - x_407 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_262, 0, x_257); +lean_ctor_set(x_262, 1, x_255); +return x_262; +} +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_407 = x_406; + x_267 = x_246; + lean_ctor_set_tag(x_267, 1); } -lean_ctor_set(x_407, 0, x_403); -lean_ctor_set(x_407, 1, x_404); -lean_ctor_set(x_407, 2, x_286); -lean_ctor_set(x_407, 3, x_405); -if (lean_is_scalar(x_402)) { - x_408 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_267, 0, x_257); +lean_ctor_set(x_267, 1, x_255); +return x_267; +} +} +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_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 { - x_408 = x_402; + lean_dec_ref(x_256); + x_276 = lean_box(0); } -lean_ctor_set(x_408, 0, x_397); -lean_ctor_set(x_408, 1, x_398); -lean_ctor_set(x_408, 2, x_407); -lean_ctor_set(x_408, 3, x_399); -lean_ctor_set(x_408, 4, x_400); -lean_ctor_set(x_408, 5, x_401); -if (lean_is_scalar(x_396)) { - x_409 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(0, 4, 0); } else { - x_409 = x_396; + x_277 = x_276; +} +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, 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); +} else { + x_279 = x_246; + lean_ctor_set_tag(x_279, 1); +} +lean_ctor_set(x_279, 0, x_257); +lean_ctor_set(x_279, 1, x_278); +return x_279; +} +} +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_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_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); +} else { + x_291 = x_246; +} +lean_ctor_set(x_291, 0, x_281); +lean_ctor_set(x_291, 1, x_255); +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_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); +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; +} else { + lean_dec_ref(x_280); + x_300 = lean_box(0); +} +if (lean_is_scalar(x_300)) { + x_301 = lean_alloc_ctor(0, 4, 0); +} else { + x_301 = x_300; +} +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); +} else { + x_303 = x_246; +} +lean_ctor_set(x_303, 0, x_281); +lean_ctor_set(x_303, 1, x_302); +return x_303; } -lean_ctor_set(x_409, 0, x_395); -lean_ctor_set(x_409, 1, x_408); -return x_409; } } } else { -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_284, 0); -x_411 = lean_ctor_get(x_284, 1); -x_412 = lean_ctor_get(x_284, 2); -x_413 = lean_ctor_get(x_284, 3); -lean_inc(x_413); -lean_inc(x_412); -lean_inc(x_411); -lean_inc(x_410); -lean_dec(x_284); -x_414 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_415 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_415, 0, x_410); -lean_ctor_set(x_415, 1, x_411); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_413); -lean_ctor_set(x_279, 2, x_415); -x_416 = lean_ctor_get(x_13, 0); -lean_inc(x_416); -x_417 = lean_ctor_get(x_13, 1); -lean_inc(x_417); -x_418 = lean_ctor_get(x_13, 2); -lean_inc(x_418); -x_419 = lean_ctor_get(x_13, 3); -lean_inc(x_419); -x_420 = lean_ctor_get(x_13, 4); -lean_inc(x_420); +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); 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_421 = x_13; + x_376 = x_13; } else { lean_dec_ref(x_13); - x_421 = lean_box(0); + x_376 = lean_box(0); } -x_422 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_422, 0, x_280); -lean_ctor_set(x_422, 1, x_22); -x_423 = lean_array_push(x_418, x_422); -if (lean_is_scalar(x_421)) { - x_424 = lean_alloc_ctor(0, 5, 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); } else { - x_424 = x_421; + x_379 = x_376; } -lean_ctor_set(x_424, 0, x_416); -lean_ctor_set(x_424, 1, x_417); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_419); -lean_ctor_set(x_424, 4, x_420); -x_425 = 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_282, x_424, x_279); -if (lean_obj_tag(x_425) == 0) +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_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; lean_object* x_442; -x_426 = lean_ctor_get(x_425, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_426, 2); -lean_inc(x_427); -x_428 = lean_ctor_get(x_425, 0); -lean_inc(x_428); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - x_429 = x_425; -} else { - lean_dec_ref(x_425); - x_429 = lean_box(0); -} -x_430 = lean_ctor_get(x_426, 0); -lean_inc(x_430); -x_431 = lean_ctor_get(x_426, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_426, 3); -lean_inc(x_432); -x_433 = lean_ctor_get(x_426, 4); -lean_inc(x_433); -x_434 = lean_ctor_get(x_426, 5); -lean_inc(x_434); -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); - lean_ctor_release(x_426, 5); - x_435 = x_426; -} else { - lean_dec_ref(x_426); - x_435 = lean_box(0); -} -x_436 = lean_ctor_get(x_427, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_427, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_427, 3); -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); - 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, 4, 0); -} else { - x_440 = x_439; -} -lean_ctor_set(x_440, 0, x_436); -lean_ctor_set(x_440, 1, x_437); -lean_ctor_set(x_440, 2, x_412); -lean_ctor_set(x_440, 3, x_438); -if (lean_is_scalar(x_435)) { - x_441 = lean_alloc_ctor(0, 6, 0); -} else { - x_441 = x_435; -} -lean_ctor_set(x_441, 0, x_430); -lean_ctor_set(x_441, 1, x_431); -lean_ctor_set(x_441, 2, x_440); -lean_ctor_set(x_441, 3, x_432); -lean_ctor_set(x_441, 4, x_433); -lean_ctor_set(x_441, 5, x_434); -if (lean_is_scalar(x_429)) { - x_442 = lean_alloc_ctor(0, 2, 0); -} else { - x_442 = x_429; -} -lean_ctor_set(x_442, 0, x_428); -lean_ctor_set(x_442, 1, x_441); -return x_442; +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; } else { -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; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_443 = lean_ctor_get(x_425, 1); -lean_inc(x_443); -x_444 = lean_ctor_get(x_443, 2); -lean_inc(x_444); -x_445 = lean_ctor_get(x_425, 0); -lean_inc(x_445); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - x_446 = x_425; -} else { - lean_dec_ref(x_425); - x_446 = lean_box(0); +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; } +block_368: +{ +if (lean_obj_tag(x_336) == 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_inc(x_353); +x_354 = lean_ctor_get(x_336, 0); +lean_inc(x_354); +lean_dec(x_336); +x_355 = lean_ctor_get(x_337, 0); +lean_inc(x_355); +x_356 = lean_ctor_get(x_337, 1); +lean_inc(x_356); +x_357 = lean_ctor_get(x_337, 3); +lean_inc(x_357); +x_358 = lean_ctor_get(x_337, 4); +lean_inc(x_358); +x_359 = lean_ctor_get(x_337, 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; +} else { + lean_dec_ref(x_337); + x_360 = lean_box(0); +} +x_361 = lean_ctor_get(x_353, 0); +lean_inc(x_361); +x_362 = lean_ctor_get(x_353, 1); +lean_inc(x_362); +x_363 = lean_ctor_get(x_353, 3); +lean_inc(x_363); +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; +} else { + lean_dec_ref(x_353); + x_364 = lean_box(0); +} +if (lean_is_scalar(x_364)) { + x_365 = lean_alloc_ctor(0, 4, 0); +} else { + x_365 = x_364; +} +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); +if (lean_is_scalar(x_360)) { + x_366 = lean_alloc_ctor(0, 6, 0); +} else { + x_366 = 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); +} else { + x_367 = x_246; +} +lean_ctor_set(x_367, 0, x_354); +lean_ctor_set(x_367, 1, x_366); +return x_367; +} +} +} +} +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; +} else { + lean_dec_ref(x_387); + x_397 = 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); +} else { + x_432 = x_397; +} +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); +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; +} else { + lean_dec_ref(x_13); + x_439 = 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); +} else { + x_442 = x_439; +} +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_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; +} +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); -x_449 = lean_ctor_get(x_443, 3); -lean_inc(x_449); -x_450 = lean_ctor_get(x_443, 4); -lean_inc(x_450); -x_451 = lean_ctor_get(x_443, 5); -lean_inc(x_451); -if (lean_is_exclusive(x_443)) { - lean_ctor_release(x_443, 0); - lean_ctor_release(x_443, 1); - lean_ctor_release(x_443, 2); - lean_ctor_release(x_443, 3); - lean_ctor_release(x_443, 4); - lean_ctor_release(x_443, 5); - x_452 = x_443; +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; +} +block_430: +{ +if (lean_obj_tag(x_398) == 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_443); - x_452 = lean_box(0); + lean_dec_ref(x_399); + x_407 = lean_box(0); } -x_453 = lean_ctor_get(x_444, 0); -lean_inc(x_453); -x_454 = lean_ctor_get(x_444, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_444, 3); -lean_inc(x_455); -if (lean_is_exclusive(x_444)) { - lean_ctor_release(x_444, 0); - lean_ctor_release(x_444, 1); - lean_ctor_release(x_444, 2); - lean_ctor_release(x_444, 3); - x_456 = x_444; +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_444); - x_456 = lean_box(0); + lean_dec_ref(x_400); + x_411 = lean_box(0); } -if (lean_is_scalar(x_456)) { - x_457 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_411)) { + x_412 = lean_alloc_ctor(0, 4, 0); } else { - x_457 = x_456; + x_412 = x_411; } -lean_ctor_set(x_457, 0, x_453); -lean_ctor_set(x_457, 1, x_454); -lean_ctor_set(x_457, 2, x_412); -lean_ctor_set(x_457, 3, x_455); -if (lean_is_scalar(x_452)) { - x_458 = lean_alloc_ctor(0, 6, 0); +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_458 = x_452; + x_413 = x_407; } -lean_ctor_set(x_458, 0, x_447); -lean_ctor_set(x_458, 1, x_448); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_449); -lean_ctor_set(x_458, 4, x_450); -lean_ctor_set(x_458, 5, x_451); -if (lean_is_scalar(x_446)) { - x_459 = lean_alloc_ctor(1, 2, 0); +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_459 = x_446; -} -lean_ctor_set(x_459, 0, x_445); -lean_ctor_set(x_459, 1, x_458); -return x_459; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; -x_460 = lean_ctor_get(x_279, 2); -x_461 = lean_ctor_get(x_279, 0); -x_462 = lean_ctor_get(x_279, 1); -x_463 = lean_ctor_get(x_279, 3); -x_464 = lean_ctor_get(x_279, 4); -x_465 = lean_ctor_get(x_279, 5); -lean_inc(x_465); -lean_inc(x_464); -lean_inc(x_463); -lean_inc(x_460); -lean_inc(x_462); -lean_inc(x_461); -lean_dec(x_279); -x_466 = lean_ctor_get(x_460, 0); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_460, 2); -lean_inc(x_468); -x_469 = lean_ctor_get(x_460, 3); -lean_inc(x_469); -if (lean_is_exclusive(x_460)) { - lean_ctor_release(x_460, 0); - lean_ctor_release(x_460, 1); - lean_ctor_release(x_460, 2); - lean_ctor_release(x_460, 3); - x_470 = x_460; +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_inc(x_418); +x_419 = lean_ctor_get(x_399, 3); +lean_inc(x_419); +x_420 = lean_ctor_get(x_399, 4); +lean_inc(x_420); +x_421 = lean_ctor_get(x_399, 5); +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_460); - x_470 = lean_box(0); + lean_dec_ref(x_399); + x_422 = lean_box(0); } -x_471 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_470)) { - x_472 = 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); +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; } else { - x_472 = x_470; + lean_dec_ref(x_415); + x_426 = lean_box(0); } -lean_ctor_set(x_472, 0, x_466); -lean_ctor_set(x_472, 1, x_467); -lean_ctor_set(x_472, 2, x_471); -lean_ctor_set(x_472, 3, x_469); -x_473 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_473, 0, x_461); -lean_ctor_set(x_473, 1, x_462); -lean_ctor_set(x_473, 2, x_472); -lean_ctor_set(x_473, 3, x_463); -lean_ctor_set(x_473, 4, x_464); -lean_ctor_set(x_473, 5, x_465); -x_474 = lean_ctor_get(x_13, 0); -lean_inc(x_474); -x_475 = lean_ctor_get(x_13, 1); -lean_inc(x_475); -x_476 = lean_ctor_get(x_13, 2); -lean_inc(x_476); -x_477 = lean_ctor_get(x_13, 3); -lean_inc(x_477); -x_478 = lean_ctor_get(x_13, 4); -lean_inc(x_478); -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_479 = x_13; +if (lean_is_scalar(x_426)) { + x_427 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_13); - x_479 = lean_box(0); + x_427 = x_426; } -x_480 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_480, 0, x_280); -lean_ctor_set(x_480, 1, x_22); -x_481 = lean_array_push(x_476, x_480); -if (lean_is_scalar(x_479)) { - x_482 = lean_alloc_ctor(0, 5, 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); } else { - x_482 = x_479; + x_428 = x_422; } -lean_ctor_set(x_482, 0, x_474); -lean_ctor_set(x_482, 1, x_475); -lean_ctor_set(x_482, 2, x_481); -lean_ctor_set(x_482, 3, x_477); -lean_ctor_set(x_482, 4, x_478); -x_483 = 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_282, x_482, x_473); -if (lean_obj_tag(x_483) == 0) -{ -lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; -x_484 = lean_ctor_get(x_483, 1); -lean_inc(x_484); -x_485 = lean_ctor_get(x_484, 2); -lean_inc(x_485); -x_486 = lean_ctor_get(x_483, 0); -lean_inc(x_486); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - x_487 = x_483; +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); } else { - lean_dec_ref(x_483); - x_487 = lean_box(0); + x_429 = x_246; } -x_488 = lean_ctor_get(x_484, 0); -lean_inc(x_488); -x_489 = lean_ctor_get(x_484, 1); -lean_inc(x_489); -x_490 = lean_ctor_get(x_484, 3); -lean_inc(x_490); -x_491 = lean_ctor_get(x_484, 4); -lean_inc(x_491); -x_492 = lean_ctor_get(x_484, 5); -lean_inc(x_492); -if (lean_is_exclusive(x_484)) { - lean_ctor_release(x_484, 0); - lean_ctor_release(x_484, 1); - lean_ctor_release(x_484, 2); - lean_ctor_release(x_484, 3); - lean_ctor_release(x_484, 4); - lean_ctor_release(x_484, 5); - x_493 = x_484; -} else { - lean_dec_ref(x_484); - x_493 = lean_box(0); +lean_ctor_set(x_429, 0, x_416); +lean_ctor_set(x_429, 1, x_428); +return x_429; } -x_494 = lean_ctor_get(x_485, 0); -lean_inc(x_494); -x_495 = lean_ctor_get(x_485, 1); -lean_inc(x_495); -x_496 = lean_ctor_get(x_485, 3); -lean_inc(x_496); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - lean_ctor_release(x_485, 2); - lean_ctor_release(x_485, 3); - x_497 = x_485; -} else { - lean_dec_ref(x_485); - x_497 = lean_box(0); -} -if (lean_is_scalar(x_497)) { - x_498 = lean_alloc_ctor(0, 4, 0); -} else { - x_498 = x_497; -} -lean_ctor_set(x_498, 0, x_494); -lean_ctor_set(x_498, 1, x_495); -lean_ctor_set(x_498, 2, x_468); -lean_ctor_set(x_498, 3, x_496); -if (lean_is_scalar(x_493)) { - x_499 = lean_alloc_ctor(0, 6, 0); -} else { - x_499 = x_493; -} -lean_ctor_set(x_499, 0, x_488); -lean_ctor_set(x_499, 1, x_489); -lean_ctor_set(x_499, 2, x_498); -lean_ctor_set(x_499, 3, x_490); -lean_ctor_set(x_499, 4, x_491); -lean_ctor_set(x_499, 5, x_492); -if (lean_is_scalar(x_487)) { - x_500 = lean_alloc_ctor(0, 2, 0); -} else { - x_500 = x_487; -} -lean_ctor_set(x_500, 0, x_486); -lean_ctor_set(x_500, 1, x_499); -return x_500; -} -else -{ -lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; -x_501 = lean_ctor_get(x_483, 1); -lean_inc(x_501); -x_502 = lean_ctor_get(x_501, 2); -lean_inc(x_502); -x_503 = lean_ctor_get(x_483, 0); -lean_inc(x_503); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - x_504 = x_483; -} else { - lean_dec_ref(x_483); - x_504 = lean_box(0); -} -x_505 = lean_ctor_get(x_501, 0); -lean_inc(x_505); -x_506 = lean_ctor_get(x_501, 1); -lean_inc(x_506); -x_507 = lean_ctor_get(x_501, 3); -lean_inc(x_507); -x_508 = lean_ctor_get(x_501, 4); -lean_inc(x_508); -x_509 = lean_ctor_get(x_501, 5); -lean_inc(x_509); -if (lean_is_exclusive(x_501)) { - lean_ctor_release(x_501, 0); - lean_ctor_release(x_501, 1); - lean_ctor_release(x_501, 2); - lean_ctor_release(x_501, 3); - lean_ctor_release(x_501, 4); - lean_ctor_release(x_501, 5); - x_510 = x_501; -} else { - lean_dec_ref(x_501); - x_510 = lean_box(0); -} -x_511 = lean_ctor_get(x_502, 0); -lean_inc(x_511); -x_512 = lean_ctor_get(x_502, 1); -lean_inc(x_512); -x_513 = lean_ctor_get(x_502, 3); -lean_inc(x_513); -if (lean_is_exclusive(x_502)) { - lean_ctor_release(x_502, 0); - lean_ctor_release(x_502, 1); - lean_ctor_release(x_502, 2); - lean_ctor_release(x_502, 3); - x_514 = x_502; -} else { - lean_dec_ref(x_502); - x_514 = lean_box(0); -} -if (lean_is_scalar(x_514)) { - x_515 = lean_alloc_ctor(0, 4, 0); -} else { - x_515 = x_514; -} -lean_ctor_set(x_515, 0, x_511); -lean_ctor_set(x_515, 1, x_512); -lean_ctor_set(x_515, 2, x_468); -lean_ctor_set(x_515, 3, x_513); -if (lean_is_scalar(x_510)) { - x_516 = lean_alloc_ctor(0, 6, 0); -} else { - x_516 = x_510; -} -lean_ctor_set(x_516, 0, x_505); -lean_ctor_set(x_516, 1, x_506); -lean_ctor_set(x_516, 2, x_515); -lean_ctor_set(x_516, 3, x_507); -lean_ctor_set(x_516, 4, x_508); -lean_ctor_set(x_516, 5, x_509); -if (lean_is_scalar(x_504)) { - x_517 = lean_alloc_ctor(1, 2, 0); -} else { - x_517 = x_504; -} -lean_ctor_set(x_517, 0, x_503); -lean_ctor_set(x_517, 1, x_516); -return x_517; } } } } else { -uint8_t x_518; +uint8_t x_450; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -36108,23 +33936,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_518 = !lean_is_exclusive(x_273); -if (x_518 == 0) +x_450 = !lean_is_exclusive(x_239); +if (x_450 == 0) { -return x_273; +return x_239; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; -x_519 = lean_ctor_get(x_273, 0); -x_520 = lean_ctor_get(x_273, 1); -lean_inc(x_520); -lean_inc(x_519); -lean_dec(x_273); -x_521 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_521, 0, x_519); -lean_ctor_set(x_521, 1, x_520); -return x_521; +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; } } } @@ -36132,7 +33960,7 @@ return x_521; } else { -uint8_t x_522; +uint8_t x_454; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -36144,29 +33972,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_522 = !lean_is_exclusive(x_27); -if (x_522 == 0) +x_454 = !lean_is_exclusive(x_27); +if (x_454 == 0) { return x_27; } else { -lean_object* x_523; lean_object* x_524; lean_object* x_525; -x_523 = lean_ctor_get(x_27, 0); -x_524 = lean_ctor_get(x_27, 1); -lean_inc(x_524); -lean_inc(x_523); +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_dec(x_27); -x_525 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_525, 0, x_523); -lean_ctor_set(x_525, 1, x_524); -return x_525; +x_457 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_457, 0, x_455); +lean_ctor_set(x_457, 1, x_456); +return x_457; } } } else { -uint8_t x_526; +uint8_t x_458; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -36177,23 +34005,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_526 = !lean_is_exclusive(x_23); -if (x_526 == 0) +x_458 = !lean_is_exclusive(x_23); +if (x_458 == 0) { return x_23; } else { -lean_object* x_527; lean_object* x_528; lean_object* x_529; -x_527 = lean_ctor_get(x_23, 0); -x_528 = lean_ctor_get(x_23, 1); -lean_inc(x_528); -lean_inc(x_527); +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_dec(x_23); -x_529 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_529, 0, x_527); -lean_ctor_set(x_529, 1, x_528); -return x_529; +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; } } } @@ -36309,2153 +34137,1791 @@ goto _start; } case 1: { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; lean_dec(x_28); x_35 = lean_ctor_get(x_29, 1); lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_ctor_get(x_30, 0); -lean_inc(x_36); +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + x_36 = x_29; +} else { + lean_dec_ref(x_29); + x_36 = lean_box(0); +} +x_37 = lean_ctor_get(x_30, 0); +lean_inc(x_37); lean_dec(x_30); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_add(x_7, x_37); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_add(x_7, x_38); lean_dec(x_7); -x_39 = !lean_is_exclusive(x_35); -if (x_39 == 0) +x_40 = !lean_is_exclusive(x_35); +if (x_40 == 0) { -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_35, 2); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 2); +x_42 = !lean_is_exclusive(x_41); +if (x_42 == 0) { -lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_42 = lean_ctor_get(x_40, 2); -x_43 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_40, 2, x_43); -x_44 = !lean_is_exclusive(x_8); -if (x_44 == 0) +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +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) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = lean_ctor_get(x_8, 2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_24); -x_47 = lean_array_push(x_45, x_46); -lean_ctor_set(x_8, 2, x_47); -x_48 = 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_38, x_8, x_35); -if (lean_obj_tag(x_48) == 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_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_49, 2); -lean_inc(x_50); -x_51 = !lean_is_exclusive(x_48); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_48, 1); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_49, 2); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_50); -if (x_55 == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_50, 2); -lean_dec(x_56); -lean_ctor_set(x_50, 2, x_42); -return x_48; +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_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_50, 0); -x_58 = lean_ctor_get(x_50, 1); -x_59 = lean_ctor_get(x_50, 3); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_50); -x_60 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_42); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_49, 2, x_60); -return x_48; +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_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; } } 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; -x_61 = lean_ctor_get(x_49, 0); -x_62 = lean_ctor_get(x_49, 1); -x_63 = lean_ctor_get(x_49, 3); -x_64 = lean_ctor_get(x_49, 4); -x_65 = lean_ctor_get(x_49, 5); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); +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_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; +} +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_44 = x_121; +x_45 = x_120; +goto block_94; +} +} +block_94: +{ +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_45, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_44, 0); +lean_inc(x_47); +lean_dec(x_44); +x_48 = !lean_is_exclusive(x_45); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_45, 2); +lean_dec(x_49); +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_43); +if (lean_is_scalar(x_36)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_36; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +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); +if (lean_is_scalar(x_36)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_36; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_47); +lean_ctor_set(x_57, 1, x_45); +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_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_inc(x_62); lean_inc(x_61); -lean_dec(x_49); -x_66 = lean_ctor_get(x_50, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_50, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_50, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_69 = x_50; +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); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 3); +lean_inc(x_65); +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; } else { - lean_dec_ref(x_50); - x_69 = lean_box(0); + lean_dec_ref(x_46); + x_66 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_67 = x_66; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_42); -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_48, 1, x_71); -return x_48; +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); +if (lean_is_scalar(x_36)) { + x_69 = lean_alloc_ctor(1, 2, 0); +} else { + x_69 = x_36; + lean_ctor_set_tag(x_69, 1); +} +lean_ctor_set(x_69, 0, x_47); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } 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; lean_object* x_84; lean_object* x_85; -x_72 = lean_ctor_get(x_48, 0); -lean_inc(x_72); -lean_dec(x_48); -x_73 = lean_ctor_get(x_49, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 3); -lean_inc(x_75); -x_76 = lean_ctor_get(x_49, 4); -lean_inc(x_76); -x_77 = lean_ctor_get(x_49, 5); -lean_inc(x_77); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_78 = x_49; +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_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); +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_43); +if (lean_is_scalar(x_36)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_49); - x_78 = lean_box(0); + x_76 = x_36; } -x_79 = lean_ctor_get(x_50, 0); +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_45); +return x_76; +} +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_inc(x_79); -x_80 = lean_ctor_get(x_50, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_50, 3); -lean_inc(x_81); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - x_82 = x_50; +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); +if (lean_is_scalar(x_36)) { + x_81 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_50); - x_82 = lean_box(0); + x_81 = x_36; } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 4, 0); -} else { - x_83 = x_82; -} -lean_ctor_set(x_83, 0, x_79); -lean_ctor_set(x_83, 1, x_80); -lean_ctor_set(x_83, 2, x_42); -lean_ctor_set(x_83, 3, x_81); -if (lean_is_scalar(x_78)) { - x_84 = lean_alloc_ctor(0, 6, 0); -} else { - x_84 = x_78; -} -lean_ctor_set(x_84, 0, x_73); -lean_ctor_set(x_84, 1, x_74); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_75); -lean_ctor_set(x_84, 4, x_76); -lean_ctor_set(x_84, 5, x_77); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_72); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_81, 0, x_71); +lean_ctor_set(x_81, 1, x_45); +return x_81; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_48, 1); +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_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); +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_is_exclusive(x_48); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_48, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_86, 2); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_42); -return x_48; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -x_96 = lean_ctor_get(x_87, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -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_42); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_86, 2, x_97); -return x_48; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 0); -x_99 = lean_ctor_get(x_86, 1); -x_100 = lean_ctor_get(x_86, 3); -x_101 = lean_ctor_get(x_86, 4); -x_102 = lean_ctor_get(x_86, 5); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_86); -x_103 = lean_ctor_get(x_87, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 3); -lean_inc(x_105); -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_106 = 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; } else { - lean_dec_ref(x_87); - x_106 = lean_box(0); + lean_dec_ref(x_70); + x_90 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_107 = x_106; + x_91 = x_90; } -lean_ctor_set(x_107, 0, x_103); -lean_ctor_set(x_107, 1, x_104); -lean_ctor_set(x_107, 2, x_42); -lean_ctor_set(x_107, 3, x_105); -x_108 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_108, 0, x_98); -lean_ctor_set(x_108, 1, x_99); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_100); -lean_ctor_set(x_108, 4, x_101); -lean_ctor_set(x_108, 5, x_102); -lean_ctor_set(x_48, 1, x_108); -return x_48; -} -} -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; -x_109 = lean_ctor_get(x_48, 0); -lean_inc(x_109); -lean_dec(x_48); -x_110 = lean_ctor_get(x_86, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 3); -lean_inc(x_112); -x_113 = lean_ctor_get(x_86, 4); -lean_inc(x_113); -x_114 = lean_ctor_get(x_86, 5); -lean_inc(x_114); -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_115 = x_86; +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); +if (lean_is_scalar(x_36)) { + x_93 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_86); - x_115 = lean_box(0); + x_93 = x_36; } -x_116 = lean_ctor_get(x_87, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_87, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 3); -lean_inc(x_118); -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_119 = x_87; -} else { - lean_dec_ref(x_87); - x_119 = lean_box(0); +lean_ctor_set(x_93, 0, x_71); +lean_ctor_set(x_93, 1, x_92); +return x_93; } -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 4, 0); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_116); -lean_ctor_set(x_120, 1, x_117); -lean_ctor_set(x_120, 2, x_42); -lean_ctor_set(x_120, 3, x_118); -if (lean_is_scalar(x_115)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_115; -} -lean_ctor_set(x_121, 0, x_110); -lean_ctor_set(x_121, 1, x_111); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_112); -lean_ctor_set(x_121, 4, x_113); -lean_ctor_set(x_121, 5, x_114); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_109); -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; -x_123 = lean_ctor_get(x_8, 0); -x_124 = lean_ctor_get(x_8, 1); -x_125 = lean_ctor_get(x_8, 2); -x_126 = lean_ctor_get(x_8, 3); -x_127 = lean_ctor_get(x_8, 4); -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; 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_dec(x_8); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_36); -lean_ctor_set(x_128, 1, x_24); -x_129 = lean_array_push(x_125, x_128); -x_130 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_130, 0, x_123); -lean_ctor_set(x_130, 1, x_124); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_126); -lean_ctor_set(x_130, 4, x_127); -x_131 = 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_38, x_130, x_35); -if (lean_obj_tag(x_131) == 0) -{ -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; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 0); -lean_inc(x_134); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_135 = x_131; +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_131); + 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_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_132, 0); +x_136 = lean_ctor_get(x_128, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); +x_137 = lean_ctor_get(x_128, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 3); +x_138 = lean_ctor_get(x_128, 3); lean_inc(x_138); -x_139 = lean_ctor_get(x_132, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_132, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_141 = x_132; +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_132); - x_141 = lean_box(0); + lean_dec_ref(x_128); + x_139 = lean_box(0); } -x_142 = lean_ctor_get(x_133, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_133, 3); -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); - x_145 = x_133; +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_145 = lean_box(0); + x_140 = x_139; } -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_42); -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); +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_148 = lean_alloc_ctor(0, 2, 0); + x_141 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_135; + x_141 = x_135; } -lean_ctor_set(x_148, 0, x_134); -lean_ctor_set(x_148, 1, x_147); -return x_148; +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_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_149 = lean_ctor_get(x_131, 1); +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); -x_150 = lean_ctor_get(x_149, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_131, 0); +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); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - x_152 = x_131; -} else { - lean_dec_ref(x_131); - x_152 = lean_box(0); -} -x_153 = lean_ctor_get(x_149, 0); +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_149, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 4); -lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; +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_149); - x_158 = lean_box(0); + lean_dec_ref(x_143); + x_154 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_150, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_150, 3); -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); - x_162 = x_150; +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_150); - x_162 = lean_box(0); + x_155 = x_154; } -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(0, 4, 0); +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_163 = x_162; + x_156 = x_150; } -lean_ctor_set(x_163, 0, x_159); -lean_ctor_set(x_163, 1, x_160); -lean_ctor_set(x_163, 2, x_42); -lean_ctor_set(x_163, 3, x_161); -if (lean_is_scalar(x_158)) { - x_164 = lean_alloc_ctor(0, 6, 0); +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_164 = x_158; + x_157 = x_36; } -lean_ctor_set(x_164, 0, x_153); -lean_ctor_set(x_164, 1, x_154); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_155); -lean_ctor_set(x_164, 4, x_156); -lean_ctor_set(x_164, 5, x_157); -if (lean_is_scalar(x_152)) { - x_165 = lean_alloc_ctor(1, 2, 0); -} else { - x_165 = x_152; +lean_ctor_set(x_157, 0, x_144); +lean_ctor_set(x_157, 1, x_156); +return x_157; } -lean_ctor_set(x_165, 0, x_151); -lean_ctor_set(x_165, 1, x_164); -return x_165; } } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_166 = lean_ctor_get(x_40, 0); -x_167 = lean_ctor_get(x_40, 1); -x_168 = lean_ctor_get(x_40, 2); -x_169 = lean_ctor_get(x_40, 3); -lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_40); -x_170 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_171 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_171, 0, x_166); -lean_ctor_set(x_171, 1, x_167); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_169); -lean_ctor_set(x_35, 2, x_171); -x_172 = lean_ctor_get(x_8, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_8, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_8, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_8, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_8, 4); -lean_inc(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_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); 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_177 = x_8; + x_229 = x_8; } else { lean_dec_ref(x_8); - x_177 = lean_box(0); + x_229 = lean_box(0); } -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_36); -lean_ctor_set(x_178, 1, x_24); -x_179 = lean_array_push(x_174, x_178); -if (lean_is_scalar(x_177)) { - x_180 = lean_alloc_ctor(0, 5, 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_232 = lean_alloc_ctor(0, 5, 0); } else { - x_180 = x_177; + x_232 = x_229; } -lean_ctor_set(x_180, 0, x_172); -lean_ctor_set(x_180, 1, x_173); -lean_ctor_set(x_180, 2, x_179); -lean_ctor_set(x_180, 3, x_175); -lean_ctor_set(x_180, 4, x_176); -x_181 = 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_38, x_180, x_35); -if (lean_obj_tag(x_181) == 0) +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_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_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_196; lean_object* x_197; lean_object* x_198; -x_182 = lean_ctor_get(x_181, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_186 = lean_ctor_get(x_182, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_182, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_182, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_182, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_182, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - lean_ctor_release(x_182, 2); - lean_ctor_release(x_182, 3); - lean_ctor_release(x_182, 4); - lean_ctor_release(x_182, 5); - x_191 = x_182; -} else { - lean_dec_ref(x_182); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_183, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_183, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_183, 3); -lean_inc(x_194); -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); - x_195 = x_183; -} else { - lean_dec_ref(x_183); - 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_168); -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_185)) { - x_198 = lean_alloc_ctor(0, 2, 0); -} else { - x_198 = x_185; -} -lean_ctor_set(x_198, 0, x_184); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_188 = x_236; +x_189 = x_235; +goto block_220; } 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; lean_object* x_214; lean_object* x_215; -x_199 = lean_ctor_get(x_181, 1); +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_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; +} 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_199, 2); +x_200 = lean_ctor_get(x_190, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_181, 0); -lean_inc(x_201); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - x_202 = x_181; +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_181); - x_202 = lean_box(0); + lean_dec_ref(x_190); + x_201 = lean_box(0); } -x_203 = lean_ctor_get(x_199, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_199, 3); +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_199, 4); +x_206 = lean_ctor_get(x_188, 0); lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 5); +lean_dec(x_188); +x_207 = lean_ctor_get(x_189, 0); lean_inc(x_207); -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); - lean_ctor_release(x_199, 4); - lean_ctor_release(x_199, 5); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = lean_ctor_get(x_200, 0); +x_208 = lean_ctor_get(x_189, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_189, 3); lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 1); +x_210 = lean_ctor_get(x_189, 4); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 3); +x_211 = lean_ctor_get(x_189, 5); 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); - x_212 = x_200; +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; } else { - lean_dec_ref(x_200); + lean_dec_ref(x_189); 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); +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; +} else { + lean_dec_ref(x_205); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 4, 0); +} else { + x_217 = x_216; +} +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_213 = lean_alloc_ctor(0, 4, 0); + x_218 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_218 = x_212; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_168); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_36)) { + x_219 = lean_alloc_ctor(0, 2, 0); } else { - x_214 = x_208; + x_219 = x_36; } -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); -if (lean_is_scalar(x_202)) { - x_215 = lean_alloc_ctor(1, 2, 0); -} else { - x_215 = x_202; +lean_ctor_set(x_219, 0, x_206); +lean_ctor_set(x_219, 1, x_218); +return x_219; } -lean_ctor_set(x_215, 0, x_201); -lean_ctor_set(x_215, 1, x_214); -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_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; -x_216 = lean_ctor_get(x_35, 2); -x_217 = lean_ctor_get(x_35, 0); -x_218 = lean_ctor_get(x_35, 1); -x_219 = lean_ctor_get(x_35, 3); -x_220 = lean_ctor_get(x_35, 4); -x_221 = lean_ctor_get(x_35, 5); -lean_inc(x_221); -lean_inc(x_220); -lean_inc(x_219); -lean_inc(x_216); -lean_inc(x_218); -lean_inc(x_217); -lean_dec(x_35); -x_222 = lean_ctor_get(x_216, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_216, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_216, 3); -lean_inc(x_225); -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_226 = x_216; -} else { - lean_dec_ref(x_216); - x_226 = lean_box(0); -} -x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 4, 0); -} else { - x_228 = x_226; -} -lean_ctor_set(x_228, 0, x_222); -lean_ctor_set(x_228, 1, x_223); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_225); -x_229 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_229, 0, x_217); -lean_ctor_set(x_229, 1, x_218); -lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_219); -lean_ctor_set(x_229, 4, x_220); -lean_ctor_set(x_229, 5, x_221); -x_230 = lean_ctor_get(x_8, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_8, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_8, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_8, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_8, 4); -lean_inc(x_234); -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_235 = x_8; -} else { - lean_dec_ref(x_8); - x_235 = lean_box(0); -} -x_236 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_236, 0, x_36); -lean_ctor_set(x_236, 1, x_24); -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_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_238, x_229); -if (lean_obj_tag(x_239) == 0) -{ -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; -x_240 = lean_ctor_get(x_239, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_239, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_243 = x_239; -} else { - lean_dec_ref(x_239); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_240, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_240, 3); -lean_inc(x_246); -x_247 = lean_ctor_get(x_240, 4); -lean_inc(x_247); -x_248 = lean_ctor_get(x_240, 5); -lean_inc(x_248); -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_249 = x_240; -} else { - lean_dec_ref(x_240); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_241, 3); -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); - x_253 = x_241; -} else { - lean_dec_ref(x_241); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 4, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_250); -lean_ctor_set(x_254, 1, x_251); -lean_ctor_set(x_254, 2, x_224); -lean_ctor_set(x_254, 3, x_252); -if (lean_is_scalar(x_249)) { - x_255 = lean_alloc_ctor(0, 6, 0); -} else { - x_255 = x_249; -} -lean_ctor_set(x_255, 0, x_244); -lean_ctor_set(x_255, 1, x_245); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_246); -lean_ctor_set(x_255, 4, x_247); -lean_ctor_set(x_255, 5, x_248); -if (lean_is_scalar(x_243)) { - x_256 = lean_alloc_ctor(0, 2, 0); -} else { - x_256 = x_243; -} -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; lean_object* x_273; -x_257 = lean_ctor_get(x_239, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_239, 0); -lean_inc(x_259); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_260 = x_239; -} else { - lean_dec_ref(x_239); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_257, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_257, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_257, 3); -lean_inc(x_263); -x_264 = lean_ctor_get(x_257, 4); -lean_inc(x_264); -x_265 = lean_ctor_get(x_257, 5); -lean_inc(x_265); -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); - lean_ctor_release(x_257, 5); - x_266 = x_257; -} else { - lean_dec_ref(x_257); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_258, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_258, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_258, 3); -lean_inc(x_269); -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_270 = x_258; -} else { - lean_dec_ref(x_258); - x_270 = lean_box(0); -} -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); -} else { - x_271 = x_270; -} -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_224); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); -} else { - x_272 = x_266; -} -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(1, 2, 0); -} else { - x_273 = x_260; -} -lean_ctor_set(x_273, 0, x_259); -lean_ctor_set(x_273, 1, x_272); -return x_273; } } } default: { -lean_object* x_274; lean_object* x_275; -x_274 = lean_ctor_get(x_29, 1); -lean_inc(x_274); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_29, 1); +lean_inc(x_240); lean_dec(x_29); lean_inc(x_8); -x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); -if (lean_obj_tag(x_275) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_276; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -if (lean_obj_tag(x_276) == 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_277; lean_object* x_278; lean_object* x_279; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_24); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_7, x_278); +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); lean_dec(x_7); -x_7 = x_279; -x_9 = x_277; +x_7 = x_245; +x_9 = x_243; goto _start; } else { -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; uint8_t x_285; -x_281 = lean_ctor_get(x_275, 1); -lean_inc(x_281); -lean_dec(x_275); -x_282 = lean_ctor_get(x_276, 0); -lean_inc(x_282); -lean_dec(x_276); -x_283 = lean_unsigned_to_nat(1u); -x_284 = lean_nat_add(x_7, x_283); +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_241); + x_248 = 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_285 = !lean_is_exclusive(x_281); -if (x_285 == 0) +x_252 = !lean_is_exclusive(x_247); +if (x_252 == 0) { -lean_object* x_286; uint8_t x_287; -x_286 = lean_ctor_get(x_281, 2); -x_287 = !lean_is_exclusive(x_286); -if (x_287 == 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_288; lean_object* x_289; uint8_t x_290; -x_288 = lean_ctor_get(x_286, 2); -x_289 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_286, 2, x_289); -x_290 = !lean_is_exclusive(x_8); -if (x_290 == 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_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_291 = lean_ctor_get(x_8, 2); -x_292 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_292, 0, x_282); -lean_ctor_set(x_292, 1, x_24); -x_293 = lean_array_push(x_291, x_292); -lean_ctor_set(x_8, 2, x_293); -x_294 = 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_284, x_8, x_281); -if (lean_obj_tag(x_294) == 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_295; lean_object* x_296; uint8_t x_297; -x_295 = lean_ctor_get(x_294, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_295, 2); -lean_inc(x_296); -x_297 = !lean_is_exclusive(x_294); -if (x_297 == 0) -{ -lean_object* x_298; uint8_t x_299; -x_298 = lean_ctor_get(x_294, 1); -lean_dec(x_298); -x_299 = !lean_is_exclusive(x_295); -if (x_299 == 0) -{ -lean_object* x_300; uint8_t x_301; -x_300 = lean_ctor_get(x_295, 2); -lean_dec(x_300); -x_301 = !lean_is_exclusive(x_296); -if (x_301 == 0) -{ -lean_object* x_302; -x_302 = lean_ctor_get(x_296, 2); -lean_dec(x_302); -lean_ctor_set(x_296, 2, x_288); -return x_294; -} -else -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_296, 0); -x_304 = lean_ctor_get(x_296, 1); -x_305 = lean_ctor_get(x_296, 3); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_dec(x_296); -x_306 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_288); -lean_ctor_set(x_306, 3, x_305); -lean_ctor_set(x_295, 2, x_306); -return x_294; -} -} -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; -x_307 = lean_ctor_get(x_295, 0); -x_308 = lean_ctor_get(x_295, 1); -x_309 = lean_ctor_get(x_295, 3); -x_310 = lean_ctor_get(x_295, 4); -x_311 = lean_ctor_get(x_295, 5); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_dec(x_295); -x_312 = lean_ctor_get(x_296, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_296, 1); +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_296, 3); +x_314 = lean_ctor_get(x_312, 1); lean_inc(x_314); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_315 = x_296; -} else { - lean_dec_ref(x_296); - x_315 = lean_box(0); +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; } -if (lean_is_scalar(x_315)) { - x_316 = lean_alloc_ctor(0, 4, 0); -} else { - x_316 = x_315; -} -lean_ctor_set(x_316, 0, x_312); -lean_ctor_set(x_316, 1, x_313); -lean_ctor_set(x_316, 2, x_288); -lean_ctor_set(x_316, 3, x_314); -x_317 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_317, 0, x_307); -lean_ctor_set(x_317, 1, x_308); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_309); -lean_ctor_set(x_317, 4, x_310); -lean_ctor_set(x_317, 5, x_311); -lean_ctor_set(x_294, 1, x_317); -return x_294; +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_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_318 = lean_ctor_get(x_294, 0); -lean_inc(x_318); -lean_dec(x_294); -x_319 = lean_ctor_get(x_295, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_295, 1); -lean_inc(x_320); -x_321 = lean_ctor_get(x_295, 3); -lean_inc(x_321); -x_322 = lean_ctor_get(x_295, 4); -lean_inc(x_322); -x_323 = lean_ctor_get(x_295, 5); +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); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - lean_ctor_release(x_295, 2); - lean_ctor_release(x_295, 3); - lean_ctor_release(x_295, 4); - lean_ctor_release(x_295, 5); - x_324 = x_295; -} else { - lean_dec_ref(x_295); - x_324 = lean_box(0); -} -x_325 = lean_ctor_get(x_296, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_296, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_296, 3); -lean_inc(x_327); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - x_328 = x_296; -} else { - lean_dec_ref(x_296); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 4, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_325); -lean_ctor_set(x_329, 1, x_326); -lean_ctor_set(x_329, 2, x_288); -lean_ctor_set(x_329, 3, x_327); -if (lean_is_scalar(x_324)) { - x_330 = lean_alloc_ctor(0, 6, 0); -} else { - x_330 = x_324; -} -lean_ctor_set(x_330, 0, x_319); -lean_ctor_set(x_330, 1, x_320); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_321); -lean_ctor_set(x_330, 4, x_322); -lean_ctor_set(x_330, 5, x_323); -x_331 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_331, 0, x_318); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} -} -else -{ -lean_object* x_332; lean_object* x_333; uint8_t x_334; -x_332 = lean_ctor_get(x_294, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_332, 2); -lean_inc(x_333); -x_334 = !lean_is_exclusive(x_294); -if (x_334 == 0) -{ -lean_object* x_335; uint8_t x_336; -x_335 = lean_ctor_get(x_294, 1); -lean_dec(x_335); -x_336 = !lean_is_exclusive(x_332); -if (x_336 == 0) -{ -lean_object* x_337; uint8_t x_338; -x_337 = lean_ctor_get(x_332, 2); -lean_dec(x_337); -x_338 = !lean_is_exclusive(x_333); -if (x_338 == 0) -{ -lean_object* x_339; -x_339 = lean_ctor_get(x_333, 2); -lean_dec(x_339); -lean_ctor_set(x_333, 2, x_288); -return x_294; -} -else -{ -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_340 = lean_ctor_get(x_333, 0); -x_341 = lean_ctor_get(x_333, 1); -x_342 = lean_ctor_get(x_333, 3); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_dec(x_333); -x_343 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_343, 0, x_340); -lean_ctor_set(x_343, 1, x_341); -lean_ctor_set(x_343, 2, x_288); -lean_ctor_set(x_343, 3, x_342); -lean_ctor_set(x_332, 2, x_343); -return x_294; -} -} -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; -x_344 = lean_ctor_get(x_332, 0); -x_345 = lean_ctor_get(x_332, 1); -x_346 = lean_ctor_get(x_332, 3); -x_347 = lean_ctor_get(x_332, 4); -x_348 = lean_ctor_get(x_332, 5); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); -lean_dec(x_332); -x_349 = lean_ctor_get(x_333, 0); -lean_inc(x_349); -x_350 = lean_ctor_get(x_333, 1); -lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 3); -lean_inc(x_351); -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); - x_352 = x_333; -} else { - lean_dec_ref(x_333); - x_352 = lean_box(0); -} -if (lean_is_scalar(x_352)) { - x_353 = lean_alloc_ctor(0, 4, 0); -} else { - x_353 = x_352; -} -lean_ctor_set(x_353, 0, x_349); -lean_ctor_set(x_353, 1, x_350); -lean_ctor_set(x_353, 2, x_288); -lean_ctor_set(x_353, 3, x_351); -x_354 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_354, 0, x_344); -lean_ctor_set(x_354, 1, x_345); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_346); -lean_ctor_set(x_354, 4, x_347); -lean_ctor_set(x_354, 5, x_348); -lean_ctor_set(x_294, 1, x_354); -return x_294; -} -} -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; -x_355 = lean_ctor_get(x_294, 0); -lean_inc(x_355); -lean_dec(x_294); -x_356 = lean_ctor_get(x_332, 0); -lean_inc(x_356); -x_357 = lean_ctor_get(x_332, 1); -lean_inc(x_357); -x_358 = lean_ctor_get(x_332, 3); -lean_inc(x_358); -x_359 = lean_ctor_get(x_332, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_332, 5); -lean_inc(x_360); -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); - lean_ctor_release(x_332, 5); - x_361 = x_332; -} else { - lean_dec_ref(x_332); - x_361 = lean_box(0); -} -x_362 = lean_ctor_get(x_333, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_333, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_333, 3); -lean_inc(x_364); -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); - x_365 = x_333; -} else { - lean_dec_ref(x_333); - x_365 = lean_box(0); -} -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 4, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_362); -lean_ctor_set(x_366, 1, x_363); -lean_ctor_set(x_366, 2, x_288); -lean_ctor_set(x_366, 3, x_364); -if (lean_is_scalar(x_361)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_361; -} -lean_ctor_set(x_367, 0, x_356); -lean_ctor_set(x_367, 1, x_357); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_358); -lean_ctor_set(x_367, 4, x_359); -lean_ctor_set(x_367, 5, x_360); -x_368 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_368, 0, x_355); -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; -x_369 = lean_ctor_get(x_8, 0); -x_370 = lean_ctor_get(x_8, 1); -x_371 = lean_ctor_get(x_8, 2); -x_372 = lean_ctor_get(x_8, 3); -x_373 = lean_ctor_get(x_8, 4); -lean_inc(x_373); -lean_inc(x_372); -lean_inc(x_371); -lean_inc(x_370); -lean_inc(x_369); +lean_inc(x_322); +lean_inc(x_321); +lean_inc(x_320); +lean_inc(x_319); lean_dec(x_8); -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_282); -lean_ctor_set(x_374, 1, x_24); -x_375 = lean_array_push(x_371, x_374); -x_376 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_376, 0, x_369); -lean_ctor_set(x_376, 1, x_370); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_372); -lean_ctor_set(x_376, 4, x_373); -x_377 = 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_284, x_376, x_281); -if (lean_obj_tag(x_377) == 0) +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_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_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; -x_378 = lean_ctor_get(x_377, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_378, 2); -lean_inc(x_379); -x_380 = lean_ctor_get(x_377, 0); -lean_inc(x_380); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_381 = x_377; -} else { - lean_dec_ref(x_377); - x_381 = lean_box(0); -} -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 4); -lean_inc(x_385); -x_386 = lean_ctor_get(x_378, 5); -lean_inc(x_386); -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); - lean_ctor_release(x_378, 4); - lean_ctor_release(x_378, 5); - x_387 = x_378; -} else { - lean_dec_ref(x_378); - x_387 = lean_box(0); -} -x_388 = lean_ctor_get(x_379, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_379, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_379, 3); -lean_inc(x_390); -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_391 = x_379; -} else { - lean_dec_ref(x_379); - x_391 = lean_box(0); -} -if (lean_is_scalar(x_391)) { - x_392 = lean_alloc_ctor(0, 4, 0); -} else { - x_392 = x_391; -} -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_288); -lean_ctor_set(x_392, 3, x_390); -if (lean_is_scalar(x_387)) { - x_393 = lean_alloc_ctor(0, 6, 0); -} else { - x_393 = x_387; -} -lean_ctor_set(x_393, 0, x_382); -lean_ctor_set(x_393, 1, x_383); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_384); -lean_ctor_set(x_393, 4, x_385); -lean_ctor_set(x_393, 5, x_386); -if (lean_is_scalar(x_381)) { - x_394 = lean_alloc_ctor(0, 2, 0); -} else { - x_394 = x_381; -} -lean_ctor_set(x_394, 0, x_380); -lean_ctor_set(x_394, 1, x_393); -return x_394; +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_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_409; lean_object* x_410; lean_object* x_411; -x_395 = lean_ctor_get(x_377, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_377, 0); -lean_inc(x_397); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_398 = x_377; -} else { - lean_dec_ref(x_377); - x_398 = lean_box(0); +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; } -x_399 = lean_ctor_get(x_395, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_395, 5); -lean_inc(x_403); -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_404 = x_395; -} else { - lean_dec_ref(x_395); - x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_396, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_396, 3); -lean_inc(x_407); -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_408 = x_396; +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); +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 { - lean_dec_ref(x_396); - x_408 = lean_box(0); + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); } -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); +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; +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_409 = x_408; + x_269 = x_248; + lean_ctor_set_tag(x_269, 1); } -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_288); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_269, 0, x_259); +lean_ctor_set(x_269, 1, x_257); +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; 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_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 { - x_410 = x_404; + lean_dec_ref(x_258); + x_278 = lean_box(0); } -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_398)) { - x_411 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_278)) { + x_279 = lean_alloc_ctor(0, 4, 0); } else { - x_411 = x_398; + x_279 = x_278; +} +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, 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); +} else { + x_281 = x_248; + lean_ctor_set_tag(x_281, 1); +} +lean_ctor_set(x_281, 0, x_259); +lean_ctor_set(x_281, 1, x_280); +return x_281; +} +} +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_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_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); +} else { + x_293 = x_248; +} +lean_ctor_set(x_293, 0, x_283); +lean_ctor_set(x_293, 1, x_257); +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_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); +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; +} else { + lean_dec_ref(x_282); + x_302 = lean_box(0); +} +if (lean_is_scalar(x_302)) { + x_303 = lean_alloc_ctor(0, 4, 0); +} else { + x_303 = x_302; +} +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); +} else { + x_305 = x_248; +} +lean_ctor_set(x_305, 0, x_283); +lean_ctor_set(x_305, 1, x_304); +return x_305; } -lean_ctor_set(x_411, 0, x_397); -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; lean_object* x_427; -x_412 = lean_ctor_get(x_286, 0); -x_413 = lean_ctor_get(x_286, 1); -x_414 = lean_ctor_get(x_286, 2); -x_415 = lean_ctor_get(x_286, 3); -lean_inc(x_415); -lean_inc(x_414); -lean_inc(x_413); -lean_inc(x_412); -lean_dec(x_286); -x_416 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_417 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_417, 0, x_412); -lean_ctor_set(x_417, 1, x_413); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_415); -lean_ctor_set(x_281, 2, x_417); -x_418 = lean_ctor_get(x_8, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_8, 1); -lean_inc(x_419); -x_420 = lean_ctor_get(x_8, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_8, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_8, 4); -lean_inc(x_422); +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); 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_423 = x_8; + x_378 = x_8; } else { lean_dec_ref(x_8); - x_423 = lean_box(0); + x_378 = lean_box(0); } -x_424 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_424, 0, x_282); -lean_ctor_set(x_424, 1, x_24); -x_425 = lean_array_push(x_420, x_424); -if (lean_is_scalar(x_423)) { - x_426 = lean_alloc_ctor(0, 5, 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); } else { - x_426 = x_423; + x_381 = x_378; } -lean_ctor_set(x_426, 0, x_418); -lean_ctor_set(x_426, 1, x_419); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_421); -lean_ctor_set(x_426, 4, x_422); -x_427 = 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_284, x_426, x_281); -if (lean_obj_tag(x_427) == 0) +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_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_428 = lean_ctor_get(x_427, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_428, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_427, 0); -lean_inc(x_430); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_431 = x_427; -} else { - lean_dec_ref(x_427); - x_431 = lean_box(0); -} -x_432 = lean_ctor_get(x_428, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_428, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_428, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_428, 4); -lean_inc(x_435); -x_436 = lean_ctor_get(x_428, 5); -lean_inc(x_436); -if (lean_is_exclusive(x_428)) { - lean_ctor_release(x_428, 0); - lean_ctor_release(x_428, 1); - lean_ctor_release(x_428, 2); - lean_ctor_release(x_428, 3); - lean_ctor_release(x_428, 4); - lean_ctor_release(x_428, 5); - x_437 = x_428; -} else { - lean_dec_ref(x_428); - x_437 = lean_box(0); -} -x_438 = lean_ctor_get(x_429, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_429, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_429, 3); -lean_inc(x_440); -if (lean_is_exclusive(x_429)) { - lean_ctor_release(x_429, 0); - lean_ctor_release(x_429, 1); - lean_ctor_release(x_429, 2); - lean_ctor_release(x_429, 3); - x_441 = x_429; -} else { - lean_dec_ref(x_429); - x_441 = lean_box(0); -} -if (lean_is_scalar(x_441)) { - x_442 = lean_alloc_ctor(0, 4, 0); -} else { - x_442 = x_441; -} -lean_ctor_set(x_442, 0, x_438); -lean_ctor_set(x_442, 1, x_439); -lean_ctor_set(x_442, 2, x_414); -lean_ctor_set(x_442, 3, x_440); -if (lean_is_scalar(x_437)) { - x_443 = lean_alloc_ctor(0, 6, 0); -} else { - x_443 = x_437; -} -lean_ctor_set(x_443, 0, x_432); -lean_ctor_set(x_443, 1, x_433); -lean_ctor_set(x_443, 2, x_442); -lean_ctor_set(x_443, 3, x_434); -lean_ctor_set(x_443, 4, x_435); -lean_ctor_set(x_443, 5, x_436); -if (lean_is_scalar(x_431)) { - x_444 = lean_alloc_ctor(0, 2, 0); -} else { - x_444 = x_431; -} -lean_ctor_set(x_444, 0, x_430); -lean_ctor_set(x_444, 1, x_443); -return x_444; +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; } else { -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_445 = lean_ctor_get(x_427, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_445, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_427, 0); -lean_inc(x_447); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - x_448 = x_427; -} else { - lean_dec_ref(x_427); - x_448 = lean_box(0); +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; } +block_370: +{ +if (lean_obj_tag(x_338) == 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_inc(x_355); +x_356 = lean_ctor_get(x_338, 0); +lean_inc(x_356); +lean_dec(x_338); +x_357 = lean_ctor_get(x_339, 0); +lean_inc(x_357); +x_358 = lean_ctor_get(x_339, 1); +lean_inc(x_358); +x_359 = lean_ctor_get(x_339, 3); +lean_inc(x_359); +x_360 = lean_ctor_get(x_339, 4); +lean_inc(x_360); +x_361 = lean_ctor_get(x_339, 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; +} else { + lean_dec_ref(x_339); + x_362 = lean_box(0); +} +x_363 = lean_ctor_get(x_355, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_355, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_355, 3); +lean_inc(x_365); +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; +} else { + lean_dec_ref(x_355); + x_366 = lean_box(0); +} +if (lean_is_scalar(x_366)) { + x_367 = lean_alloc_ctor(0, 4, 0); +} else { + x_367 = x_366; +} +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); +if (lean_is_scalar(x_362)) { + x_368 = lean_alloc_ctor(0, 6, 0); +} else { + x_368 = 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); +} else { + x_369 = x_248; +} +lean_ctor_set(x_369, 0, x_356); +lean_ctor_set(x_369, 1, x_368); +return x_369; +} +} +} +} +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; +} else { + lean_dec_ref(x_389); + x_399 = 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); +} else { + x_434 = x_399; +} +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); +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; +} else { + lean_dec_ref(x_8); + x_441 = 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); +} else { + x_444 = x_441; +} +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_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; +} +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); -x_451 = lean_ctor_get(x_445, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_445, 4); -lean_inc(x_452); -x_453 = lean_ctor_get(x_445, 5); -lean_inc(x_453); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - lean_ctor_release(x_445, 2); - lean_ctor_release(x_445, 3); - lean_ctor_release(x_445, 4); - lean_ctor_release(x_445, 5); - x_454 = x_445; +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; +} +block_432: +{ +if (lean_obj_tag(x_400) == 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_445); - x_454 = lean_box(0); + lean_dec_ref(x_401); + x_409 = lean_box(0); } -x_455 = lean_ctor_get(x_446, 0); -lean_inc(x_455); -x_456 = lean_ctor_get(x_446, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_446, 3); -lean_inc(x_457); -if (lean_is_exclusive(x_446)) { - lean_ctor_release(x_446, 0); - lean_ctor_release(x_446, 1); - lean_ctor_release(x_446, 2); - lean_ctor_release(x_446, 3); - x_458 = x_446; +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_446); - x_458 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_413)) { + x_414 = lean_alloc_ctor(0, 4, 0); } else { - x_459 = x_458; + x_414 = x_413; } -lean_ctor_set(x_459, 0, x_455); -lean_ctor_set(x_459, 1, x_456); -lean_ctor_set(x_459, 2, x_414); -lean_ctor_set(x_459, 3, x_457); -if (lean_is_scalar(x_454)) { - x_460 = lean_alloc_ctor(0, 6, 0); +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_460 = x_454; + x_415 = x_409; } -lean_ctor_set(x_460, 0, x_449); -lean_ctor_set(x_460, 1, x_450); -lean_ctor_set(x_460, 2, x_459); -lean_ctor_set(x_460, 3, x_451); -lean_ctor_set(x_460, 4, x_452); -lean_ctor_set(x_460, 5, x_453); -if (lean_is_scalar(x_448)) { - x_461 = lean_alloc_ctor(1, 2, 0); +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_461 = x_448; -} -lean_ctor_set(x_461, 0, x_447); -lean_ctor_set(x_461, 1, x_460); -return x_461; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_462 = lean_ctor_get(x_281, 2); -x_463 = lean_ctor_get(x_281, 0); -x_464 = lean_ctor_get(x_281, 1); -x_465 = lean_ctor_get(x_281, 3); -x_466 = lean_ctor_get(x_281, 4); -x_467 = lean_ctor_get(x_281, 5); -lean_inc(x_467); -lean_inc(x_466); -lean_inc(x_465); -lean_inc(x_462); -lean_inc(x_464); -lean_inc(x_463); -lean_dec(x_281); -x_468 = lean_ctor_get(x_462, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_462, 1); -lean_inc(x_469); -x_470 = lean_ctor_get(x_462, 2); -lean_inc(x_470); -x_471 = lean_ctor_get(x_462, 3); -lean_inc(x_471); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - lean_ctor_release(x_462, 2); - lean_ctor_release(x_462, 3); - x_472 = x_462; +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_inc(x_420); +x_421 = lean_ctor_get(x_401, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_401, 4); +lean_inc(x_422); +x_423 = lean_ctor_get(x_401, 5); +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_462); - x_472 = lean_box(0); + lean_dec_ref(x_401); + x_424 = lean_box(0); } -x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_472)) { - x_474 = 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); +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; } else { - x_474 = x_472; + lean_dec_ref(x_417); + x_428 = lean_box(0); } -lean_ctor_set(x_474, 0, x_468); -lean_ctor_set(x_474, 1, x_469); -lean_ctor_set(x_474, 2, x_473); -lean_ctor_set(x_474, 3, x_471); -x_475 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_475, 0, x_463); -lean_ctor_set(x_475, 1, x_464); -lean_ctor_set(x_475, 2, x_474); -lean_ctor_set(x_475, 3, x_465); -lean_ctor_set(x_475, 4, x_466); -lean_ctor_set(x_475, 5, x_467); -x_476 = lean_ctor_get(x_8, 0); -lean_inc(x_476); -x_477 = lean_ctor_get(x_8, 1); -lean_inc(x_477); -x_478 = lean_ctor_get(x_8, 2); -lean_inc(x_478); -x_479 = lean_ctor_get(x_8, 3); -lean_inc(x_479); -x_480 = lean_ctor_get(x_8, 4); -lean_inc(x_480); -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_481 = x_8; +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_8); - x_481 = lean_box(0); + x_429 = x_428; } -x_482 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_482, 0, x_282); -lean_ctor_set(x_482, 1, x_24); -x_483 = lean_array_push(x_478, x_482); -if (lean_is_scalar(x_481)) { - x_484 = lean_alloc_ctor(0, 5, 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); } else { - x_484 = x_481; + x_430 = x_424; } -lean_ctor_set(x_484, 0, x_476); -lean_ctor_set(x_484, 1, x_477); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_479); -lean_ctor_set(x_484, 4, x_480); -x_485 = 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_284, x_484, x_475); -if (lean_obj_tag(x_485) == 0) -{ -lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_486 = lean_ctor_get(x_485, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_486, 2); -lean_inc(x_487); -x_488 = lean_ctor_get(x_485, 0); -lean_inc(x_488); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_489 = x_485; +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); } else { - lean_dec_ref(x_485); - x_489 = lean_box(0); + x_431 = x_248; } -x_490 = lean_ctor_get(x_486, 0); -lean_inc(x_490); -x_491 = lean_ctor_get(x_486, 1); -lean_inc(x_491); -x_492 = lean_ctor_get(x_486, 3); -lean_inc(x_492); -x_493 = lean_ctor_get(x_486, 4); -lean_inc(x_493); -x_494 = lean_ctor_get(x_486, 5); -lean_inc(x_494); -if (lean_is_exclusive(x_486)) { - lean_ctor_release(x_486, 0); - lean_ctor_release(x_486, 1); - lean_ctor_release(x_486, 2); - lean_ctor_release(x_486, 3); - lean_ctor_release(x_486, 4); - lean_ctor_release(x_486, 5); - x_495 = x_486; -} else { - lean_dec_ref(x_486); - x_495 = lean_box(0); +lean_ctor_set(x_431, 0, x_418); +lean_ctor_set(x_431, 1, x_430); +return x_431; } -x_496 = lean_ctor_get(x_487, 0); -lean_inc(x_496); -x_497 = lean_ctor_get(x_487, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_487, 3); -lean_inc(x_498); -if (lean_is_exclusive(x_487)) { - lean_ctor_release(x_487, 0); - lean_ctor_release(x_487, 1); - lean_ctor_release(x_487, 2); - lean_ctor_release(x_487, 3); - x_499 = x_487; -} else { - lean_dec_ref(x_487); - x_499 = lean_box(0); -} -if (lean_is_scalar(x_499)) { - x_500 = lean_alloc_ctor(0, 4, 0); -} else { - x_500 = x_499; -} -lean_ctor_set(x_500, 0, x_496); -lean_ctor_set(x_500, 1, x_497); -lean_ctor_set(x_500, 2, x_470); -lean_ctor_set(x_500, 3, x_498); -if (lean_is_scalar(x_495)) { - x_501 = lean_alloc_ctor(0, 6, 0); -} else { - x_501 = x_495; -} -lean_ctor_set(x_501, 0, x_490); -lean_ctor_set(x_501, 1, x_491); -lean_ctor_set(x_501, 2, x_500); -lean_ctor_set(x_501, 3, x_492); -lean_ctor_set(x_501, 4, x_493); -lean_ctor_set(x_501, 5, x_494); -if (lean_is_scalar(x_489)) { - x_502 = lean_alloc_ctor(0, 2, 0); -} else { - x_502 = x_489; -} -lean_ctor_set(x_502, 0, x_488); -lean_ctor_set(x_502, 1, x_501); -return x_502; -} -else -{ -lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_503 = lean_ctor_get(x_485, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_503, 2); -lean_inc(x_504); -x_505 = lean_ctor_get(x_485, 0); -lean_inc(x_505); -if (lean_is_exclusive(x_485)) { - lean_ctor_release(x_485, 0); - lean_ctor_release(x_485, 1); - x_506 = x_485; -} else { - lean_dec_ref(x_485); - x_506 = lean_box(0); -} -x_507 = lean_ctor_get(x_503, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_503, 1); -lean_inc(x_508); -x_509 = lean_ctor_get(x_503, 3); -lean_inc(x_509); -x_510 = lean_ctor_get(x_503, 4); -lean_inc(x_510); -x_511 = lean_ctor_get(x_503, 5); -lean_inc(x_511); -if (lean_is_exclusive(x_503)) { - lean_ctor_release(x_503, 0); - lean_ctor_release(x_503, 1); - lean_ctor_release(x_503, 2); - lean_ctor_release(x_503, 3); - lean_ctor_release(x_503, 4); - lean_ctor_release(x_503, 5); - x_512 = x_503; -} else { - lean_dec_ref(x_503); - x_512 = lean_box(0); -} -x_513 = lean_ctor_get(x_504, 0); -lean_inc(x_513); -x_514 = lean_ctor_get(x_504, 1); -lean_inc(x_514); -x_515 = lean_ctor_get(x_504, 3); -lean_inc(x_515); -if (lean_is_exclusive(x_504)) { - lean_ctor_release(x_504, 0); - lean_ctor_release(x_504, 1); - lean_ctor_release(x_504, 2); - lean_ctor_release(x_504, 3); - x_516 = x_504; -} else { - lean_dec_ref(x_504); - x_516 = lean_box(0); -} -if (lean_is_scalar(x_516)) { - x_517 = lean_alloc_ctor(0, 4, 0); -} else { - x_517 = x_516; -} -lean_ctor_set(x_517, 0, x_513); -lean_ctor_set(x_517, 1, x_514); -lean_ctor_set(x_517, 2, x_470); -lean_ctor_set(x_517, 3, x_515); -if (lean_is_scalar(x_512)) { - x_518 = lean_alloc_ctor(0, 6, 0); -} else { - x_518 = x_512; -} -lean_ctor_set(x_518, 0, x_507); -lean_ctor_set(x_518, 1, x_508); -lean_ctor_set(x_518, 2, x_517); -lean_ctor_set(x_518, 3, x_509); -lean_ctor_set(x_518, 4, x_510); -lean_ctor_set(x_518, 5, x_511); -if (lean_is_scalar(x_506)) { - x_519 = lean_alloc_ctor(1, 2, 0); -} else { - x_519 = x_506; -} -lean_ctor_set(x_519, 0, x_505); -lean_ctor_set(x_519, 1, x_518); -return x_519; } } } } else { -uint8_t x_520; +uint8_t x_452; 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_520 = !lean_is_exclusive(x_275); -if (x_520 == 0) +x_452 = !lean_is_exclusive(x_241); +if (x_452 == 0) { -return x_275; +return x_241; } else { -lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_521 = lean_ctor_get(x_275, 0); -x_522 = lean_ctor_get(x_275, 1); -lean_inc(x_522); -lean_inc(x_521); -lean_dec(x_275); -x_523 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_523, 0, x_521); -lean_ctor_set(x_523, 1, x_522); -return x_523; +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; } } } @@ -38463,7 +35929,7 @@ return x_523; } else { -uint8_t x_524; +uint8_t x_456; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -38471,52 +35937,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_524 = !lean_is_exclusive(x_29); -if (x_524 == 0) +x_456 = !lean_is_exclusive(x_29); +if (x_456 == 0) { return x_29; } else { -lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_525 = lean_ctor_get(x_29, 0); -x_526 = lean_ctor_get(x_29, 1); -lean_inc(x_526); -lean_inc(x_525); +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_dec(x_29); -x_527 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_527, 0, x_525); -lean_ctor_set(x_527, 1, x_526); -return x_527; +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; } } } else { -uint8_t x_528; +uint8_t x_460; 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_528 = !lean_is_exclusive(x_25); -if (x_528 == 0) +x_460 = !lean_is_exclusive(x_25); +if (x_460 == 0) { return x_25; } else { -lean_object* x_529; lean_object* x_530; lean_object* x_531; -x_529 = lean_ctor_get(x_25, 0); -x_530 = lean_ctor_get(x_25, 1); -lean_inc(x_530); -lean_inc(x_529); +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_dec(x_25); -x_531 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_531, 0, x_529); -lean_ctor_set(x_531, 1, x_530); -return x_531; +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; } } } diff --git a/stage0/stdlib/Lean/Meta/FunInfo.c b/stage0/stdlib/Lean/Meta/FunInfo.c index e7ea6059c1..5c159f7a35 100644 --- a/stage0/stdlib/Lean/Meta/FunInfo.c +++ b/stage0/stdlib/Lean/Meta/FunInfo.c @@ -2737,2151 +2737,1789 @@ goto _start; } case 1: { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; uint8_t x_43; lean_dec(x_31); x_38 = lean_ctor_get(x_32, 1); lean_inc(x_38); -lean_dec(x_32); -x_39 = lean_ctor_get(x_33, 0); -lean_inc(x_39); +if (lean_is_exclusive(x_32)) { + lean_ctor_release(x_32, 0); + lean_ctor_release(x_32, 1); + x_39 = x_32; +} else { + lean_dec_ref(x_32); + x_39 = lean_box(0); +} +x_40 = lean_ctor_get(x_33, 0); +lean_inc(x_40); lean_dec(x_33); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_5, x_40); +x_41 = lean_unsigned_to_nat(1u); +x_42 = lean_nat_add(x_5, x_41); lean_dec(x_5); -x_42 = !lean_is_exclusive(x_38); -if (x_42 == 0) +x_43 = !lean_is_exclusive(x_38); +if (x_43 == 0) { -lean_object* x_43; uint8_t x_44; -x_43 = lean_ctor_get(x_38, 2); -x_44 = !lean_is_exclusive(x_43); -if (x_44 == 0) +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_38, 2); +x_45 = !lean_is_exclusive(x_44); +if (x_45 == 0) { -lean_object* x_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_43, 2); -x_46 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_43, 2, x_46); -x_47 = !lean_is_exclusive(x_6); -if (x_47 == 0) +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_98; uint8_t x_99; +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) { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_48 = lean_ctor_get(x_6, 2); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_39); -lean_ctor_set(x_49, 1, x_27); -x_50 = lean_array_push(x_48, x_49); -lean_ctor_set(x_6, 2, x_50); -x_51 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_6, x_38); -if (lean_obj_tag(x_51) == 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_52; lean_object* x_53; uint8_t x_54; -x_52 = lean_ctor_get(x_51, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_52, 2); -lean_inc(x_53); -x_54 = !lean_is_exclusive(x_51); -if (x_54 == 0) -{ -lean_object* x_55; uint8_t x_56; -x_55 = lean_ctor_get(x_51, 1); -lean_dec(x_55); -x_56 = !lean_is_exclusive(x_52); -if (x_56 == 0) -{ -lean_object* x_57; uint8_t x_58; -x_57 = lean_ctor_get(x_52, 2); -lean_dec(x_57); -x_58 = !lean_is_exclusive(x_53); -if (x_58 == 0) -{ -lean_object* x_59; -x_59 = lean_ctor_get(x_53, 2); -lean_dec(x_59); -lean_ctor_set(x_53, 2, x_45); -return x_51; +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_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_60 = lean_ctor_get(x_53, 0); -x_61 = lean_ctor_get(x_53, 1); -x_62 = lean_ctor_get(x_53, 3); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_53); -x_63 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_61); -lean_ctor_set(x_63, 2, x_45); -lean_ctor_set(x_63, 3, x_62); -lean_ctor_set(x_52, 2, x_63); -return x_51; +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_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; } } 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; -x_64 = lean_ctor_get(x_52, 0); -x_65 = lean_ctor_get(x_52, 1); -x_66 = lean_ctor_get(x_52, 3); -x_67 = lean_ctor_get(x_52, 4); -x_68 = lean_ctor_get(x_52, 5); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); +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_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; +} +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_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; +} +} +block_97: +{ +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_49; lean_object* x_50; uint8_t x_51; +x_49 = lean_ctor_get(x_48, 2); +lean_inc(x_49); +x_50 = lean_ctor_get(x_47, 0); +lean_inc(x_50); +lean_dec(x_47); +x_51 = !lean_is_exclusive(x_48); +if (x_51 == 0) +{ +lean_object* x_52; uint8_t x_53; +x_52 = lean_ctor_get(x_48, 2); +lean_dec(x_52); +x_53 = !lean_is_exclusive(x_49); +if (x_53 == 0) +{ +lean_object* x_54; lean_object* x_55; +x_54 = lean_ctor_get(x_49, 2); +lean_dec(x_54); +lean_ctor_set(x_49, 2, x_46); +if (lean_is_scalar(x_39)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_39; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_50); +lean_ctor_set(x_55, 1, x_48); +return x_55; +} +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_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); +if (lean_is_scalar(x_39)) { + x_60 = lean_alloc_ctor(1, 2, 0); +} else { + x_60 = x_39; + lean_ctor_set_tag(x_60, 1); +} +lean_ctor_set(x_60, 0, x_50); +lean_ctor_set(x_60, 1, x_48); +return x_60; +} +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; 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_inc(x_65); lean_inc(x_64); -lean_dec(x_52); -x_69 = lean_ctor_get(x_53, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_53, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_53, 3); -lean_inc(x_71); -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); - x_72 = x_53; +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); +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; } else { - lean_dec_ref(x_53); - x_72 = lean_box(0); + lean_dec_ref(x_49); + x_69 = lean_box(0); } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_73 = x_72; + x_70 = x_69; } -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_45); -lean_ctor_set(x_73, 3, x_71); -x_74 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_74, 0, x_64); -lean_ctor_set(x_74, 1, x_65); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_66); -lean_ctor_set(x_74, 4, x_67); -lean_ctor_set(x_74, 5, x_68); -lean_ctor_set(x_51, 1, x_74); -return x_51; +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); +if (lean_is_scalar(x_39)) { + x_72 = lean_alloc_ctor(1, 2, 0); +} else { + x_72 = x_39; + lean_ctor_set_tag(x_72, 1); +} +lean_ctor_set(x_72, 0, x_50); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } 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; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_75 = lean_ctor_get(x_51, 0); -lean_inc(x_75); -lean_dec(x_51); -x_76 = lean_ctor_get(x_52, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_52, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_52, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_52, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_52, 5); -lean_inc(x_80); -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); - x_81 = x_52; +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_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); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; +x_78 = lean_ctor_get(x_73, 2); +lean_dec(x_78); +lean_ctor_set(x_73, 2, x_46); +if (lean_is_scalar(x_39)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_52); - x_81 = lean_box(0); + x_79 = x_39; } -x_82 = lean_ctor_get(x_53, 0); +lean_ctor_set(x_79, 0, x_74); +lean_ctor_set(x_79, 1, x_48); +return x_79; +} +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_inc(x_82); -x_83 = lean_ctor_get(x_53, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_53, 3); -lean_inc(x_84); -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); - x_85 = x_53; +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); +if (lean_is_scalar(x_39)) { + x_84 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_53); - x_85 = lean_box(0); + x_84 = x_39; } -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(0, 4, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_82); -lean_ctor_set(x_86, 1, x_83); -lean_ctor_set(x_86, 2, x_45); -lean_ctor_set(x_86, 3, x_84); -if (lean_is_scalar(x_81)) { - x_87 = lean_alloc_ctor(0, 6, 0); -} else { - x_87 = x_81; -} -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); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_75); -lean_ctor_set(x_88, 1, x_87); -return x_88; +lean_ctor_set(x_84, 0, x_74); +lean_ctor_set(x_84, 1, x_48); +return x_84; } } else { -lean_object* x_89; lean_object* x_90; uint8_t x_91; -x_89 = lean_ctor_get(x_51, 1); +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_inc(x_89); -x_90 = lean_ctor_get(x_89, 2); +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_is_exclusive(x_51); -if (x_91 == 0) -{ -lean_object* x_92; uint8_t x_93; -x_92 = lean_ctor_get(x_51, 1); -lean_dec(x_92); -x_93 = !lean_is_exclusive(x_89); -if (x_93 == 0) -{ -lean_object* x_94; uint8_t x_95; -x_94 = lean_ctor_get(x_89, 2); -lean_dec(x_94); -x_95 = !lean_is_exclusive(x_90); -if (x_95 == 0) -{ -lean_object* x_96; -x_96 = lean_ctor_get(x_90, 2); -lean_dec(x_96); -lean_ctor_set(x_90, 2, x_45); -return x_51; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_90, 0); -x_98 = lean_ctor_get(x_90, 1); -x_99 = lean_ctor_get(x_90, 3); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_90); -x_100 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -lean_ctor_set(x_100, 2, x_45); -lean_ctor_set(x_100, 3, x_99); -lean_ctor_set(x_89, 2, x_100); -return x_51; -} -} -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; -x_101 = lean_ctor_get(x_89, 0); -x_102 = lean_ctor_get(x_89, 1); -x_103 = lean_ctor_get(x_89, 3); -x_104 = lean_ctor_get(x_89, 4); -x_105 = lean_ctor_get(x_89, 5); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); -lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_89); -x_106 = lean_ctor_get(x_90, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_90, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_90, 3); -lean_inc(x_108); -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); - x_109 = 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; } else { - lean_dec_ref(x_90); - x_109 = lean_box(0); + lean_dec_ref(x_73); + x_93 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_93)) { + x_94 = lean_alloc_ctor(0, 4, 0); } else { - x_110 = x_109; + x_94 = x_93; } -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_45); -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_51, 1, x_111); -return x_51; -} -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; 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_112 = lean_ctor_get(x_51, 0); -lean_inc(x_112); -lean_dec(x_51); -x_113 = lean_ctor_get(x_89, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_89, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_89, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_89, 4); -lean_inc(x_116); -x_117 = lean_ctor_get(x_89, 5); -lean_inc(x_117); -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_118 = x_89; +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); +if (lean_is_scalar(x_39)) { + x_96 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_89); - x_118 = lean_box(0); + x_96 = x_39; } -x_119 = lean_ctor_get(x_90, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_90, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_90, 3); -lean_inc(x_121); -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); - x_122 = x_90; -} else { - lean_dec_ref(x_90); - x_122 = lean_box(0); +lean_ctor_set(x_96, 0, x_74); +lean_ctor_set(x_96, 1, x_95); +return x_96; } -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(0, 4, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_119); -lean_ctor_set(x_123, 1, x_120); -lean_ctor_set(x_123, 2, x_45); -lean_ctor_set(x_123, 3, x_121); -if (lean_is_scalar(x_118)) { - x_124 = lean_alloc_ctor(0, 6, 0); -} else { - x_124 = x_118; -} -lean_ctor_set(x_124, 0, x_113); -lean_ctor_set(x_124, 1, x_114); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_115); -lean_ctor_set(x_124, 4, x_116); -lean_ctor_set(x_124, 5, x_117); -x_125 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_125, 0, x_112); -lean_ctor_set(x_125, 1, x_124); -return x_125; } } } else { -lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_126 = lean_ctor_get(x_6, 0); -x_127 = lean_ctor_get(x_6, 1); -x_128 = lean_ctor_get(x_6, 2); -x_129 = lean_ctor_get(x_6, 3); -x_130 = lean_ctor_get(x_6, 4); -lean_inc(x_130); -lean_inc(x_129); +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_dec(x_6); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_39); -lean_ctor_set(x_131, 1, x_27); -x_132 = lean_array_push(x_128, x_131); -x_133 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_133, 0, x_126); -lean_ctor_set(x_133, 1, x_127); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_129); -lean_ctor_set(x_133, 4, x_130); -x_134 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_133, x_38); -if (lean_obj_tag(x_134) == 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; -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; +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_134); + 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_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_135, 0); +x_139 = lean_ctor_get(x_131, 0); lean_inc(x_139); -x_140 = lean_ctor_get(x_135, 1); +x_140 = lean_ctor_get(x_131, 1); lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); +x_141 = lean_ctor_get(x_131, 3); lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); -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; +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_135); - x_144 = lean_box(0); + lean_dec_ref(x_131); + x_142 = lean_box(0); } -x_145 = lean_ctor_get(x_136, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_136, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 3); -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); - x_148 = x_136; +if (lean_is_scalar(x_142)) { + x_143 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_136); - x_148 = lean_box(0); + x_143 = 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_45); -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); +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_151 = lean_alloc_ctor(0, 2, 0); + x_144 = lean_alloc_ctor(0, 6, 0); } else { - x_151 = x_138; + x_144 = x_138; } -lean_ctor_set(x_151, 0, x_137); -lean_ctor_set(x_151, 1, x_150); -return x_151; +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_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_152 = lean_ctor_get(x_134, 1); +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); -x_153 = lean_ctor_get(x_152, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_134, 0); +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); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_155 = x_134; -} else { - lean_dec_ref(x_134); - x_155 = lean_box(0); -} -x_156 = lean_ctor_get(x_152, 0); +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_152, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 4); -lean_inc(x_159); -x_160 = lean_ctor_get(x_152, 5); -lean_inc(x_160); -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_161 = x_152; +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_152); - x_161 = lean_box(0); + lean_dec_ref(x_146); + x_157 = lean_box(0); } -x_162 = lean_ctor_get(x_153, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_153, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_153, 3); -lean_inc(x_164); -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_165 = x_153; +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_153); - x_165 = lean_box(0); + x_158 = x_157; } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(0, 4, 0); +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_166 = x_165; + x_159 = x_153; } -lean_ctor_set(x_166, 0, x_162); -lean_ctor_set(x_166, 1, x_163); -lean_ctor_set(x_166, 2, x_45); -lean_ctor_set(x_166, 3, x_164); -if (lean_is_scalar(x_161)) { - x_167 = lean_alloc_ctor(0, 6, 0); +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_167 = x_161; + x_160 = x_39; } -lean_ctor_set(x_167, 0, x_156); -lean_ctor_set(x_167, 1, x_157); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_158); -lean_ctor_set(x_167, 4, x_159); -lean_ctor_set(x_167, 5, x_160); -if (lean_is_scalar(x_155)) { - x_168 = lean_alloc_ctor(1, 2, 0); -} else { - x_168 = x_155; +lean_ctor_set(x_160, 0, x_147); +lean_ctor_set(x_160, 1, x_159); +return x_160; } -lean_ctor_set(x_168, 0, x_154); -lean_ctor_set(x_168, 1, x_167); -return x_168; } } } 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; 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; -x_169 = lean_ctor_get(x_43, 0); -x_170 = lean_ctor_get(x_43, 1); -x_171 = lean_ctor_get(x_43, 2); -x_172 = lean_ctor_get(x_43, 3); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_43); -x_173 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_174 = 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_173); -lean_ctor_set(x_174, 3, x_172); -lean_ctor_set(x_38, 2, x_174); -x_175 = lean_ctor_get(x_6, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_6, 1); -lean_inc(x_176); -x_177 = lean_ctor_get(x_6, 2); -lean_inc(x_177); -x_178 = lean_ctor_get(x_6, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_6, 4); -lean_inc(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_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); 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_180 = x_6; + x_232 = x_6; } else { lean_dec_ref(x_6); - x_180 = lean_box(0); + x_232 = lean_box(0); } -x_181 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_181, 0, x_39); -lean_ctor_set(x_181, 1, x_27); -x_182 = lean_array_push(x_177, x_181); -if (lean_is_scalar(x_180)) { - x_183 = lean_alloc_ctor(0, 5, 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_235 = lean_alloc_ctor(0, 5, 0); } else { - x_183 = x_180; + x_235 = x_232; } -lean_ctor_set(x_183, 0, x_175); -lean_ctor_set(x_183, 1, x_176); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_178); -lean_ctor_set(x_183, 4, x_179); -x_184 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_183, x_38); -if (lean_obj_tag(x_184) == 0) +lean_ctor_set(x_235, 0, x_227); +lean_ctor_set(x_235, 1, x_228); +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_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; lean_object* x_200; lean_object* x_201; -x_185 = lean_ctor_get(x_184, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - x_188 = x_184; -} else { - lean_dec_ref(x_184); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_185, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 3); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 4); -lean_inc(x_192); -x_193 = lean_ctor_get(x_185, 5); -lean_inc(x_193); -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_194 = x_185; -} else { - lean_dec_ref(x_185); - x_194 = lean_box(0); -} -x_195 = lean_ctor_get(x_186, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_186, 3); -lean_inc(x_197); -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_198 = x_186; -} else { - lean_dec_ref(x_186); - 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_171); -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_188)) { - x_201 = lean_alloc_ctor(0, 2, 0); -} else { - x_201 = x_188; -} -lean_ctor_set(x_201, 0, x_187); -lean_ctor_set(x_201, 1, x_200); -return x_201; +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_236, 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_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_202 = lean_ctor_get(x_184, 1); +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_236, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_236, 1); +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; +} +block_223: +{ +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_202, 2); +x_203 = lean_ctor_get(x_193, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_184, 0); -lean_inc(x_204); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - x_205 = 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); + x_204 = x_193; } else { - lean_dec_ref(x_184); - x_205 = lean_box(0); + lean_dec_ref(x_193); + x_204 = lean_box(0); } -x_206 = lean_ctor_get(x_202, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_202, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_202, 3); +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; +} +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_202, 4); +x_209 = lean_ctor_get(x_191, 0); lean_inc(x_209); -x_210 = lean_ctor_get(x_202, 5); +lean_dec(x_191); +x_210 = lean_ctor_get(x_192, 0); lean_inc(x_210); -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); - lean_ctor_release(x_202, 4); - lean_ctor_release(x_202, 5); - x_211 = x_202; -} else { - lean_dec_ref(x_202); - x_211 = lean_box(0); -} -x_212 = lean_ctor_get(x_203, 0); +x_211 = lean_ctor_get(x_192, 1); +lean_inc(x_211); +x_212 = lean_ctor_get(x_192, 3); lean_inc(x_212); -x_213 = lean_ctor_get(x_203, 1); +x_213 = lean_ctor_get(x_192, 4); lean_inc(x_213); -x_214 = lean_ctor_get(x_203, 3); +x_214 = lean_ctor_get(x_192, 5); 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); - x_215 = x_203; +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; } else { - lean_dec_ref(x_203); + lean_dec_ref(x_192); 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); +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; +} else { + lean_dec_ref(x_208); + x_219 = lean_box(0); +} +if (lean_is_scalar(x_219)) { + x_220 = lean_alloc_ctor(0, 4, 0); +} else { + x_220 = x_219; +} +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_216 = lean_alloc_ctor(0, 4, 0); + x_221 = lean_alloc_ctor(0, 6, 0); } else { - x_216 = x_215; + x_221 = x_215; } -lean_ctor_set(x_216, 0, x_212); -lean_ctor_set(x_216, 1, x_213); -lean_ctor_set(x_216, 2, x_171); -lean_ctor_set(x_216, 3, x_214); -if (lean_is_scalar(x_211)) { - x_217 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_39)) { + x_222 = lean_alloc_ctor(0, 2, 0); } else { - x_217 = x_211; + x_222 = x_39; } -lean_ctor_set(x_217, 0, x_206); -lean_ctor_set(x_217, 1, x_207); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_208); -lean_ctor_set(x_217, 4, x_209); -lean_ctor_set(x_217, 5, x_210); -if (lean_is_scalar(x_205)) { - x_218 = lean_alloc_ctor(1, 2, 0); -} else { - x_218 = x_205; +lean_ctor_set(x_222, 0, x_209); +lean_ctor_set(x_222, 1, x_221); +return x_222; } -lean_ctor_set(x_218, 0, x_204); -lean_ctor_set(x_218, 1, x_217); -return x_218; -} -} -} -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; 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; -x_219 = lean_ctor_get(x_38, 2); -x_220 = lean_ctor_get(x_38, 0); -x_221 = lean_ctor_get(x_38, 1); -x_222 = lean_ctor_get(x_38, 3); -x_223 = lean_ctor_get(x_38, 4); -x_224 = lean_ctor_get(x_38, 5); -lean_inc(x_224); -lean_inc(x_223); -lean_inc(x_222); -lean_inc(x_219); -lean_inc(x_221); -lean_inc(x_220); -lean_dec(x_38); -x_225 = lean_ctor_get(x_219, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_219, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_219, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_219, 3); -lean_inc(x_228); -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); - x_229 = x_219; -} else { - lean_dec_ref(x_219); - x_229 = lean_box(0); -} -x_230 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_229)) { - x_231 = lean_alloc_ctor(0, 4, 0); -} else { - x_231 = x_229; -} -lean_ctor_set(x_231, 0, x_225); -lean_ctor_set(x_231, 1, x_226); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_228); -x_232 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_232, 0, x_220); -lean_ctor_set(x_232, 1, x_221); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_222); -lean_ctor_set(x_232, 4, x_223); -lean_ctor_set(x_232, 5, x_224); -x_233 = lean_ctor_get(x_6, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_6, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_6, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_6, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_6, 4); -lean_inc(x_237); -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_238 = x_6; -} else { - lean_dec_ref(x_6); - x_238 = lean_box(0); -} -x_239 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_239, 0, x_39); -lean_ctor_set(x_239, 1, x_27); -x_240 = lean_array_push(x_235, x_239); -if (lean_is_scalar(x_238)) { - x_241 = lean_alloc_ctor(0, 5, 0); -} else { - x_241 = x_238; -} -lean_ctor_set(x_241, 0, x_233); -lean_ctor_set(x_241, 1, x_234); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_236); -lean_ctor_set(x_241, 4, x_237); -x_242 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_241, x_232); -if (lean_obj_tag(x_242) == 0) -{ -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; -x_243 = lean_ctor_get(x_242, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_243, 2); -lean_inc(x_244); -x_245 = lean_ctor_get(x_242, 0); -lean_inc(x_245); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - x_246 = x_242; -} else { - lean_dec_ref(x_242); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_243, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_243, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_243, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_243, 4); -lean_inc(x_250); -x_251 = lean_ctor_get(x_243, 5); -lean_inc(x_251); -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); - lean_ctor_release(x_243, 4); - lean_ctor_release(x_243, 5); - x_252 = x_243; -} else { - lean_dec_ref(x_243); - x_252 = lean_box(0); -} -x_253 = lean_ctor_get(x_244, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_244, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_244, 3); -lean_inc(x_255); -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_256 = x_244; -} else { - lean_dec_ref(x_244); - x_256 = lean_box(0); -} -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 4, 0); -} else { - x_257 = x_256; -} -lean_ctor_set(x_257, 0, x_253); -lean_ctor_set(x_257, 1, x_254); -lean_ctor_set(x_257, 2, x_227); -lean_ctor_set(x_257, 3, x_255); -if (lean_is_scalar(x_252)) { - x_258 = lean_alloc_ctor(0, 6, 0); -} else { - x_258 = x_252; -} -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_246)) { - x_259 = lean_alloc_ctor(0, 2, 0); -} else { - x_259 = x_246; -} -lean_ctor_set(x_259, 0, x_245); -lean_ctor_set(x_259, 1, x_258); -return x_259; -} -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; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_260 = lean_ctor_get(x_242, 1); -lean_inc(x_260); -x_261 = lean_ctor_get(x_260, 2); -lean_inc(x_261); -x_262 = lean_ctor_get(x_242, 0); -lean_inc(x_262); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - x_263 = x_242; -} else { - lean_dec_ref(x_242); - x_263 = lean_box(0); -} -x_264 = lean_ctor_get(x_260, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_260, 1); -lean_inc(x_265); -x_266 = lean_ctor_get(x_260, 3); -lean_inc(x_266); -x_267 = lean_ctor_get(x_260, 4); -lean_inc(x_267); -x_268 = lean_ctor_get(x_260, 5); -lean_inc(x_268); -if (lean_is_exclusive(x_260)) { - lean_ctor_release(x_260, 0); - lean_ctor_release(x_260, 1); - lean_ctor_release(x_260, 2); - lean_ctor_release(x_260, 3); - lean_ctor_release(x_260, 4); - lean_ctor_release(x_260, 5); - x_269 = x_260; -} else { - lean_dec_ref(x_260); - x_269 = lean_box(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); -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_273 = x_261; -} else { - lean_dec_ref(x_261); - 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_ctor_set(x_274, 0, x_270); -lean_ctor_set(x_274, 1, x_271); -lean_ctor_set(x_274, 2, x_227); -lean_ctor_set(x_274, 3, x_272); -if (lean_is_scalar(x_269)) { - x_275 = lean_alloc_ctor(0, 6, 0); -} else { - x_275 = x_269; -} -lean_ctor_set(x_275, 0, x_264); -lean_ctor_set(x_275, 1, x_265); -lean_ctor_set(x_275, 2, x_274); -lean_ctor_set(x_275, 3, x_266); -lean_ctor_set(x_275, 4, x_267); -lean_ctor_set(x_275, 5, x_268); -if (lean_is_scalar(x_263)) { - x_276 = lean_alloc_ctor(1, 2, 0); -} else { - x_276 = x_263; -} -lean_ctor_set(x_276, 0, x_262); -lean_ctor_set(x_276, 1, x_275); -return x_276; } } } default: { -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_32, 1); -lean_inc(x_277); +lean_object* x_243; lean_object* x_244; +x_243 = lean_ctor_get(x_32, 1); +lean_inc(x_243); lean_dec(x_32); lean_inc(x_6); -x_278 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_277); -if (lean_obj_tag(x_278) == 0) +x_244 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_243); +if (lean_obj_tag(x_244) == 0) { -lean_object* x_279; -x_279 = lean_ctor_get(x_278, 0); -lean_inc(x_279); -if (lean_obj_tag(x_279) == 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_280; lean_object* x_281; lean_object* x_282; +lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_dec(x_27); -x_280 = lean_ctor_get(x_278, 1); -lean_inc(x_280); -lean_dec(x_278); -x_281 = lean_unsigned_to_nat(1u); -x_282 = lean_nat_add(x_5, x_281); +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); lean_dec(x_5); -x_5 = x_282; -x_7 = x_280; +x_5 = x_248; +x_7 = x_246; goto _start; } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; uint8_t x_288; -x_284 = lean_ctor_get(x_278, 1); -lean_inc(x_284); -lean_dec(x_278); -x_285 = lean_ctor_get(x_279, 0); -lean_inc(x_285); -lean_dec(x_279); -x_286 = lean_unsigned_to_nat(1u); -x_287 = lean_nat_add(x_5, x_286); +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; +} else { + lean_dec_ref(x_244); + x_251 = 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_288 = !lean_is_exclusive(x_284); -if (x_288 == 0) +x_255 = !lean_is_exclusive(x_250); +if (x_255 == 0) { -lean_object* x_289; uint8_t x_290; -x_289 = lean_ctor_get(x_284, 2); -x_290 = !lean_is_exclusive(x_289); -if (x_290 == 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_291; lean_object* x_292; uint8_t x_293; -x_291 = lean_ctor_get(x_289, 2); -x_292 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_289, 2, x_292); -x_293 = !lean_is_exclusive(x_6); -if (x_293 == 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_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; -x_294 = lean_ctor_get(x_6, 2); -x_295 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_295, 0, x_285); -lean_ctor_set(x_295, 1, x_27); -x_296 = lean_array_push(x_294, x_295); -lean_ctor_set(x_6, 2, x_296); -x_297 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_287, x_6, x_284); -if (lean_obj_tag(x_297) == 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_298; lean_object* x_299; uint8_t x_300; -x_298 = lean_ctor_get(x_297, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_298, 2); -lean_inc(x_299); -x_300 = !lean_is_exclusive(x_297); -if (x_300 == 0) -{ -lean_object* x_301; uint8_t x_302; -x_301 = lean_ctor_get(x_297, 1); -lean_dec(x_301); -x_302 = !lean_is_exclusive(x_298); -if (x_302 == 0) -{ -lean_object* x_303; uint8_t x_304; -x_303 = lean_ctor_get(x_298, 2); -lean_dec(x_303); -x_304 = !lean_is_exclusive(x_299); -if (x_304 == 0) -{ -lean_object* x_305; -x_305 = lean_ctor_get(x_299, 2); -lean_dec(x_305); -lean_ctor_set(x_299, 2, x_291); -return x_297; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_306 = lean_ctor_get(x_299, 0); -x_307 = lean_ctor_get(x_299, 1); -x_308 = lean_ctor_get(x_299, 3); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_dec(x_299); -x_309 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_309, 0, x_306); -lean_ctor_set(x_309, 1, x_307); -lean_ctor_set(x_309, 2, x_291); -lean_ctor_set(x_309, 3, x_308); -lean_ctor_set(x_298, 2, x_309); -return x_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; lean_object* x_319; lean_object* x_320; -x_310 = lean_ctor_get(x_298, 0); -x_311 = lean_ctor_get(x_298, 1); -x_312 = lean_ctor_get(x_298, 3); -x_313 = lean_ctor_get(x_298, 4); -x_314 = lean_ctor_get(x_298, 5); -lean_inc(x_314); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_dec(x_298); -x_315 = lean_ctor_get(x_299, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_299, 1); +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_299, 3); +x_317 = lean_ctor_get(x_315, 1); lean_inc(x_317); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - lean_ctor_release(x_299, 1); - lean_ctor_release(x_299, 2); - lean_ctor_release(x_299, 3); - x_318 = x_299; -} else { - lean_dec_ref(x_299); - x_318 = lean_box(0); +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; } -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_291); -lean_ctor_set(x_319, 3, x_317); -x_320 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_320, 0, x_310); -lean_ctor_set(x_320, 1, x_311); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_312); -lean_ctor_set(x_320, 4, x_313); -lean_ctor_set(x_320, 5, x_314); -lean_ctor_set(x_297, 1, x_320); -return x_297; +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_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; -x_321 = lean_ctor_get(x_297, 0); -lean_inc(x_321); -lean_dec(x_297); -x_322 = lean_ctor_get(x_298, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_298, 1); -lean_inc(x_323); -x_324 = lean_ctor_get(x_298, 3); -lean_inc(x_324); -x_325 = lean_ctor_get(x_298, 4); -lean_inc(x_325); -x_326 = lean_ctor_get(x_298, 5); +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); -if (lean_is_exclusive(x_298)) { - lean_ctor_release(x_298, 0); - lean_ctor_release(x_298, 1); - lean_ctor_release(x_298, 2); - lean_ctor_release(x_298, 3); - lean_ctor_release(x_298, 4); - lean_ctor_release(x_298, 5); - x_327 = x_298; -} else { - lean_dec_ref(x_298); - x_327 = lean_box(0); -} -x_328 = lean_ctor_get(x_299, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_299, 1); -lean_inc(x_329); -x_330 = lean_ctor_get(x_299, 3); -lean_inc(x_330); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - lean_ctor_release(x_299, 1); - lean_ctor_release(x_299, 2); - lean_ctor_release(x_299, 3); - x_331 = x_299; -} else { - lean_dec_ref(x_299); - x_331 = lean_box(0); -} -if (lean_is_scalar(x_331)) { - x_332 = lean_alloc_ctor(0, 4, 0); -} else { - x_332 = x_331; -} -lean_ctor_set(x_332, 0, x_328); -lean_ctor_set(x_332, 1, x_329); -lean_ctor_set(x_332, 2, x_291); -lean_ctor_set(x_332, 3, x_330); -if (lean_is_scalar(x_327)) { - x_333 = lean_alloc_ctor(0, 6, 0); -} else { - x_333 = x_327; -} -lean_ctor_set(x_333, 0, x_322); -lean_ctor_set(x_333, 1, x_323); -lean_ctor_set(x_333, 2, x_332); -lean_ctor_set(x_333, 3, x_324); -lean_ctor_set(x_333, 4, x_325); -lean_ctor_set(x_333, 5, x_326); -x_334 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_334, 0, x_321); -lean_ctor_set(x_334, 1, x_333); -return x_334; -} -} -else -{ -lean_object* x_335; lean_object* x_336; uint8_t x_337; -x_335 = lean_ctor_get(x_297, 1); -lean_inc(x_335); -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = !lean_is_exclusive(x_297); -if (x_337 == 0) -{ -lean_object* x_338; uint8_t x_339; -x_338 = lean_ctor_get(x_297, 1); -lean_dec(x_338); -x_339 = !lean_is_exclusive(x_335); -if (x_339 == 0) -{ -lean_object* x_340; uint8_t x_341; -x_340 = lean_ctor_get(x_335, 2); -lean_dec(x_340); -x_341 = !lean_is_exclusive(x_336); -if (x_341 == 0) -{ -lean_object* x_342; -x_342 = lean_ctor_get(x_336, 2); -lean_dec(x_342); -lean_ctor_set(x_336, 2, x_291); -return x_297; -} -else -{ -lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; -x_343 = lean_ctor_get(x_336, 0); -x_344 = lean_ctor_get(x_336, 1); -x_345 = lean_ctor_get(x_336, 3); -lean_inc(x_345); -lean_inc(x_344); -lean_inc(x_343); -lean_dec(x_336); -x_346 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_291); -lean_ctor_set(x_346, 3, x_345); -lean_ctor_set(x_335, 2, x_346); -return x_297; -} -} -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; -x_347 = lean_ctor_get(x_335, 0); -x_348 = lean_ctor_get(x_335, 1); -x_349 = lean_ctor_get(x_335, 3); -x_350 = lean_ctor_get(x_335, 4); -x_351 = lean_ctor_get(x_335, 5); -lean_inc(x_351); -lean_inc(x_350); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); -lean_dec(x_335); -x_352 = lean_ctor_get(x_336, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_336, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_336, 3); -lean_inc(x_354); -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_355 = x_336; -} else { - lean_dec_ref(x_336); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_291); -lean_ctor_set(x_356, 3, x_354); -x_357 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_357, 0, x_347); -lean_ctor_set(x_357, 1, x_348); -lean_ctor_set(x_357, 2, x_356); -lean_ctor_set(x_357, 3, x_349); -lean_ctor_set(x_357, 4, x_350); -lean_ctor_set(x_357, 5, x_351); -lean_ctor_set(x_297, 1, x_357); -return x_297; -} -} -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; -x_358 = lean_ctor_get(x_297, 0); -lean_inc(x_358); -lean_dec(x_297); -x_359 = lean_ctor_get(x_335, 0); -lean_inc(x_359); -x_360 = lean_ctor_get(x_335, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_335, 3); -lean_inc(x_361); -x_362 = lean_ctor_get(x_335, 4); -lean_inc(x_362); -x_363 = lean_ctor_get(x_335, 5); -lean_inc(x_363); -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_364 = x_335; -} else { - lean_dec_ref(x_335); - x_364 = lean_box(0); -} -x_365 = lean_ctor_get(x_336, 0); -lean_inc(x_365); -x_366 = lean_ctor_get(x_336, 1); -lean_inc(x_366); -x_367 = lean_ctor_get(x_336, 3); -lean_inc(x_367); -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_368 = x_336; -} else { - lean_dec_ref(x_336); - x_368 = lean_box(0); -} -if (lean_is_scalar(x_368)) { - x_369 = lean_alloc_ctor(0, 4, 0); -} else { - x_369 = x_368; -} -lean_ctor_set(x_369, 0, x_365); -lean_ctor_set(x_369, 1, x_366); -lean_ctor_set(x_369, 2, x_291); -lean_ctor_set(x_369, 3, x_367); -if (lean_is_scalar(x_364)) { - x_370 = lean_alloc_ctor(0, 6, 0); -} else { - x_370 = x_364; -} -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); -x_371 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_371, 0, x_358); -lean_ctor_set(x_371, 1, x_370); -return x_371; -} -} -} -else -{ -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_372 = lean_ctor_get(x_6, 0); -x_373 = lean_ctor_get(x_6, 1); -x_374 = lean_ctor_get(x_6, 2); -x_375 = lean_ctor_get(x_6, 3); -x_376 = lean_ctor_get(x_6, 4); -lean_inc(x_376); -lean_inc(x_375); -lean_inc(x_374); -lean_inc(x_373); -lean_inc(x_372); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_inc(x_322); lean_dec(x_6); -x_377 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_377, 0, x_285); -lean_ctor_set(x_377, 1, x_27); -x_378 = lean_array_push(x_374, x_377); -x_379 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_379, 0, x_372); -lean_ctor_set(x_379, 1, x_373); -lean_ctor_set(x_379, 2, x_378); -lean_ctor_set(x_379, 3, x_375); -lean_ctor_set(x_379, 4, x_376); -x_380 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_287, x_379, x_284); -if (lean_obj_tag(x_380) == 0) +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_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_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_381 = lean_ctor_get(x_380, 1); -lean_inc(x_381); -x_382 = lean_ctor_get(x_381, 2); -lean_inc(x_382); -x_383 = lean_ctor_get(x_380, 0); -lean_inc(x_383); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - x_384 = x_380; -} else { - lean_dec_ref(x_380); - x_384 = lean_box(0); -} -x_385 = lean_ctor_get(x_381, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_381, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_381, 3); -lean_inc(x_387); -x_388 = lean_ctor_get(x_381, 4); -lean_inc(x_388); -x_389 = lean_ctor_get(x_381, 5); -lean_inc(x_389); -if (lean_is_exclusive(x_381)) { - lean_ctor_release(x_381, 0); - lean_ctor_release(x_381, 1); - lean_ctor_release(x_381, 2); - lean_ctor_release(x_381, 3); - lean_ctor_release(x_381, 4); - lean_ctor_release(x_381, 5); - x_390 = x_381; -} else { - lean_dec_ref(x_381); - x_390 = lean_box(0); -} -x_391 = lean_ctor_get(x_382, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_382, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_382, 3); -lean_inc(x_393); -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_394 = x_382; -} else { - lean_dec_ref(x_382); - x_394 = lean_box(0); -} -if (lean_is_scalar(x_394)) { - x_395 = lean_alloc_ctor(0, 4, 0); -} else { - x_395 = x_394; -} -lean_ctor_set(x_395, 0, x_391); -lean_ctor_set(x_395, 1, x_392); -lean_ctor_set(x_395, 2, x_291); -lean_ctor_set(x_395, 3, x_393); -if (lean_is_scalar(x_390)) { - x_396 = lean_alloc_ctor(0, 6, 0); -} else { - x_396 = x_390; -} -lean_ctor_set(x_396, 0, x_385); -lean_ctor_set(x_396, 1, x_386); -lean_ctor_set(x_396, 2, x_395); -lean_ctor_set(x_396, 3, x_387); -lean_ctor_set(x_396, 4, x_388); -lean_ctor_set(x_396, 5, x_389); -if (lean_is_scalar(x_384)) { - x_397 = lean_alloc_ctor(0, 2, 0); -} else { - x_397 = x_384; -} -lean_ctor_set(x_397, 0, x_383); -lean_ctor_set(x_397, 1, x_396); -return x_397; +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_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; lean_object* x_413; lean_object* x_414; -x_398 = lean_ctor_get(x_380, 1); -lean_inc(x_398); -x_399 = lean_ctor_get(x_398, 2); -lean_inc(x_399); -x_400 = lean_ctor_get(x_380, 0); -lean_inc(x_400); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - x_401 = x_380; -} else { - lean_dec_ref(x_380); - x_401 = lean_box(0); +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; } -x_402 = lean_ctor_get(x_398, 0); -lean_inc(x_402); -x_403 = lean_ctor_get(x_398, 1); -lean_inc(x_403); -x_404 = lean_ctor_get(x_398, 3); -lean_inc(x_404); -x_405 = lean_ctor_get(x_398, 4); -lean_inc(x_405); -x_406 = lean_ctor_get(x_398, 5); -lean_inc(x_406); -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_407 = x_398; -} else { - lean_dec_ref(x_398); - x_407 = lean_box(0); } -x_408 = lean_ctor_get(x_399, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_399, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_399, 3); -lean_inc(x_410); -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_411 = x_399; +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); +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); +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 { - lean_dec_ref(x_399); - x_411 = lean_box(0); + x_267 = x_251; + lean_ctor_set_tag(x_267, 1); } -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_267, 0, x_262); +lean_ctor_set(x_267, 1, x_260); +return x_267; +} +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_412 = x_411; + x_272 = x_251; + lean_ctor_set_tag(x_272, 1); } -lean_ctor_set(x_412, 0, x_408); -lean_ctor_set(x_412, 1, x_409); -lean_ctor_set(x_412, 2, x_291); -lean_ctor_set(x_412, 3, x_410); -if (lean_is_scalar(x_407)) { - x_413 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_272, 0, x_262); +lean_ctor_set(x_272, 1, x_260); +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; 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_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 { - x_413 = x_407; + lean_dec_ref(x_261); + x_281 = lean_box(0); } -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_401)) { - x_414 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_281)) { + x_282 = lean_alloc_ctor(0, 4, 0); } else { - x_414 = x_401; + x_282 = x_281; +} +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, 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); +} else { + x_284 = x_251; + lean_ctor_set_tag(x_284, 1); +} +lean_ctor_set(x_284, 0, x_262); +lean_ctor_set(x_284, 1, x_283); +return x_284; +} +} +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_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_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); +} else { + x_296 = x_251; +} +lean_ctor_set(x_296, 0, x_286); +lean_ctor_set(x_296, 1, x_260); +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_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); +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; +} else { + lean_dec_ref(x_285); + x_305 = lean_box(0); +} +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); +} else { + x_306 = x_305; +} +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); +} else { + x_308 = x_251; +} +lean_ctor_set(x_308, 0, x_286); +lean_ctor_set(x_308, 1, x_307); +return x_308; } -lean_ctor_set(x_414, 0, x_400); -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; lean_object* x_430; -x_415 = lean_ctor_get(x_289, 0); -x_416 = lean_ctor_get(x_289, 1); -x_417 = lean_ctor_get(x_289, 2); -x_418 = lean_ctor_get(x_289, 3); -lean_inc(x_418); -lean_inc(x_417); -lean_inc(x_416); -lean_inc(x_415); -lean_dec(x_289); -x_419 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_420 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_420, 0, x_415); -lean_ctor_set(x_420, 1, x_416); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_418); -lean_ctor_set(x_284, 2, x_420); -x_421 = lean_ctor_get(x_6, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_6, 1); -lean_inc(x_422); -x_423 = lean_ctor_get(x_6, 2); -lean_inc(x_423); -x_424 = lean_ctor_get(x_6, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_6, 4); -lean_inc(x_425); +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); 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_426 = x_6; + x_381 = x_6; } else { lean_dec_ref(x_6); - x_426 = lean_box(0); + x_381 = lean_box(0); } -x_427 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_427, 0, x_285); -lean_ctor_set(x_427, 1, x_27); -x_428 = lean_array_push(x_423, x_427); -if (lean_is_scalar(x_426)) { - x_429 = lean_alloc_ctor(0, 5, 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); } else { - x_429 = x_426; + x_384 = x_381; } -lean_ctor_set(x_429, 0, x_421); -lean_ctor_set(x_429, 1, x_422); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_424); -lean_ctor_set(x_429, 4, x_425); -x_430 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_287, x_429, x_284); -if (lean_obj_tag(x_430) == 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___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_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; lean_object* x_447; -x_431 = lean_ctor_get(x_430, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_431, 2); -lean_inc(x_432); -x_433 = lean_ctor_get(x_430, 0); -lean_inc(x_433); -if (lean_is_exclusive(x_430)) { - lean_ctor_release(x_430, 0); - lean_ctor_release(x_430, 1); - x_434 = x_430; -} else { - lean_dec_ref(x_430); - x_434 = lean_box(0); -} -x_435 = lean_ctor_get(x_431, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_431, 1); -lean_inc(x_436); -x_437 = lean_ctor_get(x_431, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_431, 4); -lean_inc(x_438); -x_439 = lean_ctor_get(x_431, 5); -lean_inc(x_439); -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); - lean_ctor_release(x_431, 5); - x_440 = x_431; -} else { - lean_dec_ref(x_431); - x_440 = lean_box(0); -} -x_441 = lean_ctor_get(x_432, 0); -lean_inc(x_441); -x_442 = lean_ctor_get(x_432, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_432, 3); -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); - 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, 4, 0); -} else { - x_445 = x_444; -} -lean_ctor_set(x_445, 0, x_441); -lean_ctor_set(x_445, 1, x_442); -lean_ctor_set(x_445, 2, x_417); -lean_ctor_set(x_445, 3, x_443); -if (lean_is_scalar(x_440)) { - x_446 = lean_alloc_ctor(0, 6, 0); -} else { - x_446 = x_440; -} -lean_ctor_set(x_446, 0, x_435); -lean_ctor_set(x_446, 1, x_436); -lean_ctor_set(x_446, 2, x_445); -lean_ctor_set(x_446, 3, x_437); -lean_ctor_set(x_446, 4, x_438); -lean_ctor_set(x_446, 5, x_439); -if (lean_is_scalar(x_434)) { - x_447 = lean_alloc_ctor(0, 2, 0); -} else { - x_447 = x_434; -} -lean_ctor_set(x_447, 0, x_433); -lean_ctor_set(x_447, 1, x_446); -return x_447; +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; } else { -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; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; -x_448 = lean_ctor_get(x_430, 1); -lean_inc(x_448); -x_449 = lean_ctor_get(x_448, 2); -lean_inc(x_449); -x_450 = lean_ctor_get(x_430, 0); -lean_inc(x_450); -if (lean_is_exclusive(x_430)) { - lean_ctor_release(x_430, 0); - lean_ctor_release(x_430, 1); - x_451 = x_430; -} else { - lean_dec_ref(x_430); - x_451 = lean_box(0); +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; } +block_373: +{ +if (lean_obj_tag(x_341) == 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_inc(x_358); +x_359 = lean_ctor_get(x_341, 0); +lean_inc(x_359); +lean_dec(x_341); +x_360 = lean_ctor_get(x_342, 0); +lean_inc(x_360); +x_361 = lean_ctor_get(x_342, 1); +lean_inc(x_361); +x_362 = lean_ctor_get(x_342, 3); +lean_inc(x_362); +x_363 = lean_ctor_get(x_342, 4); +lean_inc(x_363); +x_364 = lean_ctor_get(x_342, 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; +} else { + lean_dec_ref(x_342); + x_365 = lean_box(0); +} +x_366 = lean_ctor_get(x_358, 0); +lean_inc(x_366); +x_367 = lean_ctor_get(x_358, 1); +lean_inc(x_367); +x_368 = lean_ctor_get(x_358, 3); +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); + x_369 = x_358; +} else { + lean_dec_ref(x_358); + x_369 = lean_box(0); +} +if (lean_is_scalar(x_369)) { + x_370 = lean_alloc_ctor(0, 4, 0); +} else { + x_370 = x_369; +} +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); +if (lean_is_scalar(x_365)) { + x_371 = lean_alloc_ctor(0, 6, 0); +} else { + x_371 = 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); +} else { + x_372 = x_251; +} +lean_ctor_set(x_372, 0, x_359); +lean_ctor_set(x_372, 1, x_371); +return x_372; +} +} +} +} +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; +} else { + lean_dec_ref(x_392); + x_402 = 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); +} else { + x_437 = x_402; +} +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); +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; +} else { + lean_dec_ref(x_6); + x_444 = 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); +} else { + x_447 = x_444; +} +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_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; +} +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); -x_454 = lean_ctor_get(x_448, 3); -lean_inc(x_454); -x_455 = lean_ctor_get(x_448, 4); -lean_inc(x_455); -x_456 = lean_ctor_get(x_448, 5); -lean_inc(x_456); -if (lean_is_exclusive(x_448)) { - lean_ctor_release(x_448, 0); - lean_ctor_release(x_448, 1); - lean_ctor_release(x_448, 2); - lean_ctor_release(x_448, 3); - lean_ctor_release(x_448, 4); - lean_ctor_release(x_448, 5); - x_457 = x_448; +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; +} +block_435: +{ +if (lean_obj_tag(x_403) == 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_448); - x_457 = lean_box(0); + lean_dec_ref(x_404); + x_412 = lean_box(0); } -x_458 = lean_ctor_get(x_449, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_449, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_449, 3); -lean_inc(x_460); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - lean_ctor_release(x_449, 2); - lean_ctor_release(x_449, 3); - x_461 = x_449; +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_449); - x_461 = lean_box(0); + lean_dec_ref(x_405); + x_416 = lean_box(0); } -if (lean_is_scalar(x_461)) { - x_462 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_416)) { + x_417 = lean_alloc_ctor(0, 4, 0); } else { - x_462 = x_461; + x_417 = x_416; } -lean_ctor_set(x_462, 0, x_458); -lean_ctor_set(x_462, 1, x_459); -lean_ctor_set(x_462, 2, x_417); -lean_ctor_set(x_462, 3, x_460); -if (lean_is_scalar(x_457)) { - x_463 = lean_alloc_ctor(0, 6, 0); +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_463 = x_457; + x_418 = x_412; } -lean_ctor_set(x_463, 0, x_452); -lean_ctor_set(x_463, 1, x_453); -lean_ctor_set(x_463, 2, x_462); -lean_ctor_set(x_463, 3, x_454); -lean_ctor_set(x_463, 4, x_455); -lean_ctor_set(x_463, 5, x_456); -if (lean_is_scalar(x_451)) { - x_464 = lean_alloc_ctor(1, 2, 0); +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_464 = x_451; -} -lean_ctor_set(x_464, 0, x_450); -lean_ctor_set(x_464, 1, x_463); -return x_464; -} + 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_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; -x_465 = lean_ctor_get(x_284, 2); -x_466 = lean_ctor_get(x_284, 0); -x_467 = lean_ctor_get(x_284, 1); -x_468 = lean_ctor_get(x_284, 3); -x_469 = lean_ctor_get(x_284, 4); -x_470 = lean_ctor_get(x_284, 5); -lean_inc(x_470); -lean_inc(x_469); -lean_inc(x_468); -lean_inc(x_465); -lean_inc(x_467); -lean_inc(x_466); -lean_dec(x_284); -x_471 = lean_ctor_get(x_465, 0); -lean_inc(x_471); -x_472 = lean_ctor_get(x_465, 1); -lean_inc(x_472); -x_473 = lean_ctor_get(x_465, 2); -lean_inc(x_473); -x_474 = lean_ctor_get(x_465, 3); -lean_inc(x_474); -if (lean_is_exclusive(x_465)) { - lean_ctor_release(x_465, 0); - lean_ctor_release(x_465, 1); - lean_ctor_release(x_465, 2); - lean_ctor_release(x_465, 3); - x_475 = x_465; +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_inc(x_423); +x_424 = lean_ctor_get(x_404, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_404, 4); +lean_inc(x_425); +x_426 = lean_ctor_get(x_404, 5); +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_465); - x_475 = lean_box(0); + lean_dec_ref(x_404); + x_427 = lean_box(0); } -x_476 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_475)) { - x_477 = 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); +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; } else { - x_477 = x_475; + lean_dec_ref(x_420); + x_431 = lean_box(0); } -lean_ctor_set(x_477, 0, x_471); -lean_ctor_set(x_477, 1, x_472); -lean_ctor_set(x_477, 2, x_476); -lean_ctor_set(x_477, 3, x_474); -x_478 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_478, 0, x_466); -lean_ctor_set(x_478, 1, x_467); -lean_ctor_set(x_478, 2, x_477); -lean_ctor_set(x_478, 3, x_468); -lean_ctor_set(x_478, 4, x_469); -lean_ctor_set(x_478, 5, x_470); -x_479 = lean_ctor_get(x_6, 0); -lean_inc(x_479); -x_480 = lean_ctor_get(x_6, 1); -lean_inc(x_480); -x_481 = lean_ctor_get(x_6, 2); -lean_inc(x_481); -x_482 = lean_ctor_get(x_6, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_6, 4); -lean_inc(x_483); -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_484 = x_6; +if (lean_is_scalar(x_431)) { + x_432 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_6); - x_484 = lean_box(0); + x_432 = x_431; } -x_485 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_485, 0, x_285); -lean_ctor_set(x_485, 1, x_27); -x_486 = lean_array_push(x_481, x_485); -if (lean_is_scalar(x_484)) { - x_487 = lean_alloc_ctor(0, 5, 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); } else { - x_487 = x_484; + x_433 = x_427; } -lean_ctor_set(x_487, 0, x_479); -lean_ctor_set(x_487, 1, x_480); -lean_ctor_set(x_487, 2, x_486); -lean_ctor_set(x_487, 3, x_482); -lean_ctor_set(x_487, 4, x_483); -x_488 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_287, x_487, x_478); -if (lean_obj_tag(x_488) == 0) -{ -lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; -x_489 = lean_ctor_get(x_488, 1); -lean_inc(x_489); -x_490 = lean_ctor_get(x_489, 2); -lean_inc(x_490); -x_491 = lean_ctor_get(x_488, 0); -lean_inc(x_491); -if (lean_is_exclusive(x_488)) { - lean_ctor_release(x_488, 0); - lean_ctor_release(x_488, 1); - x_492 = x_488; +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); } else { - lean_dec_ref(x_488); - x_492 = lean_box(0); + x_434 = x_251; } -x_493 = lean_ctor_get(x_489, 0); -lean_inc(x_493); -x_494 = lean_ctor_get(x_489, 1); -lean_inc(x_494); -x_495 = lean_ctor_get(x_489, 3); -lean_inc(x_495); -x_496 = lean_ctor_get(x_489, 4); -lean_inc(x_496); -x_497 = lean_ctor_get(x_489, 5); -lean_inc(x_497); -if (lean_is_exclusive(x_489)) { - lean_ctor_release(x_489, 0); - lean_ctor_release(x_489, 1); - lean_ctor_release(x_489, 2); - lean_ctor_release(x_489, 3); - lean_ctor_release(x_489, 4); - lean_ctor_release(x_489, 5); - x_498 = x_489; -} else { - lean_dec_ref(x_489); - x_498 = lean_box(0); +lean_ctor_set(x_434, 0, x_421); +lean_ctor_set(x_434, 1, x_433); +return x_434; } -x_499 = lean_ctor_get(x_490, 0); -lean_inc(x_499); -x_500 = lean_ctor_get(x_490, 1); -lean_inc(x_500); -x_501 = lean_ctor_get(x_490, 3); -lean_inc(x_501); -if (lean_is_exclusive(x_490)) { - lean_ctor_release(x_490, 0); - lean_ctor_release(x_490, 1); - lean_ctor_release(x_490, 2); - lean_ctor_release(x_490, 3); - x_502 = x_490; -} else { - lean_dec_ref(x_490); - x_502 = lean_box(0); -} -if (lean_is_scalar(x_502)) { - x_503 = lean_alloc_ctor(0, 4, 0); -} else { - x_503 = x_502; -} -lean_ctor_set(x_503, 0, x_499); -lean_ctor_set(x_503, 1, x_500); -lean_ctor_set(x_503, 2, x_473); -lean_ctor_set(x_503, 3, x_501); -if (lean_is_scalar(x_498)) { - x_504 = lean_alloc_ctor(0, 6, 0); -} else { - x_504 = x_498; -} -lean_ctor_set(x_504, 0, x_493); -lean_ctor_set(x_504, 1, x_494); -lean_ctor_set(x_504, 2, x_503); -lean_ctor_set(x_504, 3, x_495); -lean_ctor_set(x_504, 4, x_496); -lean_ctor_set(x_504, 5, x_497); -if (lean_is_scalar(x_492)) { - x_505 = lean_alloc_ctor(0, 2, 0); -} else { - x_505 = x_492; -} -lean_ctor_set(x_505, 0, x_491); -lean_ctor_set(x_505, 1, x_504); -return x_505; -} -else -{ -lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_506 = lean_ctor_get(x_488, 1); -lean_inc(x_506); -x_507 = lean_ctor_get(x_506, 2); -lean_inc(x_507); -x_508 = lean_ctor_get(x_488, 0); -lean_inc(x_508); -if (lean_is_exclusive(x_488)) { - lean_ctor_release(x_488, 0); - lean_ctor_release(x_488, 1); - x_509 = x_488; -} else { - lean_dec_ref(x_488); - x_509 = lean_box(0); -} -x_510 = lean_ctor_get(x_506, 0); -lean_inc(x_510); -x_511 = lean_ctor_get(x_506, 1); -lean_inc(x_511); -x_512 = lean_ctor_get(x_506, 3); -lean_inc(x_512); -x_513 = lean_ctor_get(x_506, 4); -lean_inc(x_513); -x_514 = lean_ctor_get(x_506, 5); -lean_inc(x_514); -if (lean_is_exclusive(x_506)) { - lean_ctor_release(x_506, 0); - lean_ctor_release(x_506, 1); - lean_ctor_release(x_506, 2); - lean_ctor_release(x_506, 3); - lean_ctor_release(x_506, 4); - lean_ctor_release(x_506, 5); - x_515 = x_506; -} else { - lean_dec_ref(x_506); - x_515 = lean_box(0); -} -x_516 = lean_ctor_get(x_507, 0); -lean_inc(x_516); -x_517 = lean_ctor_get(x_507, 1); -lean_inc(x_517); -x_518 = lean_ctor_get(x_507, 3); -lean_inc(x_518); -if (lean_is_exclusive(x_507)) { - lean_ctor_release(x_507, 0); - lean_ctor_release(x_507, 1); - lean_ctor_release(x_507, 2); - lean_ctor_release(x_507, 3); - x_519 = x_507; -} else { - lean_dec_ref(x_507); - x_519 = lean_box(0); -} -if (lean_is_scalar(x_519)) { - x_520 = lean_alloc_ctor(0, 4, 0); -} else { - x_520 = x_519; -} -lean_ctor_set(x_520, 0, x_516); -lean_ctor_set(x_520, 1, x_517); -lean_ctor_set(x_520, 2, x_473); -lean_ctor_set(x_520, 3, x_518); -if (lean_is_scalar(x_515)) { - x_521 = lean_alloc_ctor(0, 6, 0); -} else { - x_521 = x_515; -} -lean_ctor_set(x_521, 0, x_510); -lean_ctor_set(x_521, 1, x_511); -lean_ctor_set(x_521, 2, x_520); -lean_ctor_set(x_521, 3, x_512); -lean_ctor_set(x_521, 4, x_513); -lean_ctor_set(x_521, 5, x_514); -if (lean_is_scalar(x_509)) { - x_522 = lean_alloc_ctor(1, 2, 0); -} else { - x_522 = x_509; -} -lean_ctor_set(x_522, 0, x_508); -lean_ctor_set(x_522, 1, x_521); -return x_522; } } } } else { -uint8_t x_523; +uint8_t x_455; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_523 = !lean_is_exclusive(x_278); -if (x_523 == 0) +x_455 = !lean_is_exclusive(x_244); +if (x_455 == 0) { -return x_278; +return x_244; } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; -x_524 = lean_ctor_get(x_278, 0); -x_525 = lean_ctor_get(x_278, 1); -lean_inc(x_525); -lean_inc(x_524); -lean_dec(x_278); -x_526 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_526, 0, x_524); -lean_ctor_set(x_526, 1, x_525); -return x_526; +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; } } } @@ -4889,56 +4527,56 @@ return x_526; } else { -uint8_t x_527; +uint8_t x_459; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_527 = !lean_is_exclusive(x_32); -if (x_527 == 0) +x_459 = !lean_is_exclusive(x_32); +if (x_459 == 0) { return x_32; } else { -lean_object* x_528; lean_object* x_529; lean_object* x_530; -x_528 = lean_ctor_get(x_32, 0); -x_529 = lean_ctor_get(x_32, 1); -lean_inc(x_529); -lean_inc(x_528); +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_dec(x_32); -x_530 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_530, 0, x_528); -lean_ctor_set(x_530, 1, x_529); -return x_530; +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; } } } else { -uint8_t x_531; +uint8_t x_463; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_531 = !lean_is_exclusive(x_28); -if (x_531 == 0) +x_463 = !lean_is_exclusive(x_28); +if (x_463 == 0) { return x_28; } else { -lean_object* x_532; lean_object* x_533; lean_object* x_534; -x_532 = lean_ctor_get(x_28, 0); -x_533 = lean_ctor_get(x_28, 1); -lean_inc(x_533); -lean_inc(x_532); +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_dec(x_28); -x_534 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_534, 0, x_532); -lean_ctor_set(x_534, 1, x_533); -return x_534; +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; } } } @@ -5107,2130 +4745,1768 @@ goto _start; } case 1: { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; lean_dec(x_23); x_30 = lean_ctor_get(x_24, 1); lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + x_31 = x_24; +} else { + lean_dec_ref(x_24); + x_31 = lean_box(0); +} +x_32 = lean_ctor_get(x_25, 0); +lean_inc(x_32); lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_10, x_32); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_10, x_33); lean_dec(x_10); -x_34 = !lean_is_exclusive(x_30); -if (x_34 == 0) +x_35 = !lean_is_exclusive(x_30); +if (x_35 == 0) { -lean_object* x_35; uint8_t x_36; -x_35 = lean_ctor_get(x_30, 2); -x_36 = !lean_is_exclusive(x_35); -if (x_36 == 0) +lean_object* x_36; uint8_t x_37; +x_36 = lean_ctor_get(x_30, 2); +x_37 = !lean_is_exclusive(x_36); +if (x_37 == 0) { -lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_37 = lean_ctor_get(x_35, 2); -x_38 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_35, 2, x_38); -x_39 = !lean_is_exclusive(x_11); -if (x_39 == 0) +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_90; uint8_t x_91; +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) { -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_40 = lean_ctor_get(x_11, 2); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_31); -lean_ctor_set(x_41, 1, x_19); -x_42 = lean_array_push(x_40, x_41); -lean_ctor_set(x_11, 2, x_42); -x_43 = 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_33, x_11, x_30); -if (lean_obj_tag(x_43) == 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_44; lean_object* x_45; uint8_t x_46; -x_44 = lean_ctor_get(x_43, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_44, 2); -lean_inc(x_45); -x_46 = !lean_is_exclusive(x_43); -if (x_46 == 0) -{ -lean_object* x_47; uint8_t x_48; -x_47 = lean_ctor_get(x_43, 1); -lean_dec(x_47); -x_48 = !lean_is_exclusive(x_44); -if (x_48 == 0) -{ -lean_object* x_49; uint8_t x_50; -x_49 = lean_ctor_get(x_44, 2); -lean_dec(x_49); -x_50 = !lean_is_exclusive(x_45); -if (x_50 == 0) -{ -lean_object* x_51; -x_51 = lean_ctor_get(x_45, 2); -lean_dec(x_51); -lean_ctor_set(x_45, 2, x_37); -return x_43; +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_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -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_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_37); -lean_ctor_set(x_55, 3, x_54); -lean_ctor_set(x_44, 2, x_55); -return x_43; +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_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; } } 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; -x_56 = lean_ctor_get(x_44, 0); -x_57 = lean_ctor_get(x_44, 1); -x_58 = lean_ctor_get(x_44, 3); -x_59 = lean_ctor_get(x_44, 4); -x_60 = lean_ctor_get(x_44, 5); -lean_inc(x_60); -lean_inc(x_59); -lean_inc(x_58); +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_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; +} +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_39 = x_116; +x_40 = x_115; +goto block_89; +} +} +block_89: +{ +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_41; lean_object* x_42; uint8_t x_43; +x_41 = lean_ctor_get(x_40, 2); +lean_inc(x_41); +x_42 = lean_ctor_get(x_39, 0); +lean_inc(x_42); +lean_dec(x_39); +x_43 = !lean_is_exclusive(x_40); +if (x_43 == 0) +{ +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_40, 2); +lean_dec(x_44); +x_45 = !lean_is_exclusive(x_41); +if (x_45 == 0) +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_41, 2); +lean_dec(x_46); +lean_ctor_set(x_41, 2, x_38); +if (lean_is_scalar(x_31)) { + x_47 = lean_alloc_ctor(1, 2, 0); +} else { + x_47 = x_31; + lean_ctor_set_tag(x_47, 1); +} +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_40); +return x_47; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_48 = lean_ctor_get(x_41, 0); +x_49 = lean_ctor_get(x_41, 1); +x_50 = lean_ctor_get(x_41, 3); +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); +if (lean_is_scalar(x_31)) { + x_52 = lean_alloc_ctor(1, 2, 0); +} else { + x_52 = x_31; + lean_ctor_set_tag(x_52, 1); +} +lean_ctor_set(x_52, 0, x_42); +lean_ctor_set(x_52, 1, x_40); +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; +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_inc(x_57); lean_inc(x_56); -lean_dec(x_44); -x_61 = lean_ctor_get(x_45, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_45, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_45, 3); -lean_inc(x_63); -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_64 = x_45; +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); +lean_inc(x_59); +x_60 = lean_ctor_get(x_41, 3); +lean_inc(x_60); +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; } else { - lean_dec_ref(x_45); - x_64 = lean_box(0); + lean_dec_ref(x_41); + x_61 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 4, 0); } else { - x_65 = x_64; + x_62 = x_61; } -lean_ctor_set(x_65, 0, x_61); -lean_ctor_set(x_65, 1, x_62); -lean_ctor_set(x_65, 2, x_37); -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_43, 1, x_66); -return x_43; +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); +if (lean_is_scalar(x_31)) { + x_64 = lean_alloc_ctor(1, 2, 0); +} else { + x_64 = x_31; + lean_ctor_set_tag(x_64, 1); +} +lean_ctor_set(x_64, 0, x_42); +lean_ctor_set(x_64, 1, x_63); +return x_64; } } 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; -x_67 = lean_ctor_get(x_43, 0); -lean_inc(x_67); -lean_dec(x_43); -x_68 = lean_ctor_get(x_44, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_44, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_44, 3); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 4); -lean_inc(x_71); -x_72 = lean_ctor_get(x_44, 5); -lean_inc(x_72); -if (lean_is_exclusive(x_44)) { - lean_ctor_release(x_44, 0); - lean_ctor_release(x_44, 1); - lean_ctor_release(x_44, 2); - lean_ctor_release(x_44, 3); - lean_ctor_release(x_44, 4); - lean_ctor_release(x_44, 5); - x_73 = x_44; +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_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); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; +x_70 = lean_ctor_get(x_65, 2); +lean_dec(x_70); +lean_ctor_set(x_65, 2, x_38); +if (lean_is_scalar(x_31)) { + x_71 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_44); - x_73 = lean_box(0); + x_71 = x_31; } -x_74 = lean_ctor_get(x_45, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_40); +return x_71; +} +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_inc(x_74); -x_75 = lean_ctor_get(x_45, 1); -lean_inc(x_75); -x_76 = lean_ctor_get(x_45, 3); -lean_inc(x_76); -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_77 = x_45; +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); +if (lean_is_scalar(x_31)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_45); - x_77 = lean_box(0); + x_76 = x_31; } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 4, 0); -} else { - x_78 = x_77; -} -lean_ctor_set(x_78, 0, x_74); -lean_ctor_set(x_78, 1, x_75); -lean_ctor_set(x_78, 2, x_37); -lean_ctor_set(x_78, 3, x_76); -if (lean_is_scalar(x_73)) { - x_79 = lean_alloc_ctor(0, 6, 0); -} else { - x_79 = x_73; -} -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); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_67); -lean_ctor_set(x_80, 1, x_79); -return x_80; +lean_ctor_set(x_76, 0, x_66); +lean_ctor_set(x_76, 1, x_40); +return x_76; } } else { -lean_object* x_81; lean_object* x_82; uint8_t x_83; -x_81 = lean_ctor_get(x_43, 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; 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_inc(x_81); -x_82 = lean_ctor_get(x_81, 2); +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_is_exclusive(x_43); -if (x_83 == 0) -{ -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_43, 1); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_81); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; -x_86 = lean_ctor_get(x_81, 2); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_82); -if (x_87 == 0) -{ -lean_object* x_88; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -lean_ctor_set(x_82, 2, x_37); -return x_43; -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_89 = lean_ctor_get(x_82, 0); -x_90 = lean_ctor_get(x_82, 1); -x_91 = lean_ctor_get(x_82, 3); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_82); -x_92 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_37); -lean_ctor_set(x_92, 3, x_91); -lean_ctor_set(x_81, 2, x_92); -return x_43; -} -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_93 = lean_ctor_get(x_81, 0); -x_94 = lean_ctor_get(x_81, 1); -x_95 = lean_ctor_get(x_81, 3); -x_96 = lean_ctor_get(x_81, 4); -x_97 = lean_ctor_get(x_81, 5); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_81); -x_98 = lean_ctor_get(x_82, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_82, 1); -lean_inc(x_99); -x_100 = lean_ctor_get(x_82, 3); -lean_inc(x_100); -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); - x_101 = 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; } else { - lean_dec_ref(x_82); - x_101 = lean_box(0); + lean_dec_ref(x_65); + x_85 = lean_box(0); } -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 4, 0); } else { - x_102 = x_101; + x_86 = x_85; } -lean_ctor_set(x_102, 0, x_98); -lean_ctor_set(x_102, 1, x_99); -lean_ctor_set(x_102, 2, x_37); -lean_ctor_set(x_102, 3, x_100); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_93); -lean_ctor_set(x_103, 1, x_94); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_95); -lean_ctor_set(x_103, 4, x_96); -lean_ctor_set(x_103, 5, x_97); -lean_ctor_set(x_43, 1, x_103); -return x_43; -} -} -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; lean_object* x_117; -x_104 = lean_ctor_get(x_43, 0); -lean_inc(x_104); -lean_dec(x_43); -x_105 = lean_ctor_get(x_81, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_81, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_81, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_81, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_81, 5); -lean_inc(x_109); -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_110 = x_81; +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); +if (lean_is_scalar(x_31)) { + x_88 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_81); - x_110 = lean_box(0); + x_88 = x_31; } -x_111 = lean_ctor_get(x_82, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_82, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_82, 3); -lean_inc(x_113); -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); - x_114 = x_82; -} else { - lean_dec_ref(x_82); - x_114 = lean_box(0); +lean_ctor_set(x_88, 0, x_66); +lean_ctor_set(x_88, 1, x_87); +return x_88; } -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(0, 4, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_111); -lean_ctor_set(x_115, 1, x_112); -lean_ctor_set(x_115, 2, x_37); -lean_ctor_set(x_115, 3, x_113); -if (lean_is_scalar(x_110)) { - x_116 = lean_alloc_ctor(0, 6, 0); -} else { - x_116 = x_110; -} -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); -x_117 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_117, 0, x_104); -lean_ctor_set(x_117, 1, x_116); -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; -x_118 = lean_ctor_get(x_11, 0); -x_119 = lean_ctor_get(x_11, 1); -x_120 = lean_ctor_get(x_11, 2); -x_121 = lean_ctor_get(x_11, 3); -x_122 = lean_ctor_get(x_11, 4); -lean_inc(x_122); -lean_inc(x_121); +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_dec(x_11); -x_123 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_123, 0, x_31); -lean_ctor_set(x_123, 1, x_19); -x_124 = lean_array_push(x_120, x_123); -x_125 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_125, 0, x_118); -lean_ctor_set(x_125, 1, x_119); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_121); -lean_ctor_set(x_125, 4, x_122); -x_126 = 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_33, x_125, x_30); -if (lean_obj_tag(x_126) == 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; lean_object* x_143; -x_127 = lean_ctor_get(x_126, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_130 = x_126; +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_126); + 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_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_127, 0); +x_131 = lean_ctor_get(x_123, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 1); +x_132 = lean_ctor_get(x_123, 1); lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 3); +x_133 = lean_ctor_get(x_123, 3); lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 4); -lean_inc(x_134); -x_135 = lean_ctor_get(x_127, 5); -lean_inc(x_135); -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_136 = x_127; +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_127); - x_136 = lean_box(0); + lean_dec_ref(x_123); + x_134 = lean_box(0); } -x_137 = lean_ctor_get(x_128, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_128, 3); -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); - x_140 = x_128; +if (lean_is_scalar(x_134)) { + x_135 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_128); - x_140 = lean_box(0); + x_135 = x_134; } -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_37); -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); +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_143 = lean_alloc_ctor(0, 2, 0); + x_136 = lean_alloc_ctor(0, 6, 0); } else { - x_143 = x_130; + x_136 = x_130; } -lean_ctor_set(x_143, 0, x_129); -lean_ctor_set(x_143, 1, x_142); -return x_143; +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_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_144 = lean_ctor_get(x_126, 1); +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); -x_145 = lean_ctor_get(x_144, 2); -lean_inc(x_145); -x_146 = lean_ctor_get(x_126, 0); +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); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_147 = x_126; -} else { - lean_dec_ref(x_126); - x_147 = lean_box(0); -} -x_148 = lean_ctor_get(x_144, 0); +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_144, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_144, 3); -lean_inc(x_150); -x_151 = lean_ctor_get(x_144, 4); -lean_inc(x_151); -x_152 = lean_ctor_get(x_144, 5); -lean_inc(x_152); -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_153 = x_144; +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_144); - x_153 = lean_box(0); + lean_dec_ref(x_138); + x_149 = lean_box(0); } -x_154 = lean_ctor_get(x_145, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_145, 1); -lean_inc(x_155); -x_156 = lean_ctor_get(x_145, 3); -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); - x_157 = x_145; +if (lean_is_scalar(x_149)) { + x_150 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_145); - x_157 = lean_box(0); + x_150 = x_149; } -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 4, 0); +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_158 = x_157; + x_151 = x_145; } -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_37); -lean_ctor_set(x_158, 3, x_156); -if (lean_is_scalar(x_153)) { - x_159 = lean_alloc_ctor(0, 6, 0); +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_159 = x_153; + x_152 = x_31; } -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_147)) { - x_160 = lean_alloc_ctor(1, 2, 0); -} else { - x_160 = x_147; +lean_ctor_set(x_152, 0, x_139); +lean_ctor_set(x_152, 1, x_151); +return x_152; } -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_35, 0); -x_162 = lean_ctor_get(x_35, 1); -x_163 = lean_ctor_get(x_35, 2); -x_164 = lean_ctor_get(x_35, 3); -lean_inc(x_164); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_dec(x_35); -x_165 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_166 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_166, 0, x_161); -lean_ctor_set(x_166, 1, x_162); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_164); -lean_ctor_set(x_30, 2, x_166); -x_167 = lean_ctor_get(x_11, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_11, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_11, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_11, 3); -lean_inc(x_170); -x_171 = lean_ctor_get(x_11, 4); -lean_inc(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_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); 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_172 = x_11; + x_224 = x_11; } else { lean_dec_ref(x_11); - x_172 = lean_box(0); + x_224 = lean_box(0); } -x_173 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_173, 0, x_31); -lean_ctor_set(x_173, 1, x_19); -x_174 = lean_array_push(x_169, x_173); -if (lean_is_scalar(x_172)) { - x_175 = lean_alloc_ctor(0, 5, 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_227 = lean_alloc_ctor(0, 5, 0); } else { - x_175 = x_172; + x_227 = x_224; } -lean_ctor_set(x_175, 0, x_167); -lean_ctor_set(x_175, 1, x_168); -lean_ctor_set(x_175, 2, x_174); -lean_ctor_set(x_175, 3, x_170); -lean_ctor_set(x_175, 4, x_171); -x_176 = 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_33, x_175, x_30); -if (lean_obj_tag(x_176) == 0) +lean_ctor_set(x_227, 0, x_219); +lean_ctor_set(x_227, 1, x_220); +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_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; -x_177 = lean_ctor_get(x_176, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_177, 2); -lean_inc(x_178); -x_179 = lean_ctor_get(x_176, 0); -lean_inc(x_179); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - x_180 = x_176; -} else { - lean_dec_ref(x_176); - x_180 = lean_box(0); -} -x_181 = lean_ctor_get(x_177, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_177, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_177, 3); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 4); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 5); -lean_inc(x_185); -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); - lean_ctor_release(x_177, 5); - x_186 = x_177; -} else { - lean_dec_ref(x_177); - x_186 = lean_box(0); -} -x_187 = lean_ctor_get(x_178, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_178, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_178, 3); -lean_inc(x_189); -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_190 = x_178; -} else { - lean_dec_ref(x_178); - 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_163); -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_180)) { - x_193 = lean_alloc_ctor(0, 2, 0); -} else { - x_193 = x_180; -} -lean_ctor_set(x_193, 0, x_179); -lean_ctor_set(x_193, 1, x_192); -return x_193; +lean_object* x_229; lean_object* x_230; lean_object* x_231; +x_229 = lean_ctor_get(x_228, 0); +lean_inc(x_229); +x_230 = lean_ctor_get(x_228, 1); +lean_inc(x_230); +lean_dec(x_228); +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_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_194 = lean_ctor_get(x_176, 1); +lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_232 = lean_ctor_get(x_228, 0); +lean_inc(x_232); +x_233 = lean_ctor_get(x_228, 1); +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; +} +block_215: +{ +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_194, 2); +x_195 = lean_ctor_get(x_185, 3); lean_inc(x_195); -x_196 = lean_ctor_get(x_176, 0); -lean_inc(x_196); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - x_197 = x_176; +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_176); - x_197 = lean_box(0); + lean_dec_ref(x_185); + x_196 = lean_box(0); } -x_198 = lean_ctor_get(x_194, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_194, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_194, 3); +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; +} +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_194, 4); +x_201 = lean_ctor_get(x_183, 0); lean_inc(x_201); -x_202 = lean_ctor_get(x_194, 5); +lean_dec(x_183); +x_202 = lean_ctor_get(x_184, 0); lean_inc(x_202); -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_203 = x_194; -} else { - lean_dec_ref(x_194); - x_203 = lean_box(0); -} -x_204 = lean_ctor_get(x_195, 0); +x_203 = lean_ctor_get(x_184, 1); +lean_inc(x_203); +x_204 = lean_ctor_get(x_184, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 1); +x_205 = lean_ctor_get(x_184, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_195, 3); +x_206 = lean_ctor_get(x_184, 5); lean_inc(x_206); -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_207 = x_195; +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; } else { - lean_dec_ref(x_195); + lean_dec_ref(x_184); 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); +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; +} else { + lean_dec_ref(x_200); + x_211 = lean_box(0); +} +if (lean_is_scalar(x_211)) { + x_212 = lean_alloc_ctor(0, 4, 0); +} else { + x_212 = x_211; +} +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_208 = lean_alloc_ctor(0, 4, 0); + x_213 = lean_alloc_ctor(0, 6, 0); } else { - x_208 = x_207; + x_213 = x_207; } -lean_ctor_set(x_208, 0, x_204); -lean_ctor_set(x_208, 1, x_205); -lean_ctor_set(x_208, 2, x_163); -lean_ctor_set(x_208, 3, x_206); -if (lean_is_scalar(x_203)) { - x_209 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_31)) { + x_214 = lean_alloc_ctor(0, 2, 0); } else { - x_209 = x_203; + x_214 = x_31; } -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); -if (lean_is_scalar(x_197)) { - x_210 = lean_alloc_ctor(1, 2, 0); -} else { - x_210 = x_197; +lean_ctor_set(x_214, 0, x_201); +lean_ctor_set(x_214, 1, x_213); +return x_214; } -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; 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_211 = lean_ctor_get(x_30, 2); -x_212 = lean_ctor_get(x_30, 0); -x_213 = lean_ctor_get(x_30, 1); -x_214 = lean_ctor_get(x_30, 3); -x_215 = lean_ctor_get(x_30, 4); -x_216 = lean_ctor_get(x_30, 5); -lean_inc(x_216); -lean_inc(x_215); -lean_inc(x_214); -lean_inc(x_211); -lean_inc(x_213); -lean_inc(x_212); -lean_dec(x_30); -x_217 = lean_ctor_get(x_211, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_211, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_211, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_211, 3); -lean_inc(x_220); -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); - x_221 = x_211; -} else { - lean_dec_ref(x_211); - x_221 = lean_box(0); -} -x_222 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_221)) { - x_223 = lean_alloc_ctor(0, 4, 0); -} else { - x_223 = x_221; -} -lean_ctor_set(x_223, 0, x_217); -lean_ctor_set(x_223, 1, x_218); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_220); -x_224 = lean_alloc_ctor(0, 6, 0); -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); -x_225 = lean_ctor_get(x_11, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_11, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_11, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_11, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_11, 4); -lean_inc(x_229); -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_230 = x_11; -} else { - lean_dec_ref(x_11); - x_230 = lean_box(0); -} -x_231 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_231, 0, x_31); -lean_ctor_set(x_231, 1, x_19); -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_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_33, x_233, x_224); -if (lean_obj_tag(x_234) == 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; lean_object* x_249; lean_object* x_250; lean_object* x_251; -x_235 = lean_ctor_get(x_234, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_235, 2); -lean_inc(x_236); -x_237 = lean_ctor_get(x_234, 0); -lean_inc(x_237); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_238 = x_234; -} else { - lean_dec_ref(x_234); - x_238 = lean_box(0); -} -x_239 = lean_ctor_get(x_235, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_235, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_235, 3); -lean_inc(x_241); -x_242 = lean_ctor_get(x_235, 4); -lean_inc(x_242); -x_243 = lean_ctor_get(x_235, 5); -lean_inc(x_243); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - lean_ctor_release(x_235, 3); - lean_ctor_release(x_235, 4); - lean_ctor_release(x_235, 5); - x_244 = x_235; -} else { - lean_dec_ref(x_235); - x_244 = lean_box(0); -} -x_245 = lean_ctor_get(x_236, 0); -lean_inc(x_245); -x_246 = lean_ctor_get(x_236, 1); -lean_inc(x_246); -x_247 = lean_ctor_get(x_236, 3); -lean_inc(x_247); -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); - x_248 = x_236; -} else { - lean_dec_ref(x_236); - x_248 = lean_box(0); -} -if (lean_is_scalar(x_248)) { - x_249 = lean_alloc_ctor(0, 4, 0); -} else { - x_249 = x_248; -} -lean_ctor_set(x_249, 0, x_245); -lean_ctor_set(x_249, 1, x_246); -lean_ctor_set(x_249, 2, x_219); -lean_ctor_set(x_249, 3, x_247); -if (lean_is_scalar(x_244)) { - x_250 = lean_alloc_ctor(0, 6, 0); -} else { - x_250 = x_244; -} -lean_ctor_set(x_250, 0, x_239); -lean_ctor_set(x_250, 1, x_240); -lean_ctor_set(x_250, 2, x_249); -lean_ctor_set(x_250, 3, x_241); -lean_ctor_set(x_250, 4, x_242); -lean_ctor_set(x_250, 5, x_243); -if (lean_is_scalar(x_238)) { - x_251 = lean_alloc_ctor(0, 2, 0); -} else { - x_251 = x_238; -} -lean_ctor_set(x_251, 0, x_237); -lean_ctor_set(x_251, 1, x_250); -return x_251; -} -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; -x_252 = lean_ctor_get(x_234, 1); -lean_inc(x_252); -x_253 = lean_ctor_get(x_252, 2); -lean_inc(x_253); -x_254 = lean_ctor_get(x_234, 0); -lean_inc(x_254); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_255 = x_234; -} else { - lean_dec_ref(x_234); - x_255 = lean_box(0); -} -x_256 = lean_ctor_get(x_252, 0); -lean_inc(x_256); -x_257 = lean_ctor_get(x_252, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_252, 3); -lean_inc(x_258); -x_259 = lean_ctor_get(x_252, 4); -lean_inc(x_259); -x_260 = lean_ctor_get(x_252, 5); -lean_inc(x_260); -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_261 = x_252; -} else { - lean_dec_ref(x_252); - x_261 = lean_box(0); -} -x_262 = lean_ctor_get(x_253, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_253, 1); -lean_inc(x_263); -x_264 = lean_ctor_get(x_253, 3); -lean_inc(x_264); -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_265 = x_253; -} else { - lean_dec_ref(x_253); - x_265 = lean_box(0); -} -if (lean_is_scalar(x_265)) { - x_266 = lean_alloc_ctor(0, 4, 0); -} else { - x_266 = x_265; -} -lean_ctor_set(x_266, 0, x_262); -lean_ctor_set(x_266, 1, x_263); -lean_ctor_set(x_266, 2, x_219); -lean_ctor_set(x_266, 3, x_264); -if (lean_is_scalar(x_261)) { - x_267 = lean_alloc_ctor(0, 6, 0); -} else { - x_267 = x_261; -} -lean_ctor_set(x_267, 0, x_256); -lean_ctor_set(x_267, 1, x_257); -lean_ctor_set(x_267, 2, x_266); -lean_ctor_set(x_267, 3, x_258); -lean_ctor_set(x_267, 4, x_259); -lean_ctor_set(x_267, 5, x_260); -if (lean_is_scalar(x_255)) { - x_268 = lean_alloc_ctor(1, 2, 0); -} else { - x_268 = x_255; -} -lean_ctor_set(x_268, 0, x_254); -lean_ctor_set(x_268, 1, x_267); -return x_268; } } } default: { -lean_object* x_269; lean_object* x_270; -x_269 = lean_ctor_get(x_24, 1); -lean_inc(x_269); +lean_object* x_235; lean_object* x_236; +x_235 = lean_ctor_get(x_24, 1); +lean_inc(x_235); lean_dec(x_24); lean_inc(x_11); -x_270 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_269); -if (lean_obj_tag(x_270) == 0) +x_236 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_235); +if (lean_obj_tag(x_236) == 0) { -lean_object* x_271; -x_271 = lean_ctor_get(x_270, 0); -lean_inc(x_271); -if (lean_obj_tag(x_271) == 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_272; lean_object* x_273; lean_object* x_274; +lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_dec(x_19); -x_272 = lean_ctor_get(x_270, 1); -lean_inc(x_272); -lean_dec(x_270); -x_273 = lean_unsigned_to_nat(1u); -x_274 = lean_nat_add(x_10, x_273); +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); lean_dec(x_10); -x_10 = x_274; -x_12 = x_272; +x_10 = x_240; +x_12 = x_238; goto _start; } else { -lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_276 = lean_ctor_get(x_270, 1); -lean_inc(x_276); -lean_dec(x_270); -x_277 = lean_ctor_get(x_271, 0); -lean_inc(x_277); -lean_dec(x_271); -x_278 = lean_unsigned_to_nat(1u); -x_279 = lean_nat_add(x_10, x_278); +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; +} else { + lean_dec_ref(x_236); + x_243 = 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_280 = !lean_is_exclusive(x_276); -if (x_280 == 0) +x_247 = !lean_is_exclusive(x_242); +if (x_247 == 0) { -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_276, 2); -x_282 = !lean_is_exclusive(x_281); -if (x_282 == 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_283; lean_object* x_284; uint8_t x_285; -x_283 = lean_ctor_get(x_281, 2); -x_284 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_281, 2, x_284); -x_285 = !lean_is_exclusive(x_11); -if (x_285 == 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_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_286 = lean_ctor_get(x_11, 2); -x_287 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_287, 0, x_277); -lean_ctor_set(x_287, 1, x_19); -x_288 = lean_array_push(x_286, x_287); -lean_ctor_set(x_11, 2, x_288); -x_289 = 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_279, x_11, x_276); -if (lean_obj_tag(x_289) == 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_290; lean_object* x_291; uint8_t x_292; -x_290 = lean_ctor_get(x_289, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_290, 2); -lean_inc(x_291); -x_292 = !lean_is_exclusive(x_289); -if (x_292 == 0) -{ -lean_object* x_293; uint8_t x_294; -x_293 = lean_ctor_get(x_289, 1); -lean_dec(x_293); -x_294 = !lean_is_exclusive(x_290); -if (x_294 == 0) -{ -lean_object* x_295; uint8_t x_296; -x_295 = lean_ctor_get(x_290, 2); -lean_dec(x_295); -x_296 = !lean_is_exclusive(x_291); -if (x_296 == 0) -{ -lean_object* x_297; -x_297 = lean_ctor_get(x_291, 2); -lean_dec(x_297); -lean_ctor_set(x_291, 2, x_283); -return x_289; -} -else -{ -lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_298 = lean_ctor_get(x_291, 0); -x_299 = lean_ctor_get(x_291, 1); -x_300 = lean_ctor_get(x_291, 3); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_dec(x_291); -x_301 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_301, 0, x_298); -lean_ctor_set(x_301, 1, x_299); -lean_ctor_set(x_301, 2, x_283); -lean_ctor_set(x_301, 3, x_300); -lean_ctor_set(x_290, 2, x_301); -return x_289; -} -} -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; -x_302 = lean_ctor_get(x_290, 0); -x_303 = lean_ctor_get(x_290, 1); -x_304 = lean_ctor_get(x_290, 3); -x_305 = lean_ctor_get(x_290, 4); -x_306 = lean_ctor_get(x_290, 5); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_inc(x_303); -lean_inc(x_302); -lean_dec(x_290); -x_307 = lean_ctor_get(x_291, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_291, 1); +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_291, 3); +x_309 = lean_ctor_get(x_307, 1); lean_inc(x_309); -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); - x_310 = x_291; -} else { - lean_dec_ref(x_291); - x_310 = lean_box(0); +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; } -if (lean_is_scalar(x_310)) { - x_311 = lean_alloc_ctor(0, 4, 0); -} else { - x_311 = x_310; -} -lean_ctor_set(x_311, 0, x_307); -lean_ctor_set(x_311, 1, x_308); -lean_ctor_set(x_311, 2, x_283); -lean_ctor_set(x_311, 3, x_309); -x_312 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_312, 0, x_302); -lean_ctor_set(x_312, 1, x_303); -lean_ctor_set(x_312, 2, x_311); -lean_ctor_set(x_312, 3, x_304); -lean_ctor_set(x_312, 4, x_305); -lean_ctor_set(x_312, 5, x_306); -lean_ctor_set(x_289, 1, x_312); -return x_289; +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_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_313 = lean_ctor_get(x_289, 0); -lean_inc(x_313); -lean_dec(x_289); -x_314 = lean_ctor_get(x_290, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_290, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_290, 3); -lean_inc(x_316); -x_317 = lean_ctor_get(x_290, 4); -lean_inc(x_317); -x_318 = lean_ctor_get(x_290, 5); +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); -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); - lean_ctor_release(x_290, 5); - x_319 = x_290; -} else { - lean_dec_ref(x_290); - x_319 = lean_box(0); -} -x_320 = lean_ctor_get(x_291, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_291, 1); -lean_inc(x_321); -x_322 = lean_ctor_get(x_291, 3); -lean_inc(x_322); -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); - x_323 = x_291; -} else { - lean_dec_ref(x_291); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 4, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_320); -lean_ctor_set(x_324, 1, x_321); -lean_ctor_set(x_324, 2, x_283); -lean_ctor_set(x_324, 3, x_322); -if (lean_is_scalar(x_319)) { - x_325 = lean_alloc_ctor(0, 6, 0); -} else { - x_325 = x_319; -} -lean_ctor_set(x_325, 0, x_314); -lean_ctor_set(x_325, 1, x_315); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_316); -lean_ctor_set(x_325, 4, x_317); -lean_ctor_set(x_325, 5, x_318); -x_326 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_326, 0, x_313); -lean_ctor_set(x_326, 1, x_325); -return x_326; -} -} -else -{ -lean_object* x_327; lean_object* x_328; uint8_t x_329; -x_327 = lean_ctor_get(x_289, 1); -lean_inc(x_327); -x_328 = lean_ctor_get(x_327, 2); -lean_inc(x_328); -x_329 = !lean_is_exclusive(x_289); -if (x_329 == 0) -{ -lean_object* x_330; uint8_t x_331; -x_330 = lean_ctor_get(x_289, 1); -lean_dec(x_330); -x_331 = !lean_is_exclusive(x_327); -if (x_331 == 0) -{ -lean_object* x_332; uint8_t x_333; -x_332 = lean_ctor_get(x_327, 2); -lean_dec(x_332); -x_333 = !lean_is_exclusive(x_328); -if (x_333 == 0) -{ -lean_object* x_334; -x_334 = lean_ctor_get(x_328, 2); -lean_dec(x_334); -lean_ctor_set(x_328, 2, x_283); -return x_289; -} -else -{ -lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_335 = lean_ctor_get(x_328, 0); -x_336 = lean_ctor_get(x_328, 1); -x_337 = lean_ctor_get(x_328, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_dec(x_328); -x_338 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_338, 0, x_335); -lean_ctor_set(x_338, 1, x_336); -lean_ctor_set(x_338, 2, x_283); -lean_ctor_set(x_338, 3, x_337); -lean_ctor_set(x_327, 2, x_338); -return x_289; -} -} -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; lean_object* x_347; lean_object* x_348; lean_object* x_349; -x_339 = lean_ctor_get(x_327, 0); -x_340 = lean_ctor_get(x_327, 1); -x_341 = lean_ctor_get(x_327, 3); -x_342 = lean_ctor_get(x_327, 4); -x_343 = lean_ctor_get(x_327, 5); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_inc(x_339); -lean_dec(x_327); -x_344 = lean_ctor_get(x_328, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_328, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 3); -lean_inc(x_346); -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); - x_347 = x_328; -} else { - lean_dec_ref(x_328); - 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_283); -lean_ctor_set(x_348, 3, x_346); -x_349 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_349, 0, x_339); -lean_ctor_set(x_349, 1, x_340); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_341); -lean_ctor_set(x_349, 4, x_342); -lean_ctor_set(x_349, 5, x_343); -lean_ctor_set(x_289, 1, x_349); -return x_289; -} -} -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; -x_350 = lean_ctor_get(x_289, 0); -lean_inc(x_350); -lean_dec(x_289); -x_351 = lean_ctor_get(x_327, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_327, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_327, 3); -lean_inc(x_353); -x_354 = lean_ctor_get(x_327, 4); -lean_inc(x_354); -x_355 = lean_ctor_get(x_327, 5); -lean_inc(x_355); -if (lean_is_exclusive(x_327)) { - lean_ctor_release(x_327, 0); - lean_ctor_release(x_327, 1); - lean_ctor_release(x_327, 2); - lean_ctor_release(x_327, 3); - lean_ctor_release(x_327, 4); - lean_ctor_release(x_327, 5); - x_356 = x_327; -} else { - lean_dec_ref(x_327); - x_356 = lean_box(0); -} -x_357 = lean_ctor_get(x_328, 0); -lean_inc(x_357); -x_358 = lean_ctor_get(x_328, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_328, 3); -lean_inc(x_359); -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); - x_360 = x_328; -} else { - lean_dec_ref(x_328); - x_360 = lean_box(0); -} -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 4, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_357); -lean_ctor_set(x_361, 1, x_358); -lean_ctor_set(x_361, 2, x_283); -lean_ctor_set(x_361, 3, x_359); -if (lean_is_scalar(x_356)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = 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); -x_363 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_363, 0, x_350); -lean_ctor_set(x_363, 1, x_362); -return x_363; -} -} -} -else -{ -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_364 = lean_ctor_get(x_11, 0); -x_365 = lean_ctor_get(x_11, 1); -x_366 = lean_ctor_get(x_11, 2); -x_367 = lean_ctor_get(x_11, 3); -x_368 = lean_ctor_get(x_11, 4); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_inc(x_365); -lean_inc(x_364); +lean_inc(x_317); +lean_inc(x_316); +lean_inc(x_315); +lean_inc(x_314); lean_dec(x_11); -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_277); -lean_ctor_set(x_369, 1, x_19); -x_370 = lean_array_push(x_366, x_369); -x_371 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_371, 0, x_364); -lean_ctor_set(x_371, 1, x_365); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_367); -lean_ctor_set(x_371, 4, x_368); -x_372 = 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_279, x_371, x_276); -if (lean_obj_tag(x_372) == 0) +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_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; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_373 = lean_ctor_get(x_372, 1); -lean_inc(x_373); -x_374 = lean_ctor_get(x_373, 2); -lean_inc(x_374); -x_375 = lean_ctor_get(x_372, 0); -lean_inc(x_375); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - x_376 = x_372; -} else { - lean_dec_ref(x_372); - x_376 = lean_box(0); -} -x_377 = lean_ctor_get(x_373, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_373, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_373, 3); -lean_inc(x_379); -x_380 = lean_ctor_get(x_373, 4); -lean_inc(x_380); -x_381 = lean_ctor_get(x_373, 5); -lean_inc(x_381); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - lean_ctor_release(x_373, 3); - lean_ctor_release(x_373, 4); - lean_ctor_release(x_373, 5); - x_382 = x_373; -} else { - lean_dec_ref(x_373); - x_382 = lean_box(0); -} -x_383 = lean_ctor_get(x_374, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_374, 1); -lean_inc(x_384); -x_385 = lean_ctor_get(x_374, 3); -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); - 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, 4, 0); -} else { - x_387 = x_386; -} -lean_ctor_set(x_387, 0, x_383); -lean_ctor_set(x_387, 1, x_384); -lean_ctor_set(x_387, 2, x_283); -lean_ctor_set(x_387, 3, x_385); -if (lean_is_scalar(x_382)) { - x_388 = lean_alloc_ctor(0, 6, 0); -} else { - x_388 = x_382; -} -lean_ctor_set(x_388, 0, x_377); -lean_ctor_set(x_388, 1, x_378); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_379); -lean_ctor_set(x_388, 4, x_380); -lean_ctor_set(x_388, 5, x_381); -if (lean_is_scalar(x_376)) { - x_389 = lean_alloc_ctor(0, 2, 0); -} else { - x_389 = x_376; -} -lean_ctor_set(x_389, 0, x_375); -lean_ctor_set(x_389, 1, x_388); -return x_389; +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_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; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_390 = lean_ctor_get(x_372, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_390, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_372, 0); -lean_inc(x_392); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - x_393 = x_372; -} else { - lean_dec_ref(x_372); - x_393 = lean_box(0); +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; } -x_394 = lean_ctor_get(x_390, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_390, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_390, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_390, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_390, 5); -lean_inc(x_398); -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_399 = x_390; -} else { - lean_dec_ref(x_390); - x_399 = lean_box(0); } -x_400 = lean_ctor_get(x_391, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_391, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_391, 3); -lean_inc(x_402); -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_403 = x_391; +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); +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); +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 { - lean_dec_ref(x_391); - x_403 = lean_box(0); + x_259 = x_243; + lean_ctor_set_tag(x_259, 1); } -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_259, 0, x_254); +lean_ctor_set(x_259, 1, x_252); +return x_259; +} +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_404 = x_403; + x_264 = x_243; + lean_ctor_set_tag(x_264, 1); } -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_283); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_264, 0, x_254); +lean_ctor_set(x_264, 1, x_252); +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; 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_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 { - x_405 = x_399; + lean_dec_ref(x_253); + x_273 = lean_box(0); } -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_393)) { - x_406 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_273)) { + x_274 = lean_alloc_ctor(0, 4, 0); } else { - x_406 = x_393; + x_274 = x_273; +} +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, 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); +} else { + x_276 = x_243; + lean_ctor_set_tag(x_276, 1); +} +lean_ctor_set(x_276, 0, x_254); +lean_ctor_set(x_276, 1, x_275); +return x_276; +} +} +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_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_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); +} else { + x_288 = x_243; +} +lean_ctor_set(x_288, 0, x_278); +lean_ctor_set(x_288, 1, x_252); +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_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); +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; +} else { + lean_dec_ref(x_277); + x_297 = lean_box(0); +} +if (lean_is_scalar(x_297)) { + x_298 = lean_alloc_ctor(0, 4, 0); +} else { + x_298 = x_297; +} +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); +} else { + x_300 = x_243; +} +lean_ctor_set(x_300, 0, x_278); +lean_ctor_set(x_300, 1, x_299); +return x_300; } -lean_ctor_set(x_406, 0, x_392); -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; lean_object* x_422; -x_407 = lean_ctor_get(x_281, 0); -x_408 = lean_ctor_get(x_281, 1); -x_409 = lean_ctor_get(x_281, 2); -x_410 = lean_ctor_get(x_281, 3); -lean_inc(x_410); -lean_inc(x_409); -lean_inc(x_408); -lean_inc(x_407); -lean_dec(x_281); -x_411 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_412 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_412, 0, x_407); -lean_ctor_set(x_412, 1, x_408); -lean_ctor_set(x_412, 2, x_411); -lean_ctor_set(x_412, 3, x_410); -lean_ctor_set(x_276, 2, x_412); -x_413 = lean_ctor_get(x_11, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_11, 1); -lean_inc(x_414); -x_415 = lean_ctor_get(x_11, 2); -lean_inc(x_415); -x_416 = lean_ctor_get(x_11, 3); -lean_inc(x_416); -x_417 = lean_ctor_get(x_11, 4); -lean_inc(x_417); +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); 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_418 = x_11; + x_373 = x_11; } else { lean_dec_ref(x_11); - x_418 = lean_box(0); + x_373 = lean_box(0); } -x_419 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_419, 0, x_277); -lean_ctor_set(x_419, 1, x_19); -x_420 = lean_array_push(x_415, x_419); -if (lean_is_scalar(x_418)) { - x_421 = lean_alloc_ctor(0, 5, 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); } else { - x_421 = x_418; + x_376 = x_373; } -lean_ctor_set(x_421, 0, x_413); -lean_ctor_set(x_421, 1, x_414); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_416); -lean_ctor_set(x_421, 4, x_417); -x_422 = 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_279, x_421, x_276); -if (lean_obj_tag(x_422) == 0) +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_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; lean_object* x_439; -x_423 = lean_ctor_get(x_422, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_423, 2); -lean_inc(x_424); -x_425 = lean_ctor_get(x_422, 0); -lean_inc(x_425); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_426 = x_422; -} else { - lean_dec_ref(x_422); - x_426 = lean_box(0); -} -x_427 = lean_ctor_get(x_423, 0); -lean_inc(x_427); -x_428 = lean_ctor_get(x_423, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_423, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_423, 4); -lean_inc(x_430); -x_431 = lean_ctor_get(x_423, 5); -lean_inc(x_431); -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); - lean_ctor_release(x_423, 5); - x_432 = x_423; -} else { - lean_dec_ref(x_423); - x_432 = lean_box(0); -} -x_433 = lean_ctor_get(x_424, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_424, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_424, 3); -lean_inc(x_435); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - x_436 = x_424; -} else { - lean_dec_ref(x_424); - x_436 = lean_box(0); -} -if (lean_is_scalar(x_436)) { - x_437 = lean_alloc_ctor(0, 4, 0); -} else { - x_437 = x_436; -} -lean_ctor_set(x_437, 0, x_433); -lean_ctor_set(x_437, 1, x_434); -lean_ctor_set(x_437, 2, x_409); -lean_ctor_set(x_437, 3, x_435); -if (lean_is_scalar(x_432)) { - x_438 = lean_alloc_ctor(0, 6, 0); -} else { - x_438 = x_432; -} -lean_ctor_set(x_438, 0, x_427); -lean_ctor_set(x_438, 1, x_428); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_429); -lean_ctor_set(x_438, 4, x_430); -lean_ctor_set(x_438, 5, x_431); -if (lean_is_scalar(x_426)) { - x_439 = lean_alloc_ctor(0, 2, 0); -} else { - x_439 = x_426; -} -lean_ctor_set(x_439, 0, x_425); -lean_ctor_set(x_439, 1, x_438); -return x_439; +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; } else { -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; lean_object* x_455; lean_object* x_456; -x_440 = lean_ctor_get(x_422, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_440, 2); -lean_inc(x_441); -x_442 = lean_ctor_get(x_422, 0); -lean_inc(x_442); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_443 = x_422; -} else { - lean_dec_ref(x_422); - x_443 = lean_box(0); +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; } +block_365: +{ +if (lean_obj_tag(x_333) == 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_inc(x_350); +x_351 = lean_ctor_get(x_333, 0); +lean_inc(x_351); +lean_dec(x_333); +x_352 = lean_ctor_get(x_334, 0); +lean_inc(x_352); +x_353 = lean_ctor_get(x_334, 1); +lean_inc(x_353); +x_354 = lean_ctor_get(x_334, 3); +lean_inc(x_354); +x_355 = lean_ctor_get(x_334, 4); +lean_inc(x_355); +x_356 = lean_ctor_get(x_334, 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; +} else { + lean_dec_ref(x_334); + x_357 = lean_box(0); +} +x_358 = lean_ctor_get(x_350, 0); +lean_inc(x_358); +x_359 = lean_ctor_get(x_350, 1); +lean_inc(x_359); +x_360 = lean_ctor_get(x_350, 3); +lean_inc(x_360); +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; +} else { + lean_dec_ref(x_350); + x_361 = lean_box(0); +} +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 4, 0); +} else { + x_362 = x_361; +} +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); +if (lean_is_scalar(x_357)) { + x_363 = lean_alloc_ctor(0, 6, 0); +} else { + x_363 = 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); +} else { + x_364 = x_243; +} +lean_ctor_set(x_364, 0, x_351); +lean_ctor_set(x_364, 1, x_363); +return x_364; +} +} +} +} +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; +} else { + lean_dec_ref(x_384); + x_394 = 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); +} else { + x_429 = x_394; +} +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); +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; +} else { + lean_dec_ref(x_11); + x_436 = 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); +} else { + x_439 = x_436; +} +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_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; +} +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); -x_446 = lean_ctor_get(x_440, 3); -lean_inc(x_446); -x_447 = lean_ctor_get(x_440, 4); -lean_inc(x_447); -x_448 = lean_ctor_get(x_440, 5); -lean_inc(x_448); -if (lean_is_exclusive(x_440)) { - lean_ctor_release(x_440, 0); - lean_ctor_release(x_440, 1); - lean_ctor_release(x_440, 2); - lean_ctor_release(x_440, 3); - lean_ctor_release(x_440, 4); - lean_ctor_release(x_440, 5); - x_449 = x_440; +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; +} +block_427: +{ +if (lean_obj_tag(x_395) == 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_440); - x_449 = lean_box(0); + lean_dec_ref(x_396); + x_404 = lean_box(0); } -x_450 = lean_ctor_get(x_441, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_441, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_441, 3); -lean_inc(x_452); -if (lean_is_exclusive(x_441)) { - lean_ctor_release(x_441, 0); - lean_ctor_release(x_441, 1); - lean_ctor_release(x_441, 2); - lean_ctor_release(x_441, 3); - x_453 = x_441; +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_441); - x_453 = lean_box(0); + lean_dec_ref(x_397); + x_408 = lean_box(0); } -if (lean_is_scalar(x_453)) { - x_454 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_408)) { + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_454 = x_453; + x_409 = x_408; } -lean_ctor_set(x_454, 0, x_450); -lean_ctor_set(x_454, 1, x_451); -lean_ctor_set(x_454, 2, x_409); -lean_ctor_set(x_454, 3, x_452); -if (lean_is_scalar(x_449)) { - x_455 = lean_alloc_ctor(0, 6, 0); +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_455 = x_449; + x_410 = x_404; } -lean_ctor_set(x_455, 0, x_444); -lean_ctor_set(x_455, 1, x_445); -lean_ctor_set(x_455, 2, x_454); -lean_ctor_set(x_455, 3, x_446); -lean_ctor_set(x_455, 4, x_447); -lean_ctor_set(x_455, 5, x_448); -if (lean_is_scalar(x_443)) { - x_456 = lean_alloc_ctor(1, 2, 0); +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_456 = x_443; -} -lean_ctor_set(x_456, 0, x_442); -lean_ctor_set(x_456, 1, x_455); -return x_456; -} + 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_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; 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_457 = lean_ctor_get(x_276, 2); -x_458 = lean_ctor_get(x_276, 0); -x_459 = lean_ctor_get(x_276, 1); -x_460 = lean_ctor_get(x_276, 3); -x_461 = lean_ctor_get(x_276, 4); -x_462 = lean_ctor_get(x_276, 5); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_460); -lean_inc(x_457); -lean_inc(x_459); -lean_inc(x_458); -lean_dec(x_276); -x_463 = lean_ctor_get(x_457, 0); -lean_inc(x_463); -x_464 = lean_ctor_get(x_457, 1); -lean_inc(x_464); -x_465 = lean_ctor_get(x_457, 2); -lean_inc(x_465); -x_466 = lean_ctor_get(x_457, 3); -lean_inc(x_466); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - lean_ctor_release(x_457, 2); - lean_ctor_release(x_457, 3); - x_467 = x_457; +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_inc(x_415); +x_416 = lean_ctor_get(x_396, 3); +lean_inc(x_416); +x_417 = lean_ctor_get(x_396, 4); +lean_inc(x_417); +x_418 = lean_ctor_get(x_396, 5); +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_457); - x_467 = lean_box(0); + lean_dec_ref(x_396); + x_419 = lean_box(0); } -x_468 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_467)) { - x_469 = lean_alloc_ctor(0, 4, 0); +x_420 = lean_ctor_get(x_412, 0); +lean_inc(x_420); +x_421 = lean_ctor_get(x_412, 1); +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; } else { - x_469 = x_467; + lean_dec_ref(x_412); + x_423 = lean_box(0); } -lean_ctor_set(x_469, 0, x_463); -lean_ctor_set(x_469, 1, x_464); -lean_ctor_set(x_469, 2, x_468); -lean_ctor_set(x_469, 3, x_466); -x_470 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_470, 0, x_458); -lean_ctor_set(x_470, 1, x_459); -lean_ctor_set(x_470, 2, x_469); -lean_ctor_set(x_470, 3, x_460); -lean_ctor_set(x_470, 4, x_461); -lean_ctor_set(x_470, 5, x_462); -x_471 = lean_ctor_get(x_11, 0); -lean_inc(x_471); -x_472 = lean_ctor_get(x_11, 1); -lean_inc(x_472); -x_473 = lean_ctor_get(x_11, 2); -lean_inc(x_473); -x_474 = lean_ctor_get(x_11, 3); -lean_inc(x_474); -x_475 = lean_ctor_get(x_11, 4); -lean_inc(x_475); -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_476 = x_11; +if (lean_is_scalar(x_423)) { + x_424 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_11); - x_476 = lean_box(0); + x_424 = x_423; } -x_477 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_477, 0, x_277); -lean_ctor_set(x_477, 1, x_19); -x_478 = lean_array_push(x_473, x_477); -if (lean_is_scalar(x_476)) { - x_479 = lean_alloc_ctor(0, 5, 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); } else { - x_479 = x_476; + x_425 = x_419; } -lean_ctor_set(x_479, 0, x_471); -lean_ctor_set(x_479, 1, x_472); -lean_ctor_set(x_479, 2, x_478); -lean_ctor_set(x_479, 3, x_474); -lean_ctor_set(x_479, 4, x_475); -x_480 = 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_279, x_479, x_470); -if (lean_obj_tag(x_480) == 0) -{ -lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_481 = lean_ctor_get(x_480, 1); -lean_inc(x_481); -x_482 = lean_ctor_get(x_481, 2); -lean_inc(x_482); -x_483 = lean_ctor_get(x_480, 0); -lean_inc(x_483); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - x_484 = x_480; +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); } else { - lean_dec_ref(x_480); - x_484 = lean_box(0); + x_426 = x_243; } -x_485 = lean_ctor_get(x_481, 0); -lean_inc(x_485); -x_486 = lean_ctor_get(x_481, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_481, 3); -lean_inc(x_487); -x_488 = lean_ctor_get(x_481, 4); -lean_inc(x_488); -x_489 = lean_ctor_get(x_481, 5); -lean_inc(x_489); -if (lean_is_exclusive(x_481)) { - lean_ctor_release(x_481, 0); - lean_ctor_release(x_481, 1); - lean_ctor_release(x_481, 2); - lean_ctor_release(x_481, 3); - lean_ctor_release(x_481, 4); - lean_ctor_release(x_481, 5); - x_490 = x_481; -} else { - lean_dec_ref(x_481); - x_490 = lean_box(0); +lean_ctor_set(x_426, 0, x_413); +lean_ctor_set(x_426, 1, x_425); +return x_426; } -x_491 = lean_ctor_get(x_482, 0); -lean_inc(x_491); -x_492 = lean_ctor_get(x_482, 1); -lean_inc(x_492); -x_493 = lean_ctor_get(x_482, 3); -lean_inc(x_493); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - x_494 = x_482; -} else { - lean_dec_ref(x_482); - x_494 = lean_box(0); -} -if (lean_is_scalar(x_494)) { - x_495 = lean_alloc_ctor(0, 4, 0); -} else { - x_495 = x_494; -} -lean_ctor_set(x_495, 0, x_491); -lean_ctor_set(x_495, 1, x_492); -lean_ctor_set(x_495, 2, x_465); -lean_ctor_set(x_495, 3, x_493); -if (lean_is_scalar(x_490)) { - x_496 = lean_alloc_ctor(0, 6, 0); -} else { - x_496 = x_490; -} -lean_ctor_set(x_496, 0, x_485); -lean_ctor_set(x_496, 1, x_486); -lean_ctor_set(x_496, 2, x_495); -lean_ctor_set(x_496, 3, x_487); -lean_ctor_set(x_496, 4, x_488); -lean_ctor_set(x_496, 5, x_489); -if (lean_is_scalar(x_484)) { - x_497 = lean_alloc_ctor(0, 2, 0); -} else { - x_497 = x_484; -} -lean_ctor_set(x_497, 0, x_483); -lean_ctor_set(x_497, 1, x_496); -return x_497; -} -else -{ -lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; -x_498 = lean_ctor_get(x_480, 1); -lean_inc(x_498); -x_499 = lean_ctor_get(x_498, 2); -lean_inc(x_499); -x_500 = lean_ctor_get(x_480, 0); -lean_inc(x_500); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - x_501 = x_480; -} else { - lean_dec_ref(x_480); - x_501 = lean_box(0); -} -x_502 = lean_ctor_get(x_498, 0); -lean_inc(x_502); -x_503 = lean_ctor_get(x_498, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_498, 3); -lean_inc(x_504); -x_505 = lean_ctor_get(x_498, 4); -lean_inc(x_505); -x_506 = lean_ctor_get(x_498, 5); -lean_inc(x_506); -if (lean_is_exclusive(x_498)) { - lean_ctor_release(x_498, 0); - lean_ctor_release(x_498, 1); - lean_ctor_release(x_498, 2); - lean_ctor_release(x_498, 3); - lean_ctor_release(x_498, 4); - lean_ctor_release(x_498, 5); - x_507 = x_498; -} else { - lean_dec_ref(x_498); - x_507 = lean_box(0); -} -x_508 = lean_ctor_get(x_499, 0); -lean_inc(x_508); -x_509 = lean_ctor_get(x_499, 1); -lean_inc(x_509); -x_510 = lean_ctor_get(x_499, 3); -lean_inc(x_510); -if (lean_is_exclusive(x_499)) { - lean_ctor_release(x_499, 0); - lean_ctor_release(x_499, 1); - lean_ctor_release(x_499, 2); - lean_ctor_release(x_499, 3); - x_511 = x_499; -} else { - lean_dec_ref(x_499); - x_511 = lean_box(0); -} -if (lean_is_scalar(x_511)) { - x_512 = lean_alloc_ctor(0, 4, 0); -} else { - x_512 = x_511; -} -lean_ctor_set(x_512, 0, x_508); -lean_ctor_set(x_512, 1, x_509); -lean_ctor_set(x_512, 2, x_465); -lean_ctor_set(x_512, 3, x_510); -if (lean_is_scalar(x_507)) { - x_513 = lean_alloc_ctor(0, 6, 0); -} else { - x_513 = x_507; -} -lean_ctor_set(x_513, 0, x_502); -lean_ctor_set(x_513, 1, x_503); -lean_ctor_set(x_513, 2, x_512); -lean_ctor_set(x_513, 3, x_504); -lean_ctor_set(x_513, 4, x_505); -lean_ctor_set(x_513, 5, x_506); -if (lean_is_scalar(x_501)) { - x_514 = lean_alloc_ctor(1, 2, 0); -} else { - x_514 = x_501; -} -lean_ctor_set(x_514, 0, x_500); -lean_ctor_set(x_514, 1, x_513); -return x_514; } } } } else { -uint8_t x_515; +uint8_t x_447; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -7239,23 +6515,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_515 = !lean_is_exclusive(x_270); -if (x_515 == 0) +x_447 = !lean_is_exclusive(x_236); +if (x_447 == 0) { -return x_270; +return x_236; } else { -lean_object* x_516; lean_object* x_517; lean_object* x_518; -x_516 = lean_ctor_get(x_270, 0); -x_517 = lean_ctor_get(x_270, 1); -lean_inc(x_517); -lean_inc(x_516); -lean_dec(x_270); -x_518 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_518, 0, x_516); -lean_ctor_set(x_518, 1, x_517); -return x_518; +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; } } } @@ -7263,7 +6539,7 @@ return x_518; } else { -uint8_t x_519; +uint8_t x_451; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -7273,29 +6549,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_519 = !lean_is_exclusive(x_24); -if (x_519 == 0) +x_451 = !lean_is_exclusive(x_24); +if (x_451 == 0) { return x_24; } else { -lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_520 = lean_ctor_get(x_24, 0); -x_521 = lean_ctor_get(x_24, 1); -lean_inc(x_521); -lean_inc(x_520); +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_dec(x_24); -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; +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; } } } else { -uint8_t x_523; +uint8_t x_455; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -7304,23 +6580,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_523 = !lean_is_exclusive(x_20); -if (x_523 == 0) +x_455 = !lean_is_exclusive(x_20); +if (x_455 == 0) { return x_20; } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; -x_524 = lean_ctor_get(x_20, 0); -x_525 = lean_ctor_get(x_20, 1); -lean_inc(x_525); -lean_inc(x_524); +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_dec(x_20); -x_526 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_526, 0, x_524); -lean_ctor_set(x_526, 1, x_525); -return x_526; +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; } } } @@ -7441,2151 +6717,1789 @@ goto _start; } case 1: { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; uint8_t x_43; lean_dec(x_31); x_38 = lean_ctor_get(x_32, 1); lean_inc(x_38); -lean_dec(x_32); -x_39 = lean_ctor_get(x_33, 0); -lean_inc(x_39); +if (lean_is_exclusive(x_32)) { + lean_ctor_release(x_32, 0); + lean_ctor_release(x_32, 1); + x_39 = x_32; +} else { + lean_dec_ref(x_32); + x_39 = lean_box(0); +} +x_40 = lean_ctor_get(x_33, 0); +lean_inc(x_40); lean_dec(x_33); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_5, x_40); +x_41 = lean_unsigned_to_nat(1u); +x_42 = lean_nat_add(x_5, x_41); lean_dec(x_5); -x_42 = !lean_is_exclusive(x_38); -if (x_42 == 0) +x_43 = !lean_is_exclusive(x_38); +if (x_43 == 0) { -lean_object* x_43; uint8_t x_44; -x_43 = lean_ctor_get(x_38, 2); -x_44 = !lean_is_exclusive(x_43); -if (x_44 == 0) +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_38, 2); +x_45 = !lean_is_exclusive(x_44); +if (x_45 == 0) { -lean_object* x_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_43, 2); -x_46 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_43, 2, x_46); -x_47 = !lean_is_exclusive(x_6); -if (x_47 == 0) +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_98; uint8_t x_99; +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) { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_48 = lean_ctor_get(x_6, 2); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_39); -lean_ctor_set(x_49, 1, x_27); -x_50 = lean_array_push(x_48, x_49); -lean_ctor_set(x_6, 2, x_50); -x_51 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_6, x_38); -if (lean_obj_tag(x_51) == 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_52; lean_object* x_53; uint8_t x_54; -x_52 = lean_ctor_get(x_51, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_52, 2); -lean_inc(x_53); -x_54 = !lean_is_exclusive(x_51); -if (x_54 == 0) -{ -lean_object* x_55; uint8_t x_56; -x_55 = lean_ctor_get(x_51, 1); -lean_dec(x_55); -x_56 = !lean_is_exclusive(x_52); -if (x_56 == 0) -{ -lean_object* x_57; uint8_t x_58; -x_57 = lean_ctor_get(x_52, 2); -lean_dec(x_57); -x_58 = !lean_is_exclusive(x_53); -if (x_58 == 0) -{ -lean_object* x_59; -x_59 = lean_ctor_get(x_53, 2); -lean_dec(x_59); -lean_ctor_set(x_53, 2, x_45); -return x_51; +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_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_60 = lean_ctor_get(x_53, 0); -x_61 = lean_ctor_get(x_53, 1); -x_62 = lean_ctor_get(x_53, 3); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_53); -x_63 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_61); -lean_ctor_set(x_63, 2, x_45); -lean_ctor_set(x_63, 3, x_62); -lean_ctor_set(x_52, 2, x_63); -return x_51; +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_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; } } 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; -x_64 = lean_ctor_get(x_52, 0); -x_65 = lean_ctor_get(x_52, 1); -x_66 = lean_ctor_get(x_52, 3); -x_67 = lean_ctor_get(x_52, 4); -x_68 = lean_ctor_get(x_52, 5); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); +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_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; +} +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_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; +} +} +block_97: +{ +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_49; lean_object* x_50; uint8_t x_51; +x_49 = lean_ctor_get(x_48, 2); +lean_inc(x_49); +x_50 = lean_ctor_get(x_47, 0); +lean_inc(x_50); +lean_dec(x_47); +x_51 = !lean_is_exclusive(x_48); +if (x_51 == 0) +{ +lean_object* x_52; uint8_t x_53; +x_52 = lean_ctor_get(x_48, 2); +lean_dec(x_52); +x_53 = !lean_is_exclusive(x_49); +if (x_53 == 0) +{ +lean_object* x_54; lean_object* x_55; +x_54 = lean_ctor_get(x_49, 2); +lean_dec(x_54); +lean_ctor_set(x_49, 2, x_46); +if (lean_is_scalar(x_39)) { + x_55 = lean_alloc_ctor(1, 2, 0); +} else { + x_55 = x_39; + lean_ctor_set_tag(x_55, 1); +} +lean_ctor_set(x_55, 0, x_50); +lean_ctor_set(x_55, 1, x_48); +return x_55; +} +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_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); +if (lean_is_scalar(x_39)) { + x_60 = lean_alloc_ctor(1, 2, 0); +} else { + x_60 = x_39; + lean_ctor_set_tag(x_60, 1); +} +lean_ctor_set(x_60, 0, x_50); +lean_ctor_set(x_60, 1, x_48); +return x_60; +} +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; 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_inc(x_65); lean_inc(x_64); -lean_dec(x_52); -x_69 = lean_ctor_get(x_53, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_53, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_53, 3); -lean_inc(x_71); -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); - x_72 = x_53; +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); +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; } else { - lean_dec_ref(x_53); - x_72 = lean_box(0); + lean_dec_ref(x_49); + x_69 = lean_box(0); } -if (lean_is_scalar(x_72)) { - x_73 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_73 = x_72; + x_70 = x_69; } -lean_ctor_set(x_73, 0, x_69); -lean_ctor_set(x_73, 1, x_70); -lean_ctor_set(x_73, 2, x_45); -lean_ctor_set(x_73, 3, x_71); -x_74 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_74, 0, x_64); -lean_ctor_set(x_74, 1, x_65); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_66); -lean_ctor_set(x_74, 4, x_67); -lean_ctor_set(x_74, 5, x_68); -lean_ctor_set(x_51, 1, x_74); -return x_51; +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); +if (lean_is_scalar(x_39)) { + x_72 = lean_alloc_ctor(1, 2, 0); +} else { + x_72 = x_39; + lean_ctor_set_tag(x_72, 1); +} +lean_ctor_set(x_72, 0, x_50); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } 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; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_75 = lean_ctor_get(x_51, 0); -lean_inc(x_75); -lean_dec(x_51); -x_76 = lean_ctor_get(x_52, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_52, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_52, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_52, 4); -lean_inc(x_79); -x_80 = lean_ctor_get(x_52, 5); -lean_inc(x_80); -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); - x_81 = x_52; +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_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); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; +x_78 = lean_ctor_get(x_73, 2); +lean_dec(x_78); +lean_ctor_set(x_73, 2, x_46); +if (lean_is_scalar(x_39)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_52); - x_81 = lean_box(0); + x_79 = x_39; } -x_82 = lean_ctor_get(x_53, 0); +lean_ctor_set(x_79, 0, x_74); +lean_ctor_set(x_79, 1, x_48); +return x_79; +} +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_inc(x_82); -x_83 = lean_ctor_get(x_53, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_53, 3); -lean_inc(x_84); -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); - x_85 = x_53; +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); +if (lean_is_scalar(x_39)) { + x_84 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_53); - x_85 = lean_box(0); + x_84 = x_39; } -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(0, 4, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_82); -lean_ctor_set(x_86, 1, x_83); -lean_ctor_set(x_86, 2, x_45); -lean_ctor_set(x_86, 3, x_84); -if (lean_is_scalar(x_81)) { - x_87 = lean_alloc_ctor(0, 6, 0); -} else { - x_87 = x_81; -} -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); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_75); -lean_ctor_set(x_88, 1, x_87); -return x_88; +lean_ctor_set(x_84, 0, x_74); +lean_ctor_set(x_84, 1, x_48); +return x_84; } } else { -lean_object* x_89; lean_object* x_90; uint8_t x_91; -x_89 = lean_ctor_get(x_51, 1); +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_inc(x_89); -x_90 = lean_ctor_get(x_89, 2); +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_is_exclusive(x_51); -if (x_91 == 0) -{ -lean_object* x_92; uint8_t x_93; -x_92 = lean_ctor_get(x_51, 1); -lean_dec(x_92); -x_93 = !lean_is_exclusive(x_89); -if (x_93 == 0) -{ -lean_object* x_94; uint8_t x_95; -x_94 = lean_ctor_get(x_89, 2); -lean_dec(x_94); -x_95 = !lean_is_exclusive(x_90); -if (x_95 == 0) -{ -lean_object* x_96; -x_96 = lean_ctor_get(x_90, 2); -lean_dec(x_96); -lean_ctor_set(x_90, 2, x_45); -return x_51; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_90, 0); -x_98 = lean_ctor_get(x_90, 1); -x_99 = lean_ctor_get(x_90, 3); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_90); -x_100 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -lean_ctor_set(x_100, 2, x_45); -lean_ctor_set(x_100, 3, x_99); -lean_ctor_set(x_89, 2, x_100); -return x_51; -} -} -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; -x_101 = lean_ctor_get(x_89, 0); -x_102 = lean_ctor_get(x_89, 1); -x_103 = lean_ctor_get(x_89, 3); -x_104 = lean_ctor_get(x_89, 4); -x_105 = lean_ctor_get(x_89, 5); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); -lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_89); -x_106 = lean_ctor_get(x_90, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_90, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_90, 3); -lean_inc(x_108); -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); - x_109 = 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; } else { - lean_dec_ref(x_90); - x_109 = lean_box(0); + lean_dec_ref(x_73); + x_93 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_93)) { + x_94 = lean_alloc_ctor(0, 4, 0); } else { - x_110 = x_109; + x_94 = x_93; } -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_45); -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_51, 1, x_111); -return x_51; -} -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; 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_112 = lean_ctor_get(x_51, 0); -lean_inc(x_112); -lean_dec(x_51); -x_113 = lean_ctor_get(x_89, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_89, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_89, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_89, 4); -lean_inc(x_116); -x_117 = lean_ctor_get(x_89, 5); -lean_inc(x_117); -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_118 = x_89; +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); +if (lean_is_scalar(x_39)) { + x_96 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_89); - x_118 = lean_box(0); + x_96 = x_39; } -x_119 = lean_ctor_get(x_90, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_90, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_90, 3); -lean_inc(x_121); -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); - x_122 = x_90; -} else { - lean_dec_ref(x_90); - x_122 = lean_box(0); +lean_ctor_set(x_96, 0, x_74); +lean_ctor_set(x_96, 1, x_95); +return x_96; } -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(0, 4, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_119); -lean_ctor_set(x_123, 1, x_120); -lean_ctor_set(x_123, 2, x_45); -lean_ctor_set(x_123, 3, x_121); -if (lean_is_scalar(x_118)) { - x_124 = lean_alloc_ctor(0, 6, 0); -} else { - x_124 = x_118; -} -lean_ctor_set(x_124, 0, x_113); -lean_ctor_set(x_124, 1, x_114); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_115); -lean_ctor_set(x_124, 4, x_116); -lean_ctor_set(x_124, 5, x_117); -x_125 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_125, 0, x_112); -lean_ctor_set(x_125, 1, x_124); -return x_125; } } } else { -lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_126 = lean_ctor_get(x_6, 0); -x_127 = lean_ctor_get(x_6, 1); -x_128 = lean_ctor_get(x_6, 2); -x_129 = lean_ctor_get(x_6, 3); -x_130 = lean_ctor_get(x_6, 4); -lean_inc(x_130); -lean_inc(x_129); +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_dec(x_6); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_39); -lean_ctor_set(x_131, 1, x_27); -x_132 = lean_array_push(x_128, x_131); -x_133 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_133, 0, x_126); -lean_ctor_set(x_133, 1, x_127); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_129); -lean_ctor_set(x_133, 4, x_130); -x_134 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_133, x_38); -if (lean_obj_tag(x_134) == 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; -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; +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_134); + 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_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_135, 0); +x_139 = lean_ctor_get(x_131, 0); lean_inc(x_139); -x_140 = lean_ctor_get(x_135, 1); +x_140 = lean_ctor_get(x_131, 1); lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); +x_141 = lean_ctor_get(x_131, 3); lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); -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; +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_135); - x_144 = lean_box(0); + lean_dec_ref(x_131); + x_142 = lean_box(0); } -x_145 = lean_ctor_get(x_136, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_136, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 3); -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); - x_148 = x_136; +if (lean_is_scalar(x_142)) { + x_143 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_136); - x_148 = lean_box(0); + x_143 = 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_45); -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); +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_151 = lean_alloc_ctor(0, 2, 0); + x_144 = lean_alloc_ctor(0, 6, 0); } else { - x_151 = x_138; + x_144 = x_138; } -lean_ctor_set(x_151, 0, x_137); -lean_ctor_set(x_151, 1, x_150); -return x_151; +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_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_152 = lean_ctor_get(x_134, 1); +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); -x_153 = lean_ctor_get(x_152, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_134, 0); +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); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_155 = x_134; -} else { - lean_dec_ref(x_134); - x_155 = lean_box(0); -} -x_156 = lean_ctor_get(x_152, 0); +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_152, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 4); -lean_inc(x_159); -x_160 = lean_ctor_get(x_152, 5); -lean_inc(x_160); -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_161 = x_152; +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_152); - x_161 = lean_box(0); + lean_dec_ref(x_146); + x_157 = lean_box(0); } -x_162 = lean_ctor_get(x_153, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_153, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_153, 3); -lean_inc(x_164); -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_165 = x_153; +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_153); - x_165 = lean_box(0); + x_158 = x_157; } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(0, 4, 0); +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_166 = x_165; + x_159 = x_153; } -lean_ctor_set(x_166, 0, x_162); -lean_ctor_set(x_166, 1, x_163); -lean_ctor_set(x_166, 2, x_45); -lean_ctor_set(x_166, 3, x_164); -if (lean_is_scalar(x_161)) { - x_167 = lean_alloc_ctor(0, 6, 0); +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_167 = x_161; + x_160 = x_39; } -lean_ctor_set(x_167, 0, x_156); -lean_ctor_set(x_167, 1, x_157); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_158); -lean_ctor_set(x_167, 4, x_159); -lean_ctor_set(x_167, 5, x_160); -if (lean_is_scalar(x_155)) { - x_168 = lean_alloc_ctor(1, 2, 0); -} else { - x_168 = x_155; +lean_ctor_set(x_160, 0, x_147); +lean_ctor_set(x_160, 1, x_159); +return x_160; } -lean_ctor_set(x_168, 0, x_154); -lean_ctor_set(x_168, 1, x_167); -return x_168; } } } 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; 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; -x_169 = lean_ctor_get(x_43, 0); -x_170 = lean_ctor_get(x_43, 1); -x_171 = lean_ctor_get(x_43, 2); -x_172 = lean_ctor_get(x_43, 3); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_43); -x_173 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_174 = 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_173); -lean_ctor_set(x_174, 3, x_172); -lean_ctor_set(x_38, 2, x_174); -x_175 = lean_ctor_get(x_6, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_6, 1); -lean_inc(x_176); -x_177 = lean_ctor_get(x_6, 2); -lean_inc(x_177); -x_178 = lean_ctor_get(x_6, 3); -lean_inc(x_178); -x_179 = lean_ctor_get(x_6, 4); -lean_inc(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_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); 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_180 = x_6; + x_232 = x_6; } else { lean_dec_ref(x_6); - x_180 = lean_box(0); + x_232 = lean_box(0); } -x_181 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_181, 0, x_39); -lean_ctor_set(x_181, 1, x_27); -x_182 = lean_array_push(x_177, x_181); -if (lean_is_scalar(x_180)) { - x_183 = lean_alloc_ctor(0, 5, 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_235 = lean_alloc_ctor(0, 5, 0); } else { - x_183 = x_180; + x_235 = x_232; } -lean_ctor_set(x_183, 0, x_175); -lean_ctor_set(x_183, 1, x_176); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_178); -lean_ctor_set(x_183, 4, x_179); -x_184 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_183, x_38); -if (lean_obj_tag(x_184) == 0) +lean_ctor_set(x_235, 0, x_227); +lean_ctor_set(x_235, 1, x_228); +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_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; lean_object* x_200; lean_object* x_201; -x_185 = lean_ctor_get(x_184, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - x_188 = x_184; -} else { - lean_dec_ref(x_184); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_185, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 3); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 4); -lean_inc(x_192); -x_193 = lean_ctor_get(x_185, 5); -lean_inc(x_193); -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_194 = x_185; -} else { - lean_dec_ref(x_185); - x_194 = lean_box(0); -} -x_195 = lean_ctor_get(x_186, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_186, 3); -lean_inc(x_197); -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_198 = x_186; -} else { - lean_dec_ref(x_186); - 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_171); -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_188)) { - x_201 = lean_alloc_ctor(0, 2, 0); -} else { - x_201 = x_188; -} -lean_ctor_set(x_201, 0, x_187); -lean_ctor_set(x_201, 1, x_200); -return x_201; +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_236, 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_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_202 = lean_ctor_get(x_184, 1); +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_236, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_236, 1); +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; +} +block_223: +{ +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_202, 2); +x_203 = lean_ctor_get(x_193, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_184, 0); -lean_inc(x_204); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - x_205 = 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); + x_204 = x_193; } else { - lean_dec_ref(x_184); - x_205 = lean_box(0); + lean_dec_ref(x_193); + x_204 = lean_box(0); } -x_206 = lean_ctor_get(x_202, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_202, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_202, 3); +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; +} +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_202, 4); +x_209 = lean_ctor_get(x_191, 0); lean_inc(x_209); -x_210 = lean_ctor_get(x_202, 5); +lean_dec(x_191); +x_210 = lean_ctor_get(x_192, 0); lean_inc(x_210); -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); - lean_ctor_release(x_202, 4); - lean_ctor_release(x_202, 5); - x_211 = x_202; -} else { - lean_dec_ref(x_202); - x_211 = lean_box(0); -} -x_212 = lean_ctor_get(x_203, 0); +x_211 = lean_ctor_get(x_192, 1); +lean_inc(x_211); +x_212 = lean_ctor_get(x_192, 3); lean_inc(x_212); -x_213 = lean_ctor_get(x_203, 1); +x_213 = lean_ctor_get(x_192, 4); lean_inc(x_213); -x_214 = lean_ctor_get(x_203, 3); +x_214 = lean_ctor_get(x_192, 5); 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); - x_215 = x_203; +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; } else { - lean_dec_ref(x_203); + lean_dec_ref(x_192); 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); +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; +} else { + lean_dec_ref(x_208); + x_219 = lean_box(0); +} +if (lean_is_scalar(x_219)) { + x_220 = lean_alloc_ctor(0, 4, 0); +} else { + x_220 = x_219; +} +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_216 = lean_alloc_ctor(0, 4, 0); + x_221 = lean_alloc_ctor(0, 6, 0); } else { - x_216 = x_215; + x_221 = x_215; } -lean_ctor_set(x_216, 0, x_212); -lean_ctor_set(x_216, 1, x_213); -lean_ctor_set(x_216, 2, x_171); -lean_ctor_set(x_216, 3, x_214); -if (lean_is_scalar(x_211)) { - x_217 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_39)) { + x_222 = lean_alloc_ctor(0, 2, 0); } else { - x_217 = x_211; + x_222 = x_39; } -lean_ctor_set(x_217, 0, x_206); -lean_ctor_set(x_217, 1, x_207); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_208); -lean_ctor_set(x_217, 4, x_209); -lean_ctor_set(x_217, 5, x_210); -if (lean_is_scalar(x_205)) { - x_218 = lean_alloc_ctor(1, 2, 0); -} else { - x_218 = x_205; +lean_ctor_set(x_222, 0, x_209); +lean_ctor_set(x_222, 1, x_221); +return x_222; } -lean_ctor_set(x_218, 0, x_204); -lean_ctor_set(x_218, 1, x_217); -return x_218; -} -} -} -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; 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; -x_219 = lean_ctor_get(x_38, 2); -x_220 = lean_ctor_get(x_38, 0); -x_221 = lean_ctor_get(x_38, 1); -x_222 = lean_ctor_get(x_38, 3); -x_223 = lean_ctor_get(x_38, 4); -x_224 = lean_ctor_get(x_38, 5); -lean_inc(x_224); -lean_inc(x_223); -lean_inc(x_222); -lean_inc(x_219); -lean_inc(x_221); -lean_inc(x_220); -lean_dec(x_38); -x_225 = lean_ctor_get(x_219, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_219, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_219, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_219, 3); -lean_inc(x_228); -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); - x_229 = x_219; -} else { - lean_dec_ref(x_219); - x_229 = lean_box(0); -} -x_230 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_229)) { - x_231 = lean_alloc_ctor(0, 4, 0); -} else { - x_231 = x_229; -} -lean_ctor_set(x_231, 0, x_225); -lean_ctor_set(x_231, 1, x_226); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_228); -x_232 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_232, 0, x_220); -lean_ctor_set(x_232, 1, x_221); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_222); -lean_ctor_set(x_232, 4, x_223); -lean_ctor_set(x_232, 5, x_224); -x_233 = lean_ctor_get(x_6, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_6, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_6, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_6, 3); -lean_inc(x_236); -x_237 = lean_ctor_get(x_6, 4); -lean_inc(x_237); -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_238 = x_6; -} else { - lean_dec_ref(x_6); - x_238 = lean_box(0); -} -x_239 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_239, 0, x_39); -lean_ctor_set(x_239, 1, x_27); -x_240 = lean_array_push(x_235, x_239); -if (lean_is_scalar(x_238)) { - x_241 = lean_alloc_ctor(0, 5, 0); -} else { - x_241 = x_238; -} -lean_ctor_set(x_241, 0, x_233); -lean_ctor_set(x_241, 1, x_234); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_236); -lean_ctor_set(x_241, 4, x_237); -x_242 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_241, x_232); -if (lean_obj_tag(x_242) == 0) -{ -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; -x_243 = lean_ctor_get(x_242, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_243, 2); -lean_inc(x_244); -x_245 = lean_ctor_get(x_242, 0); -lean_inc(x_245); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - x_246 = x_242; -} else { - lean_dec_ref(x_242); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_243, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_243, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_243, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_243, 4); -lean_inc(x_250); -x_251 = lean_ctor_get(x_243, 5); -lean_inc(x_251); -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); - lean_ctor_release(x_243, 4); - lean_ctor_release(x_243, 5); - x_252 = x_243; -} else { - lean_dec_ref(x_243); - x_252 = lean_box(0); -} -x_253 = lean_ctor_get(x_244, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_244, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_244, 3); -lean_inc(x_255); -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_256 = x_244; -} else { - lean_dec_ref(x_244); - x_256 = lean_box(0); -} -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 4, 0); -} else { - x_257 = x_256; -} -lean_ctor_set(x_257, 0, x_253); -lean_ctor_set(x_257, 1, x_254); -lean_ctor_set(x_257, 2, x_227); -lean_ctor_set(x_257, 3, x_255); -if (lean_is_scalar(x_252)) { - x_258 = lean_alloc_ctor(0, 6, 0); -} else { - x_258 = x_252; -} -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_246)) { - x_259 = lean_alloc_ctor(0, 2, 0); -} else { - x_259 = x_246; -} -lean_ctor_set(x_259, 0, x_245); -lean_ctor_set(x_259, 1, x_258); -return x_259; -} -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; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_260 = lean_ctor_get(x_242, 1); -lean_inc(x_260); -x_261 = lean_ctor_get(x_260, 2); -lean_inc(x_261); -x_262 = lean_ctor_get(x_242, 0); -lean_inc(x_262); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - x_263 = x_242; -} else { - lean_dec_ref(x_242); - x_263 = lean_box(0); -} -x_264 = lean_ctor_get(x_260, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_260, 1); -lean_inc(x_265); -x_266 = lean_ctor_get(x_260, 3); -lean_inc(x_266); -x_267 = lean_ctor_get(x_260, 4); -lean_inc(x_267); -x_268 = lean_ctor_get(x_260, 5); -lean_inc(x_268); -if (lean_is_exclusive(x_260)) { - lean_ctor_release(x_260, 0); - lean_ctor_release(x_260, 1); - lean_ctor_release(x_260, 2); - lean_ctor_release(x_260, 3); - lean_ctor_release(x_260, 4); - lean_ctor_release(x_260, 5); - x_269 = x_260; -} else { - lean_dec_ref(x_260); - x_269 = lean_box(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); -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_273 = x_261; -} else { - lean_dec_ref(x_261); - 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_ctor_set(x_274, 0, x_270); -lean_ctor_set(x_274, 1, x_271); -lean_ctor_set(x_274, 2, x_227); -lean_ctor_set(x_274, 3, x_272); -if (lean_is_scalar(x_269)) { - x_275 = lean_alloc_ctor(0, 6, 0); -} else { - x_275 = x_269; -} -lean_ctor_set(x_275, 0, x_264); -lean_ctor_set(x_275, 1, x_265); -lean_ctor_set(x_275, 2, x_274); -lean_ctor_set(x_275, 3, x_266); -lean_ctor_set(x_275, 4, x_267); -lean_ctor_set(x_275, 5, x_268); -if (lean_is_scalar(x_263)) { - x_276 = lean_alloc_ctor(1, 2, 0); -} else { - x_276 = x_263; -} -lean_ctor_set(x_276, 0, x_262); -lean_ctor_set(x_276, 1, x_275); -return x_276; } } } default: { -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_32, 1); -lean_inc(x_277); +lean_object* x_243; lean_object* x_244; +x_243 = lean_ctor_get(x_32, 1); +lean_inc(x_243); lean_dec(x_32); lean_inc(x_6); -x_278 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_277); -if (lean_obj_tag(x_278) == 0) +x_244 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_243); +if (lean_obj_tag(x_244) == 0) { -lean_object* x_279; -x_279 = lean_ctor_get(x_278, 0); -lean_inc(x_279); -if (lean_obj_tag(x_279) == 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_280; lean_object* x_281; lean_object* x_282; +lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_dec(x_27); -x_280 = lean_ctor_get(x_278, 1); -lean_inc(x_280); -lean_dec(x_278); -x_281 = lean_unsigned_to_nat(1u); -x_282 = lean_nat_add(x_5, x_281); +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); lean_dec(x_5); -x_5 = x_282; -x_7 = x_280; +x_5 = x_248; +x_7 = x_246; goto _start; } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; uint8_t x_288; -x_284 = lean_ctor_get(x_278, 1); -lean_inc(x_284); -lean_dec(x_278); -x_285 = lean_ctor_get(x_279, 0); -lean_inc(x_285); -lean_dec(x_279); -x_286 = lean_unsigned_to_nat(1u); -x_287 = lean_nat_add(x_5, x_286); +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; +} else { + lean_dec_ref(x_244); + x_251 = 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_288 = !lean_is_exclusive(x_284); -if (x_288 == 0) +x_255 = !lean_is_exclusive(x_250); +if (x_255 == 0) { -lean_object* x_289; uint8_t x_290; -x_289 = lean_ctor_get(x_284, 2); -x_290 = !lean_is_exclusive(x_289); -if (x_290 == 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_291; lean_object* x_292; uint8_t x_293; -x_291 = lean_ctor_get(x_289, 2); -x_292 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_289, 2, x_292); -x_293 = !lean_is_exclusive(x_6); -if (x_293 == 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_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; -x_294 = lean_ctor_get(x_6, 2); -x_295 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_295, 0, x_285); -lean_ctor_set(x_295, 1, x_27); -x_296 = lean_array_push(x_294, x_295); -lean_ctor_set(x_6, 2, x_296); -x_297 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_287, x_6, x_284); -if (lean_obj_tag(x_297) == 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_298; lean_object* x_299; uint8_t x_300; -x_298 = lean_ctor_get(x_297, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_298, 2); -lean_inc(x_299); -x_300 = !lean_is_exclusive(x_297); -if (x_300 == 0) -{ -lean_object* x_301; uint8_t x_302; -x_301 = lean_ctor_get(x_297, 1); -lean_dec(x_301); -x_302 = !lean_is_exclusive(x_298); -if (x_302 == 0) -{ -lean_object* x_303; uint8_t x_304; -x_303 = lean_ctor_get(x_298, 2); -lean_dec(x_303); -x_304 = !lean_is_exclusive(x_299); -if (x_304 == 0) -{ -lean_object* x_305; -x_305 = lean_ctor_get(x_299, 2); -lean_dec(x_305); -lean_ctor_set(x_299, 2, x_291); -return x_297; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_306 = lean_ctor_get(x_299, 0); -x_307 = lean_ctor_get(x_299, 1); -x_308 = lean_ctor_get(x_299, 3); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_dec(x_299); -x_309 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_309, 0, x_306); -lean_ctor_set(x_309, 1, x_307); -lean_ctor_set(x_309, 2, x_291); -lean_ctor_set(x_309, 3, x_308); -lean_ctor_set(x_298, 2, x_309); -return x_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; lean_object* x_319; lean_object* x_320; -x_310 = lean_ctor_get(x_298, 0); -x_311 = lean_ctor_get(x_298, 1); -x_312 = lean_ctor_get(x_298, 3); -x_313 = lean_ctor_get(x_298, 4); -x_314 = lean_ctor_get(x_298, 5); -lean_inc(x_314); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_dec(x_298); -x_315 = lean_ctor_get(x_299, 0); -lean_inc(x_315); -x_316 = lean_ctor_get(x_299, 1); +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_299, 3); +x_317 = lean_ctor_get(x_315, 1); lean_inc(x_317); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - lean_ctor_release(x_299, 1); - lean_ctor_release(x_299, 2); - lean_ctor_release(x_299, 3); - x_318 = x_299; -} else { - lean_dec_ref(x_299); - x_318 = lean_box(0); +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; } -if (lean_is_scalar(x_318)) { - x_319 = lean_alloc_ctor(0, 4, 0); -} else { - x_319 = x_318; -} -lean_ctor_set(x_319, 0, x_315); -lean_ctor_set(x_319, 1, x_316); -lean_ctor_set(x_319, 2, x_291); -lean_ctor_set(x_319, 3, x_317); -x_320 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_320, 0, x_310); -lean_ctor_set(x_320, 1, x_311); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_312); -lean_ctor_set(x_320, 4, x_313); -lean_ctor_set(x_320, 5, x_314); -lean_ctor_set(x_297, 1, x_320); -return x_297; +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_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; -x_321 = lean_ctor_get(x_297, 0); -lean_inc(x_321); -lean_dec(x_297); -x_322 = lean_ctor_get(x_298, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_298, 1); -lean_inc(x_323); -x_324 = lean_ctor_get(x_298, 3); -lean_inc(x_324); -x_325 = lean_ctor_get(x_298, 4); -lean_inc(x_325); -x_326 = lean_ctor_get(x_298, 5); +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); -if (lean_is_exclusive(x_298)) { - lean_ctor_release(x_298, 0); - lean_ctor_release(x_298, 1); - lean_ctor_release(x_298, 2); - lean_ctor_release(x_298, 3); - lean_ctor_release(x_298, 4); - lean_ctor_release(x_298, 5); - x_327 = x_298; -} else { - lean_dec_ref(x_298); - x_327 = lean_box(0); -} -x_328 = lean_ctor_get(x_299, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_299, 1); -lean_inc(x_329); -x_330 = lean_ctor_get(x_299, 3); -lean_inc(x_330); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - lean_ctor_release(x_299, 1); - lean_ctor_release(x_299, 2); - lean_ctor_release(x_299, 3); - x_331 = x_299; -} else { - lean_dec_ref(x_299); - x_331 = lean_box(0); -} -if (lean_is_scalar(x_331)) { - x_332 = lean_alloc_ctor(0, 4, 0); -} else { - x_332 = x_331; -} -lean_ctor_set(x_332, 0, x_328); -lean_ctor_set(x_332, 1, x_329); -lean_ctor_set(x_332, 2, x_291); -lean_ctor_set(x_332, 3, x_330); -if (lean_is_scalar(x_327)) { - x_333 = lean_alloc_ctor(0, 6, 0); -} else { - x_333 = x_327; -} -lean_ctor_set(x_333, 0, x_322); -lean_ctor_set(x_333, 1, x_323); -lean_ctor_set(x_333, 2, x_332); -lean_ctor_set(x_333, 3, x_324); -lean_ctor_set(x_333, 4, x_325); -lean_ctor_set(x_333, 5, x_326); -x_334 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_334, 0, x_321); -lean_ctor_set(x_334, 1, x_333); -return x_334; -} -} -else -{ -lean_object* x_335; lean_object* x_336; uint8_t x_337; -x_335 = lean_ctor_get(x_297, 1); -lean_inc(x_335); -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = !lean_is_exclusive(x_297); -if (x_337 == 0) -{ -lean_object* x_338; uint8_t x_339; -x_338 = lean_ctor_get(x_297, 1); -lean_dec(x_338); -x_339 = !lean_is_exclusive(x_335); -if (x_339 == 0) -{ -lean_object* x_340; uint8_t x_341; -x_340 = lean_ctor_get(x_335, 2); -lean_dec(x_340); -x_341 = !lean_is_exclusive(x_336); -if (x_341 == 0) -{ -lean_object* x_342; -x_342 = lean_ctor_get(x_336, 2); -lean_dec(x_342); -lean_ctor_set(x_336, 2, x_291); -return x_297; -} -else -{ -lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; -x_343 = lean_ctor_get(x_336, 0); -x_344 = lean_ctor_get(x_336, 1); -x_345 = lean_ctor_get(x_336, 3); -lean_inc(x_345); -lean_inc(x_344); -lean_inc(x_343); -lean_dec(x_336); -x_346 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_291); -lean_ctor_set(x_346, 3, x_345); -lean_ctor_set(x_335, 2, x_346); -return x_297; -} -} -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; -x_347 = lean_ctor_get(x_335, 0); -x_348 = lean_ctor_get(x_335, 1); -x_349 = lean_ctor_get(x_335, 3); -x_350 = lean_ctor_get(x_335, 4); -x_351 = lean_ctor_get(x_335, 5); -lean_inc(x_351); -lean_inc(x_350); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); -lean_dec(x_335); -x_352 = lean_ctor_get(x_336, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_336, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_336, 3); -lean_inc(x_354); -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_355 = x_336; -} else { - lean_dec_ref(x_336); - x_355 = lean_box(0); -} -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_291); -lean_ctor_set(x_356, 3, x_354); -x_357 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_357, 0, x_347); -lean_ctor_set(x_357, 1, x_348); -lean_ctor_set(x_357, 2, x_356); -lean_ctor_set(x_357, 3, x_349); -lean_ctor_set(x_357, 4, x_350); -lean_ctor_set(x_357, 5, x_351); -lean_ctor_set(x_297, 1, x_357); -return x_297; -} -} -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; -x_358 = lean_ctor_get(x_297, 0); -lean_inc(x_358); -lean_dec(x_297); -x_359 = lean_ctor_get(x_335, 0); -lean_inc(x_359); -x_360 = lean_ctor_get(x_335, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_335, 3); -lean_inc(x_361); -x_362 = lean_ctor_get(x_335, 4); -lean_inc(x_362); -x_363 = lean_ctor_get(x_335, 5); -lean_inc(x_363); -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_364 = x_335; -} else { - lean_dec_ref(x_335); - x_364 = lean_box(0); -} -x_365 = lean_ctor_get(x_336, 0); -lean_inc(x_365); -x_366 = lean_ctor_get(x_336, 1); -lean_inc(x_366); -x_367 = lean_ctor_get(x_336, 3); -lean_inc(x_367); -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_368 = x_336; -} else { - lean_dec_ref(x_336); - x_368 = lean_box(0); -} -if (lean_is_scalar(x_368)) { - x_369 = lean_alloc_ctor(0, 4, 0); -} else { - x_369 = x_368; -} -lean_ctor_set(x_369, 0, x_365); -lean_ctor_set(x_369, 1, x_366); -lean_ctor_set(x_369, 2, x_291); -lean_ctor_set(x_369, 3, x_367); -if (lean_is_scalar(x_364)) { - x_370 = lean_alloc_ctor(0, 6, 0); -} else { - x_370 = x_364; -} -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); -x_371 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_371, 0, x_358); -lean_ctor_set(x_371, 1, x_370); -return x_371; -} -} -} -else -{ -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_372 = lean_ctor_get(x_6, 0); -x_373 = lean_ctor_get(x_6, 1); -x_374 = lean_ctor_get(x_6, 2); -x_375 = lean_ctor_get(x_6, 3); -x_376 = lean_ctor_get(x_6, 4); -lean_inc(x_376); -lean_inc(x_375); -lean_inc(x_374); -lean_inc(x_373); -lean_inc(x_372); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_inc(x_322); lean_dec(x_6); -x_377 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_377, 0, x_285); -lean_ctor_set(x_377, 1, x_27); -x_378 = lean_array_push(x_374, x_377); -x_379 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_379, 0, x_372); -lean_ctor_set(x_379, 1, x_373); -lean_ctor_set(x_379, 2, x_378); -lean_ctor_set(x_379, 3, x_375); -lean_ctor_set(x_379, 4, x_376); -x_380 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_287, x_379, x_284); -if (lean_obj_tag(x_380) == 0) +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_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_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_381 = lean_ctor_get(x_380, 1); -lean_inc(x_381); -x_382 = lean_ctor_get(x_381, 2); -lean_inc(x_382); -x_383 = lean_ctor_get(x_380, 0); -lean_inc(x_383); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - x_384 = x_380; -} else { - lean_dec_ref(x_380); - x_384 = lean_box(0); -} -x_385 = lean_ctor_get(x_381, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_381, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_381, 3); -lean_inc(x_387); -x_388 = lean_ctor_get(x_381, 4); -lean_inc(x_388); -x_389 = lean_ctor_get(x_381, 5); -lean_inc(x_389); -if (lean_is_exclusive(x_381)) { - lean_ctor_release(x_381, 0); - lean_ctor_release(x_381, 1); - lean_ctor_release(x_381, 2); - lean_ctor_release(x_381, 3); - lean_ctor_release(x_381, 4); - lean_ctor_release(x_381, 5); - x_390 = x_381; -} else { - lean_dec_ref(x_381); - x_390 = lean_box(0); -} -x_391 = lean_ctor_get(x_382, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_382, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_382, 3); -lean_inc(x_393); -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_394 = x_382; -} else { - lean_dec_ref(x_382); - x_394 = lean_box(0); -} -if (lean_is_scalar(x_394)) { - x_395 = lean_alloc_ctor(0, 4, 0); -} else { - x_395 = x_394; -} -lean_ctor_set(x_395, 0, x_391); -lean_ctor_set(x_395, 1, x_392); -lean_ctor_set(x_395, 2, x_291); -lean_ctor_set(x_395, 3, x_393); -if (lean_is_scalar(x_390)) { - x_396 = lean_alloc_ctor(0, 6, 0); -} else { - x_396 = x_390; -} -lean_ctor_set(x_396, 0, x_385); -lean_ctor_set(x_396, 1, x_386); -lean_ctor_set(x_396, 2, x_395); -lean_ctor_set(x_396, 3, x_387); -lean_ctor_set(x_396, 4, x_388); -lean_ctor_set(x_396, 5, x_389); -if (lean_is_scalar(x_384)) { - x_397 = lean_alloc_ctor(0, 2, 0); -} else { - x_397 = x_384; -} -lean_ctor_set(x_397, 0, x_383); -lean_ctor_set(x_397, 1, x_396); -return x_397; +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_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; lean_object* x_413; lean_object* x_414; -x_398 = lean_ctor_get(x_380, 1); -lean_inc(x_398); -x_399 = lean_ctor_get(x_398, 2); -lean_inc(x_399); -x_400 = lean_ctor_get(x_380, 0); -lean_inc(x_400); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - x_401 = x_380; -} else { - lean_dec_ref(x_380); - x_401 = lean_box(0); +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; } -x_402 = lean_ctor_get(x_398, 0); -lean_inc(x_402); -x_403 = lean_ctor_get(x_398, 1); -lean_inc(x_403); -x_404 = lean_ctor_get(x_398, 3); -lean_inc(x_404); -x_405 = lean_ctor_get(x_398, 4); -lean_inc(x_405); -x_406 = lean_ctor_get(x_398, 5); -lean_inc(x_406); -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_407 = x_398; -} else { - lean_dec_ref(x_398); - x_407 = lean_box(0); } -x_408 = lean_ctor_get(x_399, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_399, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_399, 3); -lean_inc(x_410); -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_411 = x_399; +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); +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); +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 { - lean_dec_ref(x_399); - x_411 = lean_box(0); + x_267 = x_251; + lean_ctor_set_tag(x_267, 1); } -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_267, 0, x_262); +lean_ctor_set(x_267, 1, x_260); +return x_267; +} +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_412 = x_411; + x_272 = x_251; + lean_ctor_set_tag(x_272, 1); } -lean_ctor_set(x_412, 0, x_408); -lean_ctor_set(x_412, 1, x_409); -lean_ctor_set(x_412, 2, x_291); -lean_ctor_set(x_412, 3, x_410); -if (lean_is_scalar(x_407)) { - x_413 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_272, 0, x_262); +lean_ctor_set(x_272, 1, x_260); +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; 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_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 { - x_413 = x_407; + lean_dec_ref(x_261); + x_281 = lean_box(0); } -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_401)) { - x_414 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_281)) { + x_282 = lean_alloc_ctor(0, 4, 0); } else { - x_414 = x_401; + x_282 = x_281; +} +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, 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); +} else { + x_284 = x_251; + lean_ctor_set_tag(x_284, 1); +} +lean_ctor_set(x_284, 0, x_262); +lean_ctor_set(x_284, 1, x_283); +return x_284; +} +} +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_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_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); +} else { + x_296 = x_251; +} +lean_ctor_set(x_296, 0, x_286); +lean_ctor_set(x_296, 1, x_260); +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_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); +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; +} else { + lean_dec_ref(x_285); + x_305 = lean_box(0); +} +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); +} else { + x_306 = x_305; +} +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); +} else { + x_308 = x_251; +} +lean_ctor_set(x_308, 0, x_286); +lean_ctor_set(x_308, 1, x_307); +return x_308; } -lean_ctor_set(x_414, 0, x_400); -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; lean_object* x_430; -x_415 = lean_ctor_get(x_289, 0); -x_416 = lean_ctor_get(x_289, 1); -x_417 = lean_ctor_get(x_289, 2); -x_418 = lean_ctor_get(x_289, 3); -lean_inc(x_418); -lean_inc(x_417); -lean_inc(x_416); -lean_inc(x_415); -lean_dec(x_289); -x_419 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_420 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_420, 0, x_415); -lean_ctor_set(x_420, 1, x_416); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_418); -lean_ctor_set(x_284, 2, x_420); -x_421 = lean_ctor_get(x_6, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_6, 1); -lean_inc(x_422); -x_423 = lean_ctor_get(x_6, 2); -lean_inc(x_423); -x_424 = lean_ctor_get(x_6, 3); -lean_inc(x_424); -x_425 = lean_ctor_get(x_6, 4); -lean_inc(x_425); +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); 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_426 = x_6; + x_381 = x_6; } else { lean_dec_ref(x_6); - x_426 = lean_box(0); + x_381 = lean_box(0); } -x_427 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_427, 0, x_285); -lean_ctor_set(x_427, 1, x_27); -x_428 = lean_array_push(x_423, x_427); -if (lean_is_scalar(x_426)) { - x_429 = lean_alloc_ctor(0, 5, 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); } else { - x_429 = x_426; + x_384 = x_381; } -lean_ctor_set(x_429, 0, x_421); -lean_ctor_set(x_429, 1, x_422); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_424); -lean_ctor_set(x_429, 4, x_425); -x_430 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_287, x_429, x_284); -if (lean_obj_tag(x_430) == 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___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_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; lean_object* x_447; -x_431 = lean_ctor_get(x_430, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_431, 2); -lean_inc(x_432); -x_433 = lean_ctor_get(x_430, 0); -lean_inc(x_433); -if (lean_is_exclusive(x_430)) { - lean_ctor_release(x_430, 0); - lean_ctor_release(x_430, 1); - x_434 = x_430; -} else { - lean_dec_ref(x_430); - x_434 = lean_box(0); -} -x_435 = lean_ctor_get(x_431, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_431, 1); -lean_inc(x_436); -x_437 = lean_ctor_get(x_431, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_431, 4); -lean_inc(x_438); -x_439 = lean_ctor_get(x_431, 5); -lean_inc(x_439); -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); - lean_ctor_release(x_431, 5); - x_440 = x_431; -} else { - lean_dec_ref(x_431); - x_440 = lean_box(0); -} -x_441 = lean_ctor_get(x_432, 0); -lean_inc(x_441); -x_442 = lean_ctor_get(x_432, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_432, 3); -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); - 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, 4, 0); -} else { - x_445 = x_444; -} -lean_ctor_set(x_445, 0, x_441); -lean_ctor_set(x_445, 1, x_442); -lean_ctor_set(x_445, 2, x_417); -lean_ctor_set(x_445, 3, x_443); -if (lean_is_scalar(x_440)) { - x_446 = lean_alloc_ctor(0, 6, 0); -} else { - x_446 = x_440; -} -lean_ctor_set(x_446, 0, x_435); -lean_ctor_set(x_446, 1, x_436); -lean_ctor_set(x_446, 2, x_445); -lean_ctor_set(x_446, 3, x_437); -lean_ctor_set(x_446, 4, x_438); -lean_ctor_set(x_446, 5, x_439); -if (lean_is_scalar(x_434)) { - x_447 = lean_alloc_ctor(0, 2, 0); -} else { - x_447 = x_434; -} -lean_ctor_set(x_447, 0, x_433); -lean_ctor_set(x_447, 1, x_446); -return x_447; +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; } else { -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; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; -x_448 = lean_ctor_get(x_430, 1); -lean_inc(x_448); -x_449 = lean_ctor_get(x_448, 2); -lean_inc(x_449); -x_450 = lean_ctor_get(x_430, 0); -lean_inc(x_450); -if (lean_is_exclusive(x_430)) { - lean_ctor_release(x_430, 0); - lean_ctor_release(x_430, 1); - x_451 = x_430; -} else { - lean_dec_ref(x_430); - x_451 = lean_box(0); +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; } +block_373: +{ +if (lean_obj_tag(x_341) == 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_inc(x_358); +x_359 = lean_ctor_get(x_341, 0); +lean_inc(x_359); +lean_dec(x_341); +x_360 = lean_ctor_get(x_342, 0); +lean_inc(x_360); +x_361 = lean_ctor_get(x_342, 1); +lean_inc(x_361); +x_362 = lean_ctor_get(x_342, 3); +lean_inc(x_362); +x_363 = lean_ctor_get(x_342, 4); +lean_inc(x_363); +x_364 = lean_ctor_get(x_342, 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; +} else { + lean_dec_ref(x_342); + x_365 = lean_box(0); +} +x_366 = lean_ctor_get(x_358, 0); +lean_inc(x_366); +x_367 = lean_ctor_get(x_358, 1); +lean_inc(x_367); +x_368 = lean_ctor_get(x_358, 3); +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); + x_369 = x_358; +} else { + lean_dec_ref(x_358); + x_369 = lean_box(0); +} +if (lean_is_scalar(x_369)) { + x_370 = lean_alloc_ctor(0, 4, 0); +} else { + x_370 = x_369; +} +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); +if (lean_is_scalar(x_365)) { + x_371 = lean_alloc_ctor(0, 6, 0); +} else { + x_371 = 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); +} else { + x_372 = x_251; +} +lean_ctor_set(x_372, 0, x_359); +lean_ctor_set(x_372, 1, x_371); +return x_372; +} +} +} +} +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; +} else { + lean_dec_ref(x_392); + x_402 = 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); +} else { + x_437 = x_402; +} +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); +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; +} else { + lean_dec_ref(x_6); + x_444 = 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); +} else { + x_447 = x_444; +} +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_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; +} +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); -x_454 = lean_ctor_get(x_448, 3); -lean_inc(x_454); -x_455 = lean_ctor_get(x_448, 4); -lean_inc(x_455); -x_456 = lean_ctor_get(x_448, 5); -lean_inc(x_456); -if (lean_is_exclusive(x_448)) { - lean_ctor_release(x_448, 0); - lean_ctor_release(x_448, 1); - lean_ctor_release(x_448, 2); - lean_ctor_release(x_448, 3); - lean_ctor_release(x_448, 4); - lean_ctor_release(x_448, 5); - x_457 = x_448; +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; +} +block_435: +{ +if (lean_obj_tag(x_403) == 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_448); - x_457 = lean_box(0); + lean_dec_ref(x_404); + x_412 = lean_box(0); } -x_458 = lean_ctor_get(x_449, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_449, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_449, 3); -lean_inc(x_460); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - lean_ctor_release(x_449, 2); - lean_ctor_release(x_449, 3); - x_461 = x_449; +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_449); - x_461 = lean_box(0); + lean_dec_ref(x_405); + x_416 = lean_box(0); } -if (lean_is_scalar(x_461)) { - x_462 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_416)) { + x_417 = lean_alloc_ctor(0, 4, 0); } else { - x_462 = x_461; + x_417 = x_416; } -lean_ctor_set(x_462, 0, x_458); -lean_ctor_set(x_462, 1, x_459); -lean_ctor_set(x_462, 2, x_417); -lean_ctor_set(x_462, 3, x_460); -if (lean_is_scalar(x_457)) { - x_463 = lean_alloc_ctor(0, 6, 0); +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_463 = x_457; + x_418 = x_412; } -lean_ctor_set(x_463, 0, x_452); -lean_ctor_set(x_463, 1, x_453); -lean_ctor_set(x_463, 2, x_462); -lean_ctor_set(x_463, 3, x_454); -lean_ctor_set(x_463, 4, x_455); -lean_ctor_set(x_463, 5, x_456); -if (lean_is_scalar(x_451)) { - x_464 = lean_alloc_ctor(1, 2, 0); +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_464 = x_451; -} -lean_ctor_set(x_464, 0, x_450); -lean_ctor_set(x_464, 1, x_463); -return x_464; -} + 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_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; -x_465 = lean_ctor_get(x_284, 2); -x_466 = lean_ctor_get(x_284, 0); -x_467 = lean_ctor_get(x_284, 1); -x_468 = lean_ctor_get(x_284, 3); -x_469 = lean_ctor_get(x_284, 4); -x_470 = lean_ctor_get(x_284, 5); -lean_inc(x_470); -lean_inc(x_469); -lean_inc(x_468); -lean_inc(x_465); -lean_inc(x_467); -lean_inc(x_466); -lean_dec(x_284); -x_471 = lean_ctor_get(x_465, 0); -lean_inc(x_471); -x_472 = lean_ctor_get(x_465, 1); -lean_inc(x_472); -x_473 = lean_ctor_get(x_465, 2); -lean_inc(x_473); -x_474 = lean_ctor_get(x_465, 3); -lean_inc(x_474); -if (lean_is_exclusive(x_465)) { - lean_ctor_release(x_465, 0); - lean_ctor_release(x_465, 1); - lean_ctor_release(x_465, 2); - lean_ctor_release(x_465, 3); - x_475 = x_465; +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_inc(x_423); +x_424 = lean_ctor_get(x_404, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_404, 4); +lean_inc(x_425); +x_426 = lean_ctor_get(x_404, 5); +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_465); - x_475 = lean_box(0); + lean_dec_ref(x_404); + x_427 = lean_box(0); } -x_476 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_475)) { - x_477 = 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); +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; } else { - x_477 = x_475; + lean_dec_ref(x_420); + x_431 = lean_box(0); } -lean_ctor_set(x_477, 0, x_471); -lean_ctor_set(x_477, 1, x_472); -lean_ctor_set(x_477, 2, x_476); -lean_ctor_set(x_477, 3, x_474); -x_478 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_478, 0, x_466); -lean_ctor_set(x_478, 1, x_467); -lean_ctor_set(x_478, 2, x_477); -lean_ctor_set(x_478, 3, x_468); -lean_ctor_set(x_478, 4, x_469); -lean_ctor_set(x_478, 5, x_470); -x_479 = lean_ctor_get(x_6, 0); -lean_inc(x_479); -x_480 = lean_ctor_get(x_6, 1); -lean_inc(x_480); -x_481 = lean_ctor_get(x_6, 2); -lean_inc(x_481); -x_482 = lean_ctor_get(x_6, 3); -lean_inc(x_482); -x_483 = lean_ctor_get(x_6, 4); -lean_inc(x_483); -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_484 = x_6; +if (lean_is_scalar(x_431)) { + x_432 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_6); - x_484 = lean_box(0); + x_432 = x_431; } -x_485 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_485, 0, x_285); -lean_ctor_set(x_485, 1, x_27); -x_486 = lean_array_push(x_481, x_485); -if (lean_is_scalar(x_484)) { - x_487 = lean_alloc_ctor(0, 5, 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); } else { - x_487 = x_484; + x_433 = x_427; } -lean_ctor_set(x_487, 0, x_479); -lean_ctor_set(x_487, 1, x_480); -lean_ctor_set(x_487, 2, x_486); -lean_ctor_set(x_487, 3, x_482); -lean_ctor_set(x_487, 4, x_483); -x_488 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_287, x_487, x_478); -if (lean_obj_tag(x_488) == 0) -{ -lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; -x_489 = lean_ctor_get(x_488, 1); -lean_inc(x_489); -x_490 = lean_ctor_get(x_489, 2); -lean_inc(x_490); -x_491 = lean_ctor_get(x_488, 0); -lean_inc(x_491); -if (lean_is_exclusive(x_488)) { - lean_ctor_release(x_488, 0); - lean_ctor_release(x_488, 1); - x_492 = x_488; +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); } else { - lean_dec_ref(x_488); - x_492 = lean_box(0); + x_434 = x_251; } -x_493 = lean_ctor_get(x_489, 0); -lean_inc(x_493); -x_494 = lean_ctor_get(x_489, 1); -lean_inc(x_494); -x_495 = lean_ctor_get(x_489, 3); -lean_inc(x_495); -x_496 = lean_ctor_get(x_489, 4); -lean_inc(x_496); -x_497 = lean_ctor_get(x_489, 5); -lean_inc(x_497); -if (lean_is_exclusive(x_489)) { - lean_ctor_release(x_489, 0); - lean_ctor_release(x_489, 1); - lean_ctor_release(x_489, 2); - lean_ctor_release(x_489, 3); - lean_ctor_release(x_489, 4); - lean_ctor_release(x_489, 5); - x_498 = x_489; -} else { - lean_dec_ref(x_489); - x_498 = lean_box(0); +lean_ctor_set(x_434, 0, x_421); +lean_ctor_set(x_434, 1, x_433); +return x_434; } -x_499 = lean_ctor_get(x_490, 0); -lean_inc(x_499); -x_500 = lean_ctor_get(x_490, 1); -lean_inc(x_500); -x_501 = lean_ctor_get(x_490, 3); -lean_inc(x_501); -if (lean_is_exclusive(x_490)) { - lean_ctor_release(x_490, 0); - lean_ctor_release(x_490, 1); - lean_ctor_release(x_490, 2); - lean_ctor_release(x_490, 3); - x_502 = x_490; -} else { - lean_dec_ref(x_490); - x_502 = lean_box(0); -} -if (lean_is_scalar(x_502)) { - x_503 = lean_alloc_ctor(0, 4, 0); -} else { - x_503 = x_502; -} -lean_ctor_set(x_503, 0, x_499); -lean_ctor_set(x_503, 1, x_500); -lean_ctor_set(x_503, 2, x_473); -lean_ctor_set(x_503, 3, x_501); -if (lean_is_scalar(x_498)) { - x_504 = lean_alloc_ctor(0, 6, 0); -} else { - x_504 = x_498; -} -lean_ctor_set(x_504, 0, x_493); -lean_ctor_set(x_504, 1, x_494); -lean_ctor_set(x_504, 2, x_503); -lean_ctor_set(x_504, 3, x_495); -lean_ctor_set(x_504, 4, x_496); -lean_ctor_set(x_504, 5, x_497); -if (lean_is_scalar(x_492)) { - x_505 = lean_alloc_ctor(0, 2, 0); -} else { - x_505 = x_492; -} -lean_ctor_set(x_505, 0, x_491); -lean_ctor_set(x_505, 1, x_504); -return x_505; -} -else -{ -lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_506 = lean_ctor_get(x_488, 1); -lean_inc(x_506); -x_507 = lean_ctor_get(x_506, 2); -lean_inc(x_507); -x_508 = lean_ctor_get(x_488, 0); -lean_inc(x_508); -if (lean_is_exclusive(x_488)) { - lean_ctor_release(x_488, 0); - lean_ctor_release(x_488, 1); - x_509 = x_488; -} else { - lean_dec_ref(x_488); - x_509 = lean_box(0); -} -x_510 = lean_ctor_get(x_506, 0); -lean_inc(x_510); -x_511 = lean_ctor_get(x_506, 1); -lean_inc(x_511); -x_512 = lean_ctor_get(x_506, 3); -lean_inc(x_512); -x_513 = lean_ctor_get(x_506, 4); -lean_inc(x_513); -x_514 = lean_ctor_get(x_506, 5); -lean_inc(x_514); -if (lean_is_exclusive(x_506)) { - lean_ctor_release(x_506, 0); - lean_ctor_release(x_506, 1); - lean_ctor_release(x_506, 2); - lean_ctor_release(x_506, 3); - lean_ctor_release(x_506, 4); - lean_ctor_release(x_506, 5); - x_515 = x_506; -} else { - lean_dec_ref(x_506); - x_515 = lean_box(0); -} -x_516 = lean_ctor_get(x_507, 0); -lean_inc(x_516); -x_517 = lean_ctor_get(x_507, 1); -lean_inc(x_517); -x_518 = lean_ctor_get(x_507, 3); -lean_inc(x_518); -if (lean_is_exclusive(x_507)) { - lean_ctor_release(x_507, 0); - lean_ctor_release(x_507, 1); - lean_ctor_release(x_507, 2); - lean_ctor_release(x_507, 3); - x_519 = x_507; -} else { - lean_dec_ref(x_507); - x_519 = lean_box(0); -} -if (lean_is_scalar(x_519)) { - x_520 = lean_alloc_ctor(0, 4, 0); -} else { - x_520 = x_519; -} -lean_ctor_set(x_520, 0, x_516); -lean_ctor_set(x_520, 1, x_517); -lean_ctor_set(x_520, 2, x_473); -lean_ctor_set(x_520, 3, x_518); -if (lean_is_scalar(x_515)) { - x_521 = lean_alloc_ctor(0, 6, 0); -} else { - x_521 = x_515; -} -lean_ctor_set(x_521, 0, x_510); -lean_ctor_set(x_521, 1, x_511); -lean_ctor_set(x_521, 2, x_520); -lean_ctor_set(x_521, 3, x_512); -lean_ctor_set(x_521, 4, x_513); -lean_ctor_set(x_521, 5, x_514); -if (lean_is_scalar(x_509)) { - x_522 = lean_alloc_ctor(1, 2, 0); -} else { - x_522 = x_509; -} -lean_ctor_set(x_522, 0, x_508); -lean_ctor_set(x_522, 1, x_521); -return x_522; } } } } else { -uint8_t x_523; +uint8_t x_455; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_523 = !lean_is_exclusive(x_278); -if (x_523 == 0) +x_455 = !lean_is_exclusive(x_244); +if (x_455 == 0) { -return x_278; +return x_244; } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; -x_524 = lean_ctor_get(x_278, 0); -x_525 = lean_ctor_get(x_278, 1); -lean_inc(x_525); -lean_inc(x_524); -lean_dec(x_278); -x_526 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_526, 0, x_524); -lean_ctor_set(x_526, 1, x_525); -return x_526; +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; } } } @@ -9593,56 +8507,56 @@ return x_526; } else { -uint8_t x_527; +uint8_t x_459; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_527 = !lean_is_exclusive(x_32); -if (x_527 == 0) +x_459 = !lean_is_exclusive(x_32); +if (x_459 == 0) { return x_32; } else { -lean_object* x_528; lean_object* x_529; lean_object* x_530; -x_528 = lean_ctor_get(x_32, 0); -x_529 = lean_ctor_get(x_32, 1); -lean_inc(x_529); -lean_inc(x_528); +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_dec(x_32); -x_530 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_530, 0, x_528); -lean_ctor_set(x_530, 1, x_529); -return x_530; +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; } } } else { -uint8_t x_531; +uint8_t x_463; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_531 = !lean_is_exclusive(x_28); -if (x_531 == 0) +x_463 = !lean_is_exclusive(x_28); +if (x_463 == 0) { return x_28; } else { -lean_object* x_532; lean_object* x_533; lean_object* x_534; -x_532 = lean_ctor_get(x_28, 0); -x_533 = lean_ctor_get(x_28, 1); -lean_inc(x_533); -lean_inc(x_532); +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_dec(x_28); -x_534 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_534, 0, x_532); -lean_ctor_set(x_534, 1, x_533); -return x_534; +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; } } } diff --git a/stage0/stdlib/Lean/Meta/InferType.c b/stage0/stdlib/Lean/Meta/InferType.c index f6dc9a54af..702126e85e 100644 --- a/stage0/stdlib/Lean/Meta/InferType.c +++ b/stage0/stdlib/Lean/Meta/InferType.c @@ -19,14 +19,12 @@ lean_object* l_Lean_Level_normalize___main(lean_object*); uint8_t l___private_Lean_Meta_InferType_11__isAlwaysZero(lean_object*); lean_object* l___private_Lean_Meta_InferType_5__inferLambdaType(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkSort(lean_object*); -lean_object* l_Lean_Meta_isTypeFormerAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); lean_object* l___private_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_12__isArrowProp___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_16__isArrowType(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Nat_foldMAux___main___at___private_Lean_Meta_InferType_3__inferProjType___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_4__inferForallType___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeFormerAux(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkForall(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_13__isPropQuickApp(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_11__isAlwaysZero___main___boxed(lean_object*); @@ -83,6 +81,7 @@ lean_object* l___private_Lean_Meta_InferType_8__inferFVarType(lean_object*, lean lean_object* l___private_Lean_Meta_InferType_4__inferForallType___closed__1; lean_object* l_Lean_Meta_inferTypeImpl(lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_findAtAux___main___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeFormerType___main(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_9__checkInferTypeCache(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1___boxed(lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_findAux___main___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__2___boxed(lean_object*, lean_object*, lean_object*); @@ -92,6 +91,7 @@ lean_object* l_Lean_Meta_isProof(lean_object*, lean_object*, lean_object*); size_t l_USize_mul(size_t, size_t); lean_object* l_Lean_Meta_setInferTypeRef___closed__1; lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeFormerType(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_Std_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); @@ -124,7 +124,6 @@ lean_object* l___private_Lean_Meta_InferType_7__inferMVarType___boxed(lean_objec lean_object* l_Nat_foldMAux___main___at___private_Lean_Meta_InferType_1__inferAppType___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_12__isArrowProp(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeFormerAux___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasLooseBVars(lean_object*); @@ -137,6 +136,7 @@ lean_object* l___private_Lean_Meta_InferType_13__isPropQuickApp___main(lean_obje lean_object* l_Lean_Meta_mkFreshLevelMVar___rarg(lean_object*); extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; lean_object* l_Lean_Meta_isReadOnlyOrSyntheticOpaqueExprMVar(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeFormerType___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_2__inferConstType___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_find(lean_object*, lean_object*); @@ -149,7 +149,7 @@ lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_15__isProofQuickApp___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Nat_foldMAux___main___at___private_Lean_Meta_InferType_3__inferProjType___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_InferType_1__inferAppType(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeFormerAux___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeFormerType___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkConst(lean_object*, lean_object*); lean_object* l_Lean_Meta_isType(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__7(size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -7698,16 +7698,16 @@ return x_56; } } } -lean_object* l_Lean_Meta_isTypeFormerAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isTypeFormerType___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_6; x_5 = lean_expr_instantiate1(x_1, x_2); -x_6 = l_Lean_Meta_isTypeFormerAux___main(x_5, x_3, x_4); +x_6 = l_Lean_Meta_isTypeFormerType___main(x_5, x_3, x_4); return x_6; } } -lean_object* l_Lean_Meta_isTypeFormerAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Meta_isTypeFormerType___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; @@ -7764,7 +7764,7 @@ lean_inc(x_17); x_18 = lean_ctor_get_uint64(x_5, sizeof(void*)*3); lean_dec(x_5); x_19 = (uint8_t)((x_18 << 24) >> 61); -x_20 = lean_alloc_closure((void*)(l_Lean_Meta_isTypeFormerAux___main___lambda__1___boxed), 4, 1); +x_20 = lean_alloc_closure((void*)(l_Lean_Meta_isTypeFormerType___main___lambda__1___boxed), 4, 1); lean_closure_set(x_20, 0, x_17); x_21 = l_Lean_Meta_withLocalDecl___rarg(x_15, x_16, x_19, x_20, x_2, x_14); return x_21; @@ -7826,21 +7826,21 @@ return x_33; } } } -lean_object* l_Lean_Meta_isTypeFormerAux___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isTypeFormerType___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l_Lean_Meta_isTypeFormerAux___main___lambda__1(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Meta_isTypeFormerType___main___lambda__1(x_1, x_2, x_3, x_4); lean_dec(x_2); lean_dec(x_1); return x_5; } } -lean_object* l_Lean_Meta_isTypeFormerAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Meta_isTypeFormerType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_isTypeFormerAux___main(x_1, x_2, x_3); +x_4 = l_Lean_Meta_isTypeFormerType___main(x_1, x_2, x_3); return x_4; } } @@ -7858,7 +7858,7 @@ lean_inc(x_5); x_6 = lean_ctor_get(x_4, 1); lean_inc(x_6); lean_dec(x_4); -x_7 = l_Lean_Meta_isTypeFormerAux___main(x_5, x_2, x_6); +x_7 = l_Lean_Meta_isTypeFormerType___main(x_5, x_2, x_6); return x_7; } else diff --git a/stage0/stdlib/Lean/Meta/LevelDefEq.c b/stage0/stdlib/Lean/Meta/LevelDefEq.c index f80fd81731..4a3d009b0d 100644 --- a/stage0/stdlib/Lean/Meta/LevelDefEq.c +++ b/stage0/stdlib/Lean/Meta/LevelDefEq.c @@ -44,6 +44,7 @@ lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_ lean_object* l___private_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3; lean_object* l_Lean_Meta_isLevelDefEq___closed__3; lean_object* l___private_Lean_Meta_LevelDefEq_12__processPostponed(lean_object*, lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* l_Lean_Meta_isExprDefEq___closed__1; lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__5; @@ -139,7 +140,6 @@ lean_object* l_Lean_Meta_isLevelDefEq___closed__2; lean_object* l___private_Lean_Meta_LevelDefEq_4__mkMaxArgsDiff___main___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_LevelDefEq_1__decAux_x3f(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_restore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l_Lean_Meta_commitWhen___at_Lean_Meta_isLevelDefEq___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_LevelDefEq_1__decAux_x3f___main(lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentArray_foldlMAux___main___at___private_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -1520,7 +1520,7 @@ lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_isLevelDefEqAux___main___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; @@ -11166,7 +11166,7 @@ lean_object* _init_l_Lean_Meta_isExprDefEq___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_isExprDefEq___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; diff --git a/stage0/stdlib/Lean/Meta/SynthInstance.c b/stage0/stdlib/Lean/Meta/SynthInstance.c index 9677e87c4e..b982fe67d3 100644 --- a/stage0/stdlib/Lean/Meta/SynthInstance.c +++ b/stage0/stdlib/Lean/Meta/SynthInstance.c @@ -78,6 +78,7 @@ lean_object* l_Lean_Meta_SynthInstance_MkTableKey_normExpr___main(lean_object*, lean_object* l_Lean_Meta_maxStepsOption(lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Meta_SynthInstance_findEntry_x3f___spec__1___boxed(lean_object*, lean_object*); lean_object* lean_expr_instantiate1(lean_object*, lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__3; lean_object* lean_array_push(lean_object*, lean_object*); lean_object* l_Lean_Meta_SynthInstance_getEntry___closed__3; @@ -140,7 +141,7 @@ lean_object* l_Lean_Meta_abstractMVars(lean_object*, lean_object*, lean_object*) lean_object* l_Lean_Meta_SynthInstance_synth___main___closed__6; lean_object* l_Lean_Meta_SynthInstance_getTraceState(lean_object*); lean_object* l_Lean_Meta_SynthInstance_tryResolve(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Lean_Meta_SynthInstance_getSubgoals(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_List_mapM___main___at_Lean_Meta_SynthInstance_getInstances___spec__1(lean_object*, lean_object*, lean_object*); @@ -330,7 +331,7 @@ lean_object* lean_mk_array(lean_object*, lean_object*); lean_object* l_Lean_Meta_synthInstance_x3f___closed__1; lean_object* l_Lean_Meta_maxStepsOption___closed__1; lean_object* l_Std_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(lean_object*, lean_object*); -lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_SynthInstance_tryResolveCore(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_AssocList_contains___main___at_Lean_Meta_SynthInstance_newSubgoal___spec__2___boxed(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_SynthInstance_4__preprocessArgs___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -349,7 +350,6 @@ lean_object* l_Lean_Meta_SynthInstance_liftMeta___rarg(lean_object*, lean_object lean_object* l_Lean_Meta_SynthInstance_MkTableKey_normLevel___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_TagAttribute_Inhabited___closed__3; extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l_Lean_Meta_SynthInstance_consume(lean_object*, lean_object*, lean_object*); lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); @@ -372,6 +372,7 @@ lean_object* l_Lean_Meta_SynthInstance_tracer___closed__2; lean_object* l_Lean_mkConst(lean_object*, lean_object*); lean_object* l_Lean_Meta_SynthInstance_GeneratorNode_inhabited___closed__1; lean_object* l_Lean_Meta_SynthInstance_MkTableKey_normExpr(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_SynthInstance_tryAnswer___closed__1; lean_object* l_Lean_Meta_SynthInstance_main___closed__2; lean_object* l_Std_HashMapImp_expand___at_Lean_Meta_SynthInstance_MkTableKey_normExpr___main___spec__5(lean_object*, lean_object*); lean_object* l_Lean_Meta_SynthInstance_tracer___lambda__1(lean_object*, lean_object*, lean_object*); @@ -2682,41 +2683,69 @@ x_6 = lean_ctor_get(x_4, 0); x_7 = !lean_is_exclusive(x_6); if (x_7 == 0) { -lean_object* x_8; lean_object* x_9; +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_66; x_8 = lean_ctor_get(x_6, 1); lean_ctor_set(x_6, 1, x_1); -x_9 = lean_apply_2(x_2, x_3, x_4); -if (lean_obj_tag(x_9) == 0) +x_66 = lean_apply_2(x_2, x_3, x_4); +if (lean_obj_tag(x_66) == 0) { -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 1); -lean_inc(x_10); -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = !lean_is_exclusive(x_9); -if (x_12 == 0) -{ -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_9, 1); -lean_dec(x_13); -x_14 = !lean_is_exclusive(x_10); -if (x_14 == 0) -{ -lean_object* x_15; uint8_t x_16; -x_15 = lean_ctor_get(x_10, 0); -lean_dec(x_15); -x_16 = !lean_is_exclusive(x_11); -if (x_16 == 0) -{ -lean_object* x_17; -x_17 = lean_ctor_get(x_11, 1); -lean_dec(x_17); -lean_ctor_set(x_11, 1, x_8); -return x_9; +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_9 = x_69; +x_10 = x_68; +goto block_65; } 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_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_inc(x_71); +lean_dec(x_66); +x_72 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_72, 0, x_70); +x_9 = x_72; +x_10 = x_71; +goto block_65; +} +block_65: +{ +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_9, 0); +lean_inc(x_12); +lean_dec(x_9); +x_13 = !lean_is_exclusive(x_10); +if (x_13 == 0) +{ +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_10, 0); +lean_dec(x_14); +x_15 = !lean_is_exclusive(x_11); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_11, 1); +lean_dec(x_16); +lean_ctor_set(x_11, 1, x_8); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_12); +lean_ctor_set(x_17, 1, x_10); +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; x_18 = lean_ctor_get(x_11, 0); x_19 = lean_ctor_get(x_11, 2); x_20 = lean_ctor_get(x_11, 3); @@ -2736,31 +2765,34 @@ lean_ctor_set(x_23, 3, x_20); lean_ctor_set(x_23, 4, x_21); lean_ctor_set(x_23, 5, x_22); lean_ctor_set(x_10, 0, x_23); -return x_9; +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_12); +lean_ctor_set(x_24, 1, x_10); +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_10, 1); -x_25 = lean_ctor_get(x_10, 2); -x_26 = lean_ctor_get(x_10, 3); -x_27 = lean_ctor_get(x_10, 4); +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_10, 1); +x_26 = lean_ctor_get(x_10, 2); +x_27 = lean_ctor_get(x_10, 3); +x_28 = lean_ctor_get(x_10, 4); +lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); lean_dec(x_10); -x_28 = lean_ctor_get(x_11, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_11, 2); +x_29 = lean_ctor_get(x_11, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_11, 3); +x_30 = lean_ctor_get(x_11, 2); lean_inc(x_30); -x_31 = lean_ctor_get(x_11, 4); +x_31 = lean_ctor_get(x_11, 3); lean_inc(x_31); -x_32 = lean_ctor_get(x_11, 5); +x_32 = lean_ctor_get(x_11, 4); lean_inc(x_32); +x_33 = lean_ctor_get(x_11, 5); +lean_inc(x_33); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); @@ -2768,518 +2800,478 @@ 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_33 = x_11; + x_34 = x_11; } else { lean_dec_ref(x_11); - x_33 = lean_box(0); + x_34 = lean_box(0); } -if (lean_is_scalar(x_33)) { - x_34 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 6, 0); } else { - x_34 = x_33; + x_35 = x_34; } -lean_ctor_set(x_34, 0, x_28); -lean_ctor_set(x_34, 1, x_8); -lean_ctor_set(x_34, 2, x_29); -lean_ctor_set(x_34, 3, x_30); -lean_ctor_set(x_34, 4, x_31); -lean_ctor_set(x_34, 5, x_32); -x_35 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_35, 0, x_34); -lean_ctor_set(x_35, 1, x_24); -lean_ctor_set(x_35, 2, x_25); -lean_ctor_set(x_35, 3, x_26); -lean_ctor_set(x_35, 4, x_27); -lean_ctor_set(x_9, 1, x_35); -return x_9; +lean_ctor_set(x_35, 0, x_29); +lean_ctor_set(x_35, 1, x_8); +lean_ctor_set(x_35, 2, x_30); +lean_ctor_set(x_35, 3, x_31); +lean_ctor_set(x_35, 4, x_32); +lean_ctor_set(x_35, 5, x_33); +x_36 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_25); +lean_ctor_set(x_36, 2, x_26); +lean_ctor_set(x_36, 3, x_27); +lean_ctor_set(x_36, 4, x_28); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_12); +lean_ctor_set(x_37, 1, x_36); +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; -x_36 = lean_ctor_get(x_9, 0); -lean_inc(x_36); -lean_dec(x_9); -x_37 = lean_ctor_get(x_10, 1); -lean_inc(x_37); -x_38 = lean_ctor_get(x_10, 2); +lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_38 = lean_ctor_get(x_10, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_10, 3); +x_39 = lean_ctor_get(x_9, 0); lean_inc(x_39); -x_40 = lean_ctor_get(x_10, 4); -lean_inc(x_40); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - lean_ctor_release(x_10, 2); - lean_ctor_release(x_10, 3); - lean_ctor_release(x_10, 4); - x_41 = x_10; -} else { - lean_dec_ref(x_10); - x_41 = lean_box(0); -} -x_42 = lean_ctor_get(x_11, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_11, 2); -lean_inc(x_43); -x_44 = lean_ctor_get(x_11, 3); -lean_inc(x_44); -x_45 = lean_ctor_get(x_11, 4); -lean_inc(x_45); -x_46 = lean_ctor_get(x_11, 5); -lean_inc(x_46); -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); - lean_ctor_release(x_11, 5); - x_47 = x_11; -} else { - lean_dec_ref(x_11); - x_47 = lean_box(0); -} -if (lean_is_scalar(x_47)) { - x_48 = lean_alloc_ctor(0, 6, 0); -} else { - x_48 = x_47; -} -lean_ctor_set(x_48, 0, x_42); -lean_ctor_set(x_48, 1, x_8); -lean_ctor_set(x_48, 2, x_43); -lean_ctor_set(x_48, 3, x_44); -lean_ctor_set(x_48, 4, x_45); -lean_ctor_set(x_48, 5, x_46); -if (lean_is_scalar(x_41)) { - x_49 = lean_alloc_ctor(0, 5, 0); -} else { - x_49 = x_41; -} -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_37); -lean_ctor_set(x_49, 2, x_38); -lean_ctor_set(x_49, 3, x_39); -lean_ctor_set(x_49, 4, x_40); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_36); -lean_ctor_set(x_50, 1, x_49); -return x_50; -} -} -else -{ -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_9, 1); -lean_inc(x_51); -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -x_53 = !lean_is_exclusive(x_9); -if (x_53 == 0) -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_9, 1); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_51); -if (x_55 == 0) -{ -lean_object* x_56; uint8_t x_57; -x_56 = lean_ctor_get(x_51, 0); -lean_dec(x_56); -x_57 = !lean_is_exclusive(x_52); -if (x_57 == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_52, 1); -lean_dec(x_58); -lean_ctor_set(x_52, 1, x_8); -return x_9; -} -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; -x_59 = lean_ctor_get(x_52, 0); -x_60 = lean_ctor_get(x_52, 2); -x_61 = lean_ctor_get(x_52, 3); -x_62 = lean_ctor_get(x_52, 4); -x_63 = lean_ctor_get(x_52, 5); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_inc(x_59); -lean_dec(x_52); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_59); -lean_ctor_set(x_64, 1, x_8); -lean_ctor_set(x_64, 2, x_60); -lean_ctor_set(x_64, 3, x_61); -lean_ctor_set(x_64, 4, x_62); -lean_ctor_set(x_64, 5, x_63); -lean_ctor_set(x_51, 0, x_64); -return x_9; -} -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_65 = lean_ctor_get(x_51, 1); -x_66 = lean_ctor_get(x_51, 2); -x_67 = lean_ctor_get(x_51, 3); -x_68 = lean_ctor_get(x_51, 4); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_51); -x_69 = lean_ctor_get(x_52, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_52, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_52, 3); -lean_inc(x_71); -x_72 = lean_ctor_get(x_52, 4); -lean_inc(x_72); -x_73 = lean_ctor_get(x_52, 5); -lean_inc(x_73); -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); - x_74 = x_52; -} else { - lean_dec_ref(x_52); - x_74 = lean_box(0); -} -if (lean_is_scalar(x_74)) { - x_75 = lean_alloc_ctor(0, 6, 0); -} else { - x_75 = x_74; -} -lean_ctor_set(x_75, 0, x_69); -lean_ctor_set(x_75, 1, x_8); -lean_ctor_set(x_75, 2, x_70); -lean_ctor_set(x_75, 3, x_71); -lean_ctor_set(x_75, 4, x_72); -lean_ctor_set(x_75, 5, x_73); -x_76 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_65); -lean_ctor_set(x_76, 2, x_66); -lean_ctor_set(x_76, 3, x_67); -lean_ctor_set(x_76, 4, x_68); -lean_ctor_set(x_9, 1, x_76); -return x_9; -} -} -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; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_77 = lean_ctor_get(x_9, 0); -lean_inc(x_77); lean_dec(x_9); -x_78 = lean_ctor_get(x_51, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_51, 2); -lean_inc(x_79); -x_80 = lean_ctor_get(x_51, 3); -lean_inc(x_80); -x_81 = lean_ctor_get(x_51, 4); -lean_inc(x_81); -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_82 = x_51; -} else { - lean_dec_ref(x_51); - x_82 = lean_box(0); +x_40 = !lean_is_exclusive(x_10); +if (x_40 == 0) +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_10, 0); +lean_dec(x_41); +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, 1); +lean_dec(x_43); +lean_ctor_set(x_38, 1, x_8); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_10); +return x_44; } -x_83 = lean_ctor_get(x_52, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_52, 2); -lean_inc(x_84); -x_85 = lean_ctor_get(x_52, 3); -lean_inc(x_85); -x_86 = lean_ctor_get(x_52, 4); -lean_inc(x_86); -x_87 = lean_ctor_get(x_52, 5); -lean_inc(x_87); -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); - x_88 = x_52; -} else { - lean_dec_ref(x_52); - x_88 = lean_box(0); +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; +x_45 = lean_ctor_get(x_38, 0); +x_46 = lean_ctor_get(x_38, 2); +x_47 = lean_ctor_get(x_38, 3); +x_48 = lean_ctor_get(x_38, 4); +x_49 = lean_ctor_get(x_38, 5); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_38); +x_50 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_8); +lean_ctor_set(x_50, 2, x_46); +lean_ctor_set(x_50, 3, x_47); +lean_ctor_set(x_50, 4, x_48); +lean_ctor_set(x_50, 5, x_49); +lean_ctor_set(x_10, 0, x_50); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_39); +lean_ctor_set(x_51, 1, x_10); +return x_51; } -if (lean_is_scalar(x_88)) { - x_89 = lean_alloc_ctor(0, 6, 0); -} else { - x_89 = x_88; } -lean_ctor_set(x_89, 0, x_83); -lean_ctor_set(x_89, 1, x_8); -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); -if (lean_is_scalar(x_82)) { - x_90 = lean_alloc_ctor(0, 5, 0); +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; +x_52 = lean_ctor_get(x_10, 1); +x_53 = lean_ctor_get(x_10, 2); +x_54 = lean_ctor_get(x_10, 3); +x_55 = lean_ctor_get(x_10, 4); +lean_inc(x_55); +lean_inc(x_54); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_10); +x_56 = lean_ctor_get(x_38, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_38, 2); +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); +x_60 = lean_ctor_get(x_38, 5); +lean_inc(x_60); +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); + lean_ctor_release(x_38, 5); + x_61 = x_38; } else { - x_90 = x_82; + lean_dec_ref(x_38); + x_61 = lean_box(0); +} +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 6, 0); +} else { + x_62 = x_61; +} +lean_ctor_set(x_62, 0, x_56); +lean_ctor_set(x_62, 1, x_8); +lean_ctor_set(x_62, 2, x_57); +lean_ctor_set(x_62, 3, x_58); +lean_ctor_set(x_62, 4, x_59); +lean_ctor_set(x_62, 5, x_60); +x_63 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_52); +lean_ctor_set(x_63, 2, x_53); +lean_ctor_set(x_63, 3, x_54); +lean_ctor_set(x_63, 4, x_55); +x_64 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_64, 0, x_39); +lean_ctor_set(x_64, 1, x_63); +return x_64; } -lean_ctor_set(x_90, 0, x_89); -lean_ctor_set(x_90, 1, x_78); -lean_ctor_set(x_90, 2, x_79); -lean_ctor_set(x_90, 3, x_80); -lean_ctor_set(x_90, 4, x_81); -x_91 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_91, 0, x_77); -lean_ctor_set(x_91, 1, x_90); -return x_91; } } } 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_98; lean_object* x_99; -x_92 = lean_ctor_get(x_6, 0); -x_93 = lean_ctor_get(x_6, 1); -x_94 = lean_ctor_get(x_6, 2); -x_95 = lean_ctor_get(x_6, 3); -x_96 = lean_ctor_get(x_6, 4); -x_97 = lean_ctor_get(x_6, 5); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); +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_114; lean_object* x_115; +x_73 = lean_ctor_get(x_6, 0); +x_74 = lean_ctor_get(x_6, 1); +x_75 = lean_ctor_get(x_6, 2); +x_76 = lean_ctor_get(x_6, 3); +x_77 = lean_ctor_get(x_6, 4); +x_78 = lean_ctor_get(x_6, 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_dec(x_6); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_92); -lean_ctor_set(x_98, 1, x_1); -lean_ctor_set(x_98, 2, x_94); -lean_ctor_set(x_98, 3, x_95); -lean_ctor_set(x_98, 4, x_96); -lean_ctor_set(x_98, 5, x_97); -lean_ctor_set(x_4, 0, x_98); -x_99 = lean_apply_2(x_2, x_3, x_4); -if (lean_obj_tag(x_99) == 0) +x_114 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_114, 0, x_73); +lean_ctor_set(x_114, 1, x_1); +lean_ctor_set(x_114, 2, x_75); +lean_ctor_set(x_114, 3, x_76); +lean_ctor_set(x_114, 4, x_77); +lean_ctor_set(x_114, 5, x_78); +lean_ctor_set(x_4, 0, x_114); +x_115 = lean_apply_2(x_2, x_3, x_4); +if (lean_obj_tag(x_115) == 0) { -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_100 = lean_ctor_get(x_99, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_99, 0); -lean_inc(x_102); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - x_103 = x_99; +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_79 = x_118; +x_80 = x_117; +goto block_113; +} +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_79 = x_121; +x_80 = x_120; +goto block_113; +} +block_113: +{ +if (lean_obj_tag(x_79) == 0) +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; +x_81 = lean_ctor_get(x_80, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_79, 0); +lean_inc(x_82); +lean_dec(x_79); +x_83 = lean_ctor_get(x_80, 1); +lean_inc(x_83); +x_84 = lean_ctor_get(x_80, 2); +lean_inc(x_84); +x_85 = lean_ctor_get(x_80, 3); +lean_inc(x_85); +x_86 = lean_ctor_get(x_80, 4); +lean_inc(x_86); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + lean_ctor_release(x_80, 2); + lean_ctor_release(x_80, 3); + lean_ctor_release(x_80, 4); + x_87 = x_80; } else { - lean_dec_ref(x_99); + lean_dec_ref(x_80); + x_87 = lean_box(0); +} +x_88 = lean_ctor_get(x_81, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_81, 2); +lean_inc(x_89); +x_90 = lean_ctor_get(x_81, 3); +lean_inc(x_90); +x_91 = lean_ctor_get(x_81, 4); +lean_inc(x_91); +x_92 = lean_ctor_get(x_81, 5); +lean_inc(x_92); +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_93 = x_81; +} else { + lean_dec_ref(x_81); + x_93 = lean_box(0); +} +if (lean_is_scalar(x_93)) { + x_94 = lean_alloc_ctor(0, 6, 0); +} else { + x_94 = x_93; +} +lean_ctor_set(x_94, 0, x_88); +lean_ctor_set(x_94, 1, x_74); +lean_ctor_set(x_94, 2, x_89); +lean_ctor_set(x_94, 3, x_90); +lean_ctor_set(x_94, 4, x_91); +lean_ctor_set(x_94, 5, x_92); +if (lean_is_scalar(x_87)) { + x_95 = lean_alloc_ctor(0, 5, 0); +} else { + x_95 = x_87; +} +lean_ctor_set(x_95, 0, x_94); +lean_ctor_set(x_95, 1, x_83); +lean_ctor_set(x_95, 2, x_84); +lean_ctor_set(x_95, 3, x_85); +lean_ctor_set(x_95, 4, x_86); +x_96 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_96, 0, x_82); +lean_ctor_set(x_96, 1, x_95); +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; +x_97 = lean_ctor_get(x_80, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_79, 0); +lean_inc(x_98); +lean_dec(x_79); +x_99 = lean_ctor_get(x_80, 1); +lean_inc(x_99); +x_100 = lean_ctor_get(x_80, 2); +lean_inc(x_100); +x_101 = lean_ctor_get(x_80, 3); +lean_inc(x_101); +x_102 = lean_ctor_get(x_80, 4); +lean_inc(x_102); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + lean_ctor_release(x_80, 2); + lean_ctor_release(x_80, 3); + lean_ctor_release(x_80, 4); + x_103 = x_80; +} else { + lean_dec_ref(x_80); x_103 = lean_box(0); } -x_104 = lean_ctor_get(x_100, 1); +x_104 = lean_ctor_get(x_97, 0); lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 2); +x_105 = lean_ctor_get(x_97, 2); lean_inc(x_105); -x_106 = lean_ctor_get(x_100, 3); +x_106 = lean_ctor_get(x_97, 3); lean_inc(x_106); -x_107 = lean_ctor_get(x_100, 4); +x_107 = lean_ctor_get(x_97, 4); lean_inc(x_107); -if (lean_is_exclusive(x_100)) { - lean_ctor_release(x_100, 0); - lean_ctor_release(x_100, 1); - lean_ctor_release(x_100, 2); - lean_ctor_release(x_100, 3); - lean_ctor_release(x_100, 4); - x_108 = x_100; +x_108 = lean_ctor_get(x_97, 5); +lean_inc(x_108); +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_109 = x_97; } else { - lean_dec_ref(x_100); - x_108 = lean_box(0); + lean_dec_ref(x_97); + x_109 = lean_box(0); } -x_109 = lean_ctor_get(x_101, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_101, 2); -lean_inc(x_110); -x_111 = lean_ctor_get(x_101, 3); -lean_inc(x_111); -x_112 = lean_ctor_get(x_101, 4); -lean_inc(x_112); -x_113 = lean_ctor_get(x_101, 5); -lean_inc(x_113); -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_114 = x_101; +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_101); - x_114 = lean_box(0); + x_110 = x_109; } -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(0, 6, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_109); -lean_ctor_set(x_115, 1, x_93); -lean_ctor_set(x_115, 2, x_110); -lean_ctor_set(x_115, 3, x_111); -lean_ctor_set(x_115, 4, x_112); -lean_ctor_set(x_115, 5, x_113); -if (lean_is_scalar(x_108)) { - x_116 = lean_alloc_ctor(0, 5, 0); -} else { - x_116 = x_108; -} -lean_ctor_set(x_116, 0, x_115); -lean_ctor_set(x_116, 1, x_104); -lean_ctor_set(x_116, 2, x_105); -lean_ctor_set(x_116, 3, x_106); -lean_ctor_set(x_116, 4, x_107); +lean_ctor_set(x_110, 0, x_104); +lean_ctor_set(x_110, 1, x_74); +lean_ctor_set(x_110, 2, x_105); +lean_ctor_set(x_110, 3, x_106); +lean_ctor_set(x_110, 4, x_107); +lean_ctor_set(x_110, 5, x_108); if (lean_is_scalar(x_103)) { - x_117 = lean_alloc_ctor(0, 2, 0); + x_111 = lean_alloc_ctor(0, 5, 0); } else { - x_117 = x_103; + x_111 = x_103; +} +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_99); +lean_ctor_set(x_111, 2, x_100); +lean_ctor_set(x_111, 3, x_101); +lean_ctor_set(x_111, 4, x_102); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_98); +lean_ctor_set(x_112, 1, x_111); +return x_112; +} +} } -lean_ctor_set(x_117, 0, x_102); -lean_ctor_set(x_117, 1, x_116); -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; -x_118 = lean_ctor_get(x_99, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_118, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_99, 0); -lean_inc(x_120); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - x_121 = x_99; -} else { - lean_dec_ref(x_99); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_118, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 3); -lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 4); +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_169; lean_object* x_170; lean_object* x_171; +x_122 = lean_ctor_get(x_4, 0); +x_123 = lean_ctor_get(x_4, 1); +x_124 = lean_ctor_get(x_4, 2); +x_125 = lean_ctor_get(x_4, 3); +x_126 = lean_ctor_get(x_4, 4); +lean_inc(x_126); 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); - 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_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_4); +x_127 = lean_ctor_get(x_122, 0); lean_inc(x_127); -x_128 = lean_ctor_get(x_119, 2); +x_128 = lean_ctor_get(x_122, 1); lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 3); +x_129 = lean_ctor_get(x_122, 2); lean_inc(x_129); -x_130 = lean_ctor_get(x_119, 4); +x_130 = lean_ctor_get(x_122, 3); lean_inc(x_130); -x_131 = lean_ctor_get(x_119, 5); +x_131 = lean_ctor_get(x_122, 4); lean_inc(x_131); -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); - lean_ctor_release(x_119, 5); - x_132 = x_119; +x_132 = lean_ctor_get(x_122, 5); +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); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_133 = x_122; } else { - lean_dec_ref(x_119); - x_132 = lean_box(0); + lean_dec_ref(x_122); + x_133 = lean_box(0); } -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_133)) { + x_169 = lean_alloc_ctor(0, 6, 0); } else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_127); -lean_ctor_set(x_133, 1, x_93); -lean_ctor_set(x_133, 2, x_128); -lean_ctor_set(x_133, 3, x_129); -lean_ctor_set(x_133, 4, x_130); -lean_ctor_set(x_133, 5, x_131); -if (lean_is_scalar(x_126)) { - x_134 = lean_alloc_ctor(0, 5, 0); -} else { - x_134 = x_126; -} -lean_ctor_set(x_134, 0, x_133); -lean_ctor_set(x_134, 1, x_122); -lean_ctor_set(x_134, 2, x_123); -lean_ctor_set(x_134, 3, x_124); -lean_ctor_set(x_134, 4, x_125); -if (lean_is_scalar(x_121)) { - x_135 = lean_alloc_ctor(1, 2, 0); -} else { - x_135 = x_121; -} -lean_ctor_set(x_135, 0, x_120); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} + x_169 = x_133; } +lean_ctor_set(x_169, 0, x_127); +lean_ctor_set(x_169, 1, x_1); +lean_ctor_set(x_169, 2, x_129); +lean_ctor_set(x_169, 3, x_130); +lean_ctor_set(x_169, 4, x_131); +lean_ctor_set(x_169, 5, x_132); +x_170 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_170, 0, x_169); +lean_ctor_set(x_170, 1, x_123); +lean_ctor_set(x_170, 2, x_124); +lean_ctor_set(x_170, 3, x_125); +lean_ctor_set(x_170, 4, x_126); +x_171 = lean_apply_2(x_2, x_3, 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_134 = x_174; +x_135 = x_173; +goto block_168; } 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; -x_136 = lean_ctor_get(x_4, 0); -x_137 = lean_ctor_get(x_4, 1); -x_138 = lean_ctor_get(x_4, 2); -x_139 = lean_ctor_get(x_4, 3); -x_140 = lean_ctor_get(x_4, 4); -lean_inc(x_140); -lean_inc(x_139); -lean_inc(x_138); -lean_inc(x_137); +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_134 = x_177; +x_135 = x_176; +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, 0); lean_inc(x_136); -lean_dec(x_4); -x_141 = lean_ctor_get(x_136, 0); +x_137 = lean_ctor_get(x_134, 0); +lean_inc(x_137); +lean_dec(x_134); +x_138 = lean_ctor_get(x_135, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_135, 2); +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_136, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_136, 2); +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_142 = x_135; +} else { + lean_dec_ref(x_135); + x_142 = lean_box(0); +} +x_143 = lean_ctor_get(x_136, 0); lean_inc(x_143); -x_144 = lean_ctor_get(x_136, 3); +x_144 = lean_ctor_get(x_136, 2); lean_inc(x_144); -x_145 = lean_ctor_get(x_136, 4); +x_145 = lean_ctor_get(x_136, 3); lean_inc(x_145); -x_146 = lean_ctor_get(x_136, 5); +x_146 = lean_ctor_get(x_136, 4); lean_inc(x_146); +x_147 = lean_ctor_get(x_136, 5); +lean_inc(x_147); if (lean_is_exclusive(x_136)) { lean_ctor_release(x_136, 0); lean_ctor_release(x_136, 1); @@ -3287,75 +3279,74 @@ if (lean_is_exclusive(x_136)) { lean_ctor_release(x_136, 3); lean_ctor_release(x_136, 4); lean_ctor_release(x_136, 5); - x_147 = x_136; + x_148 = x_136; } else { lean_dec_ref(x_136); - x_147 = lean_box(0); + x_148 = lean_box(0); } -if (lean_is_scalar(x_147)) { - x_148 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 6, 0); } else { - x_148 = x_147; + x_149 = x_148; } -lean_ctor_set(x_148, 0, x_141); -lean_ctor_set(x_148, 1, x_1); -lean_ctor_set(x_148, 2, x_143); -lean_ctor_set(x_148, 3, x_144); -lean_ctor_set(x_148, 4, x_145); -lean_ctor_set(x_148, 5, x_146); -x_149 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_149, 0, x_148); -lean_ctor_set(x_149, 1, x_137); -lean_ctor_set(x_149, 2, x_138); -lean_ctor_set(x_149, 3, x_139); -lean_ctor_set(x_149, 4, x_140); -x_150 = lean_apply_2(x_2, x_3, x_149); -if (lean_obj_tag(x_150) == 0) +lean_ctor_set(x_149, 0, x_143); +lean_ctor_set(x_149, 1, x_128); +lean_ctor_set(x_149, 2, x_144); +lean_ctor_set(x_149, 3, x_145); +lean_ctor_set(x_149, 4, x_146); +lean_ctor_set(x_149, 5, x_147); +if (lean_is_scalar(x_142)) { + x_150 = lean_alloc_ctor(0, 5, 0); +} else { + x_150 = x_142; +} +lean_ctor_set(x_150, 0, x_149); +lean_ctor_set(x_150, 1, x_138); +lean_ctor_set(x_150, 2, x_139); +lean_ctor_set(x_150, 3, x_140); +lean_ctor_set(x_150, 4, x_141); +x_151 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_151, 0, x_137); +lean_ctor_set(x_151, 1, x_150); +return x_151; +} +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_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_151 = lean_ctor_get(x_150, 1); -lean_inc(x_151); -x_152 = lean_ctor_get(x_151, 0); +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, 0); lean_inc(x_152); -x_153 = lean_ctor_get(x_150, 0); +x_153 = lean_ctor_get(x_134, 0); lean_inc(x_153); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - x_154 = x_150; -} else { - lean_dec_ref(x_150); - x_154 = lean_box(0); -} -x_155 = lean_ctor_get(x_151, 1); +lean_dec(x_134); +x_154 = lean_ctor_get(x_135, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_135, 2); lean_inc(x_155); -x_156 = lean_ctor_get(x_151, 2); +x_156 = lean_ctor_get(x_135, 3); lean_inc(x_156); -x_157 = lean_ctor_get(x_151, 3); +x_157 = lean_ctor_get(x_135, 4); lean_inc(x_157); -x_158 = lean_ctor_get(x_151, 4); -lean_inc(x_158); -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_159 = x_151; +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_158 = x_135; } else { - lean_dec_ref(x_151); - x_159 = lean_box(0); + lean_dec_ref(x_135); + x_158 = lean_box(0); } -x_160 = lean_ctor_get(x_152, 0); +x_159 = lean_ctor_get(x_152, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_152, 2); lean_inc(x_160); -x_161 = lean_ctor_get(x_152, 2); +x_161 = lean_ctor_get(x_152, 3); lean_inc(x_161); -x_162 = lean_ctor_get(x_152, 3); +x_162 = lean_ctor_get(x_152, 4); lean_inc(x_162); -x_163 = lean_ctor_get(x_152, 4); +x_163 = lean_ctor_get(x_152, 5); lean_inc(x_163); -x_164 = lean_ctor_get(x_152, 5); -lean_inc(x_164); if (lean_is_exclusive(x_152)) { lean_ctor_release(x_152, 0); lean_ctor_release(x_152, 1); @@ -3363,128 +3354,37 @@ if (lean_is_exclusive(x_152)) { lean_ctor_release(x_152, 3); lean_ctor_release(x_152, 4); lean_ctor_release(x_152, 5); - x_165 = x_152; + x_164 = x_152; } else { lean_dec_ref(x_152); - x_165 = lean_box(0); + x_164 = lean_box(0); } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 6, 0); } else { - x_166 = x_165; + x_165 = x_164; } -lean_ctor_set(x_166, 0, x_160); -lean_ctor_set(x_166, 1, x_142); -lean_ctor_set(x_166, 2, x_161); -lean_ctor_set(x_166, 3, x_162); -lean_ctor_set(x_166, 4, x_163); -lean_ctor_set(x_166, 5, x_164); -if (lean_is_scalar(x_159)) { - x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_165, 0, x_159); +lean_ctor_set(x_165, 1, x_128); +lean_ctor_set(x_165, 2, x_160); +lean_ctor_set(x_165, 3, x_161); +lean_ctor_set(x_165, 4, x_162); +lean_ctor_set(x_165, 5, x_163); +if (lean_is_scalar(x_158)) { + x_166 = lean_alloc_ctor(0, 5, 0); } else { - x_167 = x_159; + x_166 = x_158; } -lean_ctor_set(x_167, 0, x_166); -lean_ctor_set(x_167, 1, x_155); -lean_ctor_set(x_167, 2, x_156); -lean_ctor_set(x_167, 3, x_157); -lean_ctor_set(x_167, 4, x_158); -if (lean_is_scalar(x_154)) { - x_168 = lean_alloc_ctor(0, 2, 0); -} else { - x_168 = x_154; +lean_ctor_set(x_166, 0, x_165); +lean_ctor_set(x_166, 1, x_154); +lean_ctor_set(x_166, 2, x_155); +lean_ctor_set(x_166, 3, x_156); +lean_ctor_set(x_166, 4, x_157); +x_167 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_167, 0, x_153); +lean_ctor_set(x_167, 1, x_166); +return x_167; } -lean_ctor_set(x_168, 0, x_153); -lean_ctor_set(x_168, 1, x_167); -return x_168; -} -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; 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_169 = lean_ctor_get(x_150, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_169, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_150, 0); -lean_inc(x_171); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - x_172 = x_150; -} else { - lean_dec_ref(x_150); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_169, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_169, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_169, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_169, 4); -lean_inc(x_176); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - lean_ctor_release(x_169, 3); - lean_ctor_release(x_169, 4); - x_177 = x_169; -} else { - lean_dec_ref(x_169); - x_177 = lean_box(0); -} -x_178 = lean_ctor_get(x_170, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_170, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_170, 3); -lean_inc(x_180); -x_181 = lean_ctor_get(x_170, 4); -lean_inc(x_181); -x_182 = lean_ctor_get(x_170, 5); -lean_inc(x_182); -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_183 = x_170; -} else { - lean_dec_ref(x_170); - x_183 = lean_box(0); -} -if (lean_is_scalar(x_183)) { - x_184 = lean_alloc_ctor(0, 6, 0); -} else { - x_184 = x_183; -} -lean_ctor_set(x_184, 0, x_178); -lean_ctor_set(x_184, 1, x_142); -lean_ctor_set(x_184, 2, x_179); -lean_ctor_set(x_184, 3, x_180); -lean_ctor_set(x_184, 4, x_181); -lean_ctor_set(x_184, 5, x_182); -if (lean_is_scalar(x_177)) { - x_185 = lean_alloc_ctor(0, 5, 0); -} else { - x_185 = x_177; -} -lean_ctor_set(x_185, 0, x_184); -lean_ctor_set(x_185, 1, x_173); -lean_ctor_set(x_185, 2, x_174); -lean_ctor_set(x_185, 3, x_175); -lean_ctor_set(x_185, 4, x_176); -if (lean_is_scalar(x_172)) { - x_186 = lean_alloc_ctor(1, 2, 0); -} else { - x_186 = x_172; -} -lean_ctor_set(x_186, 0, x_171); -lean_ctor_set(x_186, 1, x_185); -return x_186; } } } @@ -3828,7 +3728,7 @@ lean_object* _init_l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l_Lean_Meta_Exception_toTraceMessageData___closed__72; x_3 = lean_name_mk_string(x_1, x_2); return x_3; @@ -4893,208 +4793,220 @@ if (lean_is_exclusive(x_6)) { x_13 = !lean_is_exclusive(x_7); if (x_13 == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_44; lean_object* x_45; lean_object* x_73; lean_object* x_143; lean_object* x_144; lean_object* x_145; uint8_t x_146; +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_72; lean_object* x_146; lean_object* x_147; lean_object* x_148; uint8_t x_149; x_14 = lean_ctor_get(x_7, 1); lean_ctor_set(x_7, 1, x_1); -x_143 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_143, 0, x_7); -lean_ctor_set(x_143, 1, x_8); -lean_ctor_set(x_143, 2, x_9); -lean_ctor_set(x_143, 3, x_10); -lean_ctor_set(x_143, 4, x_11); -x_144 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_143); -x_145 = lean_ctor_get(x_144, 0); -lean_inc(x_145); -x_146 = lean_ctor_get_uint8(x_145, sizeof(void*)*1); -lean_dec(x_145); -if (x_146 == 0) -{ -lean_object* x_147; -x_147 = lean_ctor_get(x_144, 1); -lean_inc(x_147); -lean_dec(x_144); -x_73 = x_147; -goto block_142; -} -else -{ -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; uint8_t x_152; -x_148 = lean_ctor_get(x_144, 1); +x_146 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_146, 0, x_7); +lean_ctor_set(x_146, 1, x_8); +lean_ctor_set(x_146, 2, x_9); +lean_ctor_set(x_146, 3, x_10); +lean_ctor_set(x_146, 4, x_11); +x_147 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_146); +x_148 = lean_ctor_get(x_147, 0); lean_inc(x_148); -lean_dec(x_144); -x_149 = l_Lean_Meta_SynthInstance_newSubgoal___closed__2; -x_150 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_149, x_5, x_148); -x_151 = lean_ctor_get(x_150, 0); -lean_inc(x_151); -x_152 = lean_unbox(x_151); -lean_dec(x_151); -if (x_152 == 0) +x_149 = lean_ctor_get_uint8(x_148, sizeof(void*)*1); +lean_dec(x_148); +if (x_149 == 0) { -lean_object* x_153; -x_153 = lean_ctor_get(x_150, 1); -lean_inc(x_153); -lean_dec(x_150); -x_73 = x_153; -goto block_142; +lean_object* x_150; +x_150 = lean_ctor_get(x_147, 1); +lean_inc(x_150); +lean_dec(x_147); +x_72 = x_150; +goto block_145; } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; -x_154 = lean_ctor_get(x_150, 1); +lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; uint8_t x_155; +x_151 = lean_ctor_get(x_147, 1); +lean_inc(x_151); +lean_dec(x_147); +x_152 = l_Lean_Meta_SynthInstance_newSubgoal___closed__2; +x_153 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_152, x_5, x_151); +x_154 = lean_ctor_get(x_153, 0); lean_inc(x_154); -lean_dec(x_150); -lean_inc(x_2); -x_155 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_155, 0, x_2); -x_156 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_149, x_155, x_5, x_154); -x_157 = lean_ctor_get(x_156, 1); +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_inc(x_156); +lean_dec(x_153); +x_72 = x_156; +goto block_145; +} +else +{ +lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; +x_157 = lean_ctor_get(x_153, 1); lean_inc(x_157); -lean_dec(x_156); -x_73 = x_157; -goto block_142; +lean_dec(x_153); +lean_inc(x_2); +x_158 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_158, 0, x_2); +x_159 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_152, x_158, x_5, x_157); +x_160 = lean_ctor_get(x_159, 1); +lean_inc(x_160); +lean_dec(x_159); +x_72 = x_160; +goto block_145; } } -block_43: +block_71: { -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) +if (lean_obj_tag(x_15) == 0) { -lean_object* x_18; uint8_t x_19; -x_18 = lean_ctor_get(x_16, 0); -x_19 = !lean_is_exclusive(x_18); +lean_object* x_17; lean_object* x_18; uint8_t x_19; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_15, 0); +lean_inc(x_18); +lean_dec(x_15); +x_19 = !lean_is_exclusive(x_16); if (x_19 == 0) { -lean_object* x_20; lean_object* x_21; -x_20 = lean_ctor_get(x_18, 1); +lean_object* x_20; uint8_t x_21; +x_20 = lean_ctor_get(x_16, 0); lean_dec(x_20); -lean_ctor_set(x_18, 1, x_14); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_15); -lean_ctor_set(x_21, 1, x_16); -return x_21; +x_21 = !lean_is_exclusive(x_17); +if (x_21 == 0) +{ +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_17, 1); +lean_dec(x_22); +lean_ctor_set(x_17, 1, x_14); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_18); +lean_ctor_set(x_23, 1, x_16); +return x_23; } 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; -x_22 = lean_ctor_get(x_18, 0); -x_23 = lean_ctor_get(x_18, 2); -x_24 = lean_ctor_get(x_18, 3); -x_25 = lean_ctor_get(x_18, 4); -x_26 = lean_ctor_get(x_18, 5); +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_24 = lean_ctor_get(x_17, 0); +x_25 = lean_ctor_get(x_17, 2); +x_26 = lean_ctor_get(x_17, 3); +x_27 = lean_ctor_get(x_17, 4); +x_28 = lean_ctor_get(x_17, 5); +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_dec(x_18); -x_27 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_27, 0, x_22); -lean_ctor_set(x_27, 1, x_14); -lean_ctor_set(x_27, 2, x_23); -lean_ctor_set(x_27, 3, x_24); -lean_ctor_set(x_27, 4, x_25); -lean_ctor_set(x_27, 5, x_26); -lean_ctor_set(x_16, 0, x_27); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_15); -lean_ctor_set(x_28, 1, x_16); -return x_28; +lean_dec(x_17); +x_29 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_29, 0, x_24); +lean_ctor_set(x_29, 1, x_14); +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_29, 5, x_28); +lean_ctor_set(x_16, 0, x_29); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_18); +lean_ctor_set(x_30, 1, x_16); +return x_30; } } 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; lean_object* x_42; -x_29 = lean_ctor_get(x_16, 0); -x_30 = lean_ctor_get(x_16, 1); -x_31 = lean_ctor_get(x_16, 2); -x_32 = lean_ctor_get(x_16, 3); -x_33 = lean_ctor_get(x_16, 4); +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_16, 1); +x_32 = lean_ctor_get(x_16, 2); +x_33 = lean_ctor_get(x_16, 3); +x_34 = lean_ctor_get(x_16, 4); +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_16); -x_34 = lean_ctor_get(x_29, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_29, 2); +x_35 = lean_ctor_get(x_17, 0); lean_inc(x_35); -x_36 = lean_ctor_get(x_29, 3); +x_36 = lean_ctor_get(x_17, 2); lean_inc(x_36); -x_37 = lean_ctor_get(x_29, 4); +x_37 = lean_ctor_get(x_17, 3); lean_inc(x_37); -x_38 = lean_ctor_get(x_29, 5); +x_38 = lean_ctor_get(x_17, 4); lean_inc(x_38); -if (lean_is_exclusive(x_29)) { - lean_ctor_release(x_29, 0); - lean_ctor_release(x_29, 1); - lean_ctor_release(x_29, 2); - lean_ctor_release(x_29, 3); - lean_ctor_release(x_29, 4); - lean_ctor_release(x_29, 5); - x_39 = x_29; +x_39 = lean_ctor_get(x_17, 5); +lean_inc(x_39); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + lean_ctor_release(x_17, 2); + lean_ctor_release(x_17, 3); + lean_ctor_release(x_17, 4); + lean_ctor_release(x_17, 5); + x_40 = x_17; } else { - lean_dec_ref(x_29); - x_39 = lean_box(0); + lean_dec_ref(x_17); + x_40 = lean_box(0); } -if (lean_is_scalar(x_39)) { - x_40 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_40)) { + x_41 = lean_alloc_ctor(0, 6, 0); } else { - x_40 = x_39; + x_41 = x_40; } -lean_ctor_set(x_40, 0, x_34); -lean_ctor_set(x_40, 1, x_14); -lean_ctor_set(x_40, 2, x_35); -lean_ctor_set(x_40, 3, x_36); -lean_ctor_set(x_40, 4, x_37); -lean_ctor_set(x_40, 5, x_38); -x_41 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_41, 0, x_40); -lean_ctor_set(x_41, 1, x_30); -lean_ctor_set(x_41, 2, x_31); -lean_ctor_set(x_41, 3, x_32); -lean_ctor_set(x_41, 4, x_33); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_15); -lean_ctor_set(x_42, 1, x_41); -return x_42; +lean_ctor_set(x_41, 0, x_35); +lean_ctor_set(x_41, 1, x_14); +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); +x_42 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_42, 0, x_41); +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_34); +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_18); +lean_ctor_set(x_43, 1, x_42); +return x_43; } } -block_72: +else { -uint8_t x_46; -x_46 = !lean_is_exclusive(x_45); +lean_object* x_44; lean_object* x_45; uint8_t x_46; +x_44 = lean_ctor_get(x_16, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_15, 0); +lean_inc(x_45); +lean_dec(x_15); +x_46 = !lean_is_exclusive(x_16); if (x_46 == 0) { lean_object* x_47; uint8_t x_48; -x_47 = lean_ctor_get(x_45, 0); -x_48 = !lean_is_exclusive(x_47); +x_47 = lean_ctor_get(x_16, 0); +lean_dec(x_47); +x_48 = !lean_is_exclusive(x_44); if (x_48 == 0) { lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_47, 1); +x_49 = lean_ctor_get(x_44, 1); lean_dec(x_49); -lean_ctor_set(x_47, 1, x_14); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_44); -lean_ctor_set(x_50, 1, x_45); +lean_ctor_set(x_44, 1, x_14); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_16); 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_56; lean_object* x_57; -x_51 = lean_ctor_get(x_47, 0); -x_52 = lean_ctor_get(x_47, 2); -x_53 = lean_ctor_get(x_47, 3); -x_54 = lean_ctor_get(x_47, 4); -x_55 = lean_ctor_get(x_47, 5); +x_51 = lean_ctor_get(x_44, 0); +x_52 = lean_ctor_get(x_44, 2); +x_53 = lean_ctor_get(x_44, 3); +x_54 = lean_ctor_get(x_44, 4); +x_55 = lean_ctor_get(x_44, 5); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); -lean_dec(x_47); +lean_dec(x_44); x_56 = lean_alloc_ctor(0, 6, 0); lean_ctor_set(x_56, 0, x_51); lean_ctor_set(x_56, 1, x_14); @@ -5102,773 +5014,793 @@ lean_ctor_set(x_56, 2, x_52); lean_ctor_set(x_56, 3, x_53); lean_ctor_set(x_56, 4, x_54); lean_ctor_set(x_56, 5, x_55); -lean_ctor_set(x_45, 0, x_56); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_44); -lean_ctor_set(x_57, 1, x_45); +lean_ctor_set(x_16, 0, x_56); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_45); +lean_ctor_set(x_57, 1, x_16); 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_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_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 2); -x_61 = lean_ctor_get(x_45, 3); -x_62 = lean_ctor_get(x_45, 4); -lean_inc(x_62); +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; +x_58 = lean_ctor_get(x_16, 1); +x_59 = lean_ctor_get(x_16, 2); +x_60 = lean_ctor_get(x_16, 3); +x_61 = lean_ctor_get(x_16, 4); 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_58, 0); +lean_dec(x_16); +x_62 = lean_ctor_get(x_44, 0); +lean_inc(x_62); +x_63 = lean_ctor_get(x_44, 2); lean_inc(x_63); -x_64 = lean_ctor_get(x_58, 2); +x_64 = lean_ctor_get(x_44, 3); lean_inc(x_64); -x_65 = lean_ctor_get(x_58, 3); +x_65 = lean_ctor_get(x_44, 4); lean_inc(x_65); -x_66 = lean_ctor_get(x_58, 4); +x_66 = lean_ctor_get(x_44, 5); lean_inc(x_66); -x_67 = lean_ctor_get(x_58, 5); -lean_inc(x_67); -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_68 = x_58; +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + lean_ctor_release(x_44, 2); + lean_ctor_release(x_44, 3); + lean_ctor_release(x_44, 4); + lean_ctor_release(x_44, 5); + x_67 = x_44; } else { - lean_dec_ref(x_58); - x_68 = lean_box(0); + lean_dec_ref(x_44); + x_67 = lean_box(0); } -if (lean_is_scalar(x_68)) { - x_69 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 6, 0); } else { - x_69 = x_68; + x_68 = x_67; } -lean_ctor_set(x_69, 0, x_63); -lean_ctor_set(x_69, 1, x_14); -lean_ctor_set(x_69, 2, x_64); -lean_ctor_set(x_69, 3, x_65); -lean_ctor_set(x_69, 4, x_66); -lean_ctor_set(x_69, 5, x_67); -x_70 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_70, 0, x_69); -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); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_44); -lean_ctor_set(x_71, 1, x_70); -return x_71; +lean_ctor_set(x_68, 0, x_62); +lean_ctor_set(x_68, 1, x_14); +lean_ctor_set(x_68, 2, x_63); +lean_ctor_set(x_68, 3, x_64); +lean_ctor_set(x_68, 4, x_65); +lean_ctor_set(x_68, 5, x_66); +x_69 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_58); +lean_ctor_set(x_69, 2, x_59); +lean_ctor_set(x_69, 3, x_60); +lean_ctor_set(x_69, 4, x_61); +x_70 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_70, 0, x_45); +lean_ctor_set(x_70, 1, x_69); +return x_70; } } -block_142: +} +block_145: { -uint8_t x_74; -x_74 = !lean_is_exclusive(x_73); -if (x_74 == 0) +uint8_t x_73; +x_73 = !lean_is_exclusive(x_72); +if (x_73 == 0) { -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_73, 0); -x_76 = lean_ctor_get(x_73, 1); -x_77 = lean_ctor_get(x_73, 2); -x_78 = lean_ctor_get(x_73, 3); -x_79 = lean_ctor_get(x_73, 4); +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_72, 0); +x_75 = lean_ctor_get(x_72, 1); +x_76 = lean_ctor_get(x_72, 2); +x_77 = lean_ctor_get(x_72, 3); +x_78 = lean_ctor_get(x_72, 4); lean_inc(x_5); lean_inc(x_3); -x_80 = l_Lean_Meta_inferType(x_3, x_5, x_75); -if (lean_obj_tag(x_80) == 0) +x_79 = l_Lean_Meta_inferType(x_3, x_5, x_74); +if (lean_obj_tag(x_79) == 0) { -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_81 = lean_ctor_get(x_80, 0); +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_80 = lean_ctor_get(x_79, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_79, 1); lean_inc(x_81); -x_82 = lean_ctor_get(x_80, 1); -lean_inc(x_82); -lean_dec(x_80); -x_83 = l_Lean_Meta_instantiateMVars(x_81, x_5, x_82); -x_84 = lean_ctor_get(x_83, 0); +lean_dec(x_79); +x_82 = l_Lean_Meta_instantiateMVars(x_80, x_5, x_81); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_82, 1); lean_inc(x_84); -x_85 = lean_ctor_get(x_83, 1); -lean_inc(x_85); -lean_dec(x_83); -x_86 = l_Lean_Meta_SynthInstance_getInstances___closed__1; -x_87 = l_Lean_Meta_forallTelescopeReducing___rarg(x_84, x_86, x_5, x_85); -if (lean_obj_tag(x_87) == 0) +lean_dec(x_82); +x_85 = l_Lean_Meta_SynthInstance_getInstances___closed__1; +x_86 = l_Lean_Meta_forallTelescopeReducing___rarg(x_83, x_85, x_5, x_84); +if (lean_obj_tag(x_86) == 0) { -lean_object* x_88; lean_object* x_89; lean_object* x_90; uint8_t x_91; -x_88 = lean_ctor_get(x_87, 0); +lean_object* x_87; lean_object* x_88; lean_object* x_89; uint8_t 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); -x_89 = lean_ctor_get(x_87, 1); +lean_dec(x_86); +x_89 = lean_ctor_get(x_88, 1); lean_inc(x_89); -lean_dec(x_87); -x_90 = lean_ctor_get(x_89, 1); -lean_inc(x_90); -lean_inc(x_79); lean_inc(x_78); lean_inc(x_77); lean_inc(x_76); -lean_inc(x_89); -lean_ctor_set(x_73, 0, x_89); -x_91 = l_Array_isEmpty___rarg(x_88); -if (x_91 == 0) +lean_inc(x_75); +lean_inc(x_88); +lean_ctor_set(x_72, 0, x_88); +x_90 = l_Array_isEmpty___rarg(x_87); +if (x_90 == 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_99; lean_object* x_100; lean_object* x_101; -lean_dec(x_73); -x_92 = lean_array_get_size(x_88); +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +lean_dec(x_72); +x_91 = lean_array_get_size(x_87); lean_inc(x_2); -x_93 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_93, 0, x_3); -lean_ctor_set(x_93, 1, x_2); -lean_ctor_set(x_93, 2, x_90); -lean_ctor_set(x_93, 3, x_88); -lean_ctor_set(x_93, 4, x_92); -x_94 = l_Lean_mkOptionalNode___closed__2; -x_95 = lean_array_push(x_94, x_4); -x_96 = l_Array_empty___closed__1; -x_97 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_97, 0, x_95); -lean_ctor_set(x_97, 1, x_96); -x_98 = lean_array_push(x_77, x_93); -x_99 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_79, x_2, x_97); +x_92 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_92, 0, x_3); +lean_ctor_set(x_92, 1, x_2); +lean_ctor_set(x_92, 2, x_89); +lean_ctor_set(x_92, 3, x_87); +lean_ctor_set(x_92, 4, x_91); +x_93 = l_Lean_mkOptionalNode___closed__2; +x_94 = lean_array_push(x_93, x_4); +x_95 = l_Array_empty___closed__1; +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_94); +lean_ctor_set(x_96, 1, x_95); +x_97 = lean_array_push(x_76, x_92); +x_98 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_78, x_2, x_96); if (lean_is_scalar(x_12)) { - x_100 = lean_alloc_ctor(0, 5, 0); + x_99 = lean_alloc_ctor(0, 5, 0); } else { - x_100 = x_12; + x_99 = x_12; } -lean_ctor_set(x_100, 0, x_89); -lean_ctor_set(x_100, 1, x_76); -lean_ctor_set(x_100, 2, x_98); -lean_ctor_set(x_100, 3, x_78); -lean_ctor_set(x_100, 4, x_99); -x_101 = lean_box(0); -x_15 = x_101; -x_16 = x_100; -goto block_43; +lean_ctor_set(x_99, 0, x_88); +lean_ctor_set(x_99, 1, x_75); +lean_ctor_set(x_99, 2, x_97); +lean_ctor_set(x_99, 3, x_77); +lean_ctor_set(x_99, 4, x_98); +x_100 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_15 = x_100; +x_16 = x_99; +goto block_71; } else { -lean_object* x_102; -lean_dec(x_90); +lean_object* x_101; lean_dec(x_89); lean_dec(x_88); -lean_dec(x_79); +lean_dec(x_87); lean_dec(x_78); lean_dec(x_77); lean_dec(x_76); +lean_dec(x_75); lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_102 = lean_box(0); -x_15 = x_102; -x_16 = x_73; -goto block_43; +x_101 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_15 = x_101; +x_16 = x_72; +goto block_71; } } else { -lean_object* x_103; lean_object* x_104; +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_103 = lean_ctor_get(x_87, 0); +x_102 = lean_ctor_get(x_86, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_86, 1); lean_inc(x_103); -x_104 = lean_ctor_get(x_87, 1); -lean_inc(x_104); -lean_dec(x_87); -lean_ctor_set(x_73, 0, x_104); -x_44 = x_103; -x_45 = x_73; -goto block_72; +lean_dec(x_86); +lean_ctor_set(x_72, 0, x_103); +x_104 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_104, 0, x_102); +x_15 = x_104; +x_16 = x_72; +goto block_71; } } else { -lean_object* x_105; lean_object* x_106; +lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_dec(x_12); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_105 = lean_ctor_get(x_80, 0); +x_105 = lean_ctor_get(x_79, 0); lean_inc(x_105); -x_106 = lean_ctor_get(x_80, 1); +x_106 = lean_ctor_get(x_79, 1); lean_inc(x_106); -lean_dec(x_80); -lean_ctor_set(x_73, 0, x_106); -x_44 = x_105; -x_45 = x_73; -goto block_72; +lean_dec(x_79); +lean_ctor_set(x_72, 0, x_106); +x_107 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_15 = x_107; +x_16 = x_72; +goto block_71; } } 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; -x_107 = lean_ctor_get(x_73, 0); -x_108 = lean_ctor_get(x_73, 1); -x_109 = lean_ctor_get(x_73, 2); -x_110 = lean_ctor_get(x_73, 3); -x_111 = lean_ctor_get(x_73, 4); +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_108 = lean_ctor_get(x_72, 0); +x_109 = lean_ctor_get(x_72, 1); +x_110 = lean_ctor_get(x_72, 2); +x_111 = lean_ctor_get(x_72, 3); +x_112 = lean_ctor_get(x_72, 4); +lean_inc(x_112); lean_inc(x_111); lean_inc(x_110); lean_inc(x_109); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_73); +lean_dec(x_72); lean_inc(x_5); lean_inc(x_3); -x_112 = l_Lean_Meta_inferType(x_3, x_5, x_107); -if (lean_obj_tag(x_112) == 0) +x_113 = l_Lean_Meta_inferType(x_3, x_5, x_108); +if (lean_obj_tag(x_113) == 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; -x_113 = lean_ctor_get(x_112, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_112, 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; +x_114 = lean_ctor_get(x_113, 0); lean_inc(x_114); -lean_dec(x_112); -x_115 = l_Lean_Meta_instantiateMVars(x_113, x_5, x_114); -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); +x_115 = lean_ctor_get(x_113, 1); +lean_inc(x_115); +lean_dec(x_113); +x_116 = l_Lean_Meta_instantiateMVars(x_114, x_5, x_115); +x_117 = lean_ctor_get(x_116, 0); lean_inc(x_117); -lean_dec(x_115); -x_118 = l_Lean_Meta_SynthInstance_getInstances___closed__1; -x_119 = l_Lean_Meta_forallTelescopeReducing___rarg(x_116, x_118, x_5, x_117); -if (lean_obj_tag(x_119) == 0) +x_118 = lean_ctor_get(x_116, 1); +lean_inc(x_118); +lean_dec(x_116); +x_119 = l_Lean_Meta_SynthInstance_getInstances___closed__1; +x_120 = l_Lean_Meta_forallTelescopeReducing___rarg(x_117, x_119, x_5, x_118); +if (lean_obj_tag(x_120) == 0) { -lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; uint8_t x_124; -x_120 = lean_ctor_get(x_119, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_119, 1); +lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; uint8_t x_125; +x_121 = lean_ctor_get(x_120, 0); lean_inc(x_121); -lean_dec(x_119); -x_122 = lean_ctor_get(x_121, 1); +x_122 = lean_ctor_get(x_120, 1); lean_inc(x_122); +lean_dec(x_120); +x_123 = lean_ctor_get(x_122, 1); +lean_inc(x_123); +lean_inc(x_112); lean_inc(x_111); lean_inc(x_110); lean_inc(x_109); -lean_inc(x_108); -lean_inc(x_121); -x_123 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_123, 0, x_121); -lean_ctor_set(x_123, 1, x_108); -lean_ctor_set(x_123, 2, x_109); -lean_ctor_set(x_123, 3, x_110); -lean_ctor_set(x_123, 4, x_111); -x_124 = l_Array_isEmpty___rarg(x_120); -if (x_124 == 0) +lean_inc(x_122); +x_124 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_124, 0, x_122); +lean_ctor_set(x_124, 1, x_109); +lean_ctor_set(x_124, 2, x_110); +lean_ctor_set(x_124, 3, x_111); +lean_ctor_set(x_124, 4, x_112); +x_125 = l_Array_isEmpty___rarg(x_121); +if (x_125 == 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_dec(x_123); -x_125 = lean_array_get_size(x_120); +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_dec(x_124); +x_126 = lean_array_get_size(x_121); lean_inc(x_2); -x_126 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_126, 0, x_3); -lean_ctor_set(x_126, 1, x_2); -lean_ctor_set(x_126, 2, x_122); -lean_ctor_set(x_126, 3, x_120); -lean_ctor_set(x_126, 4, x_125); -x_127 = l_Lean_mkOptionalNode___closed__2; -x_128 = lean_array_push(x_127, x_4); -x_129 = l_Array_empty___closed__1; -x_130 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_130, 0, x_128); -lean_ctor_set(x_130, 1, x_129); -x_131 = lean_array_push(x_109, x_126); -x_132 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_111, x_2, x_130); +x_127 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_127, 0, x_3); +lean_ctor_set(x_127, 1, x_2); +lean_ctor_set(x_127, 2, x_123); +lean_ctor_set(x_127, 3, x_121); +lean_ctor_set(x_127, 4, x_126); +x_128 = l_Lean_mkOptionalNode___closed__2; +x_129 = lean_array_push(x_128, x_4); +x_130 = l_Array_empty___closed__1; +x_131 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_131, 0, x_129); +lean_ctor_set(x_131, 1, x_130); +x_132 = lean_array_push(x_110, x_127); +x_133 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_112, x_2, x_131); if (lean_is_scalar(x_12)) { - x_133 = lean_alloc_ctor(0, 5, 0); + x_134 = lean_alloc_ctor(0, 5, 0); } else { - x_133 = x_12; + x_134 = x_12; } -lean_ctor_set(x_133, 0, x_121); -lean_ctor_set(x_133, 1, x_108); -lean_ctor_set(x_133, 2, x_131); -lean_ctor_set(x_133, 3, x_110); -lean_ctor_set(x_133, 4, x_132); -x_134 = lean_box(0); -x_15 = x_134; -x_16 = x_133; -goto block_43; +lean_ctor_set(x_134, 0, x_122); +lean_ctor_set(x_134, 1, x_109); +lean_ctor_set(x_134, 2, x_132); +lean_ctor_set(x_134, 3, x_111); +lean_ctor_set(x_134, 4, x_133); +x_135 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_15 = x_135; +x_16 = x_134; +goto block_71; } else { -lean_object* x_135; +lean_object* x_136; +lean_dec(x_123); lean_dec(x_122); lean_dec(x_121); -lean_dec(x_120); +lean_dec(x_112); lean_dec(x_111); lean_dec(x_110); lean_dec(x_109); -lean_dec(x_108); lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_135 = lean_box(0); -x_15 = x_135; -x_16 = x_123; -goto block_43; +x_136 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_15 = x_136; +x_16 = x_124; +goto block_71; } } else { -lean_object* x_136; lean_object* x_137; lean_object* x_138; +lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_136 = lean_ctor_get(x_119, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_119, 1); +x_137 = lean_ctor_get(x_120, 0); lean_inc(x_137); -lean_dec(x_119); -x_138 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_138, 0, x_137); -lean_ctor_set(x_138, 1, x_108); -lean_ctor_set(x_138, 2, x_109); -lean_ctor_set(x_138, 3, x_110); -lean_ctor_set(x_138, 4, x_111); -x_44 = x_136; -x_45 = x_138; -goto block_72; +x_138 = lean_ctor_get(x_120, 1); +lean_inc(x_138); +lean_dec(x_120); +x_139 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_139, 0, x_138); +lean_ctor_set(x_139, 1, x_109); +lean_ctor_set(x_139, 2, x_110); +lean_ctor_set(x_139, 3, x_111); +lean_ctor_set(x_139, 4, x_112); +x_140 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_140, 0, x_137); +x_15 = x_140; +x_16 = x_139; +goto block_71; } } else { -lean_object* x_139; lean_object* x_140; lean_object* x_141; +lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_dec(x_12); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_139 = lean_ctor_get(x_112, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_112, 1); -lean_inc(x_140); -lean_dec(x_112); -x_141 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_108); -lean_ctor_set(x_141, 2, x_109); -lean_ctor_set(x_141, 3, x_110); -lean_ctor_set(x_141, 4, x_111); -x_44 = x_139; -x_45 = x_141; -goto block_72; +x_141 = lean_ctor_get(x_113, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_113, 1); +lean_inc(x_142); +lean_dec(x_113); +x_143 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_143, 0, x_142); +lean_ctor_set(x_143, 1, x_109); +lean_ctor_set(x_143, 2, x_110); +lean_ctor_set(x_143, 3, x_111); +lean_ctor_set(x_143, 4, x_112); +x_144 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_144, 0, x_141); +x_15 = x_144; +x_16 = x_143; +goto block_71; } } } } 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_182; lean_object* x_183; lean_object* x_200; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_158 = lean_ctor_get(x_7, 0); -x_159 = lean_ctor_get(x_7, 1); -x_160 = lean_ctor_get(x_7, 2); -x_161 = lean_ctor_get(x_7, 3); -x_162 = lean_ctor_get(x_7, 4); -x_163 = lean_ctor_get(x_7, 5); +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_202; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; uint8_t x_246; +x_161 = lean_ctor_get(x_7, 0); +x_162 = lean_ctor_get(x_7, 1); +x_163 = lean_ctor_get(x_7, 2); +x_164 = lean_ctor_get(x_7, 3); +x_165 = lean_ctor_get(x_7, 4); +x_166 = lean_ctor_get(x_7, 5); +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_dec(x_7); -x_238 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_238, 0, x_158); -lean_ctor_set(x_238, 1, x_1); -lean_ctor_set(x_238, 2, x_160); -lean_ctor_set(x_238, 3, x_161); -lean_ctor_set(x_238, 4, x_162); -lean_ctor_set(x_238, 5, x_163); -x_239 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_239, 0, x_238); -lean_ctor_set(x_239, 1, x_8); -lean_ctor_set(x_239, 2, x_9); -lean_ctor_set(x_239, 3, x_10); -lean_ctor_set(x_239, 4, x_11); -x_240 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_239); -x_241 = lean_ctor_get(x_240, 0); -lean_inc(x_241); -x_242 = lean_ctor_get_uint8(x_241, sizeof(void*)*1); -lean_dec(x_241); -if (x_242 == 0) +x_242 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_242, 0, x_161); +lean_ctor_set(x_242, 1, x_1); +lean_ctor_set(x_242, 2, x_163); +lean_ctor_set(x_242, 3, x_164); +lean_ctor_set(x_242, 4, x_165); +lean_ctor_set(x_242, 5, x_166); +x_243 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_243, 0, x_242); +lean_ctor_set(x_243, 1, x_8); +lean_ctor_set(x_243, 2, x_9); +lean_ctor_set(x_243, 3, x_10); +lean_ctor_set(x_243, 4, x_11); +x_244 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_243); +x_245 = lean_ctor_get(x_244, 0); +lean_inc(x_245); +x_246 = lean_ctor_get_uint8(x_245, sizeof(void*)*1); +lean_dec(x_245); +if (x_246 == 0) { -lean_object* x_243; -x_243 = lean_ctor_get(x_240, 1); -lean_inc(x_243); -lean_dec(x_240); -x_200 = x_243; -goto block_237; -} -else -{ -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; -x_244 = lean_ctor_get(x_240, 1); -lean_inc(x_244); -lean_dec(x_240); -x_245 = l_Lean_Meta_SynthInstance_newSubgoal___closed__2; -x_246 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_245, x_5, x_244); -x_247 = lean_ctor_get(x_246, 0); +lean_object* x_247; +x_247 = lean_ctor_get(x_244, 1); lean_inc(x_247); -x_248 = lean_unbox(x_247); -lean_dec(x_247); -if (x_248 == 0) -{ -lean_object* x_249; -x_249 = lean_ctor_get(x_246, 1); -lean_inc(x_249); -lean_dec(x_246); -x_200 = x_249; -goto block_237; +lean_dec(x_244); +x_202 = x_247; +goto block_241; } else { -lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; -x_250 = lean_ctor_get(x_246, 1); -lean_inc(x_250); -lean_dec(x_246); -lean_inc(x_2); -x_251 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_251, 0, x_2); -x_252 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_245, x_251, x_5, x_250); -x_253 = lean_ctor_get(x_252, 1); +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_248 = lean_ctor_get(x_244, 1); +lean_inc(x_248); +lean_dec(x_244); +x_249 = l_Lean_Meta_SynthInstance_newSubgoal___closed__2; +x_250 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_249, x_5, x_248); +x_251 = lean_ctor_get(x_250, 0); +lean_inc(x_251); +x_252 = lean_unbox(x_251); +lean_dec(x_251); +if (x_252 == 0) +{ +lean_object* x_253; +x_253 = lean_ctor_get(x_250, 1); lean_inc(x_253); -lean_dec(x_252); -x_200 = x_253; -goto block_237; +lean_dec(x_250); +x_202 = x_253; +goto block_241; } -} -block_181: +else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; -x_166 = lean_ctor_get(x_165, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_165, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_165, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_165, 3); +lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_254 = lean_ctor_get(x_250, 1); +lean_inc(x_254); +lean_dec(x_250); +lean_inc(x_2); +x_255 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_255, 0, x_2); +x_256 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_249, x_255, x_5, x_254); +x_257 = lean_ctor_get(x_256, 1); +lean_inc(x_257); +lean_dec(x_256); +x_202 = x_257; +goto block_241; +} +} +block_201: +{ +if (lean_obj_tag(x_167) == 0) +{ +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; +x_169 = lean_ctor_get(x_168, 0); lean_inc(x_169); -x_170 = lean_ctor_get(x_165, 4); +x_170 = lean_ctor_get(x_167, 0); lean_inc(x_170); -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); - x_171 = x_165; -} else { - lean_dec_ref(x_165); - x_171 = lean_box(0); -} -x_172 = lean_ctor_get(x_166, 0); +lean_dec(x_167); +x_171 = lean_ctor_get(x_168, 1); +lean_inc(x_171); +x_172 = lean_ctor_get(x_168, 2); lean_inc(x_172); -x_173 = lean_ctor_get(x_166, 2); +x_173 = lean_ctor_get(x_168, 3); lean_inc(x_173); -x_174 = lean_ctor_get(x_166, 3); +x_174 = lean_ctor_get(x_168, 4); lean_inc(x_174); -x_175 = lean_ctor_get(x_166, 4); -lean_inc(x_175); -x_176 = lean_ctor_get(x_166, 5); +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); + lean_ctor_release(x_168, 4); + x_175 = x_168; +} else { + lean_dec_ref(x_168); + x_175 = lean_box(0); +} +x_176 = lean_ctor_get(x_169, 0); lean_inc(x_176); -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); - lean_ctor_release(x_166, 4); - lean_ctor_release(x_166, 5); - x_177 = x_166; +x_177 = lean_ctor_get(x_169, 2); +lean_inc(x_177); +x_178 = lean_ctor_get(x_169, 3); +lean_inc(x_178); +x_179 = lean_ctor_get(x_169, 4); +lean_inc(x_179); +x_180 = lean_ctor_get(x_169, 5); +lean_inc(x_180); +if (lean_is_exclusive(x_169)) { + lean_ctor_release(x_169, 0); + lean_ctor_release(x_169, 1); + lean_ctor_release(x_169, 2); + lean_ctor_release(x_169, 3); + lean_ctor_release(x_169, 4); + lean_ctor_release(x_169, 5); + x_181 = x_169; } else { - lean_dec_ref(x_166); - x_177 = lean_box(0); + lean_dec_ref(x_169); + x_181 = lean_box(0); } -if (lean_is_scalar(x_177)) { - x_178 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_181)) { + x_182 = lean_alloc_ctor(0, 6, 0); } else { - x_178 = x_177; + x_182 = x_181; } -lean_ctor_set(x_178, 0, x_172); -lean_ctor_set(x_178, 1, x_159); -lean_ctor_set(x_178, 2, x_173); -lean_ctor_set(x_178, 3, x_174); -lean_ctor_set(x_178, 4, x_175); -lean_ctor_set(x_178, 5, x_176); -if (lean_is_scalar(x_171)) { - x_179 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_182, 0, x_176); +lean_ctor_set(x_182, 1, x_162); +lean_ctor_set(x_182, 2, x_177); +lean_ctor_set(x_182, 3, x_178); +lean_ctor_set(x_182, 4, x_179); +lean_ctor_set(x_182, 5, x_180); +if (lean_is_scalar(x_175)) { + x_183 = lean_alloc_ctor(0, 5, 0); } else { - x_179 = x_171; + x_183 = x_175; } -lean_ctor_set(x_179, 0, x_178); -lean_ctor_set(x_179, 1, x_167); -lean_ctor_set(x_179, 2, x_168); -lean_ctor_set(x_179, 3, x_169); -lean_ctor_set(x_179, 4, x_170); -x_180 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_180, 0, x_164); -lean_ctor_set(x_180, 1, x_179); -return x_180; +lean_ctor_set(x_183, 0, x_182); +lean_ctor_set(x_183, 1, x_171); +lean_ctor_set(x_183, 2, x_172); +lean_ctor_set(x_183, 3, x_173); +lean_ctor_set(x_183, 4, x_174); +x_184 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_184, 0, x_170); +lean_ctor_set(x_184, 1, x_183); +return x_184; } -block_199: +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_198; -x_184 = lean_ctor_get(x_183, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_183, 1); +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; lean_object* x_200; +x_185 = lean_ctor_get(x_168, 0); lean_inc(x_185); -x_186 = lean_ctor_get(x_183, 2); +x_186 = lean_ctor_get(x_167, 0); lean_inc(x_186); -x_187 = lean_ctor_get(x_183, 3); +lean_dec(x_167); +x_187 = lean_ctor_get(x_168, 1); lean_inc(x_187); -x_188 = lean_ctor_get(x_183, 4); +x_188 = lean_ctor_get(x_168, 2); lean_inc(x_188); -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); - x_189 = x_183; -} else { - lean_dec_ref(x_183); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_184, 0); +x_189 = lean_ctor_get(x_168, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_168, 4); lean_inc(x_190); -x_191 = lean_ctor_get(x_184, 2); -lean_inc(x_191); -x_192 = lean_ctor_get(x_184, 3); +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); + lean_ctor_release(x_168, 4); + x_191 = x_168; +} else { + lean_dec_ref(x_168); + x_191 = lean_box(0); +} +x_192 = lean_ctor_get(x_185, 0); lean_inc(x_192); -x_193 = lean_ctor_get(x_184, 4); +x_193 = lean_ctor_get(x_185, 2); lean_inc(x_193); -x_194 = lean_ctor_get(x_184, 5); +x_194 = lean_ctor_get(x_185, 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); - lean_ctor_release(x_184, 4); - lean_ctor_release(x_184, 5); - x_195 = x_184; +x_195 = lean_ctor_get(x_185, 4); +lean_inc(x_195); +x_196 = lean_ctor_get(x_185, 5); +lean_inc(x_196); +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_197 = x_185; } else { - lean_dec_ref(x_184); - x_195 = lean_box(0); + lean_dec_ref(x_185); + x_197 = lean_box(0); } -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_197)) { + x_198 = lean_alloc_ctor(0, 6, 0); } else { - x_196 = x_195; + x_198 = x_197; } -lean_ctor_set(x_196, 0, x_190); -lean_ctor_set(x_196, 1, x_159); -lean_ctor_set(x_196, 2, x_191); -lean_ctor_set(x_196, 3, x_192); -lean_ctor_set(x_196, 4, x_193); -lean_ctor_set(x_196, 5, x_194); -if (lean_is_scalar(x_189)) { - x_197 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_198, 0, x_192); +lean_ctor_set(x_198, 1, x_162); +lean_ctor_set(x_198, 2, x_193); +lean_ctor_set(x_198, 3, x_194); +lean_ctor_set(x_198, 4, x_195); +lean_ctor_set(x_198, 5, x_196); +if (lean_is_scalar(x_191)) { + x_199 = lean_alloc_ctor(0, 5, 0); } else { - x_197 = x_189; + x_199 = x_191; } -lean_ctor_set(x_197, 0, x_196); -lean_ctor_set(x_197, 1, x_185); -lean_ctor_set(x_197, 2, x_186); -lean_ctor_set(x_197, 3, x_187); -lean_ctor_set(x_197, 4, x_188); -x_198 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_198, 0, x_182); -lean_ctor_set(x_198, 1, x_197); -return x_198; +lean_ctor_set(x_199, 0, x_198); +lean_ctor_set(x_199, 1, x_187); +lean_ctor_set(x_199, 2, x_188); +lean_ctor_set(x_199, 3, x_189); +lean_ctor_set(x_199, 4, x_190); +x_200 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_200, 0, x_186); +lean_ctor_set(x_200, 1, x_199); +return x_200; } -block_237: +} +block_241: { -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_201 = lean_ctor_get(x_200, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_200, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_200, 2); +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_203 = lean_ctor_get(x_202, 0); lean_inc(x_203); -x_204 = lean_ctor_get(x_200, 3); +x_204 = lean_ctor_get(x_202, 1); lean_inc(x_204); -x_205 = lean_ctor_get(x_200, 4); +x_205 = lean_ctor_get(x_202, 2); lean_inc(x_205); -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_206 = x_200; +x_206 = lean_ctor_get(x_202, 3); +lean_inc(x_206); +x_207 = lean_ctor_get(x_202, 4); +lean_inc(x_207); +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); + lean_ctor_release(x_202, 4); + x_208 = x_202; } else { - lean_dec_ref(x_200); - x_206 = lean_box(0); + lean_dec_ref(x_202); + x_208 = lean_box(0); } lean_inc(x_5); lean_inc(x_3); -x_207 = l_Lean_Meta_inferType(x_3, x_5, x_201); -if (lean_obj_tag(x_207) == 0) +x_209 = l_Lean_Meta_inferType(x_3, x_5, x_203); +if (lean_obj_tag(x_209) == 0) { -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_208 = lean_ctor_get(x_207, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_207, 1); -lean_inc(x_209); -lean_dec(x_207); -x_210 = l_Lean_Meta_instantiateMVars(x_208, x_5, x_209); -x_211 = lean_ctor_get(x_210, 0); +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_210 = lean_ctor_get(x_209, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_209, 1); lean_inc(x_211); -x_212 = lean_ctor_get(x_210, 1); -lean_inc(x_212); -lean_dec(x_210); -x_213 = l_Lean_Meta_SynthInstance_getInstances___closed__1; -x_214 = l_Lean_Meta_forallTelescopeReducing___rarg(x_211, x_213, x_5, x_212); -if (lean_obj_tag(x_214) == 0) +lean_dec(x_209); +x_212 = l_Lean_Meta_instantiateMVars(x_210, x_5, x_211); +x_213 = lean_ctor_get(x_212, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_212, 1); +lean_inc(x_214); +lean_dec(x_212); +x_215 = l_Lean_Meta_SynthInstance_getInstances___closed__1; +x_216 = l_Lean_Meta_forallTelescopeReducing___rarg(x_213, x_215, x_5, x_214); +if (lean_obj_tag(x_216) == 0) { -lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; uint8_t x_219; -x_215 = lean_ctor_get(x_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_ctor_get(x_216, 1); +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; uint8_t x_221; +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_ctor_get(x_218, 1); +lean_inc(x_219); +lean_inc(x_207); +lean_inc(x_206); lean_inc(x_205); lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_inc(x_216); -if (lean_is_scalar(x_206)) { - x_218 = lean_alloc_ctor(0, 5, 0); +lean_inc(x_218); +if (lean_is_scalar(x_208)) { + x_220 = lean_alloc_ctor(0, 5, 0); } else { - x_218 = x_206; + x_220 = x_208; } -lean_ctor_set(x_218, 0, x_216); -lean_ctor_set(x_218, 1, x_202); -lean_ctor_set(x_218, 2, x_203); -lean_ctor_set(x_218, 3, x_204); -lean_ctor_set(x_218, 4, x_205); -x_219 = l_Array_isEmpty___rarg(x_215); -if (x_219 == 0) +lean_ctor_set(x_220, 0, x_218); +lean_ctor_set(x_220, 1, x_204); +lean_ctor_set(x_220, 2, x_205); +lean_ctor_set(x_220, 3, x_206); +lean_ctor_set(x_220, 4, x_207); +x_221 = l_Array_isEmpty___rarg(x_217); +if (x_221 == 0) { -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_dec(x_218); -x_220 = lean_array_get_size(x_215); +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_dec(x_220); +x_222 = lean_array_get_size(x_217); lean_inc(x_2); -x_221 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_221, 0, x_3); -lean_ctor_set(x_221, 1, x_2); -lean_ctor_set(x_221, 2, x_217); -lean_ctor_set(x_221, 3, x_215); -lean_ctor_set(x_221, 4, x_220); -x_222 = l_Lean_mkOptionalNode___closed__2; -x_223 = lean_array_push(x_222, x_4); -x_224 = l_Array_empty___closed__1; -x_225 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_225, 0, x_223); -lean_ctor_set(x_225, 1, x_224); -x_226 = lean_array_push(x_203, x_221); -x_227 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_205, x_2, x_225); +x_223 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_223, 0, x_3); +lean_ctor_set(x_223, 1, x_2); +lean_ctor_set(x_223, 2, x_219); +lean_ctor_set(x_223, 3, x_217); +lean_ctor_set(x_223, 4, x_222); +x_224 = l_Lean_mkOptionalNode___closed__2; +x_225 = lean_array_push(x_224, x_4); +x_226 = l_Array_empty___closed__1; +x_227 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_227, 0, x_225); +lean_ctor_set(x_227, 1, x_226); +x_228 = lean_array_push(x_205, x_223); +x_229 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_207, x_2, x_227); if (lean_is_scalar(x_12)) { - x_228 = lean_alloc_ctor(0, 5, 0); + x_230 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_12; + x_230 = x_12; } -lean_ctor_set(x_228, 0, x_216); -lean_ctor_set(x_228, 1, x_202); -lean_ctor_set(x_228, 2, x_226); -lean_ctor_set(x_228, 3, x_204); -lean_ctor_set(x_228, 4, x_227); -x_229 = lean_box(0); -x_164 = x_229; -x_165 = x_228; -goto block_181; +lean_ctor_set(x_230, 0, x_218); +lean_ctor_set(x_230, 1, x_204); +lean_ctor_set(x_230, 2, x_228); +lean_ctor_set(x_230, 3, x_206); +lean_ctor_set(x_230, 4, x_229); +x_231 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_167 = x_231; +x_168 = x_230; +goto block_201; } else { -lean_object* x_230; +lean_object* x_232; +lean_dec(x_219); +lean_dec(x_218); lean_dec(x_217); -lean_dec(x_216); -lean_dec(x_215); +lean_dec(x_207); +lean_dec(x_206); lean_dec(x_205); lean_dec(x_204); -lean_dec(x_203); -lean_dec(x_202); lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_230 = lean_box(0); -x_164 = x_230; -x_165 = x_218; -goto block_181; +x_232 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_167 = x_232; +x_168 = x_220; +goto block_201; } } else { -lean_object* x_231; lean_object* x_232; lean_object* x_233; +lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_dec(x_12); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_231 = lean_ctor_get(x_214, 0); -lean_inc(x_231); -x_232 = lean_ctor_get(x_214, 1); -lean_inc(x_232); -lean_dec(x_214); -if (lean_is_scalar(x_206)) { - x_233 = lean_alloc_ctor(0, 5, 0); +x_233 = lean_ctor_get(x_216, 0); +lean_inc(x_233); +x_234 = lean_ctor_get(x_216, 1); +lean_inc(x_234); +lean_dec(x_216); +if (lean_is_scalar(x_208)) { + x_235 = lean_alloc_ctor(0, 5, 0); } else { - x_233 = x_206; + x_235 = x_208; } -lean_ctor_set(x_233, 0, x_232); -lean_ctor_set(x_233, 1, x_202); -lean_ctor_set(x_233, 2, x_203); -lean_ctor_set(x_233, 3, x_204); -lean_ctor_set(x_233, 4, x_205); -x_182 = x_231; -x_183 = x_233; -goto block_199; +lean_ctor_set(x_235, 0, x_234); +lean_ctor_set(x_235, 1, x_204); +lean_ctor_set(x_235, 2, x_205); +lean_ctor_set(x_235, 3, x_206); +lean_ctor_set(x_235, 4, x_207); +x_236 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_236, 0, x_233); +x_167 = x_236; +x_168 = x_235; +goto block_201; } } else { -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_dec(x_12); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_234 = lean_ctor_get(x_207, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_207, 1); -lean_inc(x_235); -lean_dec(x_207); -if (lean_is_scalar(x_206)) { - x_236 = lean_alloc_ctor(0, 5, 0); +x_237 = lean_ctor_get(x_209, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_209, 1); +lean_inc(x_238); +lean_dec(x_209); +if (lean_is_scalar(x_208)) { + x_239 = lean_alloc_ctor(0, 5, 0); } else { - x_236 = x_206; + x_239 = x_208; } -lean_ctor_set(x_236, 0, x_235); -lean_ctor_set(x_236, 1, x_202); -lean_ctor_set(x_236, 2, x_203); -lean_ctor_set(x_236, 3, x_204); -lean_ctor_set(x_236, 4, x_205); -x_182 = x_234; -x_183 = x_236; -goto block_199; +lean_ctor_set(x_239, 0, x_238); +lean_ctor_set(x_239, 1, x_204); +lean_ctor_set(x_239, 2, x_205); +lean_ctor_set(x_239, 3, x_206); +lean_ctor_set(x_239, 4, x_207); +x_240 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_240, 0, x_237); +x_167 = x_240; +x_168 = x_239; +goto block_201; } } } @@ -6095,635 +6027,753 @@ x_6 = lean_ctor_get(x_4, 0); x_7 = !lean_is_exclusive(x_6); if (x_7 == 0) { -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_38; +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_66; x_8 = lean_ctor_get(x_6, 1); lean_inc(x_1); lean_ctor_set(x_6, 1, x_1); lean_inc(x_3); -x_38 = l_Lean_Meta_inferType(x_2, x_3, x_6); -if (lean_obj_tag(x_38) == 0) +x_66 = l_Lean_Meta_inferType(x_2, x_3, x_6); +if (lean_obj_tag(x_66) == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_38, 1); -lean_inc(x_40); -lean_dec(x_38); -x_41 = l_Lean_Meta_instantiateMVars(x_39, x_3, x_40); +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_67 = lean_ctor_get(x_66, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_66, 1); +lean_inc(x_68); +lean_dec(x_66); +x_69 = l_Lean_Meta_instantiateMVars(x_67, x_3, x_68); lean_dec(x_3); -x_42 = !lean_is_exclusive(x_41); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; -x_43 = lean_ctor_get(x_41, 0); -x_44 = lean_ctor_get(x_41, 1); -x_45 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_43); -x_46 = !lean_is_exclusive(x_44); -if (x_46 == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_44, 1); -lean_dec(x_47); -lean_ctor_set(x_44, 1, x_8); -lean_ctor_set(x_4, 0, x_44); -lean_ctor_set(x_41, 1, x_4); -lean_ctor_set(x_41, 0, x_45); -return x_41; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_69, 1); +lean_inc(x_71); +lean_dec(x_69); +lean_ctor_set(x_4, 0, x_71); +x_72 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_70); +x_73 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_73, 0, x_72); +x_9 = x_73; +x_10 = x_4; +goto block_65; } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_48 = lean_ctor_get(x_44, 0); -x_49 = lean_ctor_get(x_44, 2); -x_50 = lean_ctor_get(x_44, 3); -x_51 = lean_ctor_get(x_44, 4); -x_52 = lean_ctor_get(x_44, 5); -lean_inc(x_52); -lean_inc(x_51); -lean_inc(x_50); -lean_inc(x_49); -lean_inc(x_48); -lean_dec(x_44); -x_53 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_53, 0, x_48); -lean_ctor_set(x_53, 1, x_8); -lean_ctor_set(x_53, 2, x_49); -lean_ctor_set(x_53, 3, x_50); -lean_ctor_set(x_53, 4, x_51); -lean_ctor_set(x_53, 5, x_52); -lean_ctor_set(x_4, 0, x_53); -lean_ctor_set(x_41, 1, x_4); -lean_ctor_set(x_41, 0, x_45); -return x_41; -} -} -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; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_41); -x_56 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_54); -x_57 = lean_ctor_get(x_55, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_55, 2); -lean_inc(x_58); -x_59 = lean_ctor_get(x_55, 3); -lean_inc(x_59); -x_60 = lean_ctor_get(x_55, 4); -lean_inc(x_60); -x_61 = lean_ctor_get(x_55, 5); -lean_inc(x_61); -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_62 = x_55; -} else { - lean_dec_ref(x_55); - x_62 = lean_box(0); -} -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 6, 0); -} else { - x_63 = x_62; -} -lean_ctor_set(x_63, 0, x_57); -lean_ctor_set(x_63, 1, x_8); -lean_ctor_set(x_63, 2, x_58); -lean_ctor_set(x_63, 3, x_59); -lean_ctor_set(x_63, 4, x_60); -lean_ctor_set(x_63, 5, x_61); -lean_ctor_set(x_4, 0, x_63); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_56); -lean_ctor_set(x_64, 1, x_4); -return x_64; -} -} -else -{ -lean_object* x_65; lean_object* x_66; +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_dec(x_3); lean_dec(x_1); -x_65 = lean_ctor_get(x_38, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_38, 1); -lean_inc(x_66); -lean_dec(x_38); -lean_ctor_set(x_4, 0, x_66); -x_9 = x_65; +x_74 = lean_ctor_get(x_66, 0); +lean_inc(x_74); +x_75 = lean_ctor_get(x_66, 1); +lean_inc(x_75); +lean_dec(x_66); +lean_ctor_set(x_4, 0, x_75); +x_76 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_76, 0, x_74); +x_9 = x_76; x_10 = x_4; -goto block_37; +goto block_65; } -block_37: +block_65: { -uint8_t x_11; -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) +if (lean_obj_tag(x_9) == 0) { -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_10, 0); -x_13 = !lean_is_exclusive(x_12); +lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_9, 0); +lean_inc(x_12); +lean_dec(x_9); +x_13 = !lean_is_exclusive(x_10); if (x_13 == 0) { -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_12, 1); +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_10, 0); lean_dec(x_14); -lean_ctor_set(x_12, 1, x_8); -x_15 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_15, 0, x_9); -lean_ctor_set(x_15, 1, x_10); -return x_15; +x_15 = !lean_is_exclusive(x_11); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_11, 1); +lean_dec(x_16); +lean_ctor_set(x_11, 1, x_8); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_12); +lean_ctor_set(x_17, 1, x_10); +return x_17; } 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; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 2); -x_18 = lean_ctor_get(x_12, 3); -x_19 = lean_ctor_get(x_12, 4); -x_20 = lean_ctor_get(x_12, 5); +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_18 = lean_ctor_get(x_11, 0); +x_19 = lean_ctor_get(x_11, 2); +x_20 = lean_ctor_get(x_11, 3); +x_21 = lean_ctor_get(x_11, 4); +x_22 = lean_ctor_get(x_11, 5); +lean_inc(x_22); +lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_12); -x_21 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_21, 0, x_16); -lean_ctor_set(x_21, 1, x_8); -lean_ctor_set(x_21, 2, x_17); -lean_ctor_set(x_21, 3, x_18); -lean_ctor_set(x_21, 4, x_19); -lean_ctor_set(x_21, 5, x_20); -lean_ctor_set(x_10, 0, x_21); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_9); -lean_ctor_set(x_22, 1, x_10); -return x_22; +lean_dec(x_11); +x_23 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_23, 0, x_18); +lean_ctor_set(x_23, 1, x_8); +lean_ctor_set(x_23, 2, x_19); +lean_ctor_set(x_23, 3, x_20); +lean_ctor_set(x_23, 4, x_21); +lean_ctor_set(x_23, 5, x_22); +lean_ctor_set(x_10, 0, x_23); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_12); +lean_ctor_set(x_24, 1, x_10); +return x_24; } } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_23 = lean_ctor_get(x_10, 0); -x_24 = lean_ctor_get(x_10, 1); -x_25 = lean_ctor_get(x_10, 2); -x_26 = lean_ctor_get(x_10, 3); -x_27 = lean_ctor_get(x_10, 4); +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_10, 1); +x_26 = lean_ctor_get(x_10, 2); +x_27 = lean_ctor_get(x_10, 3); +x_28 = lean_ctor_get(x_10, 4); +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_dec(x_10); -x_28 = lean_ctor_get(x_23, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_23, 2); +x_29 = lean_ctor_get(x_11, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_23, 3); +x_30 = lean_ctor_get(x_11, 2); lean_inc(x_30); -x_31 = lean_ctor_get(x_23, 4); +x_31 = lean_ctor_get(x_11, 3); lean_inc(x_31); -x_32 = lean_ctor_get(x_23, 5); +x_32 = lean_ctor_get(x_11, 4); lean_inc(x_32); -if (lean_is_exclusive(x_23)) { - lean_ctor_release(x_23, 0); - lean_ctor_release(x_23, 1); - lean_ctor_release(x_23, 2); - lean_ctor_release(x_23, 3); - lean_ctor_release(x_23, 4); - lean_ctor_release(x_23, 5); - x_33 = x_23; +x_33 = lean_ctor_get(x_11, 5); +lean_inc(x_33); +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); + lean_ctor_release(x_11, 5); + x_34 = x_11; } else { - lean_dec_ref(x_23); - x_33 = lean_box(0); + lean_dec_ref(x_11); + x_34 = lean_box(0); } -if (lean_is_scalar(x_33)) { - x_34 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 6, 0); } else { - x_34 = x_33; + x_35 = x_34; +} +lean_ctor_set(x_35, 0, x_29); +lean_ctor_set(x_35, 1, x_8); +lean_ctor_set(x_35, 2, x_30); +lean_ctor_set(x_35, 3, x_31); +lean_ctor_set(x_35, 4, x_32); +lean_ctor_set(x_35, 5, x_33); +x_36 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_25); +lean_ctor_set(x_36, 2, x_26); +lean_ctor_set(x_36, 3, x_27); +lean_ctor_set(x_36, 4, x_28); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_12); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +else +{ +lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_38 = lean_ctor_get(x_10, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_9, 0); +lean_inc(x_39); +lean_dec(x_9); +x_40 = !lean_is_exclusive(x_10); +if (x_40 == 0) +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_10, 0); +lean_dec(x_41); +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, 1); +lean_dec(x_43); +lean_ctor_set(x_38, 1, x_8); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_10); +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; +x_45 = lean_ctor_get(x_38, 0); +x_46 = lean_ctor_get(x_38, 2); +x_47 = lean_ctor_get(x_38, 3); +x_48 = lean_ctor_get(x_38, 4); +x_49 = lean_ctor_get(x_38, 5); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_38); +x_50 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_8); +lean_ctor_set(x_50, 2, x_46); +lean_ctor_set(x_50, 3, x_47); +lean_ctor_set(x_50, 4, x_48); +lean_ctor_set(x_50, 5, x_49); +lean_ctor_set(x_10, 0, x_50); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_39); +lean_ctor_set(x_51, 1, x_10); +return x_51; +} +} +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; +x_52 = lean_ctor_get(x_10, 1); +x_53 = lean_ctor_get(x_10, 2); +x_54 = lean_ctor_get(x_10, 3); +x_55 = lean_ctor_get(x_10, 4); +lean_inc(x_55); +lean_inc(x_54); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_10); +x_56 = lean_ctor_get(x_38, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_38, 2); +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); +x_60 = lean_ctor_get(x_38, 5); +lean_inc(x_60); +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); + lean_ctor_release(x_38, 5); + x_61 = x_38; +} else { + lean_dec_ref(x_38); + x_61 = lean_box(0); +} +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 6, 0); +} else { + x_62 = x_61; +} +lean_ctor_set(x_62, 0, x_56); +lean_ctor_set(x_62, 1, x_8); +lean_ctor_set(x_62, 2, x_57); +lean_ctor_set(x_62, 3, x_58); +lean_ctor_set(x_62, 4, x_59); +lean_ctor_set(x_62, 5, x_60); +x_63 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_52); +lean_ctor_set(x_63, 2, x_53); +lean_ctor_set(x_63, 3, x_54); +lean_ctor_set(x_63, 4, x_55); +x_64 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_64, 0, x_39); +lean_ctor_set(x_64, 1, x_63); +return x_64; } -lean_ctor_set(x_34, 0, x_28); -lean_ctor_set(x_34, 1, x_8); -lean_ctor_set(x_34, 2, x_29); -lean_ctor_set(x_34, 3, x_30); -lean_ctor_set(x_34, 4, x_31); -lean_ctor_set(x_34, 5, x_32); -x_35 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_35, 0, x_34); -lean_ctor_set(x_35, 1, x_24); -lean_ctor_set(x_35, 2, x_25); -lean_ctor_set(x_35, 3, x_26); -lean_ctor_set(x_35, 4, x_27); -x_36 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_36, 0, x_9); -lean_ctor_set(x_36, 1, x_35); -return x_36; } } } 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_91; lean_object* x_92; -x_67 = lean_ctor_get(x_6, 0); -x_68 = lean_ctor_get(x_6, 1); -x_69 = lean_ctor_get(x_6, 2); -x_70 = lean_ctor_get(x_6, 3); -x_71 = lean_ctor_get(x_6, 4); -x_72 = lean_ctor_get(x_6, 5); -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_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_118; lean_object* x_119; +x_77 = lean_ctor_get(x_6, 0); +x_78 = lean_ctor_get(x_6, 1); +x_79 = lean_ctor_get(x_6, 2); +x_80 = lean_ctor_get(x_6, 3); +x_81 = lean_ctor_get(x_6, 4); +x_82 = lean_ctor_get(x_6, 5); +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_6); lean_inc(x_1); -x_91 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_91, 0, x_67); -lean_ctor_set(x_91, 1, x_1); -lean_ctor_set(x_91, 2, x_69); -lean_ctor_set(x_91, 3, x_70); -lean_ctor_set(x_91, 4, x_71); -lean_ctor_set(x_91, 5, x_72); +x_118 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_118, 0, x_77); +lean_ctor_set(x_118, 1, x_1); +lean_ctor_set(x_118, 2, x_79); +lean_ctor_set(x_118, 3, x_80); +lean_ctor_set(x_118, 4, x_81); +lean_ctor_set(x_118, 5, x_82); lean_inc(x_3); -x_92 = l_Lean_Meta_inferType(x_2, x_3, x_91); -if (lean_obj_tag(x_92) == 0) +x_119 = l_Lean_Meta_inferType(x_2, x_3, x_118); +if (lean_obj_tag(x_119) == 0) { -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; -x_93 = lean_ctor_get(x_92, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_92, 1); -lean_inc(x_94); -lean_dec(x_92); -x_95 = l_Lean_Meta_instantiateMVars(x_93, x_3, x_94); +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_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 = l_Lean_Meta_instantiateMVars(x_120, x_3, x_121); lean_dec(x_3); -x_96 = lean_ctor_get(x_95, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_95, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_95)) { - lean_ctor_release(x_95, 0); - lean_ctor_release(x_95, 1); - x_98 = x_95; -} else { - lean_dec_ref(x_95); - x_98 = lean_box(0); -} -x_99 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_96); -x_100 = lean_ctor_get(x_97, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_97, 2); -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); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 6, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_100); -lean_ctor_set(x_106, 1, x_68); -lean_ctor_set(x_106, 2, x_101); -lean_ctor_set(x_106, 3, x_102); -lean_ctor_set(x_106, 4, x_103); -lean_ctor_set(x_106, 5, x_104); -lean_ctor_set(x_4, 0, x_106); -if (lean_is_scalar(x_98)) { - x_107 = lean_alloc_ctor(0, 2, 0); -} else { - x_107 = x_98; -} -lean_ctor_set(x_107, 0, x_99); -lean_ctor_set(x_107, 1, x_4); -return x_107; +x_123 = lean_ctor_get(x_122, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_122, 1); +lean_inc(x_124); +lean_dec(x_122); +lean_ctor_set(x_4, 0, x_124); +x_125 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_123); +x_126 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_126, 0, x_125); +x_83 = x_126; +x_84 = x_4; +goto block_117; } else { -lean_object* x_108; lean_object* x_109; +lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_dec(x_3); lean_dec(x_1); -x_108 = lean_ctor_get(x_92, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_92, 1); -lean_inc(x_109); -lean_dec(x_92); -lean_ctor_set(x_4, 0, x_109); -x_73 = x_108; -x_74 = x_4; -goto block_90; +x_127 = lean_ctor_get(x_119, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_119, 1); +lean_inc(x_128); +lean_dec(x_119); +lean_ctor_set(x_4, 0, x_128); +x_129 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_129, 0, x_127); +x_83 = x_129; +x_84 = x_4; +goto block_117; } -block_90: +block_117: { -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_75 = lean_ctor_get(x_74, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_74, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_74, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_74, 3); -lean_inc(x_78); -x_79 = lean_ctor_get(x_74, 4); -lean_inc(x_79); -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_80 = x_74; -} else { - lean_dec_ref(x_74); - x_80 = lean_box(0); -} -x_81 = lean_ctor_get(x_75, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_75, 2); -lean_inc(x_82); -x_83 = lean_ctor_get(x_75, 3); -lean_inc(x_83); -x_84 = lean_ctor_get(x_75, 4); -lean_inc(x_84); -x_85 = lean_ctor_get(x_75, 5); +if (lean_obj_tag(x_83) == 0) +{ +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_85 = lean_ctor_get(x_84, 0); lean_inc(x_85); -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); - lean_ctor_release(x_75, 5); - x_86 = x_75; +x_86 = lean_ctor_get(x_83, 0); +lean_inc(x_86); +lean_dec(x_83); +x_87 = lean_ctor_get(x_84, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_84, 2); +lean_inc(x_88); +x_89 = lean_ctor_get(x_84, 3); +lean_inc(x_89); +x_90 = lean_ctor_get(x_84, 4); +lean_inc(x_90); +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); + x_91 = x_84; } else { - lean_dec_ref(x_75); - x_86 = lean_box(0); + lean_dec_ref(x_84); + x_91 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 6, 0); +x_92 = lean_ctor_get(x_85, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_85, 2); +lean_inc(x_93); +x_94 = lean_ctor_get(x_85, 3); +lean_inc(x_94); +x_95 = lean_ctor_get(x_85, 4); +lean_inc(x_95); +x_96 = lean_ctor_get(x_85, 5); +lean_inc(x_96); +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_97 = x_85; } else { - x_87 = x_86; + lean_dec_ref(x_85); + x_97 = lean_box(0); } -lean_ctor_set(x_87, 0, x_81); -lean_ctor_set(x_87, 1, x_68); -lean_ctor_set(x_87, 2, x_82); -lean_ctor_set(x_87, 3, x_83); -lean_ctor_set(x_87, 4, x_84); -lean_ctor_set(x_87, 5, x_85); -if (lean_is_scalar(x_80)) { - x_88 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_97)) { + x_98 = lean_alloc_ctor(0, 6, 0); } else { - x_88 = x_80; + x_98 = x_97; +} +lean_ctor_set(x_98, 0, x_92); +lean_ctor_set(x_98, 1, x_78); +lean_ctor_set(x_98, 2, x_93); +lean_ctor_set(x_98, 3, x_94); +lean_ctor_set(x_98, 4, x_95); +lean_ctor_set(x_98, 5, x_96); +if (lean_is_scalar(x_91)) { + x_99 = lean_alloc_ctor(0, 5, 0); +} else { + x_99 = x_91; +} +lean_ctor_set(x_99, 0, x_98); +lean_ctor_set(x_99, 1, x_87); +lean_ctor_set(x_99, 2, x_88); +lean_ctor_set(x_99, 3, x_89); +lean_ctor_set(x_99, 4, x_90); +x_100 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_100, 0, x_86); +lean_ctor_set(x_100, 1, x_99); +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; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_101 = lean_ctor_get(x_84, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_83, 0); +lean_inc(x_102); +lean_dec(x_83); +x_103 = lean_ctor_get(x_84, 1); +lean_inc(x_103); +x_104 = lean_ctor_get(x_84, 2); +lean_inc(x_104); +x_105 = lean_ctor_get(x_84, 3); +lean_inc(x_105); +x_106 = lean_ctor_get(x_84, 4); +lean_inc(x_106); +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); + x_107 = x_84; +} else { + lean_dec_ref(x_84); + x_107 = lean_box(0); +} +x_108 = lean_ctor_get(x_101, 0); +lean_inc(x_108); +x_109 = lean_ctor_get(x_101, 2); +lean_inc(x_109); +x_110 = lean_ctor_get(x_101, 3); +lean_inc(x_110); +x_111 = lean_ctor_get(x_101, 4); +lean_inc(x_111); +x_112 = lean_ctor_get(x_101, 5); +lean_inc(x_112); +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_113 = x_101; +} else { + lean_dec_ref(x_101); + x_113 = lean_box(0); +} +if (lean_is_scalar(x_113)) { + x_114 = lean_alloc_ctor(0, 6, 0); +} else { + x_114 = x_113; +} +lean_ctor_set(x_114, 0, x_108); +lean_ctor_set(x_114, 1, x_78); +lean_ctor_set(x_114, 2, x_109); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +lean_ctor_set(x_114, 5, x_112); +if (lean_is_scalar(x_107)) { + x_115 = lean_alloc_ctor(0, 5, 0); +} else { + x_115 = x_107; +} +lean_ctor_set(x_115, 0, x_114); +lean_ctor_set(x_115, 1, x_103); +lean_ctor_set(x_115, 2, x_104); +lean_ctor_set(x_115, 3, x_105); +lean_ctor_set(x_115, 4, x_106); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_102); +lean_ctor_set(x_116, 1, x_115); +return x_116; } -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_76); -lean_ctor_set(x_88, 2, x_77); -lean_ctor_set(x_88, 3, x_78); -lean_ctor_set(x_88, 4, x_79); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_73); -lean_ctor_set(x_89, 1, x_88); -return x_89; } } } 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_140; lean_object* x_141; -x_110 = lean_ctor_get(x_4, 0); -x_111 = lean_ctor_get(x_4, 1); -x_112 = lean_ctor_get(x_4, 2); -x_113 = lean_ctor_get(x_4, 3); -x_114 = lean_ctor_get(x_4, 4); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_inc(x_111); -lean_inc(x_110); +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_177; lean_object* x_178; +x_130 = lean_ctor_get(x_4, 0); +x_131 = lean_ctor_get(x_4, 1); +x_132 = lean_ctor_get(x_4, 2); +x_133 = lean_ctor_get(x_4, 3); +x_134 = lean_ctor_get(x_4, 4); +lean_inc(x_134); +lean_inc(x_133); +lean_inc(x_132); +lean_inc(x_131); +lean_inc(x_130); lean_dec(x_4); -x_115 = lean_ctor_get(x_110, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_110, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_110, 2); -lean_inc(x_117); -x_118 = lean_ctor_get(x_110, 3); -lean_inc(x_118); -x_119 = lean_ctor_get(x_110, 4); -lean_inc(x_119); -x_120 = lean_ctor_get(x_110, 5); -lean_inc(x_120); -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_121 = x_110; +x_135 = lean_ctor_get(x_130, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_130, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_130, 2); +lean_inc(x_137); +x_138 = lean_ctor_get(x_130, 3); +lean_inc(x_138); +x_139 = lean_ctor_get(x_130, 4); +lean_inc(x_139); +x_140 = lean_ctor_get(x_130, 5); +lean_inc(x_140); +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_141 = x_130; } else { - lean_dec_ref(x_110); - x_121 = lean_box(0); + lean_dec_ref(x_130); + x_141 = lean_box(0); } lean_inc(x_1); -if (lean_is_scalar(x_121)) { - x_140 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_141)) { + x_177 = lean_alloc_ctor(0, 6, 0); } else { - x_140 = x_121; + x_177 = x_141; } -lean_ctor_set(x_140, 0, x_115); -lean_ctor_set(x_140, 1, x_1); -lean_ctor_set(x_140, 2, x_117); -lean_ctor_set(x_140, 3, x_118); -lean_ctor_set(x_140, 4, x_119); -lean_ctor_set(x_140, 5, x_120); +lean_ctor_set(x_177, 0, x_135); +lean_ctor_set(x_177, 1, x_1); +lean_ctor_set(x_177, 2, x_137); +lean_ctor_set(x_177, 3, x_138); +lean_ctor_set(x_177, 4, x_139); +lean_ctor_set(x_177, 5, x_140); lean_inc(x_3); -x_141 = l_Lean_Meta_inferType(x_2, x_3, x_140); -if (lean_obj_tag(x_141) == 0) +x_178 = l_Lean_Meta_inferType(x_2, x_3, x_177); +if (lean_obj_tag(x_178) == 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; -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 = l_Lean_Meta_instantiateMVars(x_142, x_3, x_143); +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_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 = l_Lean_Meta_instantiateMVars(x_179, x_3, x_180); lean_dec(x_3); -x_145 = lean_ctor_get(x_144, 0); +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(0, 5, 0); +lean_ctor_set(x_184, 0, x_183); +lean_ctor_set(x_184, 1, x_131); +lean_ctor_set(x_184, 2, x_132); +lean_ctor_set(x_184, 3, x_133); +lean_ctor_set(x_184, 4, x_134); +x_185 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_182); +x_186 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_186, 0, x_185); +x_142 = x_186; +x_143 = x_184; +goto block_176; +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; +lean_dec(x_3); +lean_dec(x_1); +x_187 = lean_ctor_get(x_178, 0); +lean_inc(x_187); +x_188 = lean_ctor_get(x_178, 1); +lean_inc(x_188); +lean_dec(x_178); +x_189 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_189, 0, x_188); +lean_ctor_set(x_189, 1, x_131); +lean_ctor_set(x_189, 2, x_132); +lean_ctor_set(x_189, 3, x_133); +lean_ctor_set(x_189, 4, x_134); +x_190 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_190, 0, x_187); +x_142 = x_190; +x_143 = x_189; +goto block_176; +} +block_176: +{ +if (lean_obj_tag(x_142) == 0) +{ +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_143, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_142, 0); lean_inc(x_145); -x_146 = lean_ctor_get(x_144, 1); +lean_dec(x_142); +x_146 = lean_ctor_get(x_143, 1); lean_inc(x_146); +x_147 = lean_ctor_get(x_143, 2); +lean_inc(x_147); +x_148 = lean_ctor_get(x_143, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_143, 4); +lean_inc(x_149); +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_150 = x_143; +} else { + lean_dec_ref(x_143); + x_150 = lean_box(0); +} +x_151 = lean_ctor_get(x_144, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_144, 2); +lean_inc(x_152); +x_153 = lean_ctor_get(x_144, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_144, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_144, 5); +lean_inc(x_155); if (lean_is_exclusive(x_144)) { lean_ctor_release(x_144, 0); lean_ctor_release(x_144, 1); - x_147 = x_144; + 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_156 = x_144; } else { lean_dec_ref(x_144); - x_147 = lean_box(0); + x_156 = lean_box(0); } -x_148 = l_Lean_Meta_SynthInstance_mkTableKey(x_1, x_145); -x_149 = lean_ctor_get(x_146, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_146, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_146, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_146, 4); -lean_inc(x_152); -x_153 = lean_ctor_get(x_146, 5); -lean_inc(x_153); -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); - lean_ctor_release(x_146, 5); - x_154 = x_146; +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_146); - x_154 = lean_box(0); + x_157 = x_156; } -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_157, 0, x_151); +lean_ctor_set(x_157, 1, x_136); +lean_ctor_set(x_157, 2, x_152); +lean_ctor_set(x_157, 3, x_153); +lean_ctor_set(x_157, 4, x_154); +lean_ctor_set(x_157, 5, x_155); +if (lean_is_scalar(x_150)) { + x_158 = lean_alloc_ctor(0, 5, 0); } else { - x_155 = x_154; + x_158 = x_150; } -lean_ctor_set(x_155, 0, x_149); -lean_ctor_set(x_155, 1, x_116); -lean_ctor_set(x_155, 2, x_150); -lean_ctor_set(x_155, 3, x_151); -lean_ctor_set(x_155, 4, x_152); -lean_ctor_set(x_155, 5, x_153); -x_156 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_156, 0, x_155); -lean_ctor_set(x_156, 1, x_111); -lean_ctor_set(x_156, 2, x_112); -lean_ctor_set(x_156, 3, x_113); -lean_ctor_set(x_156, 4, x_114); -if (lean_is_scalar(x_147)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_147; -} -lean_ctor_set(x_157, 0, x_148); -lean_ctor_set(x_157, 1, x_156); -return x_157; +lean_ctor_set(x_158, 0, x_157); +lean_ctor_set(x_158, 1, x_146); +lean_ctor_set(x_158, 2, x_147); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +x_159 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_159, 0, x_145); +lean_ctor_set(x_159, 1, x_158); +return x_159; } else { -lean_object* x_158; lean_object* x_159; lean_object* x_160; -lean_dec(x_3); -lean_dec(x_1); -x_158 = lean_ctor_get(x_141, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_141, 1); -lean_inc(x_159); -lean_dec(x_141); -x_160 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_160, 0, x_159); -lean_ctor_set(x_160, 1, x_111); -lean_ctor_set(x_160, 2, x_112); -lean_ctor_set(x_160, 3, x_113); -lean_ctor_set(x_160, 4, x_114); -x_122 = x_158; -x_123 = x_160; -goto block_139; -} -block_139: -{ -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, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_123, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_123, 2); -lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 3); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 4); -lean_inc(x_128); -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_129 = x_123; +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_160 = lean_ctor_get(x_143, 0); +lean_inc(x_160); +x_161 = lean_ctor_get(x_142, 0); +lean_inc(x_161); +lean_dec(x_142); +x_162 = lean_ctor_get(x_143, 1); +lean_inc(x_162); +x_163 = lean_ctor_get(x_143, 2); +lean_inc(x_163); +x_164 = lean_ctor_get(x_143, 3); +lean_inc(x_164); +x_165 = lean_ctor_get(x_143, 4); +lean_inc(x_165); +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_166 = x_143; } else { - lean_dec_ref(x_123); - x_129 = lean_box(0); + lean_dec_ref(x_143); + x_166 = lean_box(0); } -x_130 = lean_ctor_get(x_124, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_124, 2); -lean_inc(x_131); -x_132 = lean_ctor_get(x_124, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 5); -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); - lean_ctor_release(x_124, 4); - lean_ctor_release(x_124, 5); - x_135 = x_124; +x_167 = lean_ctor_get(x_160, 0); +lean_inc(x_167); +x_168 = lean_ctor_get(x_160, 2); +lean_inc(x_168); +x_169 = lean_ctor_get(x_160, 3); +lean_inc(x_169); +x_170 = lean_ctor_get(x_160, 4); +lean_inc(x_170); +x_171 = lean_ctor_get(x_160, 5); +lean_inc(x_171); +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_172 = x_160; } else { - lean_dec_ref(x_124); - x_135 = lean_box(0); + lean_dec_ref(x_160); + x_172 = lean_box(0); } -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_172)) { + x_173 = lean_alloc_ctor(0, 6, 0); } else { - x_136 = x_135; + x_173 = x_172; } -lean_ctor_set(x_136, 0, x_130); -lean_ctor_set(x_136, 1, x_116); -lean_ctor_set(x_136, 2, x_131); -lean_ctor_set(x_136, 3, x_132); -lean_ctor_set(x_136, 4, x_133); -lean_ctor_set(x_136, 5, x_134); -if (lean_is_scalar(x_129)) { - x_137 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_173, 0, x_167); +lean_ctor_set(x_173, 1, x_136); +lean_ctor_set(x_173, 2, x_168); +lean_ctor_set(x_173, 3, x_169); +lean_ctor_set(x_173, 4, x_170); +lean_ctor_set(x_173, 5, x_171); +if (lean_is_scalar(x_166)) { + x_174 = lean_alloc_ctor(0, 5, 0); } else { - x_137 = x_129; + x_174 = x_166; +} +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_162); +lean_ctor_set(x_174, 2, x_163); +lean_ctor_set(x_174, 3, x_164); +lean_ctor_set(x_174, 4, x_165); +x_175 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_175, 0, x_161); +lean_ctor_set(x_175, 1, x_174); +return x_175; } -lean_ctor_set(x_137, 0, x_136); -lean_ctor_set(x_137, 1, x_125); -lean_ctor_set(x_137, 2, x_126); -lean_ctor_set(x_137, 3, x_127); -lean_ctor_set(x_137, 4, x_128); -x_138 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_138, 0, x_122); -lean_ctor_set(x_138, 1, x_137); -return x_138; } } } @@ -8549,43 +8599,43 @@ return x_65; lean_object* l_Lean_Meta_SynthInstance_tryResolve(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -uint8_t x_6; lean_object* x_7; lean_object* x_540; lean_object* x_541; uint8_t x_542; -x_540 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_5); -x_541 = lean_ctor_get(x_540, 0); -lean_inc(x_541); -x_542 = lean_ctor_get_uint8(x_541, sizeof(void*)*1); -lean_dec(x_541); -if (x_542 == 0) +uint8_t x_6; lean_object* x_7; lean_object* x_751; lean_object* x_752; uint8_t x_753; +x_751 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_5); +x_752 = lean_ctor_get(x_751, 0); +lean_inc(x_752); +x_753 = lean_ctor_get_uint8(x_752, sizeof(void*)*1); +lean_dec(x_752); +if (x_753 == 0) { -lean_object* x_543; uint8_t x_544; -x_543 = lean_ctor_get(x_540, 1); -lean_inc(x_543); -lean_dec(x_540); -x_544 = 0; -x_6 = x_544; -x_7 = x_543; -goto block_539; +lean_object* x_754; uint8_t x_755; +x_754 = lean_ctor_get(x_751, 1); +lean_inc(x_754); +lean_dec(x_751); +x_755 = 0; +x_6 = x_755; +x_7 = x_754; +goto block_750; } else { -lean_object* x_545; lean_object* x_546; lean_object* x_547; lean_object* x_548; lean_object* x_549; uint8_t x_550; -x_545 = lean_ctor_get(x_540, 1); -lean_inc(x_545); -lean_dec(x_540); -x_546 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_547 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_546, x_4, x_545); -x_548 = lean_ctor_get(x_547, 0); -lean_inc(x_548); -x_549 = lean_ctor_get(x_547, 1); -lean_inc(x_549); -lean_dec(x_547); -x_550 = lean_unbox(x_548); -lean_dec(x_548); -x_6 = x_550; -x_7 = x_549; -goto block_539; +lean_object* x_756; lean_object* x_757; lean_object* x_758; lean_object* x_759; lean_object* x_760; uint8_t x_761; +x_756 = lean_ctor_get(x_751, 1); +lean_inc(x_756); +lean_dec(x_751); +x_757 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_758 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_757, x_4, x_756); +x_759 = lean_ctor_get(x_758, 0); +lean_inc(x_759); +x_760 = lean_ctor_get(x_758, 1); +lean_inc(x_760); +lean_dec(x_758); +x_761 = lean_unbox(x_759); +lean_dec(x_759); +x_6 = x_761; +x_7 = x_760; +goto block_750; } -block_539: +block_750: { if (x_6 == 0) { @@ -8618,451 +8668,40 @@ lean_dec(x_18); x_19 = !lean_is_exclusive(x_12); if (x_19 == 0) { -uint8_t x_20; lean_object* x_21; lean_object* x_22; lean_object* x_81; +uint8_t x_20; lean_object* x_21; lean_object* x_22; lean_object* x_81; lean_object* x_82; lean_object* x_233; x_20 = 0; lean_ctor_set_uint8(x_12, sizeof(void*)*1, x_20); lean_ctor_set(x_11, 1, x_1); -x_81 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_11); -if (lean_obj_tag(x_81) == 0) +x_233 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_11); +if (lean_obj_tag(x_233) == 0) { -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_81, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_81, 0); -lean_inc(x_83); -lean_dec(x_81); -x_84 = !lean_is_exclusive(x_82); -if (x_84 == 0) -{ -lean_object* x_85; lean_object* x_86; uint8_t x_87; -x_85 = lean_ctor_get(x_82, 1); -lean_dec(x_85); -lean_ctor_set(x_82, 1, x_17); -lean_ctor_set(x_10, 0, x_82); -x_86 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_10); -x_87 = !lean_is_exclusive(x_86); -if (x_87 == 0) -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; -x_88 = lean_ctor_get(x_86, 1); -x_89 = lean_ctor_get(x_86, 0); -lean_dec(x_89); -x_90 = lean_ctor_get(x_88, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_90, 4); -lean_inc(x_91); -x_92 = !lean_is_exclusive(x_88); -if (x_92 == 0) -{ -lean_object* x_93; uint8_t x_94; -x_93 = lean_ctor_get(x_88, 0); -lean_dec(x_93); -x_94 = !lean_is_exclusive(x_90); -if (x_94 == 0) -{ -lean_object* x_95; uint8_t x_96; -x_95 = lean_ctor_get(x_90, 4); -lean_dec(x_95); -x_96 = !lean_is_exclusive(x_91); -if (x_96 == 0) -{ -lean_ctor_set_uint8(x_91, sizeof(void*)*1, x_13); -lean_ctor_set(x_86, 0, x_83); -return x_86; +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); +lean_ctor_set(x_10, 0, x_235); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_81 = x_236; +x_82 = x_10; +goto block_232; } else { -lean_object* x_97; lean_object* x_98; -x_97 = lean_ctor_get(x_91, 0); -lean_inc(x_97); -lean_dec(x_91); -x_98 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set_uint8(x_98, sizeof(void*)*1, x_13); -lean_ctor_set(x_90, 4, x_98); -lean_ctor_set(x_86, 0, x_83); -return x_86; -} -} -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; -x_99 = lean_ctor_get(x_90, 0); -x_100 = lean_ctor_get(x_90, 1); -x_101 = lean_ctor_get(x_90, 2); -x_102 = lean_ctor_get(x_90, 3); -x_103 = lean_ctor_get(x_90, 5); -lean_inc(x_103); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_dec(x_90); -x_104 = lean_ctor_get(x_91, 0); -lean_inc(x_104); -if (lean_is_exclusive(x_91)) { - lean_ctor_release(x_91, 0); - x_105 = x_91; -} else { - lean_dec_ref(x_91); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 1, 1); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_104); -lean_ctor_set_uint8(x_106, sizeof(void*)*1, x_13); -x_107 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_107, 0, x_99); -lean_ctor_set(x_107, 1, x_100); -lean_ctor_set(x_107, 2, x_101); -lean_ctor_set(x_107, 3, x_102); -lean_ctor_set(x_107, 4, x_106); -lean_ctor_set(x_107, 5, x_103); -lean_ctor_set(x_88, 0, x_107); -lean_ctor_set(x_86, 0, x_83); -return x_86; -} -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_108 = lean_ctor_get(x_88, 1); -x_109 = lean_ctor_get(x_88, 2); -x_110 = lean_ctor_get(x_88, 3); -x_111 = lean_ctor_get(x_88, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_88); -x_112 = lean_ctor_get(x_90, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_90, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_90, 2); -lean_inc(x_114); -x_115 = lean_ctor_get(x_90, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_90, 5); -lean_inc(x_116); -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_117 = x_90; -} else { - lean_dec_ref(x_90); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_91, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_91)) { - lean_ctor_release(x_91, 0); - x_119 = x_91; -} else { - lean_dec_ref(x_91); - x_119 = lean_box(0); -} -if (lean_is_scalar(x_119)) { - x_120 = lean_alloc_ctor(0, 1, 1); -} else { - x_120 = x_119; -} -lean_ctor_set(x_120, 0, x_118); -lean_ctor_set_uint8(x_120, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_117)) { - x_121 = lean_alloc_ctor(0, 6, 0); -} else { - x_121 = x_117; -} -lean_ctor_set(x_121, 0, x_112); -lean_ctor_set(x_121, 1, x_113); -lean_ctor_set(x_121, 2, x_114); -lean_ctor_set(x_121, 3, x_115); -lean_ctor_set(x_121, 4, x_120); -lean_ctor_set(x_121, 5, x_116); -x_122 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_122, 0, x_121); -lean_ctor_set(x_122, 1, x_108); -lean_ctor_set(x_122, 2, x_109); -lean_ctor_set(x_122, 3, x_110); -lean_ctor_set(x_122, 4, x_111); -lean_ctor_set(x_86, 1, x_122); -lean_ctor_set(x_86, 0, x_83); -return x_86; -} -} -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; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; -x_123 = lean_ctor_get(x_86, 1); -lean_inc(x_123); -lean_dec(x_86); -x_124 = lean_ctor_get(x_123, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_124, 4); -lean_inc(x_125); -x_126 = lean_ctor_get(x_123, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 2); -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); -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_130 = x_123; -} else { - lean_dec_ref(x_123); - x_130 = lean_box(0); -} -x_131 = lean_ctor_get(x_124, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_124, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -x_135 = lean_ctor_get(x_124, 5); -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); - lean_ctor_release(x_124, 5); - x_136 = x_124; -} else { - lean_dec_ref(x_124); - x_136 = lean_box(0); -} -x_137 = lean_ctor_get(x_125, 0); -lean_inc(x_137); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - x_138 = x_125; -} else { - lean_dec_ref(x_125); - x_138 = lean_box(0); -} -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 1, 1); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_137); -lean_ctor_set_uint8(x_139, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_136)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_136; -} -lean_ctor_set(x_140, 0, x_131); -lean_ctor_set(x_140, 1, x_132); -lean_ctor_set(x_140, 2, x_133); -lean_ctor_set(x_140, 3, x_134); -lean_ctor_set(x_140, 4, x_139); -lean_ctor_set(x_140, 5, x_135); -if (lean_is_scalar(x_130)) { - x_141 = lean_alloc_ctor(0, 5, 0); -} else { - x_141 = x_130; -} -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_126); -lean_ctor_set(x_141, 2, x_127); -lean_ctor_set(x_141, 3, x_128); -lean_ctor_set(x_141, 4, x_129); -x_142 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_142, 0, x_83); -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; 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_143 = lean_ctor_get(x_82, 0); -x_144 = lean_ctor_get(x_82, 2); -x_145 = lean_ctor_get(x_82, 3); -x_146 = lean_ctor_get(x_82, 4); -x_147 = lean_ctor_get(x_82, 5); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); -lean_dec(x_82); -x_148 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_148, 0, x_143); -lean_ctor_set(x_148, 1, x_17); -lean_ctor_set(x_148, 2, x_144); -lean_ctor_set(x_148, 3, x_145); -lean_ctor_set(x_148, 4, x_146); -lean_ctor_set(x_148, 5, x_147); -lean_ctor_set(x_10, 0, x_148); -x_149 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_10); -x_150 = lean_ctor_get(x_149, 1); -lean_inc(x_150); -if (lean_is_exclusive(x_149)) { - lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - x_151 = x_149; -} else { - lean_dec_ref(x_149); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_150, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_152, 4); -lean_inc(x_153); -x_154 = lean_ctor_get(x_150, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_150, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_150, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_150, 4); -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); - x_158 = x_150; -} else { - lean_dec_ref(x_150); - x_158 = lean_box(0); -} -x_159 = lean_ctor_get(x_152, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_152, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_152, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_152, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_152, 5); -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); - lean_ctor_release(x_152, 5); - x_164 = x_152; -} else { - lean_dec_ref(x_152); - x_164 = lean_box(0); -} -x_165 = lean_ctor_get(x_153, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - x_166 = x_153; -} else { - lean_dec_ref(x_153); - x_166 = lean_box(0); -} -if (lean_is_scalar(x_166)) { - x_167 = lean_alloc_ctor(0, 1, 1); -} else { - x_167 = x_166; -} -lean_ctor_set(x_167, 0, x_165); -lean_ctor_set_uint8(x_167, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_164)) { - x_168 = lean_alloc_ctor(0, 6, 0); -} else { - x_168 = x_164; -} -lean_ctor_set(x_168, 0, x_159); -lean_ctor_set(x_168, 1, x_160); -lean_ctor_set(x_168, 2, x_161); -lean_ctor_set(x_168, 3, x_162); -lean_ctor_set(x_168, 4, x_167); -lean_ctor_set(x_168, 5, x_163); -if (lean_is_scalar(x_158)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_158; -} -lean_ctor_set(x_169, 0, x_168); -lean_ctor_set(x_169, 1, x_154); -lean_ctor_set(x_169, 2, x_155); -lean_ctor_set(x_169, 3, x_156); -lean_ctor_set(x_169, 4, x_157); -if (lean_is_scalar(x_151)) { - x_170 = lean_alloc_ctor(0, 2, 0); -} else { - x_170 = x_151; -} -lean_ctor_set(x_170, 0, x_83); -lean_ctor_set(x_170, 1, x_169); -return x_170; -} -} -else -{ -lean_object* x_171; lean_object* x_172; uint8_t x_173; -x_171 = lean_ctor_get(x_81, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_81, 0); -lean_inc(x_172); -lean_dec(x_81); -x_173 = !lean_is_exclusive(x_171); -if (x_173 == 0) -{ -lean_object* x_174; -x_174 = lean_ctor_get(x_171, 1); -lean_dec(x_174); -lean_ctor_set(x_171, 1, x_17); -lean_ctor_set(x_10, 0, x_171); -x_21 = x_172; -x_22 = x_10; -goto block_80; -} -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; -x_175 = lean_ctor_get(x_171, 0); -x_176 = lean_ctor_get(x_171, 2); -x_177 = lean_ctor_get(x_171, 3); -x_178 = lean_ctor_get(x_171, 4); -x_179 = lean_ctor_get(x_171, 5); -lean_inc(x_179); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_175); -lean_dec(x_171); -x_180 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_180, 0, x_175); -lean_ctor_set(x_180, 1, x_17); -lean_ctor_set(x_180, 2, x_176); -lean_ctor_set(x_180, 3, x_177); -lean_ctor_set(x_180, 4, x_178); -lean_ctor_set(x_180, 5, x_179); -lean_ctor_set(x_10, 0, x_180); -x_21 = x_172; -x_22 = x_10; -goto block_80; -} +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); +lean_ctor_set(x_10, 0, x_238); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_81 = x_239; +x_82 = x_10; +goto block_232; } block_80: { @@ -9324,885 +8963,1436 @@ lean_ctor_set(x_79, 1, x_78); return x_79; } } +block_232: +{ +if (lean_obj_tag(x_81) == 0) +{ +lean_object* x_83; lean_object* x_84; uint8_t x_85; +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_81, 0); +lean_inc(x_84); +lean_dec(x_81); +x_85 = !lean_is_exclusive(x_82); +if (x_85 == 0) +{ +lean_object* x_86; uint8_t x_87; +x_86 = lean_ctor_get(x_82, 0); +lean_dec(x_86); +x_87 = !lean_is_exclusive(x_83); +if (x_87 == 0) +{ +lean_object* x_88; +x_88 = lean_ctor_get(x_83, 1); +lean_dec(x_88); +lean_ctor_set(x_83, 1, x_17); +x_21 = x_84; +x_22 = x_82; +goto block_80; } else { -lean_object* x_181; uint8_t x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_209; -x_181 = lean_ctor_get(x_12, 0); -lean_inc(x_181); -lean_dec(x_12); -x_182 = 0; -x_183 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_183, 0, x_181); -lean_ctor_set_uint8(x_183, sizeof(void*)*1, x_182); -lean_ctor_set(x_11, 4, x_183); -lean_ctor_set(x_11, 1, x_1); -x_209 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_11); -if (lean_obj_tag(x_209) == 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; +x_89 = lean_ctor_get(x_83, 0); +x_90 = lean_ctor_get(x_83, 2); +x_91 = lean_ctor_get(x_83, 3); +x_92 = lean_ctor_get(x_83, 4); +x_93 = lean_ctor_get(x_83, 5); +lean_inc(x_93); +lean_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_83); +x_94 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_94, 0, x_89); +lean_ctor_set(x_94, 1, x_17); +lean_ctor_set(x_94, 2, x_90); +lean_ctor_set(x_94, 3, x_91); +lean_ctor_set(x_94, 4, x_92); +lean_ctor_set(x_94, 5, x_93); +lean_ctor_set(x_82, 0, x_94); +x_21 = x_84; +x_22 = x_82; +goto block_80; +} +} +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; 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_210 = lean_ctor_get(x_209, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_209, 0); +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_95 = lean_ctor_get(x_82, 1); +x_96 = lean_ctor_get(x_82, 2); +x_97 = lean_ctor_get(x_82, 3); +x_98 = lean_ctor_get(x_82, 4); +lean_inc(x_98); +lean_inc(x_97); +lean_inc(x_96); +lean_inc(x_95); +lean_dec(x_82); +x_99 = lean_ctor_get(x_83, 0); +lean_inc(x_99); +x_100 = lean_ctor_get(x_83, 2); +lean_inc(x_100); +x_101 = lean_ctor_get(x_83, 3); +lean_inc(x_101); +x_102 = lean_ctor_get(x_83, 4); +lean_inc(x_102); +x_103 = lean_ctor_get(x_83, 5); +lean_inc(x_103); +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_104 = x_83; +} else { + lean_dec_ref(x_83); + x_104 = lean_box(0); +} +if (lean_is_scalar(x_104)) { + x_105 = lean_alloc_ctor(0, 6, 0); +} else { + x_105 = x_104; +} +lean_ctor_set(x_105, 0, x_99); +lean_ctor_set(x_105, 1, x_17); +lean_ctor_set(x_105, 2, x_100); +lean_ctor_set(x_105, 3, x_101); +lean_ctor_set(x_105, 4, x_102); +lean_ctor_set(x_105, 5, x_103); +x_106 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_95); +lean_ctor_set(x_106, 2, x_96); +lean_ctor_set(x_106, 3, x_97); +lean_ctor_set(x_106, 4, x_98); +x_21 = x_84; +x_22 = x_106; +goto block_80; +} +} +else +{ +lean_object* x_107; lean_object* x_108; uint8_t x_109; +x_107 = lean_ctor_get(x_82, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_81, 0); +lean_inc(x_108); +lean_dec(x_81); +x_109 = !lean_is_exclusive(x_82); +if (x_109 == 0) +{ +lean_object* x_110; uint8_t x_111; +x_110 = lean_ctor_get(x_82, 0); +lean_dec(x_110); +x_111 = !lean_is_exclusive(x_107); +if (x_111 == 0) +{ +lean_object* x_112; lean_object* x_113; uint8_t x_114; +x_112 = lean_ctor_get(x_107, 1); +lean_dec(x_112); +lean_ctor_set(x_107, 1, x_17); +x_113 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_82); +x_114 = !lean_is_exclusive(x_113); +if (x_114 == 0) +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; uint8_t x_119; +x_115 = lean_ctor_get(x_113, 1); +x_116 = lean_ctor_get(x_113, 0); +lean_dec(x_116); +x_117 = lean_ctor_get(x_115, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_117, 4); +lean_inc(x_118); +x_119 = !lean_is_exclusive(x_115); +if (x_119 == 0) +{ +lean_object* x_120; uint8_t x_121; +x_120 = lean_ctor_get(x_115, 0); +lean_dec(x_120); +x_121 = !lean_is_exclusive(x_117); +if (x_121 == 0) +{ +lean_object* x_122; uint8_t x_123; +x_122 = lean_ctor_get(x_117, 4); +lean_dec(x_122); +x_123 = !lean_is_exclusive(x_118); +if (x_123 == 0) +{ +lean_ctor_set_uint8(x_118, sizeof(void*)*1, x_13); +lean_ctor_set(x_113, 0, x_108); +return x_113; +} +else +{ +lean_object* x_124; lean_object* x_125; +x_124 = lean_ctor_get(x_118, 0); +lean_inc(x_124); +lean_dec(x_118); +x_125 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_125, 0, x_124); +lean_ctor_set_uint8(x_125, sizeof(void*)*1, x_13); +lean_ctor_set(x_117, 4, x_125); +lean_ctor_set(x_113, 0, x_108); +return x_113; +} +} +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; +x_126 = lean_ctor_get(x_117, 0); +x_127 = lean_ctor_get(x_117, 1); +x_128 = lean_ctor_get(x_117, 2); +x_129 = lean_ctor_get(x_117, 3); +x_130 = lean_ctor_get(x_117, 5); +lean_inc(x_130); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_117); +x_131 = lean_ctor_get(x_118, 0); +lean_inc(x_131); +if (lean_is_exclusive(x_118)) { + lean_ctor_release(x_118, 0); + x_132 = x_118; +} else { + lean_dec_ref(x_118); + x_132 = lean_box(0); +} +if (lean_is_scalar(x_132)) { + x_133 = lean_alloc_ctor(0, 1, 1); +} else { + x_133 = x_132; +} +lean_ctor_set(x_133, 0, x_131); +lean_ctor_set_uint8(x_133, sizeof(void*)*1, x_13); +x_134 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_134, 0, x_126); +lean_ctor_set(x_134, 1, x_127); +lean_ctor_set(x_134, 2, x_128); +lean_ctor_set(x_134, 3, x_129); +lean_ctor_set(x_134, 4, x_133); +lean_ctor_set(x_134, 5, x_130); +lean_ctor_set(x_115, 0, x_134); +lean_ctor_set(x_113, 0, x_108); +return x_113; +} +} +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; +x_135 = lean_ctor_get(x_115, 1); +x_136 = lean_ctor_get(x_115, 2); +x_137 = lean_ctor_get(x_115, 3); +x_138 = lean_ctor_get(x_115, 4); +lean_inc(x_138); +lean_inc(x_137); +lean_inc(x_136); +lean_inc(x_135); +lean_dec(x_115); +x_139 = lean_ctor_get(x_117, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_117, 1); +lean_inc(x_140); +x_141 = lean_ctor_get(x_117, 2); +lean_inc(x_141); +x_142 = lean_ctor_get(x_117, 3); +lean_inc(x_142); +x_143 = lean_ctor_get(x_117, 5); +lean_inc(x_143); +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_144 = x_117; +} else { + lean_dec_ref(x_117); + x_144 = lean_box(0); +} +x_145 = lean_ctor_get(x_118, 0); +lean_inc(x_145); +if (lean_is_exclusive(x_118)) { + lean_ctor_release(x_118, 0); + x_146 = x_118; +} else { + lean_dec_ref(x_118); + x_146 = lean_box(0); +} +if (lean_is_scalar(x_146)) { + x_147 = lean_alloc_ctor(0, 1, 1); +} else { + x_147 = x_146; +} +lean_ctor_set(x_147, 0, x_145); +lean_ctor_set_uint8(x_147, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_144)) { + x_148 = lean_alloc_ctor(0, 6, 0); +} else { + x_148 = x_144; +} +lean_ctor_set(x_148, 0, x_139); +lean_ctor_set(x_148, 1, x_140); +lean_ctor_set(x_148, 2, x_141); +lean_ctor_set(x_148, 3, x_142); +lean_ctor_set(x_148, 4, x_147); +lean_ctor_set(x_148, 5, x_143); +x_149 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_149, 0, x_148); +lean_ctor_set(x_149, 1, x_135); +lean_ctor_set(x_149, 2, x_136); +lean_ctor_set(x_149, 3, x_137); +lean_ctor_set(x_149, 4, x_138); +lean_ctor_set(x_113, 1, x_149); +lean_ctor_set(x_113, 0, x_108); +return x_113; +} +} +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; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +x_150 = lean_ctor_get(x_113, 1); +lean_inc(x_150); +lean_dec(x_113); +x_151 = lean_ctor_get(x_150, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_151, 4); +lean_inc(x_152); +x_153 = lean_ctor_get(x_150, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_150, 2); +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); +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_157 = x_150; +} else { + lean_dec_ref(x_150); + x_157 = lean_box(0); +} +x_158 = lean_ctor_get(x_151, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_151, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_151, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_151, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_151, 5); +lean_inc(x_162); +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); + lean_ctor_release(x_151, 5); + x_163 = x_151; +} else { + lean_dec_ref(x_151); + x_163 = lean_box(0); +} +x_164 = lean_ctor_get(x_152, 0); +lean_inc(x_164); +if (lean_is_exclusive(x_152)) { + lean_ctor_release(x_152, 0); + x_165 = x_152; +} else { + lean_dec_ref(x_152); + x_165 = lean_box(0); +} +if (lean_is_scalar(x_165)) { + x_166 = lean_alloc_ctor(0, 1, 1); +} else { + x_166 = x_165; +} +lean_ctor_set(x_166, 0, x_164); +lean_ctor_set_uint8(x_166, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_163)) { + x_167 = lean_alloc_ctor(0, 6, 0); +} else { + x_167 = x_163; +} +lean_ctor_set(x_167, 0, x_158); +lean_ctor_set(x_167, 1, x_159); +lean_ctor_set(x_167, 2, x_160); +lean_ctor_set(x_167, 3, x_161); +lean_ctor_set(x_167, 4, x_166); +lean_ctor_set(x_167, 5, x_162); +if (lean_is_scalar(x_157)) { + x_168 = lean_alloc_ctor(0, 5, 0); +} else { + x_168 = x_157; +} +lean_ctor_set(x_168, 0, x_167); +lean_ctor_set(x_168, 1, x_153); +lean_ctor_set(x_168, 2, x_154); +lean_ctor_set(x_168, 3, x_155); +lean_ctor_set(x_168, 4, x_156); +x_169 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_169, 0, x_108); +lean_ctor_set(x_169, 1, x_168); +return x_169; +} +} +else +{ +lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; 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; lean_object* x_196; lean_object* x_197; +x_170 = lean_ctor_get(x_107, 0); +x_171 = lean_ctor_get(x_107, 2); +x_172 = lean_ctor_get(x_107, 3); +x_173 = lean_ctor_get(x_107, 4); +x_174 = lean_ctor_get(x_107, 5); +lean_inc(x_174); +lean_inc(x_173); +lean_inc(x_172); +lean_inc(x_171); +lean_inc(x_170); +lean_dec(x_107); +x_175 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_175, 0, x_170); +lean_ctor_set(x_175, 1, x_17); +lean_ctor_set(x_175, 2, x_171); +lean_ctor_set(x_175, 3, x_172); +lean_ctor_set(x_175, 4, x_173); +lean_ctor_set(x_175, 5, x_174); +lean_ctor_set(x_82, 0, x_175); +x_176 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_82); +x_177 = lean_ctor_get(x_176, 1); +lean_inc(x_177); +if (lean_is_exclusive(x_176)) { + lean_ctor_release(x_176, 0); + lean_ctor_release(x_176, 1); + x_178 = x_176; +} else { + lean_dec_ref(x_176); + x_178 = lean_box(0); +} +x_179 = lean_ctor_get(x_177, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_179, 4); +lean_inc(x_180); +x_181 = lean_ctor_get(x_177, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_177, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_177, 4); +lean_inc(x_184); +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_185 = x_177; +} else { + lean_dec_ref(x_177); + x_185 = lean_box(0); +} +x_186 = lean_ctor_get(x_179, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_179, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_179, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_179, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_179, 5); +lean_inc(x_190); +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_191 = x_179; +} else { + lean_dec_ref(x_179); + x_191 = lean_box(0); +} +x_192 = lean_ctor_get(x_180, 0); +lean_inc(x_192); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + x_193 = x_180; +} else { + lean_dec_ref(x_180); + x_193 = lean_box(0); +} +if (lean_is_scalar(x_193)) { + x_194 = lean_alloc_ctor(0, 1, 1); +} else { + x_194 = x_193; +} +lean_ctor_set(x_194, 0, x_192); +lean_ctor_set_uint8(x_194, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_191)) { + x_195 = lean_alloc_ctor(0, 6, 0); +} else { + x_195 = x_191; +} +lean_ctor_set(x_195, 0, x_186); +lean_ctor_set(x_195, 1, x_187); +lean_ctor_set(x_195, 2, x_188); +lean_ctor_set(x_195, 3, x_189); +lean_ctor_set(x_195, 4, x_194); +lean_ctor_set(x_195, 5, x_190); +if (lean_is_scalar(x_185)) { + x_196 = lean_alloc_ctor(0, 5, 0); +} else { + x_196 = x_185; +} +lean_ctor_set(x_196, 0, x_195); +lean_ctor_set(x_196, 1, x_181); +lean_ctor_set(x_196, 2, x_182); +lean_ctor_set(x_196, 3, x_183); +lean_ctor_set(x_196, 4, x_184); +if (lean_is_scalar(x_178)) { + x_197 = lean_alloc_ctor(0, 2, 0); +} else { + x_197 = x_178; +} +lean_ctor_set(x_197, 0, x_108); +lean_ctor_set(x_197, 1, x_196); +return x_197; +} +} +else +{ +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; 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_198 = lean_ctor_get(x_82, 1); +x_199 = lean_ctor_get(x_82, 2); +x_200 = lean_ctor_get(x_82, 3); +x_201 = lean_ctor_get(x_82, 4); +lean_inc(x_201); +lean_inc(x_200); +lean_inc(x_199); +lean_inc(x_198); +lean_dec(x_82); +x_202 = lean_ctor_get(x_107, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_107, 2); +lean_inc(x_203); +x_204 = lean_ctor_get(x_107, 3); +lean_inc(x_204); +x_205 = lean_ctor_get(x_107, 4); +lean_inc(x_205); +x_206 = lean_ctor_get(x_107, 5); +lean_inc(x_206); +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_207 = x_107; +} else { + lean_dec_ref(x_107); + x_207 = lean_box(0); +} +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 6, 0); +} else { + x_208 = x_207; +} +lean_ctor_set(x_208, 0, x_202); +lean_ctor_set(x_208, 1, x_17); +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_ctor_set(x_208, 5, x_206); +x_209 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_209, 0, x_208); +lean_ctor_set(x_209, 1, x_198); +lean_ctor_set(x_209, 2, x_199); +lean_ctor_set(x_209, 3, x_200); +lean_ctor_set(x_209, 4, x_201); +x_210 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_209); +x_211 = lean_ctor_get(x_210, 1); lean_inc(x_211); -lean_dec(x_209); -x_212 = lean_ctor_get(x_210, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_210, 2); -lean_inc(x_213); -x_214 = lean_ctor_get(x_210, 3); -lean_inc(x_214); -x_215 = lean_ctor_get(x_210, 4); -lean_inc(x_215); -x_216 = lean_ctor_get(x_210, 5); -lean_inc(x_216); 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_217 = x_210; + x_212 = x_210; } else { lean_dec_ref(x_210); - x_217 = lean_box(0); + x_212 = lean_box(0); } -if (lean_is_scalar(x_217)) { - x_218 = lean_alloc_ctor(0, 6, 0); +x_213 = lean_ctor_get(x_211, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_213, 4); +lean_inc(x_214); +x_215 = lean_ctor_get(x_211, 1); +lean_inc(x_215); +x_216 = lean_ctor_get(x_211, 2); +lean_inc(x_216); +x_217 = lean_ctor_get(x_211, 3); +lean_inc(x_217); +x_218 = lean_ctor_get(x_211, 4); +lean_inc(x_218); +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_219 = x_211; } else { - x_218 = x_217; + lean_dec_ref(x_211); + x_219 = lean_box(0); } -lean_ctor_set(x_218, 0, x_212); -lean_ctor_set(x_218, 1, x_17); -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_ctor_set(x_218, 5, x_216); -lean_ctor_set(x_10, 0, x_218); -x_219 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_10); -x_220 = lean_ctor_get(x_219, 1); +x_220 = lean_ctor_get(x_213, 0); lean_inc(x_220); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - x_221 = x_219; -} else { - lean_dec_ref(x_219); - x_221 = lean_box(0); -} -x_222 = lean_ctor_get(x_220, 0); +x_221 = lean_ctor_get(x_213, 1); +lean_inc(x_221); +x_222 = lean_ctor_get(x_213, 2); lean_inc(x_222); -x_223 = lean_ctor_get(x_222, 4); +x_223 = lean_ctor_get(x_213, 3); lean_inc(x_223); -x_224 = lean_ctor_get(x_220, 1); +x_224 = lean_ctor_get(x_213, 5); lean_inc(x_224); -x_225 = lean_ctor_get(x_220, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_220, 3); +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_225 = x_213; +} else { + lean_dec_ref(x_213); + x_225 = lean_box(0); +} +x_226 = lean_ctor_get(x_214, 0); lean_inc(x_226); -x_227 = lean_ctor_get(x_220, 4); -lean_inc(x_227); -if (lean_is_exclusive(x_220)) { - lean_ctor_release(x_220, 0); - lean_ctor_release(x_220, 1); - lean_ctor_release(x_220, 2); - lean_ctor_release(x_220, 3); - lean_ctor_release(x_220, 4); - x_228 = x_220; +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + x_227 = x_214; } else { - lean_dec_ref(x_220); - x_228 = lean_box(0); + lean_dec_ref(x_214); + x_227 = lean_box(0); } -x_229 = lean_ctor_get(x_222, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_222, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_222, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_222, 3); -lean_inc(x_232); -x_233 = lean_ctor_get(x_222, 5); -lean_inc(x_233); -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_234 = x_222; +if (lean_is_scalar(x_227)) { + x_228 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_222); - x_234 = lean_box(0); + x_228 = x_227; } -x_235 = lean_ctor_get(x_223, 0); -lean_inc(x_235); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - x_236 = x_223; +lean_ctor_set(x_228, 0, x_226); +lean_ctor_set_uint8(x_228, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_225)) { + x_229 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_223); - x_236 = lean_box(0); + x_229 = x_225; } -if (lean_is_scalar(x_236)) { - x_237 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_229, 0, x_220); +lean_ctor_set(x_229, 1, x_221); +lean_ctor_set(x_229, 2, x_222); +lean_ctor_set(x_229, 3, x_223); +lean_ctor_set(x_229, 4, x_228); +lean_ctor_set(x_229, 5, x_224); +if (lean_is_scalar(x_219)) { + x_230 = lean_alloc_ctor(0, 5, 0); } else { - x_237 = x_236; + x_230 = x_219; } -lean_ctor_set(x_237, 0, x_235); -lean_ctor_set_uint8(x_237, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_234)) { - x_238 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_230, 0, x_229); +lean_ctor_set(x_230, 1, x_215); +lean_ctor_set(x_230, 2, x_216); +lean_ctor_set(x_230, 3, x_217); +lean_ctor_set(x_230, 4, x_218); +if (lean_is_scalar(x_212)) { + x_231 = lean_alloc_ctor(0, 2, 0); } else { - x_238 = x_234; + x_231 = x_212; } -lean_ctor_set(x_238, 0, x_229); -lean_ctor_set(x_238, 1, x_230); -lean_ctor_set(x_238, 2, x_231); -lean_ctor_set(x_238, 3, x_232); -lean_ctor_set(x_238, 4, x_237); -lean_ctor_set(x_238, 5, x_233); -if (lean_is_scalar(x_228)) { - x_239 = lean_alloc_ctor(0, 5, 0); -} else { - x_239 = x_228; +lean_ctor_set(x_231, 0, x_108); +lean_ctor_set(x_231, 1, x_230); +return x_231; } -lean_ctor_set(x_239, 0, x_238); -lean_ctor_set(x_239, 1, x_224); -lean_ctor_set(x_239, 2, x_225); -lean_ctor_set(x_239, 3, x_226); -lean_ctor_set(x_239, 4, x_227); -if (lean_is_scalar(x_221)) { - x_240 = lean_alloc_ctor(0, 2, 0); -} else { - x_240 = x_221; -} -lean_ctor_set(x_240, 0, x_211); -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; -x_241 = lean_ctor_get(x_209, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_209, 0); -lean_inc(x_242); -lean_dec(x_209); -x_243 = lean_ctor_get(x_241, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_241, 2); -lean_inc(x_244); -x_245 = lean_ctor_get(x_241, 3); -lean_inc(x_245); -x_246 = lean_ctor_get(x_241, 4); -lean_inc(x_246); -x_247 = lean_ctor_get(x_241, 5); -lean_inc(x_247); -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_248 = x_241; -} else { - lean_dec_ref(x_241); - x_248 = lean_box(0); -} -if (lean_is_scalar(x_248)) { - x_249 = lean_alloc_ctor(0, 6, 0); -} else { - x_249 = x_248; -} -lean_ctor_set(x_249, 0, x_243); -lean_ctor_set(x_249, 1, x_17); -lean_ctor_set(x_249, 2, x_244); -lean_ctor_set(x_249, 3, x_245); -lean_ctor_set(x_249, 4, x_246); -lean_ctor_set(x_249, 5, x_247); -lean_ctor_set(x_10, 0, x_249); -x_184 = x_242; -x_185 = x_10; -goto block_208; -} -block_208: -{ -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; 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_186 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_185); -x_187 = lean_ctor_get(x_186, 1); -lean_inc(x_187); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_188 = x_186; -} else { - lean_dec_ref(x_186); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_187, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_189, 4); -lean_inc(x_190); -x_191 = lean_ctor_get(x_187, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_187, 2); -lean_inc(x_192); -x_193 = lean_ctor_get(x_187, 3); -lean_inc(x_193); -x_194 = lean_ctor_get(x_187, 4); -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); - x_195 = x_187; -} else { - lean_dec_ref(x_187); - x_195 = lean_box(0); -} -x_196 = lean_ctor_get(x_189, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_189, 2); -lean_inc(x_198); -x_199 = lean_ctor_get(x_189, 3); -lean_inc(x_199); -x_200 = lean_ctor_get(x_189, 5); -lean_inc(x_200); -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_201 = x_189; -} else { - lean_dec_ref(x_189); - x_201 = lean_box(0); -} -x_202 = lean_ctor_get(x_190, 0); -lean_inc(x_202); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - x_203 = x_190; -} else { - lean_dec_ref(x_190); - x_203 = lean_box(0); -} -if (lean_is_scalar(x_203)) { - x_204 = lean_alloc_ctor(0, 1, 1); -} else { - x_204 = x_203; -} -lean_ctor_set(x_204, 0, x_202); -lean_ctor_set_uint8(x_204, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_201)) { - x_205 = lean_alloc_ctor(0, 6, 0); -} else { - x_205 = x_201; -} -lean_ctor_set(x_205, 0, x_196); -lean_ctor_set(x_205, 1, x_197); -lean_ctor_set(x_205, 2, x_198); -lean_ctor_set(x_205, 3, x_199); -lean_ctor_set(x_205, 4, x_204); -lean_ctor_set(x_205, 5, x_200); -if (lean_is_scalar(x_195)) { - x_206 = lean_alloc_ctor(0, 5, 0); -} else { - x_206 = x_195; -} -lean_ctor_set(x_206, 0, x_205); -lean_ctor_set(x_206, 1, x_191); -lean_ctor_set(x_206, 2, x_192); -lean_ctor_set(x_206, 3, x_193); -lean_ctor_set(x_206, 4, x_194); -if (lean_is_scalar(x_188)) { - x_207 = lean_alloc_ctor(1, 2, 0); -} else { - x_207 = x_188; - lean_ctor_set_tag(x_207, 1); -} -lean_ctor_set(x_207, 0, x_184); -lean_ctor_set(x_207, 1, x_206); -return x_207; } } } 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; uint8_t x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_284; lean_object* x_285; -x_250 = lean_ctor_get(x_11, 0); -x_251 = lean_ctor_get(x_11, 1); -x_252 = lean_ctor_get(x_11, 2); -x_253 = lean_ctor_get(x_11, 3); -x_254 = lean_ctor_get(x_11, 5); -lean_inc(x_254); -lean_inc(x_253); -lean_inc(x_252); -lean_inc(x_251); -lean_inc(x_250); -lean_dec(x_11); -x_255 = lean_ctor_get(x_12, 0); -lean_inc(x_255); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - x_256 = x_12; -} else { - lean_dec_ref(x_12); - x_256 = lean_box(0); -} -x_257 = 0; -if (lean_is_scalar(x_256)) { - x_258 = lean_alloc_ctor(0, 1, 1); -} else { - x_258 = x_256; -} -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set_uint8(x_258, sizeof(void*)*1, x_257); -x_284 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_284, 0, x_250); -lean_ctor_set(x_284, 1, x_1); -lean_ctor_set(x_284, 2, x_252); -lean_ctor_set(x_284, 3, x_253); -lean_ctor_set(x_284, 4, x_258); -lean_ctor_set(x_284, 5, x_254); -x_285 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_284); -if (lean_obj_tag(x_285) == 0) +lean_object* x_240; uint8_t x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_268; lean_object* x_269; lean_object* x_323; +x_240 = lean_ctor_get(x_12, 0); +lean_inc(x_240); +lean_dec(x_12); +x_241 = 0; +x_242 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_242, 0, x_240); +lean_ctor_set_uint8(x_242, sizeof(void*)*1, x_241); +lean_ctor_set(x_11, 4, x_242); +lean_ctor_set(x_11, 1, x_1); +x_323 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_11); +if (lean_obj_tag(x_323) == 0) { -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; 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; 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_286 = lean_ctor_get(x_285, 1); -lean_inc(x_286); -x_287 = lean_ctor_get(x_285, 0); -lean_inc(x_287); -lean_dec(x_285); -x_288 = lean_ctor_get(x_286, 0); -lean_inc(x_288); -x_289 = lean_ctor_get(x_286, 2); -lean_inc(x_289); -x_290 = lean_ctor_get(x_286, 3); -lean_inc(x_290); -x_291 = lean_ctor_get(x_286, 4); -lean_inc(x_291); -x_292 = lean_ctor_get(x_286, 5); -lean_inc(x_292); -if (lean_is_exclusive(x_286)) { - lean_ctor_release(x_286, 0); - lean_ctor_release(x_286, 1); - lean_ctor_release(x_286, 2); - lean_ctor_release(x_286, 3); - lean_ctor_release(x_286, 4); - lean_ctor_release(x_286, 5); - x_293 = x_286; -} else { - lean_dec_ref(x_286); - x_293 = lean_box(0); -} -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 6, 0); -} else { - x_294 = x_293; -} -lean_ctor_set(x_294, 0, x_288); -lean_ctor_set(x_294, 1, x_251); -lean_ctor_set(x_294, 2, x_289); -lean_ctor_set(x_294, 3, x_290); -lean_ctor_set(x_294, 4, x_291); -lean_ctor_set(x_294, 5, x_292); -lean_ctor_set(x_10, 0, x_294); -x_295 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_10); -x_296 = lean_ctor_get(x_295, 1); -lean_inc(x_296); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - x_297 = x_295; -} else { - lean_dec_ref(x_295); - x_297 = lean_box(0); -} -x_298 = lean_ctor_get(x_296, 0); -lean_inc(x_298); -x_299 = lean_ctor_get(x_298, 4); -lean_inc(x_299); -x_300 = lean_ctor_get(x_296, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_296, 2); -lean_inc(x_301); -x_302 = lean_ctor_get(x_296, 3); -lean_inc(x_302); -x_303 = lean_ctor_get(x_296, 4); -lean_inc(x_303); -if (lean_is_exclusive(x_296)) { - lean_ctor_release(x_296, 0); - lean_ctor_release(x_296, 1); - lean_ctor_release(x_296, 2); - lean_ctor_release(x_296, 3); - lean_ctor_release(x_296, 4); - x_304 = x_296; -} else { - lean_dec_ref(x_296); - x_304 = lean_box(0); -} -x_305 = lean_ctor_get(x_298, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_298, 1); -lean_inc(x_306); -x_307 = lean_ctor_get(x_298, 2); -lean_inc(x_307); -x_308 = lean_ctor_get(x_298, 3); -lean_inc(x_308); -x_309 = lean_ctor_get(x_298, 5); -lean_inc(x_309); -if (lean_is_exclusive(x_298)) { - lean_ctor_release(x_298, 0); - lean_ctor_release(x_298, 1); - lean_ctor_release(x_298, 2); - lean_ctor_release(x_298, 3); - lean_ctor_release(x_298, 4); - lean_ctor_release(x_298, 5); - x_310 = x_298; -} else { - lean_dec_ref(x_298); - x_310 = lean_box(0); -} -x_311 = lean_ctor_get(x_299, 0); -lean_inc(x_311); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - x_312 = x_299; -} else { - lean_dec_ref(x_299); - x_312 = lean_box(0); -} -if (lean_is_scalar(x_312)) { - x_313 = lean_alloc_ctor(0, 1, 1); -} else { - x_313 = x_312; -} -lean_ctor_set(x_313, 0, x_311); -lean_ctor_set_uint8(x_313, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_310)) { - x_314 = lean_alloc_ctor(0, 6, 0); -} else { - x_314 = x_310; -} -lean_ctor_set(x_314, 0, x_305); -lean_ctor_set(x_314, 1, x_306); -lean_ctor_set(x_314, 2, x_307); -lean_ctor_set(x_314, 3, x_308); -lean_ctor_set(x_314, 4, x_313); -lean_ctor_set(x_314, 5, x_309); -if (lean_is_scalar(x_304)) { - x_315 = lean_alloc_ctor(0, 5, 0); -} else { - x_315 = x_304; -} -lean_ctor_set(x_315, 0, x_314); -lean_ctor_set(x_315, 1, x_300); -lean_ctor_set(x_315, 2, x_301); -lean_ctor_set(x_315, 3, x_302); -lean_ctor_set(x_315, 4, x_303); -if (lean_is_scalar(x_297)) { - x_316 = lean_alloc_ctor(0, 2, 0); -} else { - x_316 = x_297; -} -lean_ctor_set(x_316, 0, x_287); -lean_ctor_set(x_316, 1, x_315); -return x_316; -} -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_285, 1); -lean_inc(x_317); -x_318 = lean_ctor_get(x_285, 0); -lean_inc(x_318); -lean_dec(x_285); -x_319 = lean_ctor_get(x_317, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_317, 2); -lean_inc(x_320); -x_321 = lean_ctor_get(x_317, 3); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 4); -lean_inc(x_322); -x_323 = lean_ctor_get(x_317, 5); -lean_inc(x_323); -if (lean_is_exclusive(x_317)) { - lean_ctor_release(x_317, 0); - lean_ctor_release(x_317, 1); - lean_ctor_release(x_317, 2); - lean_ctor_release(x_317, 3); - lean_ctor_release(x_317, 4); - lean_ctor_release(x_317, 5); - x_324 = x_317; -} else { - lean_dec_ref(x_317); - x_324 = lean_box(0); -} -if (lean_is_scalar(x_324)) { - x_325 = lean_alloc_ctor(0, 6, 0); -} else { - x_325 = x_324; -} -lean_ctor_set(x_325, 0, x_319); -lean_ctor_set(x_325, 1, x_251); -lean_ctor_set(x_325, 2, x_320); -lean_ctor_set(x_325, 3, x_321); -lean_ctor_set(x_325, 4, x_322); -lean_ctor_set(x_325, 5, x_323); +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); lean_ctor_set(x_10, 0, x_325); -x_259 = x_318; -x_260 = x_10; -goto block_283; +x_326 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_326, 0, x_324); +x_268 = x_326; +x_269 = x_10; +goto block_322; } -block_283: +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; 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_261 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_260); -x_262 = lean_ctor_get(x_261, 1); -lean_inc(x_262); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - x_263 = x_261; -} else { - lean_dec_ref(x_261); - x_263 = lean_box(0); +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); +lean_ctor_set(x_10, 0, x_328); +x_329 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_268 = x_329; +x_269 = x_10; +goto block_322; } -x_264 = lean_ctor_get(x_262, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_264, 4); -lean_inc(x_265); -x_266 = lean_ctor_get(x_262, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_262, 2); -lean_inc(x_267); -x_268 = lean_ctor_get(x_262, 3); -lean_inc(x_268); -x_269 = lean_ctor_get(x_262, 4); -lean_inc(x_269); -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_270 = x_262; +block_267: +{ +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; +x_245 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_244); +x_246 = lean_ctor_get(x_245, 1); +lean_inc(x_246); +if (lean_is_exclusive(x_245)) { + lean_ctor_release(x_245, 0); + lean_ctor_release(x_245, 1); + x_247 = x_245; } else { - lean_dec_ref(x_262); - x_270 = lean_box(0); + lean_dec_ref(x_245); + x_247 = lean_box(0); } -x_271 = lean_ctor_get(x_264, 0); +x_248 = lean_ctor_get(x_246, 0); +lean_inc(x_248); +x_249 = lean_ctor_get(x_248, 4); +lean_inc(x_249); +x_250 = lean_ctor_get(x_246, 1); +lean_inc(x_250); +x_251 = lean_ctor_get(x_246, 2); +lean_inc(x_251); +x_252 = lean_ctor_get(x_246, 3); +lean_inc(x_252); +x_253 = lean_ctor_get(x_246, 4); +lean_inc(x_253); +if (lean_is_exclusive(x_246)) { + lean_ctor_release(x_246, 0); + lean_ctor_release(x_246, 1); + lean_ctor_release(x_246, 2); + lean_ctor_release(x_246, 3); + lean_ctor_release(x_246, 4); + x_254 = x_246; +} else { + lean_dec_ref(x_246); + x_254 = lean_box(0); +} +x_255 = lean_ctor_get(x_248, 0); +lean_inc(x_255); +x_256 = lean_ctor_get(x_248, 1); +lean_inc(x_256); +x_257 = lean_ctor_get(x_248, 2); +lean_inc(x_257); +x_258 = lean_ctor_get(x_248, 3); +lean_inc(x_258); +x_259 = lean_ctor_get(x_248, 5); +lean_inc(x_259); +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); + x_260 = x_248; +} else { + lean_dec_ref(x_248); + x_260 = lean_box(0); +} +x_261 = lean_ctor_get(x_249, 0); +lean_inc(x_261); +if (lean_is_exclusive(x_249)) { + lean_ctor_release(x_249, 0); + x_262 = x_249; +} else { + lean_dec_ref(x_249); + x_262 = lean_box(0); +} +if (lean_is_scalar(x_262)) { + x_263 = lean_alloc_ctor(0, 1, 1); +} else { + x_263 = x_262; +} +lean_ctor_set(x_263, 0, x_261); +lean_ctor_set_uint8(x_263, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_260)) { + x_264 = lean_alloc_ctor(0, 6, 0); +} else { + x_264 = x_260; +} +lean_ctor_set(x_264, 0, x_255); +lean_ctor_set(x_264, 1, x_256); +lean_ctor_set(x_264, 2, x_257); +lean_ctor_set(x_264, 3, x_258); +lean_ctor_set(x_264, 4, x_263); +lean_ctor_set(x_264, 5, x_259); +if (lean_is_scalar(x_254)) { + x_265 = lean_alloc_ctor(0, 5, 0); +} else { + x_265 = x_254; +} +lean_ctor_set(x_265, 0, x_264); +lean_ctor_set(x_265, 1, x_250); +lean_ctor_set(x_265, 2, x_251); +lean_ctor_set(x_265, 3, x_252); +lean_ctor_set(x_265, 4, x_253); +if (lean_is_scalar(x_247)) { + x_266 = lean_alloc_ctor(1, 2, 0); +} else { + x_266 = x_247; + lean_ctor_set_tag(x_266, 1); +} +lean_ctor_set(x_266, 0, x_243); +lean_ctor_set(x_266, 1, x_265); +return x_266; +} +block_322: +{ +if (lean_obj_tag(x_268) == 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; lean_object* x_283; lean_object* x_284; +x_270 = lean_ctor_get(x_269, 0); +lean_inc(x_270); +x_271 = lean_ctor_get(x_268, 0); lean_inc(x_271); -x_272 = lean_ctor_get(x_264, 1); +lean_dec(x_268); +x_272 = lean_ctor_get(x_269, 1); lean_inc(x_272); -x_273 = lean_ctor_get(x_264, 2); +x_273 = lean_ctor_get(x_269, 2); lean_inc(x_273); -x_274 = lean_ctor_get(x_264, 3); +x_274 = lean_ctor_get(x_269, 3); lean_inc(x_274); -x_275 = lean_ctor_get(x_264, 5); +x_275 = lean_ctor_get(x_269, 4); lean_inc(x_275); -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); - lean_ctor_release(x_264, 5); - x_276 = x_264; +if (lean_is_exclusive(x_269)) { + lean_ctor_release(x_269, 0); + lean_ctor_release(x_269, 1); + lean_ctor_release(x_269, 2); + lean_ctor_release(x_269, 3); + lean_ctor_release(x_269, 4); + x_276 = x_269; } else { - lean_dec_ref(x_264); + lean_dec_ref(x_269); x_276 = lean_box(0); } -x_277 = lean_ctor_get(x_265, 0); +x_277 = lean_ctor_get(x_270, 0); lean_inc(x_277); -if (lean_is_exclusive(x_265)) { - lean_ctor_release(x_265, 0); - x_278 = x_265; +x_278 = lean_ctor_get(x_270, 2); +lean_inc(x_278); +x_279 = lean_ctor_get(x_270, 3); +lean_inc(x_279); +x_280 = lean_ctor_get(x_270, 4); +lean_inc(x_280); +x_281 = lean_ctor_get(x_270, 5); +lean_inc(x_281); +if (lean_is_exclusive(x_270)) { + lean_ctor_release(x_270, 0); + lean_ctor_release(x_270, 1); + lean_ctor_release(x_270, 2); + lean_ctor_release(x_270, 3); + lean_ctor_release(x_270, 4); + lean_ctor_release(x_270, 5); + x_282 = x_270; } else { - lean_dec_ref(x_265); - x_278 = lean_box(0); + lean_dec_ref(x_270); + x_282 = lean_box(0); } -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 1, 1); +if (lean_is_scalar(x_282)) { + x_283 = lean_alloc_ctor(0, 6, 0); } else { - x_279 = x_278; + x_283 = x_282; } -lean_ctor_set(x_279, 0, x_277); -lean_ctor_set_uint8(x_279, sizeof(void*)*1, x_13); +lean_ctor_set(x_283, 0, x_277); +lean_ctor_set(x_283, 1, x_17); +lean_ctor_set(x_283, 2, x_278); +lean_ctor_set(x_283, 3, x_279); +lean_ctor_set(x_283, 4, x_280); +lean_ctor_set(x_283, 5, x_281); if (lean_is_scalar(x_276)) { - x_280 = lean_alloc_ctor(0, 6, 0); + x_284 = lean_alloc_ctor(0, 5, 0); } else { - x_280 = x_276; + x_284 = x_276; } -lean_ctor_set(x_280, 0, x_271); -lean_ctor_set(x_280, 1, x_272); -lean_ctor_set(x_280, 2, x_273); -lean_ctor_set(x_280, 3, x_274); -lean_ctor_set(x_280, 4, x_279); -lean_ctor_set(x_280, 5, x_275); -if (lean_is_scalar(x_270)) { - x_281 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_284, 0, x_283); +lean_ctor_set(x_284, 1, x_272); +lean_ctor_set(x_284, 2, x_273); +lean_ctor_set(x_284, 3, x_274); +lean_ctor_set(x_284, 4, x_275); +x_243 = x_271; +x_244 = x_284; +goto block_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; 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; 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; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_285 = lean_ctor_get(x_269, 0); +lean_inc(x_285); +x_286 = lean_ctor_get(x_268, 0); +lean_inc(x_286); +lean_dec(x_268); +x_287 = lean_ctor_get(x_269, 1); +lean_inc(x_287); +x_288 = lean_ctor_get(x_269, 2); +lean_inc(x_288); +x_289 = lean_ctor_get(x_269, 3); +lean_inc(x_289); +x_290 = lean_ctor_get(x_269, 4); +lean_inc(x_290); +if (lean_is_exclusive(x_269)) { + lean_ctor_release(x_269, 0); + lean_ctor_release(x_269, 1); + lean_ctor_release(x_269, 2); + lean_ctor_release(x_269, 3); + lean_ctor_release(x_269, 4); + x_291 = x_269; } else { - x_281 = x_270; + lean_dec_ref(x_269); + x_291 = lean_box(0); } -lean_ctor_set(x_281, 0, x_280); -lean_ctor_set(x_281, 1, x_266); -lean_ctor_set(x_281, 2, x_267); -lean_ctor_set(x_281, 3, x_268); -lean_ctor_set(x_281, 4, x_269); -if (lean_is_scalar(x_263)) { - x_282 = lean_alloc_ctor(1, 2, 0); +x_292 = lean_ctor_get(x_285, 0); +lean_inc(x_292); +x_293 = lean_ctor_get(x_285, 2); +lean_inc(x_293); +x_294 = lean_ctor_get(x_285, 3); +lean_inc(x_294); +x_295 = lean_ctor_get(x_285, 4); +lean_inc(x_295); +x_296 = lean_ctor_get(x_285, 5); +lean_inc(x_296); +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); + lean_ctor_release(x_285, 5); + x_297 = x_285; } else { - x_282 = x_263; - lean_ctor_set_tag(x_282, 1); + lean_dec_ref(x_285); + x_297 = lean_box(0); +} +if (lean_is_scalar(x_297)) { + x_298 = lean_alloc_ctor(0, 6, 0); +} else { + x_298 = x_297; +} +lean_ctor_set(x_298, 0, x_292); +lean_ctor_set(x_298, 1, x_17); +lean_ctor_set(x_298, 2, x_293); +lean_ctor_set(x_298, 3, x_294); +lean_ctor_set(x_298, 4, x_295); +lean_ctor_set(x_298, 5, x_296); +if (lean_is_scalar(x_291)) { + x_299 = lean_alloc_ctor(0, 5, 0); +} else { + x_299 = x_291; +} +lean_ctor_set(x_299, 0, x_298); +lean_ctor_set(x_299, 1, x_287); +lean_ctor_set(x_299, 2, x_288); +lean_ctor_set(x_299, 3, x_289); +lean_ctor_set(x_299, 4, x_290); +x_300 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_299); +x_301 = lean_ctor_get(x_300, 1); +lean_inc(x_301); +if (lean_is_exclusive(x_300)) { + lean_ctor_release(x_300, 0); + lean_ctor_release(x_300, 1); + x_302 = x_300; +} else { + lean_dec_ref(x_300); + x_302 = lean_box(0); +} +x_303 = lean_ctor_get(x_301, 0); +lean_inc(x_303); +x_304 = lean_ctor_get(x_303, 4); +lean_inc(x_304); +x_305 = lean_ctor_get(x_301, 1); +lean_inc(x_305); +x_306 = lean_ctor_get(x_301, 2); +lean_inc(x_306); +x_307 = lean_ctor_get(x_301, 3); +lean_inc(x_307); +x_308 = lean_ctor_get(x_301, 4); +lean_inc(x_308); +if (lean_is_exclusive(x_301)) { + lean_ctor_release(x_301, 0); + lean_ctor_release(x_301, 1); + lean_ctor_release(x_301, 2); + lean_ctor_release(x_301, 3); + lean_ctor_release(x_301, 4); + x_309 = x_301; +} else { + lean_dec_ref(x_301); + x_309 = lean_box(0); +} +x_310 = lean_ctor_get(x_303, 0); +lean_inc(x_310); +x_311 = lean_ctor_get(x_303, 1); +lean_inc(x_311); +x_312 = lean_ctor_get(x_303, 2); +lean_inc(x_312); +x_313 = lean_ctor_get(x_303, 3); +lean_inc(x_313); +x_314 = lean_ctor_get(x_303, 5); +lean_inc(x_314); +if (lean_is_exclusive(x_303)) { + lean_ctor_release(x_303, 0); + lean_ctor_release(x_303, 1); + lean_ctor_release(x_303, 2); + lean_ctor_release(x_303, 3); + lean_ctor_release(x_303, 4); + lean_ctor_release(x_303, 5); + x_315 = x_303; +} else { + lean_dec_ref(x_303); + x_315 = lean_box(0); +} +x_316 = lean_ctor_get(x_304, 0); +lean_inc(x_316); +if (lean_is_exclusive(x_304)) { + lean_ctor_release(x_304, 0); + x_317 = x_304; +} else { + lean_dec_ref(x_304); + x_317 = lean_box(0); +} +if (lean_is_scalar(x_317)) { + x_318 = lean_alloc_ctor(0, 1, 1); +} else { + x_318 = x_317; +} +lean_ctor_set(x_318, 0, x_316); +lean_ctor_set_uint8(x_318, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_315)) { + x_319 = lean_alloc_ctor(0, 6, 0); +} else { + x_319 = x_315; +} +lean_ctor_set(x_319, 0, x_310); +lean_ctor_set(x_319, 1, x_311); +lean_ctor_set(x_319, 2, x_312); +lean_ctor_set(x_319, 3, x_313); +lean_ctor_set(x_319, 4, x_318); +lean_ctor_set(x_319, 5, x_314); +if (lean_is_scalar(x_309)) { + x_320 = lean_alloc_ctor(0, 5, 0); +} else { + x_320 = x_309; +} +lean_ctor_set(x_320, 0, x_319); +lean_ctor_set(x_320, 1, x_305); +lean_ctor_set(x_320, 2, x_306); +lean_ctor_set(x_320, 3, x_307); +lean_ctor_set(x_320, 4, x_308); +if (lean_is_scalar(x_302)) { + x_321 = lean_alloc_ctor(0, 2, 0); +} else { + x_321 = x_302; +} +lean_ctor_set(x_321, 0, x_286); +lean_ctor_set(x_321, 1, x_320); +return x_321; } -lean_ctor_set(x_282, 0, x_259); -lean_ctor_set(x_282, 1, x_281); -return x_282; } } } 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; uint8_t x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_365; lean_object* x_366; -x_326 = lean_ctor_get(x_10, 1); -x_327 = lean_ctor_get(x_10, 2); -x_328 = lean_ctor_get(x_10, 3); -x_329 = lean_ctor_get(x_10, 4); -lean_inc(x_329); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_dec(x_10); +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; uint8_t x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_364; lean_object* x_365; lean_object* x_419; lean_object* x_420; x_330 = lean_ctor_get(x_11, 0); -lean_inc(x_330); x_331 = lean_ctor_get(x_11, 1); -lean_inc(x_331); x_332 = lean_ctor_get(x_11, 2); -lean_inc(x_332); x_333 = lean_ctor_get(x_11, 3); -lean_inc(x_333); x_334 = lean_ctor_get(x_11, 5); lean_inc(x_334); -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); - lean_ctor_release(x_11, 5); - x_335 = x_11; -} else { - lean_dec_ref(x_11); - x_335 = lean_box(0); -} -x_336 = lean_ctor_get(x_12, 0); -lean_inc(x_336); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_dec(x_11); +x_335 = lean_ctor_get(x_12, 0); +lean_inc(x_335); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); - x_337 = x_12; + x_336 = x_12; } else { lean_dec_ref(x_12); - x_337 = lean_box(0); + x_336 = lean_box(0); } -x_338 = 0; -if (lean_is_scalar(x_337)) { - x_339 = lean_alloc_ctor(0, 1, 1); +x_337 = 0; +if (lean_is_scalar(x_336)) { + x_338 = lean_alloc_ctor(0, 1, 1); } else { - x_339 = x_337; + x_338 = x_336; } -lean_ctor_set(x_339, 0, x_336); -lean_ctor_set_uint8(x_339, sizeof(void*)*1, x_338); -if (lean_is_scalar(x_335)) { - x_365 = lean_alloc_ctor(0, 6, 0); -} else { - x_365 = x_335; -} -lean_ctor_set(x_365, 0, x_330); -lean_ctor_set(x_365, 1, x_1); -lean_ctor_set(x_365, 2, x_332); -lean_ctor_set(x_365, 3, x_333); -lean_ctor_set(x_365, 4, x_339); -lean_ctor_set(x_365, 5, x_334); -x_366 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_365); -if (lean_obj_tag(x_366) == 0) +lean_ctor_set(x_338, 0, x_335); +lean_ctor_set_uint8(x_338, sizeof(void*)*1, x_337); +x_419 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_419, 0, x_330); +lean_ctor_set(x_419, 1, x_1); +lean_ctor_set(x_419, 2, x_332); +lean_ctor_set(x_419, 3, x_333); +lean_ctor_set(x_419, 4, x_338); +lean_ctor_set(x_419, 5, x_334); +x_420 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_419); +if (lean_obj_tag(x_420) == 0) { -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; 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; -x_367 = lean_ctor_get(x_366, 1); -lean_inc(x_367); -x_368 = lean_ctor_get(x_366, 0); -lean_inc(x_368); -lean_dec(x_366); -x_369 = lean_ctor_get(x_367, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_367, 2); -lean_inc(x_370); -x_371 = lean_ctor_get(x_367, 3); -lean_inc(x_371); -x_372 = lean_ctor_get(x_367, 4); -lean_inc(x_372); -x_373 = lean_ctor_get(x_367, 5); -lean_inc(x_373); -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); - lean_ctor_release(x_367, 5); - x_374 = x_367; -} else { - lean_dec_ref(x_367); - x_374 = lean_box(0); -} -if (lean_is_scalar(x_374)) { - x_375 = lean_alloc_ctor(0, 6, 0); -} else { - x_375 = x_374; -} -lean_ctor_set(x_375, 0, x_369); -lean_ctor_set(x_375, 1, x_331); -lean_ctor_set(x_375, 2, x_370); -lean_ctor_set(x_375, 3, x_371); -lean_ctor_set(x_375, 4, x_372); -lean_ctor_set(x_375, 5, x_373); -x_376 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_376, 0, x_375); -lean_ctor_set(x_376, 1, x_326); -lean_ctor_set(x_376, 2, x_327); -lean_ctor_set(x_376, 3, x_328); -lean_ctor_set(x_376, 4, x_329); -x_377 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_376); -x_378 = lean_ctor_get(x_377, 1); -lean_inc(x_378); -if (lean_is_exclusive(x_377)) { - lean_ctor_release(x_377, 0); - lean_ctor_release(x_377, 1); - x_379 = x_377; -} else { - lean_dec_ref(x_377); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_378, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_380, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_378, 1); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 2); -lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 4); -lean_inc(x_385); -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); - lean_ctor_release(x_378, 4); - x_386 = x_378; -} else { - lean_dec_ref(x_378); - x_386 = lean_box(0); -} -x_387 = lean_ctor_get(x_380, 0); -lean_inc(x_387); -x_388 = lean_ctor_get(x_380, 1); -lean_inc(x_388); -x_389 = lean_ctor_get(x_380, 2); -lean_inc(x_389); -x_390 = lean_ctor_get(x_380, 3); -lean_inc(x_390); -x_391 = lean_ctor_get(x_380, 5); -lean_inc(x_391); -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_392 = x_380; -} else { - lean_dec_ref(x_380); - x_392 = lean_box(0); -} -x_393 = lean_ctor_get(x_381, 0); -lean_inc(x_393); -if (lean_is_exclusive(x_381)) { - lean_ctor_release(x_381, 0); - x_394 = x_381; -} else { - lean_dec_ref(x_381); - x_394 = lean_box(0); -} -if (lean_is_scalar(x_394)) { - x_395 = lean_alloc_ctor(0, 1, 1); -} else { - x_395 = x_394; -} -lean_ctor_set(x_395, 0, x_393); -lean_ctor_set_uint8(x_395, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_392)) { - x_396 = lean_alloc_ctor(0, 6, 0); -} else { - x_396 = x_392; -} -lean_ctor_set(x_396, 0, x_387); -lean_ctor_set(x_396, 1, x_388); -lean_ctor_set(x_396, 2, x_389); -lean_ctor_set(x_396, 3, x_390); -lean_ctor_set(x_396, 4, x_395); -lean_ctor_set(x_396, 5, x_391); -if (lean_is_scalar(x_386)) { - x_397 = lean_alloc_ctor(0, 5, 0); -} else { - x_397 = x_386; -} -lean_ctor_set(x_397, 0, x_396); -lean_ctor_set(x_397, 1, x_382); -lean_ctor_set(x_397, 2, x_383); -lean_ctor_set(x_397, 3, x_384); -lean_ctor_set(x_397, 4, x_385); -if (lean_is_scalar(x_379)) { - x_398 = lean_alloc_ctor(0, 2, 0); -} else { - x_398 = x_379; -} -lean_ctor_set(x_398, 0, x_368); -lean_ctor_set(x_398, 1, x_397); -return x_398; +lean_object* x_421; lean_object* x_422; lean_object* x_423; +x_421 = lean_ctor_get(x_420, 0); +lean_inc(x_421); +x_422 = lean_ctor_get(x_420, 1); +lean_inc(x_422); +lean_dec(x_420); +lean_ctor_set(x_10, 0, x_422); +x_423 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_423, 0, x_421); +x_364 = x_423; +x_365 = x_10; +goto block_418; } else { -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; -x_399 = lean_ctor_get(x_366, 1); +lean_object* x_424; lean_object* x_425; lean_object* x_426; +x_424 = lean_ctor_get(x_420, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_420, 1); +lean_inc(x_425); +lean_dec(x_420); +lean_ctor_set(x_10, 0, x_425); +x_426 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_426, 0, x_424); +x_364 = x_426; +x_365 = x_10; +goto block_418; +} +block_363: +{ +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; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; +x_341 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_340); +x_342 = lean_ctor_get(x_341, 1); +lean_inc(x_342); +if (lean_is_exclusive(x_341)) { + lean_ctor_release(x_341, 0); + lean_ctor_release(x_341, 1); + x_343 = x_341; +} else { + lean_dec_ref(x_341); + x_343 = lean_box(0); +} +x_344 = lean_ctor_get(x_342, 0); +lean_inc(x_344); +x_345 = lean_ctor_get(x_344, 4); +lean_inc(x_345); +x_346 = lean_ctor_get(x_342, 1); +lean_inc(x_346); +x_347 = lean_ctor_get(x_342, 2); +lean_inc(x_347); +x_348 = lean_ctor_get(x_342, 3); +lean_inc(x_348); +x_349 = lean_ctor_get(x_342, 4); +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); + x_350 = x_342; +} else { + lean_dec_ref(x_342); + x_350 = lean_box(0); +} +x_351 = lean_ctor_get(x_344, 0); +lean_inc(x_351); +x_352 = lean_ctor_get(x_344, 1); +lean_inc(x_352); +x_353 = lean_ctor_get(x_344, 2); +lean_inc(x_353); +x_354 = lean_ctor_get(x_344, 3); +lean_inc(x_354); +x_355 = lean_ctor_get(x_344, 5); +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); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_356 = x_344; +} else { + lean_dec_ref(x_344); + x_356 = lean_box(0); +} +x_357 = lean_ctor_get(x_345, 0); +lean_inc(x_357); +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + x_358 = x_345; +} else { + lean_dec_ref(x_345); + x_358 = lean_box(0); +} +if (lean_is_scalar(x_358)) { + x_359 = lean_alloc_ctor(0, 1, 1); +} else { + x_359 = x_358; +} +lean_ctor_set(x_359, 0, x_357); +lean_ctor_set_uint8(x_359, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_356)) { + x_360 = lean_alloc_ctor(0, 6, 0); +} else { + x_360 = x_356; +} +lean_ctor_set(x_360, 0, x_351); +lean_ctor_set(x_360, 1, x_352); +lean_ctor_set(x_360, 2, x_353); +lean_ctor_set(x_360, 3, x_354); +lean_ctor_set(x_360, 4, x_359); +lean_ctor_set(x_360, 5, x_355); +if (lean_is_scalar(x_350)) { + x_361 = lean_alloc_ctor(0, 5, 0); +} else { + x_361 = x_350; +} +lean_ctor_set(x_361, 0, x_360); +lean_ctor_set(x_361, 1, x_346); +lean_ctor_set(x_361, 2, x_347); +lean_ctor_set(x_361, 3, x_348); +lean_ctor_set(x_361, 4, x_349); +if (lean_is_scalar(x_343)) { + x_362 = lean_alloc_ctor(1, 2, 0); +} else { + x_362 = x_343; + lean_ctor_set_tag(x_362, 1); +} +lean_ctor_set(x_362, 0, x_339); +lean_ctor_set(x_362, 1, x_361); +return x_362; +} +block_418: +{ +if (lean_obj_tag(x_364) == 0) +{ +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_366 = lean_ctor_get(x_365, 0); +lean_inc(x_366); +x_367 = lean_ctor_get(x_364, 0); +lean_inc(x_367); +lean_dec(x_364); +x_368 = lean_ctor_get(x_365, 1); +lean_inc(x_368); +x_369 = lean_ctor_get(x_365, 2); +lean_inc(x_369); +x_370 = lean_ctor_get(x_365, 3); +lean_inc(x_370); +x_371 = lean_ctor_get(x_365, 4); +lean_inc(x_371); +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_372 = x_365; +} else { + lean_dec_ref(x_365); + x_372 = lean_box(0); +} +x_373 = lean_ctor_get(x_366, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_366, 2); +lean_inc(x_374); +x_375 = lean_ctor_get(x_366, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_366, 4); +lean_inc(x_376); +x_377 = lean_ctor_get(x_366, 5); +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); + lean_ctor_release(x_366, 5); + 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, 6, 0); +} else { + x_379 = x_378; +} +lean_ctor_set(x_379, 0, x_373); +lean_ctor_set(x_379, 1, x_331); +lean_ctor_set(x_379, 2, x_374); +lean_ctor_set(x_379, 3, x_375); +lean_ctor_set(x_379, 4, x_376); +lean_ctor_set(x_379, 5, x_377); +if (lean_is_scalar(x_372)) { + x_380 = lean_alloc_ctor(0, 5, 0); +} else { + x_380 = x_372; +} +lean_ctor_set(x_380, 0, x_379); +lean_ctor_set(x_380, 1, x_368); +lean_ctor_set(x_380, 2, x_369); +lean_ctor_set(x_380, 3, x_370); +lean_ctor_set(x_380, 4, x_371); +x_339 = x_367; +x_340 = x_380; +goto block_363; +} +else +{ +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_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; 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_381 = lean_ctor_get(x_365, 0); +lean_inc(x_381); +x_382 = lean_ctor_get(x_364, 0); +lean_inc(x_382); +lean_dec(x_364); +x_383 = lean_ctor_get(x_365, 1); +lean_inc(x_383); +x_384 = lean_ctor_get(x_365, 2); +lean_inc(x_384); +x_385 = lean_ctor_get(x_365, 3); +lean_inc(x_385); +x_386 = lean_ctor_get(x_365, 4); +lean_inc(x_386); +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_387 = x_365; +} else { + lean_dec_ref(x_365); + x_387 = lean_box(0); +} +x_388 = lean_ctor_get(x_381, 0); +lean_inc(x_388); +x_389 = lean_ctor_get(x_381, 2); +lean_inc(x_389); +x_390 = lean_ctor_get(x_381, 3); +lean_inc(x_390); +x_391 = lean_ctor_get(x_381, 4); +lean_inc(x_391); +x_392 = lean_ctor_get(x_381, 5); +lean_inc(x_392); +if (lean_is_exclusive(x_381)) { + lean_ctor_release(x_381, 0); + lean_ctor_release(x_381, 1); + lean_ctor_release(x_381, 2); + lean_ctor_release(x_381, 3); + lean_ctor_release(x_381, 4); + lean_ctor_release(x_381, 5); + x_393 = x_381; +} else { + lean_dec_ref(x_381); + x_393 = lean_box(0); +} +if (lean_is_scalar(x_393)) { + x_394 = lean_alloc_ctor(0, 6, 0); +} else { + x_394 = x_393; +} +lean_ctor_set(x_394, 0, x_388); +lean_ctor_set(x_394, 1, x_331); +lean_ctor_set(x_394, 2, x_389); +lean_ctor_set(x_394, 3, x_390); +lean_ctor_set(x_394, 4, x_391); +lean_ctor_set(x_394, 5, x_392); +if (lean_is_scalar(x_387)) { + x_395 = lean_alloc_ctor(0, 5, 0); +} else { + x_395 = x_387; +} +lean_ctor_set(x_395, 0, x_394); +lean_ctor_set(x_395, 1, x_383); +lean_ctor_set(x_395, 2, x_384); +lean_ctor_set(x_395, 3, x_385); +lean_ctor_set(x_395, 4, x_386); +x_396 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_395); +x_397 = lean_ctor_get(x_396, 1); +lean_inc(x_397); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + x_398 = x_396; +} else { + lean_dec_ref(x_396); + x_398 = lean_box(0); +} +x_399 = lean_ctor_get(x_397, 0); lean_inc(x_399); -x_400 = lean_ctor_get(x_366, 0); +x_400 = lean_ctor_get(x_399, 4); lean_inc(x_400); -lean_dec(x_366); -x_401 = lean_ctor_get(x_399, 0); +x_401 = lean_ctor_get(x_397, 1); lean_inc(x_401); -x_402 = lean_ctor_get(x_399, 2); +x_402 = lean_ctor_get(x_397, 2); lean_inc(x_402); -x_403 = lean_ctor_get(x_399, 3); +x_403 = lean_ctor_get(x_397, 3); lean_inc(x_403); -x_404 = lean_ctor_get(x_399, 4); +x_404 = lean_ctor_get(x_397, 4); lean_inc(x_404); -x_405 = lean_ctor_get(x_399, 5); -lean_inc(x_405); +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_405 = x_397; +} else { + lean_dec_ref(x_397); + x_405 = lean_box(0); +} +x_406 = lean_ctor_get(x_399, 0); +lean_inc(x_406); +x_407 = lean_ctor_get(x_399, 1); +lean_inc(x_407); +x_408 = lean_ctor_get(x_399, 2); +lean_inc(x_408); +x_409 = lean_ctor_get(x_399, 3); +lean_inc(x_409); +x_410 = lean_ctor_get(x_399, 5); +lean_inc(x_410); if (lean_is_exclusive(x_399)) { lean_ctor_release(x_399, 0); lean_ctor_release(x_399, 1); @@ -10210,381 +10400,308 @@ if (lean_is_exclusive(x_399)) { lean_ctor_release(x_399, 3); lean_ctor_release(x_399, 4); lean_ctor_release(x_399, 5); - x_406 = x_399; + x_411 = x_399; } else { lean_dec_ref(x_399); - x_406 = lean_box(0); + x_411 = lean_box(0); } -if (lean_is_scalar(x_406)) { - x_407 = lean_alloc_ctor(0, 6, 0); -} else { - x_407 = x_406; -} -lean_ctor_set(x_407, 0, x_401); -lean_ctor_set(x_407, 1, x_331); -lean_ctor_set(x_407, 2, x_402); -lean_ctor_set(x_407, 3, x_403); -lean_ctor_set(x_407, 4, x_404); -lean_ctor_set(x_407, 5, x_405); -x_408 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_408, 0, x_407); -lean_ctor_set(x_408, 1, x_326); -lean_ctor_set(x_408, 2, x_327); -lean_ctor_set(x_408, 3, x_328); -lean_ctor_set(x_408, 4, x_329); -x_340 = x_400; -x_341 = x_408; -goto block_364; -} -block_364: -{ -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; 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_342 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_341); -x_343 = lean_ctor_get(x_342, 1); -lean_inc(x_343); -if (lean_is_exclusive(x_342)) { - lean_ctor_release(x_342, 0); - lean_ctor_release(x_342, 1); - x_344 = x_342; -} else { - lean_dec_ref(x_342); - x_344 = lean_box(0); -} -x_345 = lean_ctor_get(x_343, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_345, 4); -lean_inc(x_346); -x_347 = lean_ctor_get(x_343, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_343, 2); -lean_inc(x_348); -x_349 = lean_ctor_get(x_343, 3); -lean_inc(x_349); -x_350 = lean_ctor_get(x_343, 4); -lean_inc(x_350); -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); - x_351 = x_343; -} else { - lean_dec_ref(x_343); - x_351 = lean_box(0); -} -x_352 = lean_ctor_get(x_345, 0); -lean_inc(x_352); -x_353 = lean_ctor_get(x_345, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_345, 2); -lean_inc(x_354); -x_355 = lean_ctor_get(x_345, 3); -lean_inc(x_355); -x_356 = lean_ctor_get(x_345, 5); -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); - lean_ctor_release(x_345, 4); - lean_ctor_release(x_345, 5); - x_357 = x_345; -} else { - lean_dec_ref(x_345); - x_357 = lean_box(0); -} -x_358 = lean_ctor_get(x_346, 0); -lean_inc(x_358); -if (lean_is_exclusive(x_346)) { - lean_ctor_release(x_346, 0); - x_359 = x_346; -} else { - lean_dec_ref(x_346); - x_359 = lean_box(0); -} -if (lean_is_scalar(x_359)) { - x_360 = lean_alloc_ctor(0, 1, 1); -} else { - x_360 = x_359; -} -lean_ctor_set(x_360, 0, x_358); -lean_ctor_set_uint8(x_360, sizeof(void*)*1, x_13); -if (lean_is_scalar(x_357)) { - x_361 = lean_alloc_ctor(0, 6, 0); -} else { - x_361 = x_357; -} -lean_ctor_set(x_361, 0, x_352); -lean_ctor_set(x_361, 1, x_353); -lean_ctor_set(x_361, 2, x_354); -lean_ctor_set(x_361, 3, x_355); -lean_ctor_set(x_361, 4, x_360); -lean_ctor_set(x_361, 5, x_356); -if (lean_is_scalar(x_351)) { - x_362 = lean_alloc_ctor(0, 5, 0); -} else { - x_362 = x_351; -} -lean_ctor_set(x_362, 0, x_361); -lean_ctor_set(x_362, 1, x_347); -lean_ctor_set(x_362, 2, x_348); -lean_ctor_set(x_362, 3, x_349); -lean_ctor_set(x_362, 4, x_350); -if (lean_is_scalar(x_344)) { - x_363 = lean_alloc_ctor(1, 2, 0); -} else { - x_363 = x_344; - lean_ctor_set_tag(x_363, 1); -} -lean_ctor_set(x_363, 0, x_340); -lean_ctor_set(x_363, 1, x_362); -return x_363; -} -} -} -else -{ -lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; uint8_t x_413; -x_409 = l___private_Lean_Util_Trace_3__getResetTraces___at_Lean_Meta_SynthInstance_tryResolve___spec__1___rarg(x_7); -x_410 = lean_ctor_get(x_409, 1); -lean_inc(x_410); -x_411 = lean_ctor_get(x_410, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_409, 0); +x_412 = lean_ctor_get(x_400, 0); lean_inc(x_412); -lean_dec(x_409); -x_413 = !lean_is_exclusive(x_410); -if (x_413 == 0) -{ -lean_object* x_414; uint8_t x_415; -x_414 = lean_ctor_get(x_410, 0); -lean_dec(x_414); -x_415 = !lean_is_exclusive(x_411); -if (x_415 == 0) -{ -lean_object* x_416; lean_object* x_417; -x_416 = lean_ctor_get(x_411, 1); -lean_ctor_set(x_411, 1, x_1); -lean_inc(x_4); -x_417 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_411); -if (lean_obj_tag(x_417) == 0) -{ -lean_object* x_418; lean_object* x_419; uint8_t x_420; -x_418 = lean_ctor_get(x_417, 1); -lean_inc(x_418); -x_419 = lean_ctor_get(x_417, 0); -lean_inc(x_419); -lean_dec(x_417); -x_420 = !lean_is_exclusive(x_418); -if (x_420 == 0) -{ -lean_object* x_421; lean_object* x_422; lean_object* x_423; uint8_t x_424; -x_421 = lean_ctor_get(x_418, 1); -lean_dec(x_421); -lean_ctor_set(x_418, 1, x_416); -lean_ctor_set(x_410, 0, x_418); -x_422 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_423 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_422, x_4, x_410); -lean_dec(x_4); -x_424 = !lean_is_exclusive(x_423); -if (x_424 == 0) -{ -lean_object* x_425; -x_425 = lean_ctor_get(x_423, 0); -lean_dec(x_425); -lean_ctor_set(x_423, 0, x_419); -return x_423; +if (lean_is_exclusive(x_400)) { + lean_ctor_release(x_400, 0); + x_413 = x_400; +} else { + lean_dec_ref(x_400); + x_413 = lean_box(0); +} +if (lean_is_scalar(x_413)) { + x_414 = lean_alloc_ctor(0, 1, 1); +} else { + x_414 = x_413; +} +lean_ctor_set(x_414, 0, x_412); +lean_ctor_set_uint8(x_414, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_411)) { + x_415 = lean_alloc_ctor(0, 6, 0); +} else { + x_415 = x_411; +} +lean_ctor_set(x_415, 0, x_406); +lean_ctor_set(x_415, 1, x_407); +lean_ctor_set(x_415, 2, x_408); +lean_ctor_set(x_415, 3, x_409); +lean_ctor_set(x_415, 4, x_414); +lean_ctor_set(x_415, 5, x_410); +if (lean_is_scalar(x_405)) { + x_416 = lean_alloc_ctor(0, 5, 0); +} else { + x_416 = x_405; +} +lean_ctor_set(x_416, 0, x_415); +lean_ctor_set(x_416, 1, x_401); +lean_ctor_set(x_416, 2, x_402); +lean_ctor_set(x_416, 3, x_403); +lean_ctor_set(x_416, 4, x_404); +if (lean_is_scalar(x_398)) { + x_417 = lean_alloc_ctor(0, 2, 0); +} else { + x_417 = x_398; +} +lean_ctor_set(x_417, 0, x_382); +lean_ctor_set(x_417, 1, x_416); +return x_417; +} } -else -{ -lean_object* x_426; lean_object* x_427; -x_426 = lean_ctor_get(x_423, 1); -lean_inc(x_426); -lean_dec(x_423); -x_427 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_427, 0, x_419); -lean_ctor_set(x_427, 1, x_426); -return x_427; } } 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_418, 0); -x_429 = lean_ctor_get(x_418, 2); -x_430 = lean_ctor_get(x_418, 3); -x_431 = lean_ctor_get(x_418, 4); -x_432 = lean_ctor_get(x_418, 5); -lean_inc(x_432); -lean_inc(x_431); +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; uint8_t x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_466; lean_object* x_467; lean_object* x_521; lean_object* x_522; +x_427 = lean_ctor_get(x_10, 1); +x_428 = lean_ctor_get(x_10, 2); +x_429 = lean_ctor_get(x_10, 3); +x_430 = lean_ctor_get(x_10, 4); lean_inc(x_430); lean_inc(x_429); lean_inc(x_428); -lean_dec(x_418); -x_433 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_433, 0, x_428); -lean_ctor_set(x_433, 1, x_416); -lean_ctor_set(x_433, 2, x_429); -lean_ctor_set(x_433, 3, x_430); -lean_ctor_set(x_433, 4, x_431); -lean_ctor_set(x_433, 5, x_432); -lean_ctor_set(x_410, 0, x_433); -x_434 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_435 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_434, x_4, x_410); -lean_dec(x_4); -x_436 = lean_ctor_get(x_435, 1); -lean_inc(x_436); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - x_437 = x_435; +lean_inc(x_427); +lean_dec(x_10); +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, 5); +lean_inc(x_435); +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); + lean_ctor_release(x_11, 5); + x_436 = x_11; } else { - lean_dec_ref(x_435); - x_437 = lean_box(0); + lean_dec_ref(x_11); + x_436 = lean_box(0); } -if (lean_is_scalar(x_437)) { - x_438 = lean_alloc_ctor(0, 2, 0); +x_437 = lean_ctor_get(x_12, 0); +lean_inc(x_437); +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + x_438 = x_12; } else { - x_438 = x_437; + lean_dec_ref(x_12); + x_438 = lean_box(0); } -lean_ctor_set(x_438, 0, x_419); -lean_ctor_set(x_438, 1, x_436); -return x_438; +x_439 = 0; +if (lean_is_scalar(x_438)) { + x_440 = lean_alloc_ctor(0, 1, 1); +} else { + x_440 = x_438; } +lean_ctor_set(x_440, 0, x_437); +lean_ctor_set_uint8(x_440, sizeof(void*)*1, x_439); +if (lean_is_scalar(x_436)) { + x_521 = lean_alloc_ctor(0, 6, 0); +} else { + x_521 = x_436; +} +lean_ctor_set(x_521, 0, x_431); +lean_ctor_set(x_521, 1, x_1); +lean_ctor_set(x_521, 2, x_433); +lean_ctor_set(x_521, 3, x_434); +lean_ctor_set(x_521, 4, x_440); +lean_ctor_set(x_521, 5, x_435); +x_522 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_521); +if (lean_obj_tag(x_522) == 0) +{ +lean_object* x_523; lean_object* x_524; lean_object* x_525; lean_object* x_526; +x_523 = lean_ctor_get(x_522, 0); +lean_inc(x_523); +x_524 = lean_ctor_get(x_522, 1); +lean_inc(x_524); +lean_dec(x_522); +x_525 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_525, 0, x_524); +lean_ctor_set(x_525, 1, x_427); +lean_ctor_set(x_525, 2, x_428); +lean_ctor_set(x_525, 3, x_429); +lean_ctor_set(x_525, 4, x_430); +x_526 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_526, 0, x_523); +x_466 = x_526; +x_467 = x_525; +goto block_520; } else { -lean_object* x_439; lean_object* x_440; uint8_t x_441; -x_439 = lean_ctor_get(x_417, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_417, 0); -lean_inc(x_440); -lean_dec(x_417); -x_441 = !lean_is_exclusive(x_439); -if (x_441 == 0) +lean_object* x_527; lean_object* x_528; lean_object* x_529; lean_object* x_530; +x_527 = lean_ctor_get(x_522, 0); +lean_inc(x_527); +x_528 = lean_ctor_get(x_522, 1); +lean_inc(x_528); +lean_dec(x_522); +x_529 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_529, 0, x_528); +lean_ctor_set(x_529, 1, x_427); +lean_ctor_set(x_529, 2, x_428); +lean_ctor_set(x_529, 3, x_429); +lean_ctor_set(x_529, 4, x_430); +x_530 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_530, 0, x_527); +x_466 = x_530; +x_467 = x_529; +goto block_520; +} +block_465: { -lean_object* x_442; lean_object* x_443; lean_object* x_444; uint8_t x_445; -x_442 = lean_ctor_get(x_439, 1); -lean_dec(x_442); -lean_ctor_set(x_439, 1, x_416); -lean_ctor_set(x_410, 0, x_439); -x_443 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_444 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_443, x_4, x_410); -lean_dec(x_4); -x_445 = !lean_is_exclusive(x_444); -if (x_445 == 0) -{ -lean_object* x_446; +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; 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; +x_443 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_442); +x_444 = lean_ctor_get(x_443, 1); +lean_inc(x_444); +if (lean_is_exclusive(x_443)) { + lean_ctor_release(x_443, 0); + lean_ctor_release(x_443, 1); + x_445 = x_443; +} else { + lean_dec_ref(x_443); + x_445 = lean_box(0); +} x_446 = lean_ctor_get(x_444, 0); -lean_dec(x_446); -lean_ctor_set_tag(x_444, 1); -lean_ctor_set(x_444, 0, x_440); -return x_444; -} -else -{ -lean_object* x_447; lean_object* x_448; -x_447 = lean_ctor_get(x_444, 1); +lean_inc(x_446); +x_447 = lean_ctor_get(x_446, 4); lean_inc(x_447); -lean_dec(x_444); -x_448 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_447); -return x_448; -} -} -else -{ -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_449 = lean_ctor_get(x_439, 0); -x_450 = lean_ctor_get(x_439, 2); -x_451 = lean_ctor_get(x_439, 3); -x_452 = lean_ctor_get(x_439, 4); -x_453 = lean_ctor_get(x_439, 5); -lean_inc(x_453); -lean_inc(x_452); -lean_inc(x_451); -lean_inc(x_450); +x_448 = lean_ctor_get(x_444, 1); +lean_inc(x_448); +x_449 = lean_ctor_get(x_444, 2); lean_inc(x_449); -lean_dec(x_439); -x_454 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_454, 0, x_449); -lean_ctor_set(x_454, 1, x_416); -lean_ctor_set(x_454, 2, x_450); -lean_ctor_set(x_454, 3, x_451); -lean_ctor_set(x_454, 4, x_452); -lean_ctor_set(x_454, 5, x_453); -lean_ctor_set(x_410, 0, x_454); -x_455 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_456 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_455, x_4, x_410); -lean_dec(x_4); -x_457 = lean_ctor_get(x_456, 1); -lean_inc(x_457); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - x_458 = x_456; +x_450 = lean_ctor_get(x_444, 3); +lean_inc(x_450); +x_451 = lean_ctor_get(x_444, 4); +lean_inc(x_451); +if (lean_is_exclusive(x_444)) { + lean_ctor_release(x_444, 0); + lean_ctor_release(x_444, 1); + lean_ctor_release(x_444, 2); + lean_ctor_release(x_444, 3); + lean_ctor_release(x_444, 4); + x_452 = x_444; } else { - lean_dec_ref(x_456); + lean_dec_ref(x_444); + x_452 = lean_box(0); +} +x_453 = lean_ctor_get(x_446, 0); +lean_inc(x_453); +x_454 = lean_ctor_get(x_446, 1); +lean_inc(x_454); +x_455 = lean_ctor_get(x_446, 2); +lean_inc(x_455); +x_456 = lean_ctor_get(x_446, 3); +lean_inc(x_456); +x_457 = lean_ctor_get(x_446, 5); +lean_inc(x_457); +if (lean_is_exclusive(x_446)) { + lean_ctor_release(x_446, 0); + lean_ctor_release(x_446, 1); + lean_ctor_release(x_446, 2); + lean_ctor_release(x_446, 3); + lean_ctor_release(x_446, 4); + lean_ctor_release(x_446, 5); + x_458 = x_446; +} else { + lean_dec_ref(x_446); x_458 = lean_box(0); } -if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(1, 2, 0); +x_459 = lean_ctor_get(x_447, 0); +lean_inc(x_459); +if (lean_is_exclusive(x_447)) { + lean_ctor_release(x_447, 0); + x_460 = x_447; } else { - x_459 = x_458; - lean_ctor_set_tag(x_459, 1); + lean_dec_ref(x_447); + x_460 = lean_box(0); } -lean_ctor_set(x_459, 0, x_440); -lean_ctor_set(x_459, 1, x_457); -return x_459; +if (lean_is_scalar(x_460)) { + x_461 = lean_alloc_ctor(0, 1, 1); +} else { + x_461 = x_460; } +lean_ctor_set(x_461, 0, x_459); +lean_ctor_set_uint8(x_461, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_458)) { + x_462 = lean_alloc_ctor(0, 6, 0); +} else { + x_462 = x_458; } +lean_ctor_set(x_462, 0, x_453); +lean_ctor_set(x_462, 1, x_454); +lean_ctor_set(x_462, 2, x_455); +lean_ctor_set(x_462, 3, x_456); +lean_ctor_set(x_462, 4, x_461); +lean_ctor_set(x_462, 5, x_457); +if (lean_is_scalar(x_452)) { + x_463 = lean_alloc_ctor(0, 5, 0); +} else { + x_463 = x_452; } -else +lean_ctor_set(x_463, 0, x_462); +lean_ctor_set(x_463, 1, x_448); +lean_ctor_set(x_463, 2, x_449); +lean_ctor_set(x_463, 3, x_450); +lean_ctor_set(x_463, 4, x_451); +if (lean_is_scalar(x_445)) { + x_464 = lean_alloc_ctor(1, 2, 0); +} else { + x_464 = x_445; + lean_ctor_set_tag(x_464, 1); +} +lean_ctor_set(x_464, 0, x_441); +lean_ctor_set(x_464, 1, x_463); +return x_464; +} +block_520: { -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; -x_460 = lean_ctor_get(x_411, 0); -x_461 = lean_ctor_get(x_411, 1); -x_462 = lean_ctor_get(x_411, 2); -x_463 = lean_ctor_get(x_411, 3); -x_464 = lean_ctor_get(x_411, 4); -x_465 = lean_ctor_get(x_411, 5); -lean_inc(x_465); -lean_inc(x_464); -lean_inc(x_463); -lean_inc(x_462); -lean_inc(x_461); -lean_inc(x_460); -lean_dec(x_411); -x_466 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_466, 0, x_460); -lean_ctor_set(x_466, 1, x_1); -lean_ctor_set(x_466, 2, x_462); -lean_ctor_set(x_466, 3, x_463); -lean_ctor_set(x_466, 4, x_464); -lean_ctor_set(x_466, 5, x_465); -lean_inc(x_4); -x_467 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_466); -if (lean_obj_tag(x_467) == 0) +if (lean_obj_tag(x_466) == 0) { -lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; -x_468 = lean_ctor_get(x_467, 1); +lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; +x_468 = lean_ctor_get(x_467, 0); lean_inc(x_468); -x_469 = lean_ctor_get(x_467, 0); +x_469 = lean_ctor_get(x_466, 0); lean_inc(x_469); -lean_dec(x_467); -x_470 = lean_ctor_get(x_468, 0); +lean_dec(x_466); +x_470 = lean_ctor_get(x_467, 1); lean_inc(x_470); -x_471 = lean_ctor_get(x_468, 2); +x_471 = lean_ctor_get(x_467, 2); lean_inc(x_471); -x_472 = lean_ctor_get(x_468, 3); +x_472 = lean_ctor_get(x_467, 3); lean_inc(x_472); -x_473 = lean_ctor_get(x_468, 4); +x_473 = lean_ctor_get(x_467, 4); lean_inc(x_473); -x_474 = lean_ctor_get(x_468, 5); -lean_inc(x_474); +if (lean_is_exclusive(x_467)) { + lean_ctor_release(x_467, 0); + lean_ctor_release(x_467, 1); + lean_ctor_release(x_467, 2); + lean_ctor_release(x_467, 3); + lean_ctor_release(x_467, 4); + x_474 = x_467; +} else { + lean_dec_ref(x_467); + x_474 = lean_box(0); +} +x_475 = lean_ctor_get(x_468, 0); +lean_inc(x_475); +x_476 = lean_ctor_get(x_468, 2); +lean_inc(x_476); +x_477 = lean_ctor_get(x_468, 3); +lean_inc(x_477); +x_478 = lean_ctor_get(x_468, 4); +lean_inc(x_478); +x_479 = lean_ctor_get(x_468, 5); +lean_inc(x_479); if (lean_is_exclusive(x_468)) { lean_ctor_release(x_468, 0); lean_ctor_release(x_468, 1); @@ -10592,299 +10709,1122 @@ if (lean_is_exclusive(x_468)) { lean_ctor_release(x_468, 3); lean_ctor_release(x_468, 4); lean_ctor_release(x_468, 5); - x_475 = x_468; + x_480 = x_468; } else { lean_dec_ref(x_468); - x_475 = lean_box(0); -} -if (lean_is_scalar(x_475)) { - x_476 = lean_alloc_ctor(0, 6, 0); -} else { - x_476 = x_475; -} -lean_ctor_set(x_476, 0, x_470); -lean_ctor_set(x_476, 1, x_461); -lean_ctor_set(x_476, 2, x_471); -lean_ctor_set(x_476, 3, x_472); -lean_ctor_set(x_476, 4, x_473); -lean_ctor_set(x_476, 5, x_474); -lean_ctor_set(x_410, 0, x_476); -x_477 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_478 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_477, x_4, x_410); -lean_dec(x_4); -x_479 = lean_ctor_get(x_478, 1); -lean_inc(x_479); -if (lean_is_exclusive(x_478)) { - lean_ctor_release(x_478, 0); - lean_ctor_release(x_478, 1); - x_480 = x_478; -} else { - lean_dec_ref(x_478); x_480 = lean_box(0); } if (lean_is_scalar(x_480)) { - x_481 = lean_alloc_ctor(0, 2, 0); + x_481 = lean_alloc_ctor(0, 6, 0); } else { x_481 = x_480; } -lean_ctor_set(x_481, 0, x_469); -lean_ctor_set(x_481, 1, x_479); -return x_481; +lean_ctor_set(x_481, 0, x_475); +lean_ctor_set(x_481, 1, x_432); +lean_ctor_set(x_481, 2, x_476); +lean_ctor_set(x_481, 3, x_477); +lean_ctor_set(x_481, 4, x_478); +lean_ctor_set(x_481, 5, x_479); +if (lean_is_scalar(x_474)) { + x_482 = lean_alloc_ctor(0, 5, 0); +} else { + x_482 = x_474; +} +lean_ctor_set(x_482, 0, x_481); +lean_ctor_set(x_482, 1, x_470); +lean_ctor_set(x_482, 2, x_471); +lean_ctor_set(x_482, 3, x_472); +lean_ctor_set(x_482, 4, x_473); +x_441 = x_469; +x_442 = x_482; +goto block_465; } else { -lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_482 = lean_ctor_get(x_467, 1); -lean_inc(x_482); +lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; x_483 = lean_ctor_get(x_467, 0); lean_inc(x_483); -lean_dec(x_467); -x_484 = lean_ctor_get(x_482, 0); +x_484 = lean_ctor_get(x_466, 0); lean_inc(x_484); -x_485 = lean_ctor_get(x_482, 2); +lean_dec(x_466); +x_485 = lean_ctor_get(x_467, 1); lean_inc(x_485); -x_486 = lean_ctor_get(x_482, 3); +x_486 = lean_ctor_get(x_467, 2); lean_inc(x_486); -x_487 = lean_ctor_get(x_482, 4); +x_487 = lean_ctor_get(x_467, 3); lean_inc(x_487); -x_488 = lean_ctor_get(x_482, 5); +x_488 = lean_ctor_get(x_467, 4); lean_inc(x_488); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - lean_ctor_release(x_482, 2); - lean_ctor_release(x_482, 3); - lean_ctor_release(x_482, 4); - lean_ctor_release(x_482, 5); - x_489 = x_482; +if (lean_is_exclusive(x_467)) { + lean_ctor_release(x_467, 0); + lean_ctor_release(x_467, 1); + lean_ctor_release(x_467, 2); + lean_ctor_release(x_467, 3); + lean_ctor_release(x_467, 4); + x_489 = x_467; } else { - lean_dec_ref(x_482); + lean_dec_ref(x_467); x_489 = lean_box(0); } -if (lean_is_scalar(x_489)) { - x_490 = lean_alloc_ctor(0, 6, 0); -} else { - x_490 = x_489; -} -lean_ctor_set(x_490, 0, x_484); -lean_ctor_set(x_490, 1, x_461); -lean_ctor_set(x_490, 2, x_485); -lean_ctor_set(x_490, 3, x_486); -lean_ctor_set(x_490, 4, x_487); -lean_ctor_set(x_490, 5, x_488); -lean_ctor_set(x_410, 0, x_490); -x_491 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_492 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_491, x_4, x_410); -lean_dec(x_4); -x_493 = lean_ctor_get(x_492, 1); +x_490 = lean_ctor_get(x_483, 0); +lean_inc(x_490); +x_491 = lean_ctor_get(x_483, 2); +lean_inc(x_491); +x_492 = lean_ctor_get(x_483, 3); +lean_inc(x_492); +x_493 = lean_ctor_get(x_483, 4); lean_inc(x_493); -if (lean_is_exclusive(x_492)) { - lean_ctor_release(x_492, 0); - lean_ctor_release(x_492, 1); - x_494 = x_492; +x_494 = lean_ctor_get(x_483, 5); +lean_inc(x_494); +if (lean_is_exclusive(x_483)) { + lean_ctor_release(x_483, 0); + lean_ctor_release(x_483, 1); + lean_ctor_release(x_483, 2); + lean_ctor_release(x_483, 3); + lean_ctor_release(x_483, 4); + lean_ctor_release(x_483, 5); + x_495 = x_483; } else { - lean_dec_ref(x_492); - x_494 = lean_box(0); + lean_dec_ref(x_483); + x_495 = lean_box(0); } -if (lean_is_scalar(x_494)) { - x_495 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_495)) { + x_496 = lean_alloc_ctor(0, 6, 0); } else { - x_495 = x_494; - lean_ctor_set_tag(x_495, 1); + x_496 = x_495; } -lean_ctor_set(x_495, 0, x_483); -lean_ctor_set(x_495, 1, x_493); -return x_495; +lean_ctor_set(x_496, 0, x_490); +lean_ctor_set(x_496, 1, x_432); +lean_ctor_set(x_496, 2, x_491); +lean_ctor_set(x_496, 3, x_492); +lean_ctor_set(x_496, 4, x_493); +lean_ctor_set(x_496, 5, x_494); +if (lean_is_scalar(x_489)) { + x_497 = lean_alloc_ctor(0, 5, 0); +} else { + x_497 = x_489; } -} -} -else -{ -lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; -x_496 = lean_ctor_get(x_410, 1); -x_497 = lean_ctor_get(x_410, 2); -x_498 = lean_ctor_get(x_410, 3); -x_499 = lean_ctor_get(x_410, 4); +lean_ctor_set(x_497, 0, x_496); +lean_ctor_set(x_497, 1, x_485); +lean_ctor_set(x_497, 2, x_486); +lean_ctor_set(x_497, 3, x_487); +lean_ctor_set(x_497, 4, x_488); +x_498 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_497); +x_499 = lean_ctor_get(x_498, 1); lean_inc(x_499); -lean_inc(x_498); -lean_inc(x_497); -lean_inc(x_496); -lean_dec(x_410); -x_500 = lean_ctor_get(x_411, 0); -lean_inc(x_500); -x_501 = lean_ctor_get(x_411, 1); +if (lean_is_exclusive(x_498)) { + lean_ctor_release(x_498, 0); + lean_ctor_release(x_498, 1); + x_500 = x_498; +} else { + lean_dec_ref(x_498); + x_500 = lean_box(0); +} +x_501 = lean_ctor_get(x_499, 0); lean_inc(x_501); -x_502 = lean_ctor_get(x_411, 2); +x_502 = lean_ctor_get(x_501, 4); lean_inc(x_502); -x_503 = lean_ctor_get(x_411, 3); +x_503 = lean_ctor_get(x_499, 1); lean_inc(x_503); -x_504 = lean_ctor_get(x_411, 4); +x_504 = lean_ctor_get(x_499, 2); lean_inc(x_504); -x_505 = lean_ctor_get(x_411, 5); +x_505 = lean_ctor_get(x_499, 3); lean_inc(x_505); -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); - lean_ctor_release(x_411, 5); - x_506 = x_411; +x_506 = lean_ctor_get(x_499, 4); +lean_inc(x_506); +if (lean_is_exclusive(x_499)) { + lean_ctor_release(x_499, 0); + lean_ctor_release(x_499, 1); + lean_ctor_release(x_499, 2); + lean_ctor_release(x_499, 3); + lean_ctor_release(x_499, 4); + x_507 = x_499; } else { - lean_dec_ref(x_411); - x_506 = lean_box(0); + lean_dec_ref(x_499); + x_507 = lean_box(0); } -if (lean_is_scalar(x_506)) { - x_507 = lean_alloc_ctor(0, 6, 0); -} else { - x_507 = x_506; -} -lean_ctor_set(x_507, 0, x_500); -lean_ctor_set(x_507, 1, x_1); -lean_ctor_set(x_507, 2, x_502); -lean_ctor_set(x_507, 3, x_503); -lean_ctor_set(x_507, 4, x_504); -lean_ctor_set(x_507, 5, x_505); -lean_inc(x_4); -x_508 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_507); -if (lean_obj_tag(x_508) == 0) -{ -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; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; -x_509 = lean_ctor_get(x_508, 1); +x_508 = lean_ctor_get(x_501, 0); +lean_inc(x_508); +x_509 = lean_ctor_get(x_501, 1); lean_inc(x_509); -x_510 = lean_ctor_get(x_508, 0); +x_510 = lean_ctor_get(x_501, 2); lean_inc(x_510); -lean_dec(x_508); -x_511 = lean_ctor_get(x_509, 0); +x_511 = lean_ctor_get(x_501, 3); lean_inc(x_511); -x_512 = lean_ctor_get(x_509, 2); +x_512 = lean_ctor_get(x_501, 5); lean_inc(x_512); -x_513 = lean_ctor_get(x_509, 3); -lean_inc(x_513); -x_514 = lean_ctor_get(x_509, 4); -lean_inc(x_514); -x_515 = lean_ctor_get(x_509, 5); -lean_inc(x_515); -if (lean_is_exclusive(x_509)) { - lean_ctor_release(x_509, 0); - lean_ctor_release(x_509, 1); - lean_ctor_release(x_509, 2); - lean_ctor_release(x_509, 3); - lean_ctor_release(x_509, 4); - lean_ctor_release(x_509, 5); - x_516 = x_509; +if (lean_is_exclusive(x_501)) { + lean_ctor_release(x_501, 0); + lean_ctor_release(x_501, 1); + lean_ctor_release(x_501, 2); + lean_ctor_release(x_501, 3); + lean_ctor_release(x_501, 4); + lean_ctor_release(x_501, 5); + x_513 = x_501; } else { - lean_dec_ref(x_509); - x_516 = lean_box(0); + lean_dec_ref(x_501); + x_513 = lean_box(0); } -if (lean_is_scalar(x_516)) { +x_514 = lean_ctor_get(x_502, 0); +lean_inc(x_514); +if (lean_is_exclusive(x_502)) { + lean_ctor_release(x_502, 0); + x_515 = x_502; +} else { + lean_dec_ref(x_502); + x_515 = lean_box(0); +} +if (lean_is_scalar(x_515)) { + x_516 = lean_alloc_ctor(0, 1, 1); +} else { + x_516 = x_515; +} +lean_ctor_set(x_516, 0, x_514); +lean_ctor_set_uint8(x_516, sizeof(void*)*1, x_13); +if (lean_is_scalar(x_513)) { x_517 = lean_alloc_ctor(0, 6, 0); } else { - x_517 = x_516; + x_517 = x_513; +} +lean_ctor_set(x_517, 0, x_508); +lean_ctor_set(x_517, 1, x_509); +lean_ctor_set(x_517, 2, x_510); +lean_ctor_set(x_517, 3, x_511); +lean_ctor_set(x_517, 4, x_516); +lean_ctor_set(x_517, 5, x_512); +if (lean_is_scalar(x_507)) { + x_518 = lean_alloc_ctor(0, 5, 0); +} else { + x_518 = x_507; } -lean_ctor_set(x_517, 0, x_511); -lean_ctor_set(x_517, 1, x_501); -lean_ctor_set(x_517, 2, x_512); -lean_ctor_set(x_517, 3, x_513); -lean_ctor_set(x_517, 4, x_514); -lean_ctor_set(x_517, 5, x_515); -x_518 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_518, 0, x_517); -lean_ctor_set(x_518, 1, x_496); -lean_ctor_set(x_518, 2, x_497); -lean_ctor_set(x_518, 3, x_498); -lean_ctor_set(x_518, 4, x_499); -x_519 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_520 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_519, x_4, x_518); -lean_dec(x_4); -x_521 = lean_ctor_get(x_520, 1); -lean_inc(x_521); -if (lean_is_exclusive(x_520)) { - lean_ctor_release(x_520, 0); - lean_ctor_release(x_520, 1); - x_522 = x_520; +lean_ctor_set(x_518, 1, x_503); +lean_ctor_set(x_518, 2, x_504); +lean_ctor_set(x_518, 3, x_505); +lean_ctor_set(x_518, 4, x_506); +if (lean_is_scalar(x_500)) { + x_519 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_520); - x_522 = lean_box(0); + x_519 = x_500; +} +lean_ctor_set(x_519, 0, x_484); +lean_ctor_set(x_519, 1, x_518); +return x_519; +} } -if (lean_is_scalar(x_522)) { - x_523 = lean_alloc_ctor(0, 2, 0); -} else { - x_523 = x_522; } -lean_ctor_set(x_523, 0, x_510); -lean_ctor_set(x_523, 1, x_521); -return x_523; } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; lean_object* x_527; lean_object* x_528; lean_object* x_529; lean_object* x_530; lean_object* x_531; lean_object* x_532; lean_object* x_533; lean_object* x_534; lean_object* x_535; lean_object* x_536; lean_object* x_537; lean_object* x_538; -x_524 = lean_ctor_get(x_508, 1); -lean_inc(x_524); -x_525 = lean_ctor_get(x_508, 0); -lean_inc(x_525); -lean_dec(x_508); -x_526 = lean_ctor_get(x_524, 0); -lean_inc(x_526); -x_527 = lean_ctor_get(x_524, 2); -lean_inc(x_527); -x_528 = lean_ctor_get(x_524, 3); -lean_inc(x_528); -x_529 = lean_ctor_get(x_524, 4); -lean_inc(x_529); -x_530 = lean_ctor_get(x_524, 5); -lean_inc(x_530); -if (lean_is_exclusive(x_524)) { - lean_ctor_release(x_524, 0); - lean_ctor_release(x_524, 1); - lean_ctor_release(x_524, 2); - lean_ctor_release(x_524, 3); - lean_ctor_release(x_524, 4); - lean_ctor_release(x_524, 5); - x_531 = x_524; -} else { - lean_dec_ref(x_524); - x_531 = lean_box(0); +lean_object* x_531; lean_object* x_532; lean_object* x_533; lean_object* x_534; uint8_t x_535; +x_531 = l___private_Lean_Util_Trace_3__getResetTraces___at_Lean_Meta_SynthInstance_tryResolve___spec__1___rarg(x_7); +x_532 = lean_ctor_get(x_531, 1); +lean_inc(x_532); +x_533 = lean_ctor_get(x_532, 0); +lean_inc(x_533); +x_534 = lean_ctor_get(x_531, 0); +lean_inc(x_534); +lean_dec(x_531); +x_535 = !lean_is_exclusive(x_532); +if (x_535 == 0) +{ +lean_object* x_536; uint8_t x_537; +x_536 = lean_ctor_get(x_532, 0); +lean_dec(x_536); +x_537 = !lean_is_exclusive(x_533); +if (x_537 == 0) +{ +lean_object* x_538; lean_object* x_539; lean_object* x_540; lean_object* x_622; +x_538 = lean_ctor_get(x_533, 1); +lean_ctor_set(x_533, 1, x_1); +lean_inc(x_4); +x_622 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_533); +if (lean_obj_tag(x_622) == 0) +{ +lean_object* x_623; lean_object* x_624; lean_object* x_625; +x_623 = lean_ctor_get(x_622, 0); +lean_inc(x_623); +x_624 = lean_ctor_get(x_622, 1); +lean_inc(x_624); +lean_dec(x_622); +lean_ctor_set(x_532, 0, x_624); +x_625 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_625, 0, x_623); +x_539 = x_625; +x_540 = x_532; +goto block_621; } -if (lean_is_scalar(x_531)) { - x_532 = lean_alloc_ctor(0, 6, 0); -} else { - x_532 = x_531; +else +{ +lean_object* x_626; lean_object* x_627; lean_object* x_628; +x_626 = lean_ctor_get(x_622, 0); +lean_inc(x_626); +x_627 = lean_ctor_get(x_622, 1); +lean_inc(x_627); +lean_dec(x_622); +lean_ctor_set(x_532, 0, x_627); +x_628 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_628, 0, x_626); +x_539 = x_628; +x_540 = x_532; +goto block_621; } -lean_ctor_set(x_532, 0, x_526); -lean_ctor_set(x_532, 1, x_501); -lean_ctor_set(x_532, 2, x_527); -lean_ctor_set(x_532, 3, x_528); -lean_ctor_set(x_532, 4, x_529); -lean_ctor_set(x_532, 5, x_530); -x_533 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_533, 0, x_532); -lean_ctor_set(x_533, 1, x_496); -lean_ctor_set(x_533, 2, x_497); -lean_ctor_set(x_533, 3, x_498); -lean_ctor_set(x_533, 4, x_499); -x_534 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; -x_535 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_412, x_534, x_4, x_533); +block_621: +{ +if (lean_obj_tag(x_539) == 0) +{ +lean_object* x_541; lean_object* x_542; uint8_t x_543; +x_541 = lean_ctor_get(x_540, 0); +lean_inc(x_541); +x_542 = lean_ctor_get(x_539, 0); +lean_inc(x_542); +lean_dec(x_539); +x_543 = !lean_is_exclusive(x_540); +if (x_543 == 0) +{ +lean_object* x_544; uint8_t x_545; +x_544 = lean_ctor_get(x_540, 0); +lean_dec(x_544); +x_545 = !lean_is_exclusive(x_541); +if (x_545 == 0) +{ +lean_object* x_546; lean_object* x_547; lean_object* x_548; uint8_t x_549; +x_546 = lean_ctor_get(x_541, 1); +lean_dec(x_546); +lean_ctor_set(x_541, 1, x_538); +x_547 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_548 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_547, x_4, x_540); lean_dec(x_4); -x_536 = lean_ctor_get(x_535, 1); -lean_inc(x_536); -if (lean_is_exclusive(x_535)) { - lean_ctor_release(x_535, 0); - lean_ctor_release(x_535, 1); - x_537 = x_535; -} else { - lean_dec_ref(x_535); - x_537 = lean_box(0); +x_549 = !lean_is_exclusive(x_548); +if (x_549 == 0) +{ +lean_object* x_550; +x_550 = lean_ctor_get(x_548, 0); +lean_dec(x_550); +lean_ctor_set_tag(x_548, 1); +lean_ctor_set(x_548, 0, x_542); +return x_548; } -if (lean_is_scalar(x_537)) { - x_538 = lean_alloc_ctor(1, 2, 0); -} else { - x_538 = x_537; - lean_ctor_set_tag(x_538, 1); +else +{ +lean_object* x_551; lean_object* x_552; +x_551 = lean_ctor_get(x_548, 1); +lean_inc(x_551); +lean_dec(x_548); +x_552 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_552, 0, x_542); +lean_ctor_set(x_552, 1, x_551); +return x_552; +} +} +else +{ +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; lean_object* x_563; +x_553 = lean_ctor_get(x_541, 0); +x_554 = lean_ctor_get(x_541, 2); +x_555 = lean_ctor_get(x_541, 3); +x_556 = lean_ctor_get(x_541, 4); +x_557 = lean_ctor_get(x_541, 5); +lean_inc(x_557); +lean_inc(x_556); +lean_inc(x_555); +lean_inc(x_554); +lean_inc(x_553); +lean_dec(x_541); +x_558 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_558, 0, x_553); +lean_ctor_set(x_558, 1, x_538); +lean_ctor_set(x_558, 2, x_554); +lean_ctor_set(x_558, 3, x_555); +lean_ctor_set(x_558, 4, x_556); +lean_ctor_set(x_558, 5, x_557); +lean_ctor_set(x_540, 0, x_558); +x_559 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_560 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_559, x_4, x_540); +lean_dec(x_4); +x_561 = lean_ctor_get(x_560, 1); +lean_inc(x_561); +if (lean_is_exclusive(x_560)) { + lean_ctor_release(x_560, 0); + lean_ctor_release(x_560, 1); + x_562 = x_560; +} else { + lean_dec_ref(x_560); + x_562 = lean_box(0); +} +if (lean_is_scalar(x_562)) { + x_563 = lean_alloc_ctor(1, 2, 0); +} else { + x_563 = x_562; + lean_ctor_set_tag(x_563, 1); +} +lean_ctor_set(x_563, 0, x_542); +lean_ctor_set(x_563, 1, x_561); +return x_563; +} +} +else +{ +lean_object* x_564; lean_object* x_565; lean_object* x_566; lean_object* x_567; lean_object* x_568; lean_object* x_569; lean_object* x_570; lean_object* x_571; lean_object* x_572; lean_object* x_573; lean_object* x_574; lean_object* x_575; lean_object* x_576; lean_object* x_577; lean_object* x_578; lean_object* x_579; lean_object* x_580; +x_564 = lean_ctor_get(x_540, 1); +x_565 = lean_ctor_get(x_540, 2); +x_566 = lean_ctor_get(x_540, 3); +x_567 = lean_ctor_get(x_540, 4); +lean_inc(x_567); +lean_inc(x_566); +lean_inc(x_565); +lean_inc(x_564); +lean_dec(x_540); +x_568 = lean_ctor_get(x_541, 0); +lean_inc(x_568); +x_569 = lean_ctor_get(x_541, 2); +lean_inc(x_569); +x_570 = lean_ctor_get(x_541, 3); +lean_inc(x_570); +x_571 = lean_ctor_get(x_541, 4); +lean_inc(x_571); +x_572 = lean_ctor_get(x_541, 5); +lean_inc(x_572); +if (lean_is_exclusive(x_541)) { + lean_ctor_release(x_541, 0); + lean_ctor_release(x_541, 1); + lean_ctor_release(x_541, 2); + lean_ctor_release(x_541, 3); + lean_ctor_release(x_541, 4); + lean_ctor_release(x_541, 5); + x_573 = x_541; +} else { + lean_dec_ref(x_541); + x_573 = lean_box(0); +} +if (lean_is_scalar(x_573)) { + x_574 = lean_alloc_ctor(0, 6, 0); +} else { + x_574 = x_573; +} +lean_ctor_set(x_574, 0, x_568); +lean_ctor_set(x_574, 1, x_538); +lean_ctor_set(x_574, 2, x_569); +lean_ctor_set(x_574, 3, x_570); +lean_ctor_set(x_574, 4, x_571); +lean_ctor_set(x_574, 5, x_572); +x_575 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_575, 0, x_574); +lean_ctor_set(x_575, 1, x_564); +lean_ctor_set(x_575, 2, x_565); +lean_ctor_set(x_575, 3, x_566); +lean_ctor_set(x_575, 4, x_567); +x_576 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_577 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_576, x_4, x_575); +lean_dec(x_4); +x_578 = lean_ctor_get(x_577, 1); +lean_inc(x_578); +if (lean_is_exclusive(x_577)) { + lean_ctor_release(x_577, 0); + lean_ctor_release(x_577, 1); + x_579 = x_577; +} else { + lean_dec_ref(x_577); + x_579 = lean_box(0); +} +if (lean_is_scalar(x_579)) { + x_580 = lean_alloc_ctor(1, 2, 0); +} else { + x_580 = x_579; + lean_ctor_set_tag(x_580, 1); +} +lean_ctor_set(x_580, 0, x_542); +lean_ctor_set(x_580, 1, x_578); +return x_580; +} +} +else +{ +lean_object* x_581; lean_object* x_582; uint8_t x_583; +x_581 = lean_ctor_get(x_540, 0); +lean_inc(x_581); +x_582 = lean_ctor_get(x_539, 0); +lean_inc(x_582); +lean_dec(x_539); +x_583 = !lean_is_exclusive(x_540); +if (x_583 == 0) +{ +lean_object* x_584; uint8_t x_585; +x_584 = lean_ctor_get(x_540, 0); +lean_dec(x_584); +x_585 = !lean_is_exclusive(x_581); +if (x_585 == 0) +{ +lean_object* x_586; lean_object* x_587; lean_object* x_588; uint8_t x_589; +x_586 = lean_ctor_get(x_581, 1); +lean_dec(x_586); +lean_ctor_set(x_581, 1, x_538); +x_587 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_588 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_587, x_4, x_540); +lean_dec(x_4); +x_589 = !lean_is_exclusive(x_588); +if (x_589 == 0) +{ +lean_object* x_590; +x_590 = lean_ctor_get(x_588, 0); +lean_dec(x_590); +lean_ctor_set(x_588, 0, x_582); +return x_588; +} +else +{ +lean_object* x_591; lean_object* x_592; +x_591 = lean_ctor_get(x_588, 1); +lean_inc(x_591); +lean_dec(x_588); +x_592 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_592, 0, x_582); +lean_ctor_set(x_592, 1, x_591); +return x_592; +} +} +else +{ +lean_object* x_593; lean_object* x_594; lean_object* x_595; lean_object* x_596; lean_object* x_597; lean_object* x_598; lean_object* x_599; lean_object* x_600; lean_object* x_601; lean_object* x_602; lean_object* x_603; +x_593 = lean_ctor_get(x_581, 0); +x_594 = lean_ctor_get(x_581, 2); +x_595 = lean_ctor_get(x_581, 3); +x_596 = lean_ctor_get(x_581, 4); +x_597 = lean_ctor_get(x_581, 5); +lean_inc(x_597); +lean_inc(x_596); +lean_inc(x_595); +lean_inc(x_594); +lean_inc(x_593); +lean_dec(x_581); +x_598 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_598, 0, x_593); +lean_ctor_set(x_598, 1, x_538); +lean_ctor_set(x_598, 2, x_594); +lean_ctor_set(x_598, 3, x_595); +lean_ctor_set(x_598, 4, x_596); +lean_ctor_set(x_598, 5, x_597); +lean_ctor_set(x_540, 0, x_598); +x_599 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_600 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_599, x_4, x_540); +lean_dec(x_4); +x_601 = lean_ctor_get(x_600, 1); +lean_inc(x_601); +if (lean_is_exclusive(x_600)) { + lean_ctor_release(x_600, 0); + lean_ctor_release(x_600, 1); + x_602 = x_600; +} else { + lean_dec_ref(x_600); + x_602 = lean_box(0); +} +if (lean_is_scalar(x_602)) { + x_603 = lean_alloc_ctor(0, 2, 0); +} else { + x_603 = x_602; +} +lean_ctor_set(x_603, 0, x_582); +lean_ctor_set(x_603, 1, x_601); +return x_603; +} +} +else +{ +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; lean_object* x_611; lean_object* x_612; lean_object* x_613; lean_object* x_614; lean_object* x_615; lean_object* x_616; lean_object* x_617; lean_object* x_618; lean_object* x_619; lean_object* x_620; +x_604 = lean_ctor_get(x_540, 1); +x_605 = lean_ctor_get(x_540, 2); +x_606 = lean_ctor_get(x_540, 3); +x_607 = lean_ctor_get(x_540, 4); +lean_inc(x_607); +lean_inc(x_606); +lean_inc(x_605); +lean_inc(x_604); +lean_dec(x_540); +x_608 = lean_ctor_get(x_581, 0); +lean_inc(x_608); +x_609 = lean_ctor_get(x_581, 2); +lean_inc(x_609); +x_610 = lean_ctor_get(x_581, 3); +lean_inc(x_610); +x_611 = lean_ctor_get(x_581, 4); +lean_inc(x_611); +x_612 = lean_ctor_get(x_581, 5); +lean_inc(x_612); +if (lean_is_exclusive(x_581)) { + lean_ctor_release(x_581, 0); + lean_ctor_release(x_581, 1); + lean_ctor_release(x_581, 2); + lean_ctor_release(x_581, 3); + lean_ctor_release(x_581, 4); + lean_ctor_release(x_581, 5); + x_613 = x_581; +} else { + lean_dec_ref(x_581); + x_613 = lean_box(0); +} +if (lean_is_scalar(x_613)) { + x_614 = lean_alloc_ctor(0, 6, 0); +} else { + x_614 = x_613; +} +lean_ctor_set(x_614, 0, x_608); +lean_ctor_set(x_614, 1, x_538); +lean_ctor_set(x_614, 2, x_609); +lean_ctor_set(x_614, 3, x_610); +lean_ctor_set(x_614, 4, x_611); +lean_ctor_set(x_614, 5, x_612); +x_615 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_615, 0, x_614); +lean_ctor_set(x_615, 1, x_604); +lean_ctor_set(x_615, 2, x_605); +lean_ctor_set(x_615, 3, x_606); +lean_ctor_set(x_615, 4, x_607); +x_616 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_617 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_616, x_4, x_615); +lean_dec(x_4); +x_618 = lean_ctor_get(x_617, 1); +lean_inc(x_618); +if (lean_is_exclusive(x_617)) { + lean_ctor_release(x_617, 0); + lean_ctor_release(x_617, 1); + x_619 = x_617; +} else { + lean_dec_ref(x_617); + x_619 = lean_box(0); +} +if (lean_is_scalar(x_619)) { + x_620 = lean_alloc_ctor(0, 2, 0); +} else { + x_620 = x_619; +} +lean_ctor_set(x_620, 0, x_582); +lean_ctor_set(x_620, 1, x_618); +return x_620; +} +} +} +} +else +{ +lean_object* x_629; lean_object* x_630; lean_object* x_631; lean_object* x_632; lean_object* x_633; lean_object* x_634; lean_object* x_635; lean_object* x_636; lean_object* x_678; lean_object* x_679; +x_629 = lean_ctor_get(x_533, 0); +x_630 = lean_ctor_get(x_533, 1); +x_631 = lean_ctor_get(x_533, 2); +x_632 = lean_ctor_get(x_533, 3); +x_633 = lean_ctor_get(x_533, 4); +x_634 = lean_ctor_get(x_533, 5); +lean_inc(x_634); +lean_inc(x_633); +lean_inc(x_632); +lean_inc(x_631); +lean_inc(x_630); +lean_inc(x_629); +lean_dec(x_533); +x_678 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_678, 0, x_629); +lean_ctor_set(x_678, 1, x_1); +lean_ctor_set(x_678, 2, x_631); +lean_ctor_set(x_678, 3, x_632); +lean_ctor_set(x_678, 4, x_633); +lean_ctor_set(x_678, 5, x_634); +lean_inc(x_4); +x_679 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_678); +if (lean_obj_tag(x_679) == 0) +{ +lean_object* x_680; lean_object* x_681; lean_object* x_682; +x_680 = lean_ctor_get(x_679, 0); +lean_inc(x_680); +x_681 = lean_ctor_get(x_679, 1); +lean_inc(x_681); +lean_dec(x_679); +lean_ctor_set(x_532, 0, x_681); +x_682 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_682, 0, x_680); +x_635 = x_682; +x_636 = x_532; +goto block_677; +} +else +{ +lean_object* x_683; lean_object* x_684; lean_object* x_685; +x_683 = lean_ctor_get(x_679, 0); +lean_inc(x_683); +x_684 = lean_ctor_get(x_679, 1); +lean_inc(x_684); +lean_dec(x_679); +lean_ctor_set(x_532, 0, x_684); +x_685 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_685, 0, x_683); +x_635 = x_685; +x_636 = x_532; +goto block_677; +} +block_677: +{ +if (lean_obj_tag(x_635) == 0) +{ +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; lean_object* x_647; lean_object* x_648; lean_object* x_649; lean_object* x_650; lean_object* x_651; lean_object* x_652; lean_object* x_653; lean_object* x_654; lean_object* x_655; lean_object* x_656; +x_637 = lean_ctor_get(x_636, 0); +lean_inc(x_637); +x_638 = lean_ctor_get(x_635, 0); +lean_inc(x_638); +lean_dec(x_635); +x_639 = lean_ctor_get(x_636, 1); +lean_inc(x_639); +x_640 = lean_ctor_get(x_636, 2); +lean_inc(x_640); +x_641 = lean_ctor_get(x_636, 3); +lean_inc(x_641); +x_642 = lean_ctor_get(x_636, 4); +lean_inc(x_642); +if (lean_is_exclusive(x_636)) { + lean_ctor_release(x_636, 0); + lean_ctor_release(x_636, 1); + lean_ctor_release(x_636, 2); + lean_ctor_release(x_636, 3); + lean_ctor_release(x_636, 4); + x_643 = x_636; +} else { + lean_dec_ref(x_636); + x_643 = lean_box(0); +} +x_644 = lean_ctor_get(x_637, 0); +lean_inc(x_644); +x_645 = lean_ctor_get(x_637, 2); +lean_inc(x_645); +x_646 = lean_ctor_get(x_637, 3); +lean_inc(x_646); +x_647 = lean_ctor_get(x_637, 4); +lean_inc(x_647); +x_648 = lean_ctor_get(x_637, 5); +lean_inc(x_648); +if (lean_is_exclusive(x_637)) { + lean_ctor_release(x_637, 0); + lean_ctor_release(x_637, 1); + lean_ctor_release(x_637, 2); + lean_ctor_release(x_637, 3); + lean_ctor_release(x_637, 4); + lean_ctor_release(x_637, 5); + x_649 = x_637; +} else { + lean_dec_ref(x_637); + x_649 = lean_box(0); +} +if (lean_is_scalar(x_649)) { + x_650 = lean_alloc_ctor(0, 6, 0); +} else { + x_650 = x_649; +} +lean_ctor_set(x_650, 0, x_644); +lean_ctor_set(x_650, 1, x_630); +lean_ctor_set(x_650, 2, x_645); +lean_ctor_set(x_650, 3, x_646); +lean_ctor_set(x_650, 4, x_647); +lean_ctor_set(x_650, 5, x_648); +if (lean_is_scalar(x_643)) { + x_651 = lean_alloc_ctor(0, 5, 0); +} else { + x_651 = x_643; +} +lean_ctor_set(x_651, 0, x_650); +lean_ctor_set(x_651, 1, x_639); +lean_ctor_set(x_651, 2, x_640); +lean_ctor_set(x_651, 3, x_641); +lean_ctor_set(x_651, 4, x_642); +x_652 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_653 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_652, x_4, x_651); +lean_dec(x_4); +x_654 = lean_ctor_get(x_653, 1); +lean_inc(x_654); +if (lean_is_exclusive(x_653)) { + lean_ctor_release(x_653, 0); + lean_ctor_release(x_653, 1); + x_655 = x_653; +} else { + lean_dec_ref(x_653); + x_655 = lean_box(0); +} +if (lean_is_scalar(x_655)) { + x_656 = lean_alloc_ctor(1, 2, 0); +} else { + x_656 = x_655; + lean_ctor_set_tag(x_656, 1); +} +lean_ctor_set(x_656, 0, x_638); +lean_ctor_set(x_656, 1, x_654); +return x_656; +} +else +{ +lean_object* x_657; lean_object* x_658; lean_object* x_659; lean_object* x_660; lean_object* x_661; lean_object* x_662; lean_object* x_663; lean_object* x_664; lean_object* x_665; lean_object* x_666; lean_object* x_667; lean_object* x_668; lean_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; +x_657 = lean_ctor_get(x_636, 0); +lean_inc(x_657); +x_658 = lean_ctor_get(x_635, 0); +lean_inc(x_658); +lean_dec(x_635); +x_659 = lean_ctor_get(x_636, 1); +lean_inc(x_659); +x_660 = lean_ctor_get(x_636, 2); +lean_inc(x_660); +x_661 = lean_ctor_get(x_636, 3); +lean_inc(x_661); +x_662 = lean_ctor_get(x_636, 4); +lean_inc(x_662); +if (lean_is_exclusive(x_636)) { + lean_ctor_release(x_636, 0); + lean_ctor_release(x_636, 1); + lean_ctor_release(x_636, 2); + lean_ctor_release(x_636, 3); + lean_ctor_release(x_636, 4); + x_663 = x_636; +} else { + lean_dec_ref(x_636); + x_663 = lean_box(0); +} +x_664 = lean_ctor_get(x_657, 0); +lean_inc(x_664); +x_665 = lean_ctor_get(x_657, 2); +lean_inc(x_665); +x_666 = lean_ctor_get(x_657, 3); +lean_inc(x_666); +x_667 = lean_ctor_get(x_657, 4); +lean_inc(x_667); +x_668 = lean_ctor_get(x_657, 5); +lean_inc(x_668); +if (lean_is_exclusive(x_657)) { + lean_ctor_release(x_657, 0); + lean_ctor_release(x_657, 1); + lean_ctor_release(x_657, 2); + lean_ctor_release(x_657, 3); + lean_ctor_release(x_657, 4); + lean_ctor_release(x_657, 5); + x_669 = x_657; +} else { + lean_dec_ref(x_657); + x_669 = lean_box(0); +} +if (lean_is_scalar(x_669)) { + x_670 = lean_alloc_ctor(0, 6, 0); +} else { + x_670 = x_669; +} +lean_ctor_set(x_670, 0, x_664); +lean_ctor_set(x_670, 1, x_630); +lean_ctor_set(x_670, 2, x_665); +lean_ctor_set(x_670, 3, x_666); +lean_ctor_set(x_670, 4, x_667); +lean_ctor_set(x_670, 5, x_668); +if (lean_is_scalar(x_663)) { + x_671 = lean_alloc_ctor(0, 5, 0); +} else { + x_671 = x_663; +} +lean_ctor_set(x_671, 0, x_670); +lean_ctor_set(x_671, 1, x_659); +lean_ctor_set(x_671, 2, x_660); +lean_ctor_set(x_671, 3, x_661); +lean_ctor_set(x_671, 4, x_662); +x_672 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_673 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_672, x_4, x_671); +lean_dec(x_4); +x_674 = lean_ctor_get(x_673, 1); +lean_inc(x_674); +if (lean_is_exclusive(x_673)) { + lean_ctor_release(x_673, 0); + lean_ctor_release(x_673, 1); + x_675 = x_673; +} else { + lean_dec_ref(x_673); + x_675 = lean_box(0); +} +if (lean_is_scalar(x_675)) { + x_676 = lean_alloc_ctor(0, 2, 0); +} else { + x_676 = x_675; +} +lean_ctor_set(x_676, 0, x_658); +lean_ctor_set(x_676, 1, x_674); +return x_676; +} +} +} +} +else +{ +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; lean_object* x_694; lean_object* x_695; lean_object* x_696; lean_object* x_697; lean_object* x_698; lean_object* x_740; lean_object* x_741; +x_686 = lean_ctor_get(x_532, 1); +x_687 = lean_ctor_get(x_532, 2); +x_688 = lean_ctor_get(x_532, 3); +x_689 = lean_ctor_get(x_532, 4); +lean_inc(x_689); +lean_inc(x_688); +lean_inc(x_687); +lean_inc(x_686); +lean_dec(x_532); +x_690 = lean_ctor_get(x_533, 0); +lean_inc(x_690); +x_691 = lean_ctor_get(x_533, 1); +lean_inc(x_691); +x_692 = lean_ctor_get(x_533, 2); +lean_inc(x_692); +x_693 = lean_ctor_get(x_533, 3); +lean_inc(x_693); +x_694 = lean_ctor_get(x_533, 4); +lean_inc(x_694); +x_695 = lean_ctor_get(x_533, 5); +lean_inc(x_695); +if (lean_is_exclusive(x_533)) { + lean_ctor_release(x_533, 0); + lean_ctor_release(x_533, 1); + lean_ctor_release(x_533, 2); + lean_ctor_release(x_533, 3); + lean_ctor_release(x_533, 4); + lean_ctor_release(x_533, 5); + x_696 = x_533; +} else { + lean_dec_ref(x_533); + x_696 = lean_box(0); +} +if (lean_is_scalar(x_696)) { + x_740 = lean_alloc_ctor(0, 6, 0); +} else { + x_740 = x_696; +} +lean_ctor_set(x_740, 0, x_690); +lean_ctor_set(x_740, 1, x_1); +lean_ctor_set(x_740, 2, x_692); +lean_ctor_set(x_740, 3, x_693); +lean_ctor_set(x_740, 4, x_694); +lean_ctor_set(x_740, 5, x_695); +lean_inc(x_4); +x_741 = l_Lean_Meta_SynthInstance_tryResolveCore(x_2, x_3, x_4, x_740); +if (lean_obj_tag(x_741) == 0) +{ +lean_object* x_742; lean_object* x_743; lean_object* x_744; lean_object* x_745; +x_742 = lean_ctor_get(x_741, 0); +lean_inc(x_742); +x_743 = lean_ctor_get(x_741, 1); +lean_inc(x_743); +lean_dec(x_741); +x_744 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_744, 0, x_743); +lean_ctor_set(x_744, 1, x_686); +lean_ctor_set(x_744, 2, x_687); +lean_ctor_set(x_744, 3, x_688); +lean_ctor_set(x_744, 4, x_689); +x_745 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_745, 0, x_742); +x_697 = x_745; +x_698 = x_744; +goto block_739; +} +else +{ +lean_object* x_746; lean_object* x_747; lean_object* x_748; lean_object* x_749; +x_746 = lean_ctor_get(x_741, 0); +lean_inc(x_746); +x_747 = lean_ctor_get(x_741, 1); +lean_inc(x_747); +lean_dec(x_741); +x_748 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_748, 0, x_747); +lean_ctor_set(x_748, 1, x_686); +lean_ctor_set(x_748, 2, x_687); +lean_ctor_set(x_748, 3, x_688); +lean_ctor_set(x_748, 4, x_689); +x_749 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_749, 0, x_746); +x_697 = x_749; +x_698 = x_748; +goto block_739; +} +block_739: +{ +if (lean_obj_tag(x_697) == 0) +{ +lean_object* x_699; lean_object* x_700; lean_object* x_701; lean_object* x_702; lean_object* x_703; lean_object* x_704; lean_object* x_705; lean_object* x_706; lean_object* x_707; lean_object* x_708; lean_object* x_709; lean_object* x_710; lean_object* x_711; lean_object* x_712; lean_object* x_713; lean_object* x_714; lean_object* x_715; lean_object* x_716; lean_object* x_717; lean_object* x_718; +x_699 = lean_ctor_get(x_698, 0); +lean_inc(x_699); +x_700 = lean_ctor_get(x_697, 0); +lean_inc(x_700); +lean_dec(x_697); +x_701 = lean_ctor_get(x_698, 1); +lean_inc(x_701); +x_702 = lean_ctor_get(x_698, 2); +lean_inc(x_702); +x_703 = lean_ctor_get(x_698, 3); +lean_inc(x_703); +x_704 = lean_ctor_get(x_698, 4); +lean_inc(x_704); +if (lean_is_exclusive(x_698)) { + lean_ctor_release(x_698, 0); + lean_ctor_release(x_698, 1); + lean_ctor_release(x_698, 2); + lean_ctor_release(x_698, 3); + lean_ctor_release(x_698, 4); + x_705 = x_698; +} else { + lean_dec_ref(x_698); + x_705 = lean_box(0); +} +x_706 = lean_ctor_get(x_699, 0); +lean_inc(x_706); +x_707 = lean_ctor_get(x_699, 2); +lean_inc(x_707); +x_708 = lean_ctor_get(x_699, 3); +lean_inc(x_708); +x_709 = lean_ctor_get(x_699, 4); +lean_inc(x_709); +x_710 = lean_ctor_get(x_699, 5); +lean_inc(x_710); +if (lean_is_exclusive(x_699)) { + lean_ctor_release(x_699, 0); + lean_ctor_release(x_699, 1); + lean_ctor_release(x_699, 2); + lean_ctor_release(x_699, 3); + lean_ctor_release(x_699, 4); + lean_ctor_release(x_699, 5); + x_711 = x_699; +} else { + lean_dec_ref(x_699); + x_711 = lean_box(0); +} +if (lean_is_scalar(x_711)) { + x_712 = lean_alloc_ctor(0, 6, 0); +} else { + x_712 = x_711; +} +lean_ctor_set(x_712, 0, x_706); +lean_ctor_set(x_712, 1, x_691); +lean_ctor_set(x_712, 2, x_707); +lean_ctor_set(x_712, 3, x_708); +lean_ctor_set(x_712, 4, x_709); +lean_ctor_set(x_712, 5, x_710); +if (lean_is_scalar(x_705)) { + x_713 = lean_alloc_ctor(0, 5, 0); +} else { + x_713 = x_705; +} +lean_ctor_set(x_713, 0, x_712); +lean_ctor_set(x_713, 1, x_701); +lean_ctor_set(x_713, 2, x_702); +lean_ctor_set(x_713, 3, x_703); +lean_ctor_set(x_713, 4, x_704); +x_714 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_715 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_714, x_4, x_713); +lean_dec(x_4); +x_716 = lean_ctor_get(x_715, 1); +lean_inc(x_716); +if (lean_is_exclusive(x_715)) { + lean_ctor_release(x_715, 0); + lean_ctor_release(x_715, 1); + x_717 = x_715; +} else { + lean_dec_ref(x_715); + x_717 = lean_box(0); +} +if (lean_is_scalar(x_717)) { + x_718 = lean_alloc_ctor(1, 2, 0); +} else { + x_718 = x_717; + lean_ctor_set_tag(x_718, 1); +} +lean_ctor_set(x_718, 0, x_700); +lean_ctor_set(x_718, 1, x_716); +return x_718; +} +else +{ +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; lean_object* x_728; lean_object* x_729; lean_object* x_730; lean_object* x_731; lean_object* x_732; lean_object* x_733; lean_object* x_734; lean_object* x_735; lean_object* x_736; lean_object* x_737; lean_object* x_738; +x_719 = lean_ctor_get(x_698, 0); +lean_inc(x_719); +x_720 = lean_ctor_get(x_697, 0); +lean_inc(x_720); +lean_dec(x_697); +x_721 = lean_ctor_get(x_698, 1); +lean_inc(x_721); +x_722 = lean_ctor_get(x_698, 2); +lean_inc(x_722); +x_723 = lean_ctor_get(x_698, 3); +lean_inc(x_723); +x_724 = lean_ctor_get(x_698, 4); +lean_inc(x_724); +if (lean_is_exclusive(x_698)) { + lean_ctor_release(x_698, 0); + lean_ctor_release(x_698, 1); + lean_ctor_release(x_698, 2); + lean_ctor_release(x_698, 3); + lean_ctor_release(x_698, 4); + x_725 = x_698; +} else { + lean_dec_ref(x_698); + x_725 = lean_box(0); +} +x_726 = lean_ctor_get(x_719, 0); +lean_inc(x_726); +x_727 = lean_ctor_get(x_719, 2); +lean_inc(x_727); +x_728 = lean_ctor_get(x_719, 3); +lean_inc(x_728); +x_729 = lean_ctor_get(x_719, 4); +lean_inc(x_729); +x_730 = lean_ctor_get(x_719, 5); +lean_inc(x_730); +if (lean_is_exclusive(x_719)) { + lean_ctor_release(x_719, 0); + lean_ctor_release(x_719, 1); + lean_ctor_release(x_719, 2); + lean_ctor_release(x_719, 3); + lean_ctor_release(x_719, 4); + lean_ctor_release(x_719, 5); + x_731 = x_719; +} else { + lean_dec_ref(x_719); + x_731 = lean_box(0); +} +if (lean_is_scalar(x_731)) { + x_732 = lean_alloc_ctor(0, 6, 0); +} else { + x_732 = x_731; +} +lean_ctor_set(x_732, 0, x_726); +lean_ctor_set(x_732, 1, x_691); +lean_ctor_set(x_732, 2, x_727); +lean_ctor_set(x_732, 3, x_728); +lean_ctor_set(x_732, 4, x_729); +lean_ctor_set(x_732, 5, x_730); +if (lean_is_scalar(x_725)) { + x_733 = lean_alloc_ctor(0, 5, 0); +} else { + x_733 = x_725; +} +lean_ctor_set(x_733, 0, x_732); +lean_ctor_set(x_733, 1, x_721); +lean_ctor_set(x_733, 2, x_722); +lean_ctor_set(x_733, 3, x_723); +lean_ctor_set(x_733, 4, x_724); +x_734 = l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__2; +x_735 = l___private_Lean_Util_Trace_2__addNode___at_Lean_Meta_SynthInstance_tryResolve___spec__2(x_534, x_734, x_4, x_733); +lean_dec(x_4); +x_736 = lean_ctor_get(x_735, 1); +lean_inc(x_736); +if (lean_is_exclusive(x_735)) { + lean_ctor_release(x_735, 0); + lean_ctor_release(x_735, 1); + x_737 = x_735; +} else { + lean_dec_ref(x_735); + x_737 = lean_box(0); +} +if (lean_is_scalar(x_737)) { + x_738 = lean_alloc_ctor(0, 2, 0); +} else { + x_738 = x_737; +} +lean_ctor_set(x_738, 0, x_720); +lean_ctor_set(x_738, 1, x_736); +return x_738; } -lean_ctor_set(x_538, 0, x_525); -lean_ctor_set(x_538, 1, x_536); -return x_538; } } } @@ -10909,6 +11849,16 @@ lean_dec(x_3); return x_5; } } +lean_object* _init_l_Lean_Meta_SynthInstance_tryAnswer___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = lean_box(0); +x_2 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} lean_object* l_Lean_Meta_SynthInstance_tryAnswer(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { @@ -10927,231 +11877,249 @@ lean_dec(x_9); x_10 = !lean_is_exclusive(x_6); if (x_10 == 0) { -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_41; lean_object* x_42; lean_object* x_70; +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_69; x_11 = lean_ctor_get(x_6, 1); lean_ctor_set(x_6, 1, x_1); lean_inc(x_4); -x_70 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_6); -if (lean_obj_tag(x_70) == 0) +x_69 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_6); +if (lean_obj_tag(x_69) == 0) { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_71 = lean_ctor_get(x_70, 0); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_ctor_get(x_70, 1); lean_inc(x_71); -x_72 = lean_ctor_get(x_71, 1); -lean_inc(x_72); -lean_dec(x_71); -x_73 = lean_ctor_get(x_70, 1); -lean_inc(x_73); lean_dec(x_70); -x_74 = lean_ctor_get(x_72, 1); -lean_inc(x_74); -lean_dec(x_72); -x_75 = l_Lean_Meta_isExprDefEq(x_2, x_74, x_4, x_73); -if (lean_obj_tag(x_75) == 0) +x_72 = lean_ctor_get(x_69, 1); +lean_inc(x_72); +lean_dec(x_69); +x_73 = lean_ctor_get(x_71, 1); +lean_inc(x_73); +lean_dec(x_71); +x_74 = l_Lean_Meta_isExprDefEq(x_2, x_73, x_4, x_72); +if (lean_obj_tag(x_74) == 0) { -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_75, 0); -lean_inc(x_76); -x_77 = lean_unbox(x_76); -lean_dec(x_76); -if (x_77 == 0) -{ -lean_object* x_78; lean_object* x_79; -x_78 = lean_ctor_get(x_75, 1); -lean_inc(x_78); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_74, 0); +lean_inc(x_75); +x_76 = lean_unbox(x_75); lean_dec(x_75); -lean_ctor_set(x_5, 0, x_78); -x_79 = lean_box(0); -x_12 = x_79; +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_74, 1); +lean_inc(x_77); +lean_dec(x_74); +lean_ctor_set(x_5, 0, x_77); +x_78 = l_Lean_Meta_SynthInstance_tryAnswer___closed__1; +x_12 = x_78; x_13 = x_5; -goto block_40; +goto block_68; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_75, 1); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_79 = lean_ctor_get(x_74, 1); +lean_inc(x_79); +lean_dec(x_74); +x_80 = lean_ctor_get(x_79, 1); lean_inc(x_80); -lean_dec(x_75); -x_81 = lean_ctor_get(x_80, 1); -lean_inc(x_81); -lean_ctor_set(x_5, 0, x_80); +lean_ctor_set(x_5, 0, x_79); +x_81 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_81, 0, x_80); x_82 = lean_alloc_ctor(1, 1, 0); lean_ctor_set(x_82, 0, x_81); x_12 = x_82; x_13 = x_5; -goto block_40; +goto block_68; } } else { -lean_object* x_83; lean_object* x_84; -x_83 = lean_ctor_get(x_75, 0); +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_74, 0); lean_inc(x_83); -x_84 = lean_ctor_get(x_75, 1); +x_84 = lean_ctor_get(x_74, 1); lean_inc(x_84); -lean_dec(x_75); +lean_dec(x_74); lean_ctor_set(x_5, 0, x_84); -x_41 = x_83; -x_42 = x_5; -goto block_69; +x_85 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_85, 0, x_83); +x_12 = x_85; +x_13 = x_5; +goto block_68; } } else { -lean_object* x_85; lean_object* x_86; +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_dec(x_4); lean_dec(x_2); -x_85 = lean_ctor_get(x_70, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_70, 1); +x_86 = lean_ctor_get(x_69, 0); lean_inc(x_86); -lean_dec(x_70); -lean_ctor_set(x_5, 0, x_86); -x_41 = x_85; -x_42 = x_5; -goto block_69; +x_87 = lean_ctor_get(x_69, 1); +lean_inc(x_87); +lean_dec(x_69); +lean_ctor_set(x_5, 0, x_87); +x_88 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_88, 0, x_86); +x_12 = x_88; +x_13 = x_5; +goto block_68; } -block_40: +block_68: { -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) +if (lean_obj_tag(x_12) == 0) { -lean_object* x_15; uint8_t x_16; -x_15 = lean_ctor_get(x_13, 0); -x_16 = !lean_is_exclusive(x_15); +lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_12, 0); +lean_inc(x_15); +lean_dec(x_12); +x_16 = !lean_is_exclusive(x_13); if (x_16 == 0) { -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_15, 1); +lean_object* x_17; uint8_t x_18; +x_17 = lean_ctor_get(x_13, 0); lean_dec(x_17); -lean_ctor_set(x_15, 1, x_11); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_12); -lean_ctor_set(x_18, 1, x_13); -return x_18; +x_18 = !lean_is_exclusive(x_14); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_14, 1); +lean_dec(x_19); +lean_ctor_set(x_14, 1, x_11); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_15); +lean_ctor_set(x_20, 1, x_13); +return x_20; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_19 = lean_ctor_get(x_15, 0); -x_20 = lean_ctor_get(x_15, 2); -x_21 = lean_ctor_get(x_15, 3); -x_22 = lean_ctor_get(x_15, 4); -x_23 = lean_ctor_get(x_15, 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; +x_21 = lean_ctor_get(x_14, 0); +x_22 = lean_ctor_get(x_14, 2); +x_23 = lean_ctor_get(x_14, 3); +x_24 = lean_ctor_get(x_14, 4); +x_25 = lean_ctor_get(x_14, 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_inc(x_19); -lean_dec(x_15); -x_24 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_24, 0, x_19); -lean_ctor_set(x_24, 1, x_11); -lean_ctor_set(x_24, 2, x_20); -lean_ctor_set(x_24, 3, x_21); -lean_ctor_set(x_24, 4, x_22); -lean_ctor_set(x_24, 5, x_23); -lean_ctor_set(x_13, 0, x_24); -x_25 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_25, 0, x_12); -lean_ctor_set(x_25, 1, x_13); -return x_25; +lean_dec(x_14); +x_26 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_26, 0, x_21); +lean_ctor_set(x_26, 1, x_11); +lean_ctor_set(x_26, 2, x_22); +lean_ctor_set(x_26, 3, x_23); +lean_ctor_set(x_26, 4, x_24); +lean_ctor_set(x_26, 5, x_25); +lean_ctor_set(x_13, 0, x_26); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_15); +lean_ctor_set(x_27, 1, x_13); +return x_27; } } 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; -x_26 = lean_ctor_get(x_13, 0); -x_27 = lean_ctor_get(x_13, 1); -x_28 = lean_ctor_get(x_13, 2); -x_29 = lean_ctor_get(x_13, 3); -x_30 = lean_ctor_get(x_13, 4); +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_28 = lean_ctor_get(x_13, 1); +x_29 = lean_ctor_get(x_13, 2); +x_30 = lean_ctor_get(x_13, 3); +x_31 = lean_ctor_get(x_13, 4); +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_13); -x_31 = lean_ctor_get(x_26, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_26, 2); +x_32 = lean_ctor_get(x_14, 0); lean_inc(x_32); -x_33 = lean_ctor_get(x_26, 3); +x_33 = lean_ctor_get(x_14, 2); lean_inc(x_33); -x_34 = lean_ctor_get(x_26, 4); +x_34 = lean_ctor_get(x_14, 3); lean_inc(x_34); -x_35 = lean_ctor_get(x_26, 5); +x_35 = lean_ctor_get(x_14, 4); lean_inc(x_35); -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); - x_36 = x_26; +x_36 = lean_ctor_get(x_14, 5); +lean_inc(x_36); +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); + lean_ctor_release(x_14, 4); + lean_ctor_release(x_14, 5); + x_37 = x_14; } else { - lean_dec_ref(x_26); - x_36 = lean_box(0); + lean_dec_ref(x_14); + x_37 = lean_box(0); } -if (lean_is_scalar(x_36)) { - x_37 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_37)) { + x_38 = lean_alloc_ctor(0, 6, 0); } else { - x_37 = x_36; + x_38 = x_37; } -lean_ctor_set(x_37, 0, x_31); -lean_ctor_set(x_37, 1, x_11); -lean_ctor_set(x_37, 2, x_32); -lean_ctor_set(x_37, 3, x_33); -lean_ctor_set(x_37, 4, x_34); -lean_ctor_set(x_37, 5, x_35); -x_38 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_38, 0, x_37); -lean_ctor_set(x_38, 1, x_27); -lean_ctor_set(x_38, 2, x_28); -lean_ctor_set(x_38, 3, x_29); -lean_ctor_set(x_38, 4, x_30); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_12); -lean_ctor_set(x_39, 1, x_38); -return x_39; +lean_ctor_set(x_38, 0, x_32); +lean_ctor_set(x_38, 1, x_11); +lean_ctor_set(x_38, 2, x_33); +lean_ctor_set(x_38, 3, x_34); +lean_ctor_set(x_38, 4, x_35); +lean_ctor_set(x_38, 5, x_36); +x_39 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_28); +lean_ctor_set(x_39, 2, x_29); +lean_ctor_set(x_39, 3, x_30); +lean_ctor_set(x_39, 4, x_31); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_15); +lean_ctor_set(x_40, 1, x_39); +return x_40; } } -block_69: +else { -uint8_t x_43; -x_43 = !lean_is_exclusive(x_42); +lean_object* x_41; lean_object* x_42; uint8_t x_43; +x_41 = lean_ctor_get(x_13, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_12, 0); +lean_inc(x_42); +lean_dec(x_12); +x_43 = !lean_is_exclusive(x_13); if (x_43 == 0) { lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_42, 0); -x_45 = !lean_is_exclusive(x_44); +x_44 = lean_ctor_get(x_13, 0); +lean_dec(x_44); +x_45 = !lean_is_exclusive(x_41); if (x_45 == 0) { lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_44, 1); +x_46 = lean_ctor_get(x_41, 1); lean_dec(x_46); -lean_ctor_set(x_44, 1, x_11); -x_47 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); +lean_ctor_set(x_41, 1, x_11); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_13); 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_53; lean_object* x_54; -x_48 = lean_ctor_get(x_44, 0); -x_49 = lean_ctor_get(x_44, 2); -x_50 = lean_ctor_get(x_44, 3); -x_51 = lean_ctor_get(x_44, 4); -x_52 = lean_ctor_get(x_44, 5); +x_48 = lean_ctor_get(x_41, 0); +x_49 = lean_ctor_get(x_41, 2); +x_50 = lean_ctor_get(x_41, 3); +x_51 = lean_ctor_get(x_41, 4); +x_52 = lean_ctor_get(x_41, 5); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); -lean_dec(x_44); +lean_dec(x_41); x_53 = lean_alloc_ctor(0, 6, 0); lean_ctor_set(x_53, 0, x_48); lean_ctor_set(x_53, 1, x_11); @@ -11159,283 +12127,296 @@ lean_ctor_set(x_53, 2, x_49); lean_ctor_set(x_53, 3, x_50); lean_ctor_set(x_53, 4, x_51); lean_ctor_set(x_53, 5, x_52); -lean_ctor_set(x_42, 0, x_53); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_41); -lean_ctor_set(x_54, 1, x_42); +lean_ctor_set(x_13, 0, x_53); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_42); +lean_ctor_set(x_54, 1, x_13); return x_54; } } 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; lean_object* x_67; lean_object* x_68; -x_55 = lean_ctor_get(x_42, 0); -x_56 = lean_ctor_get(x_42, 1); -x_57 = lean_ctor_get(x_42, 2); -x_58 = lean_ctor_get(x_42, 3); -x_59 = lean_ctor_get(x_42, 4); -lean_inc(x_59); +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_13, 1); +x_56 = lean_ctor_get(x_13, 2); +x_57 = lean_ctor_get(x_13, 3); +x_58 = lean_ctor_get(x_13, 4); 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_55, 0); +lean_dec(x_13); +x_59 = lean_ctor_get(x_41, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_41, 2); lean_inc(x_60); -x_61 = lean_ctor_get(x_55, 2); +x_61 = lean_ctor_get(x_41, 3); lean_inc(x_61); -x_62 = lean_ctor_get(x_55, 3); +x_62 = lean_ctor_get(x_41, 4); lean_inc(x_62); -x_63 = lean_ctor_get(x_55, 4); +x_63 = lean_ctor_get(x_41, 5); lean_inc(x_63); -x_64 = lean_ctor_get(x_55, 5); -lean_inc(x_64); -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_65 = x_55; +if (lean_is_exclusive(x_41)) { + lean_ctor_release(x_41, 0); + lean_ctor_release(x_41, 1); + lean_ctor_release(x_41, 2); + lean_ctor_release(x_41, 3); + lean_ctor_release(x_41, 4); + lean_ctor_release(x_41, 5); + x_64 = x_41; } else { - lean_dec_ref(x_55); - x_65 = lean_box(0); + lean_dec_ref(x_41); + x_64 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 6, 0); } else { - x_66 = x_65; + x_65 = x_64; +} +lean_ctor_set(x_65, 0, x_59); +lean_ctor_set(x_65, 1, x_11); +lean_ctor_set(x_65, 2, x_60); +lean_ctor_set(x_65, 3, x_61); +lean_ctor_set(x_65, 4, x_62); +lean_ctor_set(x_65, 5, x_63); +x_66 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_55); +lean_ctor_set(x_66, 2, x_56); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_42); +lean_ctor_set(x_67, 1, x_66); +return x_67; } -lean_ctor_set(x_66, 0, x_60); -lean_ctor_set(x_66, 1, x_11); -lean_ctor_set(x_66, 2, x_61); -lean_ctor_set(x_66, 3, x_62); -lean_ctor_set(x_66, 4, x_63); -lean_ctor_set(x_66, 5, x_64); -x_67 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_67, 0, x_66); -lean_ctor_set(x_67, 1, x_56); -lean_ctor_set(x_67, 2, x_57); -lean_ctor_set(x_67, 3, x_58); -lean_ctor_set(x_67, 4, x_59); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_41); -lean_ctor_set(x_68, 1, x_67); -return x_68; } } } 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_111; lean_object* x_112; lean_object* x_129; lean_object* x_130; -x_87 = lean_ctor_get(x_6, 0); -x_88 = lean_ctor_get(x_6, 1); -x_89 = lean_ctor_get(x_6, 2); -x_90 = lean_ctor_get(x_6, 3); -x_91 = lean_ctor_get(x_6, 4); -x_92 = lean_ctor_get(x_6, 5); +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_130; lean_object* x_131; +x_89 = lean_ctor_get(x_6, 0); +x_90 = lean_ctor_get(x_6, 1); +x_91 = lean_ctor_get(x_6, 2); +x_92 = lean_ctor_get(x_6, 3); +x_93 = lean_ctor_get(x_6, 4); +x_94 = lean_ctor_get(x_6, 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_inc(x_87); lean_dec(x_6); -x_129 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_129, 0, x_87); -lean_ctor_set(x_129, 1, x_1); -lean_ctor_set(x_129, 2, x_89); -lean_ctor_set(x_129, 3, x_90); -lean_ctor_set(x_129, 4, x_91); -lean_ctor_set(x_129, 5, x_92); +x_130 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_130, 0, x_89); +lean_ctor_set(x_130, 1, x_1); +lean_ctor_set(x_130, 2, x_91); +lean_ctor_set(x_130, 3, x_92); +lean_ctor_set(x_130, 4, x_93); +lean_ctor_set(x_130, 5, x_94); lean_inc(x_4); -x_130 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_129); -if (lean_obj_tag(x_130) == 0) +x_131 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_130); +if (lean_obj_tag(x_131) == 0) { -lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_131 = lean_ctor_get(x_130, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_131, 1); +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_131, 0); lean_inc(x_132); -lean_dec(x_131); -x_133 = lean_ctor_get(x_130, 1); +x_133 = lean_ctor_get(x_132, 1); lean_inc(x_133); -lean_dec(x_130); -x_134 = lean_ctor_get(x_132, 1); -lean_inc(x_134); lean_dec(x_132); -x_135 = l_Lean_Meta_isExprDefEq(x_2, x_134, x_4, x_133); -if (lean_obj_tag(x_135) == 0) +x_134 = lean_ctor_get(x_131, 1); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_133, 1); +lean_inc(x_135); +lean_dec(x_133); +x_136 = l_Lean_Meta_isExprDefEq(x_2, x_135, x_4, x_134); +if (lean_obj_tag(x_136) == 0) { -lean_object* x_136; uint8_t x_137; -x_136 = lean_ctor_get(x_135, 0); -lean_inc(x_136); -x_137 = lean_unbox(x_136); +lean_object* x_137; uint8_t x_138; +x_137 = lean_ctor_get(x_136, 0); +lean_inc(x_137); +x_138 = lean_unbox(x_137); +lean_dec(x_137); +if (x_138 == 0) +{ +lean_object* x_139; lean_object* x_140; +x_139 = lean_ctor_get(x_136, 1); +lean_inc(x_139); lean_dec(x_136); -if (x_137 == 0) -{ -lean_object* x_138; lean_object* x_139; -x_138 = lean_ctor_get(x_135, 1); -lean_inc(x_138); -lean_dec(x_135); -lean_ctor_set(x_5, 0, x_138); -x_139 = lean_box(0); -x_93 = x_139; -x_94 = x_5; -goto block_110; +lean_ctor_set(x_5, 0, x_139); +x_140 = l_Lean_Meta_SynthInstance_tryAnswer___closed__1; +x_95 = x_140; +x_96 = x_5; +goto block_129; } else { -lean_object* x_140; lean_object* x_141; lean_object* x_142; -x_140 = lean_ctor_get(x_135, 1); -lean_inc(x_140); -lean_dec(x_135); -x_141 = lean_ctor_get(x_140, 1); +lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_141 = lean_ctor_get(x_136, 1); lean_inc(x_141); -lean_ctor_set(x_5, 0, x_140); -x_142 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_142, 0, x_141); -x_93 = x_142; -x_94 = x_5; -goto block_110; +lean_dec(x_136); +x_142 = lean_ctor_get(x_141, 1); +lean_inc(x_142); +lean_ctor_set(x_5, 0, x_141); +x_143 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_143, 0, x_142); +x_144 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_144, 0, x_143); +x_95 = x_144; +x_96 = x_5; +goto block_129; } } else { -lean_object* x_143; lean_object* x_144; -x_143 = lean_ctor_get(x_135, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_135, 1); -lean_inc(x_144); -lean_dec(x_135); -lean_ctor_set(x_5, 0, x_144); -x_111 = x_143; -x_112 = x_5; -goto block_128; +lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_145 = lean_ctor_get(x_136, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_136, 1); +lean_inc(x_146); +lean_dec(x_136); +lean_ctor_set(x_5, 0, x_146); +x_147 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_147, 0, x_145); +x_95 = x_147; +x_96 = x_5; +goto block_129; } } else { -lean_object* x_145; lean_object* x_146; +lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_dec(x_4); lean_dec(x_2); -x_145 = lean_ctor_get(x_130, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_130, 1); -lean_inc(x_146); -lean_dec(x_130); -lean_ctor_set(x_5, 0, x_146); -x_111 = x_145; -x_112 = x_5; -goto block_128; +x_148 = lean_ctor_get(x_131, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +lean_dec(x_131); +lean_ctor_set(x_5, 0, x_149); +x_150 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_150, 0, x_148); +x_95 = x_150; +x_96 = x_5; +goto block_129; } -block_110: +block_129: { -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_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_94, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_94, 2); +if (lean_obj_tag(x_95) == 0) +{ +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; +x_97 = lean_ctor_get(x_96, 0); lean_inc(x_97); -x_98 = lean_ctor_get(x_94, 3); +x_98 = lean_ctor_get(x_95, 0); lean_inc(x_98); -x_99 = lean_ctor_get(x_94, 4); +lean_dec(x_95); +x_99 = lean_ctor_get(x_96, 1); lean_inc(x_99); -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_100 = x_94; -} else { - lean_dec_ref(x_94); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_95, 0); +x_100 = lean_ctor_get(x_96, 2); +lean_inc(x_100); +x_101 = lean_ctor_get(x_96, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_95, 2); +x_102 = lean_ctor_get(x_96, 4); lean_inc(x_102); -x_103 = lean_ctor_get(x_95, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_95, 4); +if (lean_is_exclusive(x_96)) { + lean_ctor_release(x_96, 0); + lean_ctor_release(x_96, 1); + lean_ctor_release(x_96, 2); + lean_ctor_release(x_96, 3); + lean_ctor_release(x_96, 4); + x_103 = x_96; +} else { + lean_dec_ref(x_96); + x_103 = lean_box(0); +} +x_104 = lean_ctor_get(x_97, 0); lean_inc(x_104); -x_105 = lean_ctor_get(x_95, 5); +x_105 = lean_ctor_get(x_97, 2); lean_inc(x_105); -if (lean_is_exclusive(x_95)) { - lean_ctor_release(x_95, 0); - lean_ctor_release(x_95, 1); - lean_ctor_release(x_95, 2); - lean_ctor_release(x_95, 3); - lean_ctor_release(x_95, 4); - lean_ctor_release(x_95, 5); - x_106 = x_95; +x_106 = lean_ctor_get(x_97, 3); +lean_inc(x_106); +x_107 = lean_ctor_get(x_97, 4); +lean_inc(x_107); +x_108 = lean_ctor_get(x_97, 5); +lean_inc(x_108); +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_109 = x_97; } else { - lean_dec_ref(x_95); - x_106 = lean_box(0); + lean_dec_ref(x_97); + x_109 = lean_box(0); } -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 6, 0); } else { - x_107 = x_106; + x_110 = x_109; } -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_88); -lean_ctor_set(x_107, 2, x_102); -lean_ctor_set(x_107, 3, x_103); -lean_ctor_set(x_107, 4, x_104); -lean_ctor_set(x_107, 5, x_105); -if (lean_is_scalar(x_100)) { - x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_110, 0, x_104); +lean_ctor_set(x_110, 1, x_90); +lean_ctor_set(x_110, 2, x_105); +lean_ctor_set(x_110, 3, x_106); +lean_ctor_set(x_110, 4, x_107); +lean_ctor_set(x_110, 5, x_108); +if (lean_is_scalar(x_103)) { + x_111 = lean_alloc_ctor(0, 5, 0); } else { - x_108 = x_100; + x_111 = x_103; } -lean_ctor_set(x_108, 0, x_107); -lean_ctor_set(x_108, 1, x_96); -lean_ctor_set(x_108, 2, x_97); -lean_ctor_set(x_108, 3, x_98); -lean_ctor_set(x_108, 4, x_99); -x_109 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_109, 0, x_93); -lean_ctor_set(x_109, 1, x_108); -return x_109; +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_99); +lean_ctor_set(x_111, 2, x_100); +lean_ctor_set(x_111, 3, x_101); +lean_ctor_set(x_111, 4, x_102); +x_112 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_112, 0, x_98); +lean_ctor_set(x_112, 1, x_111); +return x_112; } -block_128: +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; -x_113 = lean_ctor_get(x_112, 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; lean_object* x_128; +x_113 = lean_ctor_get(x_96, 0); lean_inc(x_113); -x_114 = lean_ctor_get(x_112, 1); +x_114 = lean_ctor_get(x_95, 0); lean_inc(x_114); -x_115 = lean_ctor_get(x_112, 2); +lean_dec(x_95); +x_115 = lean_ctor_get(x_96, 1); lean_inc(x_115); -x_116 = lean_ctor_get(x_112, 3); +x_116 = lean_ctor_get(x_96, 2); lean_inc(x_116); -x_117 = lean_ctor_get(x_112, 4); +x_117 = lean_ctor_get(x_96, 3); lean_inc(x_117); -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); - x_118 = x_112; +x_118 = lean_ctor_get(x_96, 4); +lean_inc(x_118); +if (lean_is_exclusive(x_96)) { + lean_ctor_release(x_96, 0); + lean_ctor_release(x_96, 1); + lean_ctor_release(x_96, 2); + lean_ctor_release(x_96, 3); + lean_ctor_release(x_96, 4); + x_119 = x_96; } else { - lean_dec_ref(x_112); - x_118 = lean_box(0); + lean_dec_ref(x_96); + x_119 = lean_box(0); } -x_119 = lean_ctor_get(x_113, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_113, 2); +x_120 = lean_ctor_get(x_113, 0); lean_inc(x_120); -x_121 = lean_ctor_get(x_113, 3); +x_121 = lean_ctor_get(x_113, 2); lean_inc(x_121); -x_122 = lean_ctor_get(x_113, 4); +x_122 = lean_ctor_get(x_113, 3); lean_inc(x_122); -x_123 = lean_ctor_get(x_113, 5); +x_123 = lean_ctor_get(x_113, 4); lean_inc(x_123); +x_124 = lean_ctor_get(x_113, 5); +lean_inc(x_124); if (lean_is_exclusive(x_113)) { lean_ctor_release(x_113, 0); lean_ctor_release(x_113, 1); @@ -11443,63 +12424,64 @@ if (lean_is_exclusive(x_113)) { lean_ctor_release(x_113, 3); lean_ctor_release(x_113, 4); lean_ctor_release(x_113, 5); - x_124 = x_113; + x_125 = x_113; } else { lean_dec_ref(x_113); - x_124 = lean_box(0); + x_125 = lean_box(0); } -if (lean_is_scalar(x_124)) { - x_125 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_125)) { + x_126 = lean_alloc_ctor(0, 6, 0); } else { - x_125 = x_124; + x_126 = x_125; } -lean_ctor_set(x_125, 0, x_119); -lean_ctor_set(x_125, 1, x_88); -lean_ctor_set(x_125, 2, x_120); -lean_ctor_set(x_125, 3, x_121); -lean_ctor_set(x_125, 4, x_122); -lean_ctor_set(x_125, 5, x_123); -if (lean_is_scalar(x_118)) { - x_126 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_126, 0, x_120); +lean_ctor_set(x_126, 1, x_90); +lean_ctor_set(x_126, 2, x_121); +lean_ctor_set(x_126, 3, x_122); +lean_ctor_set(x_126, 4, x_123); +lean_ctor_set(x_126, 5, x_124); +if (lean_is_scalar(x_119)) { + x_127 = lean_alloc_ctor(0, 5, 0); } else { - x_126 = x_118; + x_127 = x_119; +} +lean_ctor_set(x_127, 0, x_126); +lean_ctor_set(x_127, 1, x_115); +lean_ctor_set(x_127, 2, x_116); +lean_ctor_set(x_127, 3, x_117); +lean_ctor_set(x_127, 4, x_118); +x_128 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_128, 0, x_114); +lean_ctor_set(x_128, 1, x_127); +return x_128; } -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_114); -lean_ctor_set(x_126, 2, x_115); -lean_ctor_set(x_126, 3, x_116); -lean_ctor_set(x_126, 4, x_117); -x_127 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_127, 0, x_111); -lean_ctor_set(x_127, 1, x_126); -return x_127; } } } 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_176; lean_object* x_177; lean_object* x_194; lean_object* x_195; -x_147 = lean_ctor_get(x_5, 1); -x_148 = lean_ctor_get(x_5, 2); -x_149 = lean_ctor_get(x_5, 3); -x_150 = lean_ctor_get(x_5, 4); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_dec(x_5); -x_151 = lean_ctor_get(x_6, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_6, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_6, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_6, 3); +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; +x_151 = lean_ctor_get(x_5, 1); +x_152 = lean_ctor_get(x_5, 2); +x_153 = lean_ctor_get(x_5, 3); +x_154 = lean_ctor_get(x_5, 4); lean_inc(x_154); -x_155 = lean_ctor_get(x_6, 4); +lean_inc(x_153); +lean_inc(x_152); +lean_inc(x_151); +lean_dec(x_5); +x_155 = lean_ctor_get(x_6, 0); lean_inc(x_155); -x_156 = lean_ctor_get(x_6, 5); +x_156 = lean_ctor_get(x_6, 1); lean_inc(x_156); +x_157 = lean_ctor_get(x_6, 2); +lean_inc(x_157); +x_158 = lean_ctor_get(x_6, 3); +lean_inc(x_158); +x_159 = lean_ctor_get(x_6, 4); +lean_inc(x_159); +x_160 = lean_ctor_get(x_6, 5); +lean_inc(x_160); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); @@ -11507,266 +12489,281 @@ if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); lean_ctor_release(x_6, 5); - x_157 = x_6; + x_161 = x_6; } else { lean_dec_ref(x_6); - x_157 = lean_box(0); + x_161 = lean_box(0); } -if (lean_is_scalar(x_157)) { - x_194 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_161)) { + x_197 = lean_alloc_ctor(0, 6, 0); } else { - x_194 = x_157; + x_197 = x_161; } -lean_ctor_set(x_194, 0, x_151); -lean_ctor_set(x_194, 1, x_1); -lean_ctor_set(x_194, 2, x_153); -lean_ctor_set(x_194, 3, x_154); -lean_ctor_set(x_194, 4, x_155); -lean_ctor_set(x_194, 5, x_156); +lean_ctor_set(x_197, 0, x_155); +lean_ctor_set(x_197, 1, x_1); +lean_ctor_set(x_197, 2, x_157); +lean_ctor_set(x_197, 3, x_158); +lean_ctor_set(x_197, 4, x_159); +lean_ctor_set(x_197, 5, x_160); lean_inc(x_4); -x_195 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_194); -if (lean_obj_tag(x_195) == 0) +x_198 = l_Lean_Meta_openAbstractMVarsResult(x_7, x_4, x_197); +if (lean_obj_tag(x_198) == 0) { -lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_196 = lean_ctor_get(x_195, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_196, 1); -lean_inc(x_197); -lean_dec(x_196); -x_198 = lean_ctor_get(x_195, 1); -lean_inc(x_198); -lean_dec(x_195); -x_199 = lean_ctor_get(x_197, 1); +lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_199 = lean_ctor_get(x_198, 0); lean_inc(x_199); -lean_dec(x_197); -x_200 = l_Lean_Meta_isExprDefEq(x_2, x_199, x_4, x_198); -if (lean_obj_tag(x_200) == 0) -{ -lean_object* x_201; uint8_t x_202; -x_201 = lean_ctor_get(x_200, 0); +x_200 = lean_ctor_get(x_199, 1); +lean_inc(x_200); +lean_dec(x_199); +x_201 = lean_ctor_get(x_198, 1); lean_inc(x_201); -x_202 = lean_unbox(x_201); -lean_dec(x_201); -if (x_202 == 0) -{ -lean_object* x_203; lean_object* x_204; lean_object* x_205; -x_203 = lean_ctor_get(x_200, 1); -lean_inc(x_203); +lean_dec(x_198); +x_202 = lean_ctor_get(x_200, 1); +lean_inc(x_202); lean_dec(x_200); -x_204 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_204, 0, x_203); -lean_ctor_set(x_204, 1, x_147); -lean_ctor_set(x_204, 2, x_148); -lean_ctor_set(x_204, 3, x_149); -lean_ctor_set(x_204, 4, x_150); -x_205 = lean_box(0); -x_158 = x_205; -x_159 = x_204; -goto block_175; -} -else +x_203 = l_Lean_Meta_isExprDefEq(x_2, x_202, x_4, x_201); +if (lean_obj_tag(x_203) == 0) { -lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_206 = lean_ctor_get(x_200, 1); +lean_object* x_204; uint8_t x_205; +x_204 = lean_ctor_get(x_203, 0); +lean_inc(x_204); +x_205 = lean_unbox(x_204); +lean_dec(x_204); +if (x_205 == 0) +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_206 = lean_ctor_get(x_203, 1); lean_inc(x_206); -lean_dec(x_200); -x_207 = lean_ctor_get(x_206, 1); -lean_inc(x_207); -x_208 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_208, 0, x_206); -lean_ctor_set(x_208, 1, x_147); -lean_ctor_set(x_208, 2, x_148); -lean_ctor_set(x_208, 3, x_149); -lean_ctor_set(x_208, 4, x_150); -x_209 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_209, 0, x_207); -x_158 = x_209; -x_159 = x_208; -goto block_175; -} +lean_dec(x_203); +x_207 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_207, 0, x_206); +lean_ctor_set(x_207, 1, x_151); +lean_ctor_set(x_207, 2, x_152); +lean_ctor_set(x_207, 3, x_153); +lean_ctor_set(x_207, 4, x_154); +x_208 = l_Lean_Meta_SynthInstance_tryAnswer___closed__1; +x_162 = x_208; +x_163 = x_207; +goto block_196; } else { -lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_210 = lean_ctor_get(x_200, 0); +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_209 = lean_ctor_get(x_203, 1); +lean_inc(x_209); +lean_dec(x_203); +x_210 = lean_ctor_get(x_209, 1); lean_inc(x_210); -x_211 = lean_ctor_get(x_200, 1); -lean_inc(x_211); -lean_dec(x_200); -x_212 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_212, 0, x_211); -lean_ctor_set(x_212, 1, x_147); -lean_ctor_set(x_212, 2, x_148); -lean_ctor_set(x_212, 3, x_149); -lean_ctor_set(x_212, 4, x_150); -x_176 = x_210; -x_177 = x_212; -goto block_193; +x_211 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_211, 0, x_209); +lean_ctor_set(x_211, 1, x_151); +lean_ctor_set(x_211, 2, x_152); +lean_ctor_set(x_211, 3, x_153); +lean_ctor_set(x_211, 4, x_154); +x_212 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_212, 0, x_210); +x_213 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_213, 0, x_212); +x_162 = x_213; +x_163 = x_211; +goto block_196; } } else { -lean_object* x_213; lean_object* x_214; lean_object* x_215; +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; +x_214 = lean_ctor_get(x_203, 0); +lean_inc(x_214); +x_215 = lean_ctor_get(x_203, 1); +lean_inc(x_215); +lean_dec(x_203); +x_216 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_216, 0, x_215); +lean_ctor_set(x_216, 1, x_151); +lean_ctor_set(x_216, 2, x_152); +lean_ctor_set(x_216, 3, x_153); +lean_ctor_set(x_216, 4, x_154); +x_217 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_217, 0, x_214); +x_162 = x_217; +x_163 = x_216; +goto block_196; +} +} +else +{ +lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_dec(x_4); lean_dec(x_2); -x_213 = lean_ctor_get(x_195, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_195, 1); -lean_inc(x_214); -lean_dec(x_195); -x_215 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_215, 0, x_214); -lean_ctor_set(x_215, 1, x_147); -lean_ctor_set(x_215, 2, x_148); -lean_ctor_set(x_215, 3, x_149); -lean_ctor_set(x_215, 4, x_150); -x_176 = x_213; -x_177 = x_215; -goto block_193; +x_218 = lean_ctor_get(x_198, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_198, 1); +lean_inc(x_219); +lean_dec(x_198); +x_220 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_220, 0, x_219); +lean_ctor_set(x_220, 1, x_151); +lean_ctor_set(x_220, 2, x_152); +lean_ctor_set(x_220, 3, x_153); +lean_ctor_set(x_220, 4, x_154); +x_221 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_221, 0, x_218); +x_162 = x_221; +x_163 = x_220; +goto block_196; } -block_175: +block_196: { -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; -x_160 = lean_ctor_get(x_159, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_159, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_159, 2); -lean_inc(x_162); -x_163 = lean_ctor_get(x_159, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 4); +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, 0); lean_inc(x_164); -if (lean_is_exclusive(x_159)) { - lean_ctor_release(x_159, 0); - lean_ctor_release(x_159, 1); - lean_ctor_release(x_159, 2); - lean_ctor_release(x_159, 3); - lean_ctor_release(x_159, 4); - x_165 = x_159; -} else { - lean_dec_ref(x_159); - x_165 = lean_box(0); -} -x_166 = lean_ctor_get(x_160, 0); +x_165 = lean_ctor_get(x_162, 0); +lean_inc(x_165); +lean_dec(x_162); +x_166 = lean_ctor_get(x_163, 1); lean_inc(x_166); -x_167 = lean_ctor_get(x_160, 2); +x_167 = lean_ctor_get(x_163, 2); lean_inc(x_167); -x_168 = lean_ctor_get(x_160, 3); +x_168 = lean_ctor_get(x_163, 3); lean_inc(x_168); -x_169 = lean_ctor_get(x_160, 4); +x_169 = lean_ctor_get(x_163, 4); lean_inc(x_169); -x_170 = lean_ctor_get(x_160, 5); -lean_inc(x_170); -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_171 = x_160; +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_170 = x_163; } else { - lean_dec_ref(x_160); - x_171 = lean_box(0); + lean_dec_ref(x_163); + x_170 = lean_box(0); } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 6, 0); +x_171 = lean_ctor_get(x_164, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_164, 2); +lean_inc(x_172); +x_173 = lean_ctor_get(x_164, 3); +lean_inc(x_173); +x_174 = lean_ctor_get(x_164, 4); +lean_inc(x_174); +x_175 = lean_ctor_get(x_164, 5); +lean_inc(x_175); +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_176 = x_164; } else { - x_172 = x_171; + lean_dec_ref(x_164); + x_176 = lean_box(0); } -lean_ctor_set(x_172, 0, x_166); -lean_ctor_set(x_172, 1, x_152); -lean_ctor_set(x_172, 2, x_167); -lean_ctor_set(x_172, 3, x_168); -lean_ctor_set(x_172, 4, x_169); -lean_ctor_set(x_172, 5, x_170); -if (lean_is_scalar(x_165)) { - x_173 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_176)) { + x_177 = lean_alloc_ctor(0, 6, 0); } else { - x_173 = x_165; + x_177 = x_176; } -lean_ctor_set(x_173, 0, x_172); -lean_ctor_set(x_173, 1, x_161); -lean_ctor_set(x_173, 2, x_162); -lean_ctor_set(x_173, 3, x_163); -lean_ctor_set(x_173, 4, x_164); -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_158); -lean_ctor_set(x_174, 1, x_173); -return x_174; +lean_ctor_set(x_177, 0, x_171); +lean_ctor_set(x_177, 1, x_156); +lean_ctor_set(x_177, 2, x_172); +lean_ctor_set(x_177, 3, x_173); +lean_ctor_set(x_177, 4, x_174); +lean_ctor_set(x_177, 5, x_175); +if (lean_is_scalar(x_170)) { + x_178 = lean_alloc_ctor(0, 5, 0); +} else { + x_178 = x_170; } -block_193: +lean_ctor_set(x_178, 0, x_177); +lean_ctor_set(x_178, 1, x_166); +lean_ctor_set(x_178, 2, x_167); +lean_ctor_set(x_178, 3, x_168); +lean_ctor_set(x_178, 4, x_169); +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_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_177, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_177, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 2); +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, 0); lean_inc(x_180); -x_181 = lean_ctor_get(x_177, 3); +x_181 = lean_ctor_get(x_162, 0); lean_inc(x_181); -x_182 = lean_ctor_get(x_177, 4); +lean_dec(x_162); +x_182 = lean_ctor_get(x_163, 1); lean_inc(x_182); -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_183 = x_177; -} else { - lean_dec_ref(x_177); - x_183 = lean_box(0); -} -x_184 = lean_ctor_get(x_178, 0); +x_183 = lean_ctor_get(x_163, 2); +lean_inc(x_183); +x_184 = lean_ctor_get(x_163, 3); lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 2); +x_185 = lean_ctor_get(x_163, 4); lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 3); -lean_inc(x_186); -x_187 = lean_ctor_get(x_178, 4); +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_186 = x_163; +} else { + lean_dec_ref(x_163); + x_186 = lean_box(0); +} +x_187 = lean_ctor_get(x_180, 0); lean_inc(x_187); -x_188 = lean_ctor_get(x_178, 5); +x_188 = lean_ctor_get(x_180, 2); 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); - lean_ctor_release(x_178, 5); - x_189 = x_178; +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +x_191 = lean_ctor_get(x_180, 5); +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); + lean_ctor_release(x_180, 5); + x_192 = x_180; } else { - lean_dec_ref(x_178); - x_189 = lean_box(0); + lean_dec_ref(x_180); + x_192 = lean_box(0); } -if (lean_is_scalar(x_189)) { - x_190 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_192)) { + x_193 = lean_alloc_ctor(0, 6, 0); } else { - x_190 = x_189; + x_193 = x_192; } -lean_ctor_set(x_190, 0, x_184); -lean_ctor_set(x_190, 1, x_152); -lean_ctor_set(x_190, 2, x_185); -lean_ctor_set(x_190, 3, x_186); -lean_ctor_set(x_190, 4, x_187); -lean_ctor_set(x_190, 5, x_188); -if (lean_is_scalar(x_183)) { - x_191 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_193, 0, x_187); +lean_ctor_set(x_193, 1, x_156); +lean_ctor_set(x_193, 2, x_188); +lean_ctor_set(x_193, 3, x_189); +lean_ctor_set(x_193, 4, x_190); +lean_ctor_set(x_193, 5, x_191); +if (lean_is_scalar(x_186)) { + x_194 = lean_alloc_ctor(0, 5, 0); } else { - x_191 = x_183; + x_194 = x_186; +} +lean_ctor_set(x_194, 0, x_193); +lean_ctor_set(x_194, 1, x_182); +lean_ctor_set(x_194, 2, x_183); +lean_ctor_set(x_194, 3, x_184); +lean_ctor_set(x_194, 4, x_185); +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; } -lean_ctor_set(x_191, 0, x_190); -lean_ctor_set(x_191, 1, x_179); -lean_ctor_set(x_191, 2, x_180); -lean_ctor_set(x_191, 3, x_181); -lean_ctor_set(x_191, 4, x_182); -x_192 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_192, 0, x_176); -lean_ctor_set(x_192, 1, x_191); -return x_192; } } } @@ -12380,76 +13377,69 @@ x_4 = lean_box(x_3); return x_4; } } -lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_7; lean_object* x_8; uint8_t x_9; -lean_inc(x_2); -lean_inc(x_1); -x_7 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_7, 0, x_1); -lean_ctor_set(x_7, 1, x_2); -x_8 = lean_array_get_size(x_3); -x_9 = lean_nat_dec_lt(x_4, x_8); -lean_dec(x_8); -if (x_9 == 0) +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) { -lean_object* x_10; lean_object* x_11; -lean_dec(x_7); -lean_dec(x_5); +lean_object* x_8; lean_object* x_9; lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_3); lean_dec(x_1); -x_10 = lean_box(0); -x_11 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_11, 0, x_10); -lean_ctor_set(x_11, 1, x_6); -return x_11; +x_8 = lean_box(0); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_5); +return x_9; } else { -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_12 = lean_array_fget(x_3, x_4); -x_13 = lean_unsigned_to_nat(1u); -x_14 = lean_nat_add(x_4, x_13); -lean_dec(x_4); -lean_inc(x_5); -x_15 = l_Lean_Meta_SynthInstance_wakeUp(x_7, x_12, x_5, x_6); -lean_dec(x_12); -if (lean_obj_tag(x_15) == 0) +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_array_fget(x_2, x_3); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_3, x_11); +lean_dec(x_3); +lean_inc(x_4); +lean_inc(x_1); +x_13 = l_Lean_Meta_SynthInstance_wakeUp(x_1, x_10, x_4, x_5); +lean_dec(x_10); +if (lean_obj_tag(x_13) == 0) { -lean_object* x_16; -x_16 = lean_ctor_get(x_15, 1); -lean_inc(x_16); -lean_dec(x_15); -x_4 = x_14; -x_6 = x_16; +lean_object* x_14; +x_14 = lean_ctor_get(x_13, 1); +lean_inc(x_14); +lean_dec(x_13); +x_3 = x_12; +x_5 = x_14; goto _start; } else { -uint8_t x_18; -lean_dec(x_14); -lean_dec(x_5); -lean_dec(x_2); +uint8_t x_16; +lean_dec(x_12); +lean_dec(x_4); lean_dec(x_1); -x_18 = !lean_is_exclusive(x_15); -if (x_18 == 0) +x_16 = !lean_is_exclusive(x_13); +if (x_16 == 0) { -return x_15; +return x_13; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_19 = lean_ctor_get(x_15, 0); -x_20 = lean_ctor_get(x_15, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_15); -x_21 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_21, 0, x_19); -lean_ctor_set(x_21, 1, x_20); -return x_21; +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_13, 0); +x_18 = lean_ctor_get(x_13, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_13); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; } } } @@ -12492,1197 +13482,1217 @@ lean_dec(x_8); x_9 = !lean_is_exclusive(x_4); if (x_9 == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_40; uint8_t x_212; lean_object* x_213; lean_object* x_242; lean_object* x_243; uint8_t x_244; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_185; uint8_t x_226; lean_object* x_227; lean_object* x_258; lean_object* x_259; uint8_t x_260; x_10 = lean_ctor_get(x_4, 1); lean_ctor_set(x_4, 1, x_5); -x_242 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_3); -x_243 = lean_ctor_get(x_242, 0); -lean_inc(x_243); -x_244 = lean_ctor_get_uint8(x_243, sizeof(void*)*1); -lean_dec(x_243); -if (x_244 == 0) +x_258 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_3); +x_259 = lean_ctor_get(x_258, 0); +lean_inc(x_259); +x_260 = lean_ctor_get_uint8(x_259, sizeof(void*)*1); +lean_dec(x_259); +if (x_260 == 0) { -lean_object* x_245; uint8_t x_246; -x_245 = lean_ctor_get(x_242, 1); -lean_inc(x_245); -lean_dec(x_242); -x_246 = 0; -x_212 = x_246; -x_213 = x_245; -goto block_241; +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_258, 1); +lean_inc(x_261); +lean_dec(x_258); +x_262 = 0; +x_226 = x_262; +x_227 = x_261; +goto block_257; } 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_242, 1); -lean_inc(x_247); -lean_dec(x_242); -x_248 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_249 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_248, x_2, x_247); -x_250 = lean_ctor_get(x_249, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_249, 1); -lean_inc(x_251); -lean_dec(x_249); -x_252 = lean_unbox(x_250); -lean_dec(x_250); -x_212 = x_252; -x_213 = x_251; -goto block_241; +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_263 = lean_ctor_get(x_258, 1); +lean_inc(x_263); +lean_dec(x_258); +x_264 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_265 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_264, x_2, x_263); +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +x_267 = lean_ctor_get(x_265, 1); +lean_inc(x_267); +lean_dec(x_265); +x_268 = lean_unbox(x_266); +lean_dec(x_266); +x_226 = x_268; +x_227 = x_267; +goto block_257; } -block_39: +block_184: { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) +if (lean_obj_tag(x_11) == 0) { -lean_object* x_14; uint8_t x_15; -x_14 = lean_ctor_get(x_12, 0); -x_15 = !lean_is_exclusive(x_14); +lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_dec(x_2); +lean_dec(x_1); +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_11, 0); +lean_inc(x_14); +lean_dec(x_11); +x_15 = !lean_is_exclusive(x_12); if (x_15 == 0) { -lean_object* x_16; lean_object* x_17; -x_16 = lean_ctor_get(x_14, 1); +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_12, 0); lean_dec(x_16); -lean_ctor_set(x_14, 1, x_10); -x_17 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_17, 0, x_11); -lean_ctor_set(x_17, 1, x_12); -return x_17; +x_17 = !lean_is_exclusive(x_13); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; +x_18 = lean_ctor_get(x_13, 1); +lean_dec(x_18); +lean_ctor_set(x_13, 1, x_10); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_14); +lean_ctor_set(x_19, 1, x_12); +return x_19; } 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; -x_18 = lean_ctor_get(x_14, 0); -x_19 = lean_ctor_get(x_14, 2); -x_20 = lean_ctor_get(x_14, 3); -x_21 = lean_ctor_get(x_14, 4); -x_22 = lean_ctor_get(x_14, 5); +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_20 = lean_ctor_get(x_13, 0); +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); +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_inc(x_18); -lean_dec(x_14); -x_23 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_23, 0, x_18); -lean_ctor_set(x_23, 1, x_10); -lean_ctor_set(x_23, 2, x_19); -lean_ctor_set(x_23, 3, x_20); -lean_ctor_set(x_23, 4, x_21); -lean_ctor_set(x_23, 5, x_22); -lean_ctor_set(x_12, 0, 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_12); -return x_24; +lean_dec(x_13); +x_25 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_25, 0, x_20); +lean_ctor_set(x_25, 1, x_10); +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_25, 5, x_24); +lean_ctor_set(x_12, 0, x_25); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_14); +lean_ctor_set(x_26, 1, x_12); +return x_26; } } 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; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -x_27 = lean_ctor_get(x_12, 2); -x_28 = lean_ctor_get(x_12, 3); -x_29 = lean_ctor_get(x_12, 4); +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_12, 1); +x_28 = lean_ctor_get(x_12, 2); +x_29 = lean_ctor_get(x_12, 3); +x_30 = lean_ctor_get(x_12, 4); +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_12); -x_30 = lean_ctor_get(x_25, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_25, 2); +x_31 = lean_ctor_get(x_13, 0); lean_inc(x_31); -x_32 = lean_ctor_get(x_25, 3); +x_32 = lean_ctor_get(x_13, 2); lean_inc(x_32); -x_33 = lean_ctor_get(x_25, 4); +x_33 = lean_ctor_get(x_13, 3); lean_inc(x_33); -x_34 = lean_ctor_get(x_25, 5); +x_34 = lean_ctor_get(x_13, 4); lean_inc(x_34); -if (lean_is_exclusive(x_25)) { - lean_ctor_release(x_25, 0); - lean_ctor_release(x_25, 1); - lean_ctor_release(x_25, 2); - lean_ctor_release(x_25, 3); - lean_ctor_release(x_25, 4); - lean_ctor_release(x_25, 5); - x_35 = x_25; +x_35 = lean_ctor_get(x_13, 5); +lean_inc(x_35); +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + lean_ctor_release(x_13, 2); + lean_ctor_release(x_13, 3); + lean_ctor_release(x_13, 4); + lean_ctor_release(x_13, 5); + x_36 = x_13; } else { - lean_dec_ref(x_25); - x_35 = lean_box(0); + lean_dec_ref(x_13); + x_36 = lean_box(0); } -if (lean_is_scalar(x_35)) { - x_36 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_36)) { + x_37 = lean_alloc_ctor(0, 6, 0); } else { - x_36 = x_35; + x_37 = x_36; } -lean_ctor_set(x_36, 0, x_30); -lean_ctor_set(x_36, 1, x_10); -lean_ctor_set(x_36, 2, x_31); -lean_ctor_set(x_36, 3, x_32); -lean_ctor_set(x_36, 4, x_33); -lean_ctor_set(x_36, 5, x_34); -x_37 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_37, 0, x_36); -lean_ctor_set(x_37, 1, x_26); -lean_ctor_set(x_37, 2, x_27); -lean_ctor_set(x_37, 3, x_28); -lean_ctor_set(x_37, 4, x_29); -x_38 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_38, 0, x_11); -lean_ctor_set(x_38, 1, x_37); -return x_38; +lean_ctor_set(x_37, 0, x_31); +lean_ctor_set(x_37, 1, x_10); +lean_ctor_set(x_37, 2, x_32); +lean_ctor_set(x_37, 3, x_33); +lean_ctor_set(x_37, 4, x_34); +lean_ctor_set(x_37, 5, x_35); +x_38 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_38, 0, x_37); +lean_ctor_set(x_38, 1, x_27); +lean_ctor_set(x_38, 2, x_28); +lean_ctor_set(x_38, 3, x_29); +lean_ctor_set(x_38, 4, x_30); +x_39 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_39, 0, x_14); +lean_ctor_set(x_39, 1, x_38); +return x_39; } } -block_211: +else { -uint8_t x_41; -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +lean_object* x_40; lean_object* x_41; uint8_t x_42; +x_40 = lean_ctor_get(x_12, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_11, 0); +lean_inc(x_41); +lean_dec(x_11); +x_42 = !lean_is_exclusive(x_12); +if (x_42 == 0) { -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_42 = lean_ctor_get(x_40, 0); -x_43 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_42); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); +lean_object* x_43; uint8_t x_44; +x_43 = lean_ctor_get(x_12, 0); lean_dec(x_43); -x_46 = l_Lean_Meta_abstractMVars(x_44, x_2, x_45); -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_ctor_get(x_47, 2); -lean_inc(x_49); +x_44 = !lean_is_exclusive(x_40); +if (x_44 == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_40, 1); +lean_dec(x_45); +lean_ctor_set(x_40, 1, x_10); +x_46 = lean_ctor_get(x_1, 1); +lean_inc(x_46); +lean_dec(x_1); lean_inc(x_2); -x_50 = l_Lean_Meta_inferType(x_49, x_2, x_48); -if (lean_obj_tag(x_50) == 0) +x_47 = l_Lean_Meta_SynthInstance_getEntry(x_46, x_2, x_12); +if (lean_obj_tag(x_47) == 0) +{ +uint8_t x_48; +x_48 = !lean_is_exclusive(x_47); +if (x_48 == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_47, 0); +x_50 = !lean_is_exclusive(x_49); +if (x_50 == 0) { lean_object* x_51; lean_object* x_52; lean_object* x_53; uint8_t x_54; -x_51 = lean_ctor_get(x_50, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_50, 1); -lean_inc(x_52); -lean_dec(x_50); -lean_inc(x_51); -lean_inc(x_47); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_47); -lean_ctor_set(x_53, 1, x_51); -x_54 = !lean_is_exclusive(x_52); +x_51 = lean_ctor_get(x_47, 1); +x_52 = lean_ctor_get(x_49, 0); +x_53 = lean_ctor_get(x_49, 1); +x_54 = l_Lean_Meta_SynthInstance_isNewAnswer(x_53, x_41); if (x_54 == 0) { -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_52, 1); -lean_dec(x_55); -lean_ctor_set(x_52, 1, x_10); -lean_ctor_set(x_40, 0, x_52); -x_56 = lean_ctor_get(x_1, 1); -lean_inc(x_56); -lean_dec(x_1); -lean_inc(x_2); -x_57 = l_Lean_Meta_SynthInstance_getEntry(x_56, x_2, x_40); -if (lean_obj_tag(x_57) == 0) -{ -uint8_t x_58; -x_58 = !lean_is_exclusive(x_57); -if (x_58 == 0) -{ -lean_object* x_59; uint8_t x_60; -x_59 = lean_ctor_get(x_57, 0); -x_60 = !lean_is_exclusive(x_59); -if (x_60 == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; uint8_t x_64; -x_61 = lean_ctor_get(x_57, 1); -x_62 = lean_ctor_get(x_59, 0); -x_63 = lean_ctor_get(x_59, 1); -x_64 = l_Lean_Meta_SynthInstance_isNewAnswer(x_63, x_53); -if (x_64 == 0) -{ -lean_object* x_65; -lean_free_object(x_59); -lean_dec(x_63); -lean_dec(x_62); -lean_dec(x_56); +lean_object* x_55; +lean_free_object(x_49); lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); +lean_dec(x_52); +lean_dec(x_46); +lean_dec(x_41); lean_dec(x_2); -x_65 = lean_box(0); -lean_ctor_set(x_57, 0, x_65); -return x_57; +x_55 = lean_box(0); +lean_ctor_set(x_47, 0, x_55); +return x_47; } else { -lean_object* x_66; uint8_t x_67; -lean_free_object(x_57); -x_66 = lean_array_push(x_63, x_53); +lean_object* x_56; uint8_t x_57; +lean_free_object(x_47); +lean_inc(x_41); +x_56 = lean_array_push(x_53, x_41); +lean_inc(x_52); +lean_ctor_set(x_49, 1, x_56); +x_57 = !lean_is_exclusive(x_51); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_58 = lean_ctor_get(x_51, 4); +x_59 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_58, x_46, x_49); +lean_ctor_set(x_51, 4, x_59); +x_60 = lean_unsigned_to_nat(0u); +x_61 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_52, x_60, x_2, x_51); +lean_dec(x_52); +return x_61; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_62 = lean_ctor_get(x_51, 0); +x_63 = lean_ctor_get(x_51, 1); +x_64 = lean_ctor_get(x_51, 2); +x_65 = lean_ctor_get(x_51, 3); +x_66 = lean_ctor_get(x_51, 4); +lean_inc(x_66); +lean_inc(x_65); +lean_inc(x_64); +lean_inc(x_63); lean_inc(x_62); -lean_ctor_set(x_59, 1, x_66); -x_67 = !lean_is_exclusive(x_61); -if (x_67 == 0) -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_68 = lean_ctor_get(x_61, 4); -x_69 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_68, x_56, x_59); -lean_ctor_set(x_61, 4, x_69); -x_70 = lean_unsigned_to_nat(0u); -x_71 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_47, x_51, x_62, x_70, x_2, x_61); -lean_dec(x_62); -return x_71; +lean_dec(x_51); +x_67 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_66, x_46, x_49); +x_68 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_68, 0, x_62); +lean_ctor_set(x_68, 1, x_63); +lean_ctor_set(x_68, 2, x_64); +lean_ctor_set(x_68, 3, x_65); +lean_ctor_set(x_68, 4, x_67); +x_69 = lean_unsigned_to_nat(0u); +x_70 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_52, x_69, x_2, x_68); +lean_dec(x_52); +return x_70; +} +} } 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; -x_72 = lean_ctor_get(x_61, 0); -x_73 = lean_ctor_get(x_61, 1); -x_74 = lean_ctor_get(x_61, 2); -x_75 = lean_ctor_get(x_61, 3); -x_76 = lean_ctor_get(x_61, 4); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); +lean_object* x_71; lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_71 = lean_ctor_get(x_47, 1); +x_72 = lean_ctor_get(x_49, 0); +x_73 = lean_ctor_get(x_49, 1); lean_inc(x_73); lean_inc(x_72); -lean_dec(x_61); -x_77 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_76, x_56, x_59); -x_78 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_78, 0, x_72); -lean_ctor_set(x_78, 1, x_73); -lean_ctor_set(x_78, 2, x_74); -lean_ctor_set(x_78, 3, x_75); -lean_ctor_set(x_78, 4, x_77); -x_79 = lean_unsigned_to_nat(0u); -x_80 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_47, x_51, x_62, x_79, x_2, x_78); -lean_dec(x_62); -return x_80; -} -} -} -else +lean_dec(x_49); +x_74 = l_Lean_Meta_SynthInstance_isNewAnswer(x_73, x_41); +if (x_74 == 0) { -lean_object* x_81; lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_81 = lean_ctor_get(x_57, 1); -x_82 = lean_ctor_get(x_59, 0); -x_83 = lean_ctor_get(x_59, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_59); -x_84 = l_Lean_Meta_SynthInstance_isNewAnswer(x_83, x_53); -if (x_84 == 0) -{ -lean_object* x_85; -lean_dec(x_83); -lean_dec(x_82); -lean_dec(x_56); -lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); +lean_object* x_75; +lean_dec(x_73); +lean_dec(x_72); +lean_dec(x_46); +lean_dec(x_41); lean_dec(x_2); -x_85 = lean_box(0); -lean_ctor_set(x_57, 0, x_85); -return x_57; +x_75 = lean_box(0); +lean_ctor_set(x_47, 0, x_75); +return x_47; } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -lean_free_object(x_57); -x_86 = lean_array_push(x_83, x_53); +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_free_object(x_47); +lean_inc(x_41); +x_76 = lean_array_push(x_73, x_41); +lean_inc(x_72); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_72); +lean_ctor_set(x_77, 1, x_76); +x_78 = lean_ctor_get(x_71, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_71, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_71, 2); +lean_inc(x_80); +x_81 = lean_ctor_get(x_71, 3); +lean_inc(x_81); +x_82 = lean_ctor_get(x_71, 4); lean_inc(x_82); -x_87 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_87, 0, x_82); -lean_ctor_set(x_87, 1, x_86); -x_88 = lean_ctor_get(x_81, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_81, 1); +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); + lean_ctor_release(x_71, 4); + x_83 = x_71; +} else { + lean_dec_ref(x_71); + x_83 = lean_box(0); +} +x_84 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_82, x_46, x_77); +if (lean_is_scalar(x_83)) { + x_85 = lean_alloc_ctor(0, 5, 0); +} else { + x_85 = x_83; +} +lean_ctor_set(x_85, 0, x_78); +lean_ctor_set(x_85, 1, x_79); +lean_ctor_set(x_85, 2, x_80); +lean_ctor_set(x_85, 3, x_81); +lean_ctor_set(x_85, 4, x_84); +x_86 = lean_unsigned_to_nat(0u); +x_87 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_72, x_86, x_2, x_85); +lean_dec(x_72); +return x_87; +} +} +} +else +{ +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; uint8_t x_93; +x_88 = lean_ctor_get(x_47, 0); +x_89 = lean_ctor_get(x_47, 1); lean_inc(x_89); -x_90 = lean_ctor_get(x_81, 2); +lean_inc(x_88); +lean_dec(x_47); +x_90 = lean_ctor_get(x_88, 0); lean_inc(x_90); -x_91 = lean_ctor_get(x_81, 3); +x_91 = lean_ctor_get(x_88, 1); lean_inc(x_91); -x_92 = lean_ctor_get(x_81, 4); -lean_inc(x_92); -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); - x_93 = x_81; +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_81); - x_93 = lean_box(0); + lean_dec_ref(x_88); + x_92 = lean_box(0); } -x_94 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_92, x_56, x_87); -if (lean_is_scalar(x_93)) { - x_95 = lean_alloc_ctor(0, 5, 0); -} else { - x_95 = x_93; -} -lean_ctor_set(x_95, 0, x_88); +x_93 = l_Lean_Meta_SynthInstance_isNewAnswer(x_91, x_41); +if (x_93 == 0) +{ +lean_object* x_94; lean_object* x_95; +lean_dec(x_92); +lean_dec(x_91); +lean_dec(x_90); +lean_dec(x_46); +lean_dec(x_41); +lean_dec(x_2); +x_94 = lean_box(0); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_94); lean_ctor_set(x_95, 1, x_89); -lean_ctor_set(x_95, 2, x_90); -lean_ctor_set(x_95, 3, x_91); -lean_ctor_set(x_95, 4, x_94); -x_96 = lean_unsigned_to_nat(0u); -x_97 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_47, x_51, x_82, x_96, x_2, x_95); -lean_dec(x_82); -return x_97; -} -} +return x_95; } else { -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; uint8_t x_103; -x_98 = lean_ctor_get(x_57, 0); -x_99 = lean_ctor_get(x_57, 1); -lean_inc(x_99); +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_inc(x_41); +x_96 = lean_array_push(x_91, x_41); +lean_inc(x_90); +if (lean_is_scalar(x_92)) { + x_97 = lean_alloc_ctor(0, 2, 0); +} else { + x_97 = x_92; +} +lean_ctor_set(x_97, 0, x_90); +lean_ctor_set(x_97, 1, x_96); +x_98 = lean_ctor_get(x_89, 0); lean_inc(x_98); -lean_dec(x_57); -x_100 = lean_ctor_get(x_98, 0); +x_99 = lean_ctor_get(x_89, 1); +lean_inc(x_99); +x_100 = lean_ctor_get(x_89, 2); lean_inc(x_100); -x_101 = lean_ctor_get(x_98, 1); +x_101 = lean_ctor_get(x_89, 3); lean_inc(x_101); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_102 = x_98; +x_102 = lean_ctor_get(x_89, 4); +lean_inc(x_102); +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_103 = x_89; } else { - lean_dec_ref(x_98); - x_102 = lean_box(0); + lean_dec_ref(x_89); + x_103 = lean_box(0); } -x_103 = l_Lean_Meta_SynthInstance_isNewAnswer(x_101, x_53); -if (x_103 == 0) -{ -lean_object* x_104; lean_object* x_105; -lean_dec(x_102); -lean_dec(x_101); -lean_dec(x_100); -lean_dec(x_56); -lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); -lean_dec(x_2); -x_104 = lean_box(0); -x_105 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_105, 0, x_104); +x_104 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_102, x_46, x_97); +if (lean_is_scalar(x_103)) { + x_105 = lean_alloc_ctor(0, 5, 0); +} else { + x_105 = x_103; +} +lean_ctor_set(x_105, 0, x_98); lean_ctor_set(x_105, 1, x_99); -return x_105; +lean_ctor_set(x_105, 2, x_100); +lean_ctor_set(x_105, 3, x_101); +lean_ctor_set(x_105, 4, x_104); +x_106 = lean_unsigned_to_nat(0u); +x_107 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_90, x_106, x_2, x_105); +lean_dec(x_90); +return x_107; +} +} } 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; -x_106 = lean_array_push(x_101, x_53); -lean_inc(x_100); -if (lean_is_scalar(x_102)) { - x_107 = lean_alloc_ctor(0, 2, 0); -} else { - x_107 = x_102; +uint8_t x_108; +lean_dec(x_46); +lean_dec(x_41); +lean_dec(x_2); +x_108 = !lean_is_exclusive(x_47); +if (x_108 == 0) +{ +return x_47; } -lean_ctor_set(x_107, 0, x_100); -lean_ctor_set(x_107, 1, x_106); -x_108 = lean_ctor_get(x_99, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_99, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_99, 2); +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_47, 0); +x_110 = lean_ctor_get(x_47, 1); lean_inc(x_110); -x_111 = lean_ctor_get(x_99, 3); -lean_inc(x_111); -x_112 = lean_ctor_get(x_99, 4); +lean_inc(x_109); +lean_dec(x_47); +x_111 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_111, 0, x_109); +lean_ctor_set(x_111, 1, x_110); +return x_111; +} +} +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_112 = lean_ctor_get(x_40, 0); +x_113 = lean_ctor_get(x_40, 2); +x_114 = lean_ctor_get(x_40, 3); +x_115 = lean_ctor_get(x_40, 4); +x_116 = lean_ctor_get(x_40, 5); +lean_inc(x_116); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); lean_inc(x_112); -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_113 = x_99; -} else { - lean_dec_ref(x_99); - x_113 = lean_box(0); -} -x_114 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_112, x_56, x_107); -if (lean_is_scalar(x_113)) { - x_115 = lean_alloc_ctor(0, 5, 0); -} else { - x_115 = x_113; -} -lean_ctor_set(x_115, 0, x_108); -lean_ctor_set(x_115, 1, x_109); -lean_ctor_set(x_115, 2, x_110); -lean_ctor_set(x_115, 3, x_111); -lean_ctor_set(x_115, 4, x_114); -x_116 = lean_unsigned_to_nat(0u); -x_117 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_47, x_51, x_100, x_116, x_2, x_115); -lean_dec(x_100); -return x_117; -} -} -} -else -{ -uint8_t x_118; -lean_dec(x_56); -lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); -lean_dec(x_2); -x_118 = !lean_is_exclusive(x_57); -if (x_118 == 0) -{ -return x_57; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_57, 0); -x_120 = lean_ctor_get(x_57, 1); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_57); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -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; -x_122 = lean_ctor_get(x_52, 0); -x_123 = lean_ctor_get(x_52, 2); -x_124 = lean_ctor_get(x_52, 3); -x_125 = lean_ctor_get(x_52, 4); -x_126 = lean_ctor_get(x_52, 5); -lean_inc(x_126); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_52); -x_127 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_127, 0, x_122); -lean_ctor_set(x_127, 1, x_10); -lean_ctor_set(x_127, 2, x_123); -lean_ctor_set(x_127, 3, x_124); -lean_ctor_set(x_127, 4, x_125); -lean_ctor_set(x_127, 5, x_126); -lean_ctor_set(x_40, 0, x_127); -x_128 = lean_ctor_get(x_1, 1); -lean_inc(x_128); -lean_dec(x_1); -lean_inc(x_2); -x_129 = l_Lean_Meta_SynthInstance_getEntry(x_128, x_2, x_40); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; uint8_t x_136; -x_130 = lean_ctor_get(x_129, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_129, 1); -lean_inc(x_131); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_132 = x_129; -} else { - lean_dec_ref(x_129); - x_132 = lean_box(0); -} -x_133 = lean_ctor_get(x_130, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_130, 1); -lean_inc(x_134); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - x_135 = x_130; -} else { - lean_dec_ref(x_130); - x_135 = lean_box(0); -} -x_136 = l_Lean_Meta_SynthInstance_isNewAnswer(x_134, x_53); -if (x_136 == 0) -{ -lean_object* x_137; lean_object* x_138; -lean_dec(x_135); -lean_dec(x_134); -lean_dec(x_133); -lean_dec(x_128); -lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); -lean_dec(x_2); -x_137 = lean_box(0); -if (lean_is_scalar(x_132)) { - x_138 = lean_alloc_ctor(0, 2, 0); -} else { - x_138 = x_132; -} -lean_ctor_set(x_138, 0, x_137); -lean_ctor_set(x_138, 1, x_131); -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_dec(x_132); -x_139 = lean_array_push(x_134, x_53); -lean_inc(x_133); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 2, 0); -} else { - x_140 = x_135; -} -lean_ctor_set(x_140, 0, x_133); -lean_ctor_set(x_140, 1, x_139); -x_141 = lean_ctor_get(x_131, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_131, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_131, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_131, 3); -lean_inc(x_144); -x_145 = lean_ctor_get(x_131, 4); -lean_inc(x_145); -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_146 = x_131; -} else { - lean_dec_ref(x_131); - x_146 = lean_box(0); -} -x_147 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_145, x_128, x_140); -if (lean_is_scalar(x_146)) { - x_148 = lean_alloc_ctor(0, 5, 0); -} else { - x_148 = x_146; -} -lean_ctor_set(x_148, 0, x_141); -lean_ctor_set(x_148, 1, x_142); -lean_ctor_set(x_148, 2, x_143); -lean_ctor_set(x_148, 3, x_144); -lean_ctor_set(x_148, 4, x_147); -x_149 = lean_unsigned_to_nat(0u); -x_150 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_47, x_51, x_133, x_149, x_2, x_148); -lean_dec(x_133); -return x_150; -} -} -else -{ -lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; -lean_dec(x_128); -lean_dec(x_53); -lean_dec(x_51); -lean_dec(x_47); -lean_dec(x_2); -x_151 = lean_ctor_get(x_129, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_129, 1); -lean_inc(x_152); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_153 = x_129; -} else { - lean_dec_ref(x_129); - x_153 = lean_box(0); -} -if (lean_is_scalar(x_153)) { - x_154 = lean_alloc_ctor(1, 2, 0); -} else { - x_154 = x_153; -} -lean_ctor_set(x_154, 0, x_151); -lean_ctor_set(x_154, 1, x_152); -return x_154; -} -} -} -else -{ -lean_object* x_155; lean_object* x_156; -lean_dec(x_47); -lean_dec(x_2); -lean_dec(x_1); -x_155 = lean_ctor_get(x_50, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_50, 1); -lean_inc(x_156); -lean_dec(x_50); -lean_ctor_set(x_40, 0, x_156); -x_11 = x_155; -x_12 = x_40; -goto block_39; -} -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -x_157 = lean_ctor_get(x_40, 0); -x_158 = lean_ctor_get(x_40, 1); -x_159 = lean_ctor_get(x_40, 2); -x_160 = lean_ctor_get(x_40, 3); -x_161 = lean_ctor_get(x_40, 4); -lean_inc(x_161); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); lean_dec(x_40); -x_162 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_157); -x_163 = lean_ctor_get(x_162, 0); +x_117 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_117, 0, x_112); +lean_ctor_set(x_117, 1, x_10); +lean_ctor_set(x_117, 2, x_113); +lean_ctor_set(x_117, 3, x_114); +lean_ctor_set(x_117, 4, x_115); +lean_ctor_set(x_117, 5, x_116); +lean_ctor_set(x_12, 0, x_117); +x_118 = lean_ctor_get(x_1, 1); +lean_inc(x_118); +lean_dec(x_1); +lean_inc(x_2); +x_119 = l_Lean_Meta_SynthInstance_getEntry(x_118, x_2, x_12); +if (lean_obj_tag(x_119) == 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; uint8_t x_126; +x_120 = lean_ctor_get(x_119, 0); +lean_inc(x_120); +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +if (lean_is_exclusive(x_119)) { + lean_ctor_release(x_119, 0); + lean_ctor_release(x_119, 1); + x_122 = x_119; +} else { + lean_dec_ref(x_119); + x_122 = lean_box(0); +} +x_123 = lean_ctor_get(x_120, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_120, 1); +lean_inc(x_124); +if (lean_is_exclusive(x_120)) { + lean_ctor_release(x_120, 0); + lean_ctor_release(x_120, 1); + x_125 = x_120; +} else { + lean_dec_ref(x_120); + x_125 = lean_box(0); +} +x_126 = l_Lean_Meta_SynthInstance_isNewAnswer(x_124, x_41); +if (x_126 == 0) +{ +lean_object* x_127; lean_object* x_128; +lean_dec(x_125); +lean_dec(x_124); +lean_dec(x_123); +lean_dec(x_118); +lean_dec(x_41); +lean_dec(x_2); +x_127 = lean_box(0); +if (lean_is_scalar(x_122)) { + x_128 = lean_alloc_ctor(0, 2, 0); +} else { + x_128 = x_122; +} +lean_ctor_set(x_128, 0, x_127); +lean_ctor_set(x_128, 1, x_121); +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_dec(x_122); +lean_inc(x_41); +x_129 = lean_array_push(x_124, x_41); +lean_inc(x_123); +if (lean_is_scalar(x_125)) { + x_130 = lean_alloc_ctor(0, 2, 0); +} else { + x_130 = x_125; +} +lean_ctor_set(x_130, 0, x_123); +lean_ctor_set(x_130, 1, x_129); +x_131 = lean_ctor_get(x_121, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_121, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_121, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_121, 3); +lean_inc(x_134); +x_135 = lean_ctor_get(x_121, 4); +lean_inc(x_135); +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); + x_136 = x_121; +} else { + lean_dec_ref(x_121); + x_136 = lean_box(0); +} +x_137 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_135, x_118, x_130); +if (lean_is_scalar(x_136)) { + x_138 = lean_alloc_ctor(0, 5, 0); +} else { + x_138 = x_136; +} +lean_ctor_set(x_138, 0, x_131); +lean_ctor_set(x_138, 1, x_132); +lean_ctor_set(x_138, 2, x_133); +lean_ctor_set(x_138, 3, x_134); +lean_ctor_set(x_138, 4, x_137); +x_139 = lean_unsigned_to_nat(0u); +x_140 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_123, x_139, x_2, x_138); +lean_dec(x_123); +return x_140; +} +} +else +{ +lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; +lean_dec(x_118); +lean_dec(x_41); +lean_dec(x_2); +x_141 = lean_ctor_get(x_119, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_119, 1); +lean_inc(x_142); +if (lean_is_exclusive(x_119)) { + lean_ctor_release(x_119, 0); + lean_ctor_release(x_119, 1); + x_143 = x_119; +} else { + lean_dec_ref(x_119); + x_143 = lean_box(0); +} +if (lean_is_scalar(x_143)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_143; +} +lean_ctor_set(x_144, 0, x_141); +lean_ctor_set(x_144, 1, x_142); +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; +x_145 = lean_ctor_get(x_12, 1); +x_146 = lean_ctor_get(x_12, 2); +x_147 = lean_ctor_get(x_12, 3); +x_148 = lean_ctor_get(x_12, 4); +lean_inc(x_148); +lean_inc(x_147); +lean_inc(x_146); +lean_inc(x_145); +lean_dec(x_12); +x_149 = lean_ctor_get(x_40, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_40, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_40, 3); +lean_inc(x_151); +x_152 = lean_ctor_get(x_40, 4); +lean_inc(x_152); +x_153 = lean_ctor_get(x_40, 5); +lean_inc(x_153); +if (lean_is_exclusive(x_40)) { + lean_ctor_release(x_40, 0); + lean_ctor_release(x_40, 1); + lean_ctor_release(x_40, 2); + lean_ctor_release(x_40, 3); + lean_ctor_release(x_40, 4); + lean_ctor_release(x_40, 5); + x_154 = x_40; +} else { + lean_dec_ref(x_40); + x_154 = lean_box(0); +} +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 6, 0); +} else { + x_155 = x_154; +} +lean_ctor_set(x_155, 0, x_149); +lean_ctor_set(x_155, 1, x_10); +lean_ctor_set(x_155, 2, x_150); +lean_ctor_set(x_155, 3, x_151); +lean_ctor_set(x_155, 4, x_152); +lean_ctor_set(x_155, 5, x_153); +x_156 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_156, 0, x_155); +lean_ctor_set(x_156, 1, x_145); +lean_ctor_set(x_156, 2, x_146); +lean_ctor_set(x_156, 3, x_147); +lean_ctor_set(x_156, 4, x_148); +x_157 = lean_ctor_get(x_1, 1); +lean_inc(x_157); +lean_dec(x_1); +lean_inc(x_2); +x_158 = l_Lean_Meta_SynthInstance_getEntry(x_157, x_2, x_156); +if (lean_obj_tag(x_158) == 0) +{ +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; uint8_t x_165; +x_159 = lean_ctor_get(x_158, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_158, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_158)) { + lean_ctor_release(x_158, 0); + lean_ctor_release(x_158, 1); + x_161 = x_158; +} else { + lean_dec_ref(x_158); + x_161 = lean_box(0); +} +x_162 = lean_ctor_get(x_159, 0); +lean_inc(x_162); +x_163 = lean_ctor_get(x_159, 1); lean_inc(x_163); -x_164 = lean_ctor_get(x_162, 1); -lean_inc(x_164); +if (lean_is_exclusive(x_159)) { + lean_ctor_release(x_159, 0); + lean_ctor_release(x_159, 1); + x_164 = x_159; +} else { + lean_dec_ref(x_159); + x_164 = lean_box(0); +} +x_165 = l_Lean_Meta_SynthInstance_isNewAnswer(x_163, x_41); +if (x_165 == 0) +{ +lean_object* x_166; lean_object* x_167; +lean_dec(x_164); +lean_dec(x_163); lean_dec(x_162); -x_165 = l_Lean_Meta_abstractMVars(x_163, x_2, 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_ctor_get(x_166, 2); -lean_inc(x_168); -lean_inc(x_2); -x_169 = l_Lean_Meta_inferType(x_168, x_2, x_167); -if (lean_obj_tag(x_169) == 0) +lean_dec(x_157); +lean_dec(x_41); +lean_dec(x_2); +x_166 = lean_box(0); +if (lean_is_scalar(x_161)) { + x_167 = lean_alloc_ctor(0, 2, 0); +} else { + x_167 = x_161; +} +lean_ctor_set(x_167, 0, x_166); +lean_ctor_set(x_167, 1, x_160); +return x_167; +} +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; -x_170 = lean_ctor_get(x_169, 0); +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_dec(x_161); +lean_inc(x_41); +x_168 = lean_array_push(x_163, x_41); +lean_inc(x_162); +if (lean_is_scalar(x_164)) { + x_169 = lean_alloc_ctor(0, 2, 0); +} else { + x_169 = x_164; +} +lean_ctor_set(x_169, 0, x_162); +lean_ctor_set(x_169, 1, x_168); +x_170 = lean_ctor_get(x_160, 0); lean_inc(x_170); -x_171 = lean_ctor_get(x_169, 1); +x_171 = lean_ctor_get(x_160, 1); lean_inc(x_171); -lean_dec(x_169); -lean_inc(x_170); -lean_inc(x_166); -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_166); -lean_ctor_set(x_172, 1, x_170); -x_173 = lean_ctor_get(x_171, 0); +x_172 = lean_ctor_get(x_160, 2); +lean_inc(x_172); +x_173 = lean_ctor_get(x_160, 3); lean_inc(x_173); -x_174 = lean_ctor_get(x_171, 2); +x_174 = lean_ctor_get(x_160, 4); lean_inc(x_174); -x_175 = lean_ctor_get(x_171, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_171, 4); -lean_inc(x_176); -x_177 = lean_ctor_get(x_171, 5); -lean_inc(x_177); -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_178 = x_171; +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); + x_175 = x_160; } else { - lean_dec_ref(x_171); - x_178 = lean_box(0); + lean_dec_ref(x_160); + x_175 = lean_box(0); } -if (lean_is_scalar(x_178)) { - x_179 = lean_alloc_ctor(0, 6, 0); +x_176 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_174, x_157, x_169); +if (lean_is_scalar(x_175)) { + x_177 = lean_alloc_ctor(0, 5, 0); } else { - x_179 = x_178; + x_177 = x_175; } -lean_ctor_set(x_179, 0, x_173); -lean_ctor_set(x_179, 1, x_10); -lean_ctor_set(x_179, 2, x_174); -lean_ctor_set(x_179, 3, x_175); -lean_ctor_set(x_179, 4, x_176); -lean_ctor_set(x_179, 5, x_177); -x_180 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_180, 0, x_179); -lean_ctor_set(x_180, 1, x_158); -lean_ctor_set(x_180, 2, x_159); -lean_ctor_set(x_180, 3, x_160); -lean_ctor_set(x_180, 4, x_161); -x_181 = lean_ctor_get(x_1, 1); +lean_ctor_set(x_177, 0, x_170); +lean_ctor_set(x_177, 1, x_171); +lean_ctor_set(x_177, 2, x_172); +lean_ctor_set(x_177, 3, x_173); +lean_ctor_set(x_177, 4, x_176); +x_178 = lean_unsigned_to_nat(0u); +x_179 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_41, x_162, x_178, x_2, x_177); +lean_dec(x_162); +return x_179; +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; +lean_dec(x_157); +lean_dec(x_41); +lean_dec(x_2); +x_180 = lean_ctor_get(x_158, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_158, 1); lean_inc(x_181); -lean_dec(x_1); -lean_inc(x_2); -x_182 = l_Lean_Meta_SynthInstance_getEntry(x_181, x_2, x_180); -if (lean_obj_tag(x_182) == 0) -{ -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; -x_183 = lean_ctor_get(x_182, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_182, 1); -lean_inc(x_184); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - x_185 = x_182; +if (lean_is_exclusive(x_158)) { + lean_ctor_release(x_158, 0); + lean_ctor_release(x_158, 1); + x_182 = x_158; } else { - lean_dec_ref(x_182); - x_185 = lean_box(0); + lean_dec_ref(x_158); + x_182 = lean_box(0); } -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_183, 1); -lean_inc(x_187); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - x_188 = x_183; +if (lean_is_scalar(x_182)) { + x_183 = lean_alloc_ctor(1, 2, 0); } else { - lean_dec_ref(x_183); - x_188 = lean_box(0); + x_183 = x_182; } -x_189 = l_Lean_Meta_SynthInstance_isNewAnswer(x_187, x_172); -if (x_189 == 0) +lean_ctor_set(x_183, 0, x_180); +lean_ctor_set(x_183, 1, x_181); +return x_183; +} +} +} +} +block_225: { -lean_object* x_190; lean_object* x_191; +uint8_t x_186; +x_186 = !lean_is_exclusive(x_185); +if (x_186 == 0) +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; +x_187 = lean_ctor_get(x_185, 0); +x_188 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_187); +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); -lean_dec(x_187); -lean_dec(x_186); -lean_dec(x_181); -lean_dec(x_172); -lean_dec(x_170); -lean_dec(x_166); -lean_dec(x_2); -x_190 = lean_box(0); -if (lean_is_scalar(x_185)) { - x_191 = lean_alloc_ctor(0, 2, 0); -} else { - x_191 = x_185; -} -lean_ctor_set(x_191, 0, x_190); -lean_ctor_set(x_191, 1, x_184); -return x_191; -} -else -{ -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_dec(x_185); -x_192 = lean_array_push(x_187, x_172); -lean_inc(x_186); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 2, 0); -} else { - x_193 = x_188; -} -lean_ctor_set(x_193, 0, x_186); -lean_ctor_set(x_193, 1, x_192); -x_194 = lean_ctor_get(x_184, 0); +x_191 = l_Lean_Meta_abstractMVars(x_189, 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); +lean_dec(x_191); +x_194 = lean_ctor_get(x_192, 2); lean_inc(x_194); -x_195 = lean_ctor_get(x_184, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_184, 2); +lean_inc(x_2); +x_195 = l_Lean_Meta_inferType(x_194, x_2, x_193); +if (lean_obj_tag(x_195) == 0) +{ +lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; +x_196 = lean_ctor_get(x_195, 0); lean_inc(x_196); -x_197 = lean_ctor_get(x_184, 3); +x_197 = lean_ctor_get(x_195, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_184, 4); -lean_inc(x_198); -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_199 = x_184; -} else { - lean_dec_ref(x_184); - x_199 = lean_box(0); +lean_dec(x_195); +lean_ctor_set(x_185, 0, x_197); +x_198 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_198, 0, x_192); +lean_ctor_set(x_198, 1, x_196); +x_199 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_199, 0, x_198); +x_11 = x_199; +x_12 = x_185; +goto block_184; } -x_200 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_198, x_181, x_193); -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_194); -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_200); -x_202 = lean_unsigned_to_nat(0u); -x_203 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_166, x_170, x_186, x_202, x_2, x_201); -lean_dec(x_186); -return x_203; +else +{ +lean_object* x_200; lean_object* x_201; lean_object* x_202; +lean_dec(x_192); +x_200 = lean_ctor_get(x_195, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_195, 1); +lean_inc(x_201); +lean_dec(x_195); +lean_ctor_set(x_185, 0, x_201); +x_202 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_202, 0, x_200); +x_11 = x_202; +x_12 = x_185; +goto block_184; } } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -lean_dec(x_181); -lean_dec(x_172); -lean_dec(x_170); -lean_dec(x_166); -lean_dec(x_2); -x_204 = lean_ctor_get(x_182, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_182, 1); +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_203 = lean_ctor_get(x_185, 0); +x_204 = lean_ctor_get(x_185, 1); +x_205 = lean_ctor_get(x_185, 2); +x_206 = lean_ctor_get(x_185, 3); +x_207 = lean_ctor_get(x_185, 4); +lean_inc(x_207); +lean_inc(x_206); lean_inc(x_205); -if (lean_is_exclusive(x_182)) { - lean_ctor_release(x_182, 0); - lean_ctor_release(x_182, 1); - x_206 = x_182; -} else { - lean_dec_ref(x_182); - x_206 = lean_box(0); -} -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(1, 2, 0); -} else { - x_207 = x_206; -} -lean_ctor_set(x_207, 0, x_204); -lean_ctor_set(x_207, 1, x_205); -return x_207; -} -} -else -{ -lean_object* x_208; lean_object* x_209; lean_object* x_210; -lean_dec(x_166); -lean_dec(x_2); -lean_dec(x_1); -x_208 = lean_ctor_get(x_169, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_169, 1); +lean_inc(x_204); +lean_inc(x_203); +lean_dec(x_185); +x_208 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_203); +x_209 = lean_ctor_get(x_208, 0); lean_inc(x_209); -lean_dec(x_169); -x_210 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_210, 0, x_209); -lean_ctor_set(x_210, 1, x_158); -lean_ctor_set(x_210, 2, x_159); -lean_ctor_set(x_210, 3, x_160); -lean_ctor_set(x_210, 4, x_161); -x_11 = x_208; -x_12 = x_210; -goto block_39; -} -} -} -block_241: -{ -if (x_212 == 0) -{ -x_40 = x_213; -goto block_211; -} -else -{ -uint8_t x_214; -x_214 = !lean_is_exclusive(x_213); -if (x_214 == 0) -{ -lean_object* x_215; lean_object* x_216; -x_215 = lean_ctor_get(x_213, 0); +x_210 = lean_ctor_get(x_208, 1); +lean_inc(x_210); +lean_dec(x_208); +x_211 = l_Lean_Meta_abstractMVars(x_209, x_2, x_210); +x_212 = lean_ctor_get(x_211, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_211, 1); +lean_inc(x_213); +lean_dec(x_211); +x_214 = lean_ctor_get(x_212, 2); +lean_inc(x_214); lean_inc(x_2); -lean_inc(x_6); -x_216 = l_Lean_Meta_inferType(x_6, x_2, x_215); -if (lean_obj_tag(x_216) == 0) +x_215 = l_Lean_Meta_inferType(x_214, x_2, x_213); +if (lean_obj_tag(x_215) == 0) { -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_217 = lean_ctor_get(x_216, 0); +lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; +x_216 = lean_ctor_get(x_215, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_215, 1); lean_inc(x_217); -x_218 = lean_ctor_get(x_216, 1); -lean_inc(x_218); -lean_dec(x_216); -lean_ctor_set(x_213, 0, x_218); -x_219 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_219, 0, x_217); -x_220 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_221 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_220, x_219, x_2, x_213); -x_222 = lean_ctor_get(x_221, 1); +lean_dec(x_215); +x_218 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_218, 0, x_217); +lean_ctor_set(x_218, 1, x_204); +lean_ctor_set(x_218, 2, x_205); +lean_ctor_set(x_218, 3, x_206); +lean_ctor_set(x_218, 4, x_207); +x_219 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_219, 0, x_212); +lean_ctor_set(x_219, 1, x_216); +x_220 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_220, 0, x_219); +x_11 = x_220; +x_12 = x_218; +goto block_184; +} +else +{ +lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; +lean_dec(x_212); +x_221 = lean_ctor_get(x_215, 0); +lean_inc(x_221); +x_222 = lean_ctor_get(x_215, 1); lean_inc(x_222); -lean_dec(x_221); -x_40 = x_222; -goto block_211; +lean_dec(x_215); +x_223 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_223, 0, x_222); +lean_ctor_set(x_223, 1, x_204); +lean_ctor_set(x_223, 2, x_205); +lean_ctor_set(x_223, 3, x_206); +lean_ctor_set(x_223, 4, x_207); +x_224 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_224, 0, x_221); +x_11 = x_224; +x_12 = x_223; +goto block_184; +} +} +} +block_257: +{ +if (x_226 == 0) +{ +x_185 = x_227; +goto block_225; } else { -lean_object* x_223; lean_object* x_224; -lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_223 = lean_ctor_get(x_216, 0); -lean_inc(x_223); -x_224 = lean_ctor_get(x_216, 1); -lean_inc(x_224); -lean_dec(x_216); -lean_ctor_set(x_213, 0, x_224); -x_11 = x_223; -x_12 = x_213; -goto block_39; -} -} -else +uint8_t x_228; +x_228 = !lean_is_exclusive(x_227); +if (x_228 == 0) { -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_225 = lean_ctor_get(x_213, 0); -x_226 = lean_ctor_get(x_213, 1); -x_227 = lean_ctor_get(x_213, 2); -x_228 = lean_ctor_get(x_213, 3); -x_229 = lean_ctor_get(x_213, 4); -lean_inc(x_229); -lean_inc(x_228); -lean_inc(x_227); -lean_inc(x_226); -lean_inc(x_225); -lean_dec(x_213); +lean_object* x_229; lean_object* x_230; +x_229 = lean_ctor_get(x_227, 0); lean_inc(x_2); lean_inc(x_6); -x_230 = l_Lean_Meta_inferType(x_6, x_2, x_225); +x_230 = l_Lean_Meta_inferType(x_6, x_2, x_229); if (lean_obj_tag(x_230) == 0) { -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_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; x_231 = lean_ctor_get(x_230, 0); lean_inc(x_231); x_232 = lean_ctor_get(x_230, 1); lean_inc(x_232); lean_dec(x_230); -x_233 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_233, 0, x_232); -lean_ctor_set(x_233, 1, x_226); -lean_ctor_set(x_233, 2, x_227); -lean_ctor_set(x_233, 3, x_228); -lean_ctor_set(x_233, 4, x_229); -x_234 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_234, 0, x_231); -x_235 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_236 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_235, x_234, x_2, x_233); -x_237 = lean_ctor_get(x_236, 1); -lean_inc(x_237); -lean_dec(x_236); -x_40 = x_237; -goto block_211; +lean_ctor_set(x_227, 0, x_232); +x_233 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_233, 0, x_231); +x_234 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_235 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_234, x_233, x_2, x_227); +x_236 = lean_ctor_get(x_235, 1); +lean_inc(x_236); +lean_dec(x_235); +x_185 = x_236; +goto block_225; } else { -lean_object* x_238; lean_object* x_239; lean_object* x_240; +lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_dec(x_6); +x_237 = lean_ctor_get(x_230, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_230, 1); +lean_inc(x_238); +lean_dec(x_230); +lean_ctor_set(x_227, 0, x_238); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_11 = x_239; +x_12 = x_227; +goto block_184; +} +} +else +{ +lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_240 = lean_ctor_get(x_227, 0); +x_241 = lean_ctor_get(x_227, 1); +x_242 = lean_ctor_get(x_227, 2); +x_243 = lean_ctor_get(x_227, 3); +x_244 = lean_ctor_get(x_227, 4); +lean_inc(x_244); +lean_inc(x_243); +lean_inc(x_242); +lean_inc(x_241); +lean_inc(x_240); +lean_dec(x_227); +lean_inc(x_2); +lean_inc(x_6); +x_245 = l_Lean_Meta_inferType(x_6, x_2, x_240); +if (lean_obj_tag(x_245) == 0) +{ +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; +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_247); +lean_ctor_set(x_248, 1, x_241); +lean_ctor_set(x_248, 2, x_242); +lean_ctor_set(x_248, 3, x_243); +lean_ctor_set(x_248, 4, x_244); +x_249 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_249, 0, x_246); +x_250 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_251 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_250, x_249, x_2, x_248); +x_252 = lean_ctor_get(x_251, 1); +lean_inc(x_252); +lean_dec(x_251); +x_185 = x_252; +goto block_225; +} +else +{ +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; +lean_dec(x_6); +x_253 = lean_ctor_get(x_245, 0); +lean_inc(x_253); +x_254 = lean_ctor_get(x_245, 1); +lean_inc(x_254); +lean_dec(x_245); +x_255 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_255, 0, x_254); +lean_ctor_set(x_255, 1, x_241); +lean_ctor_set(x_255, 2, x_242); +lean_ctor_set(x_255, 3, x_243); +lean_ctor_set(x_255, 4, x_244); +x_256 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_256, 0, x_253); +x_11 = x_256; +x_12 = x_255; +goto block_184; +} +} +} +} +} +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_336; uint8_t x_361; lean_object* x_362; lean_object* x_382; lean_object* x_383; lean_object* x_384; uint8_t x_385; +x_269 = lean_ctor_get(x_4, 0); +x_270 = lean_ctor_get(x_4, 1); +x_271 = lean_ctor_get(x_4, 2); +x_272 = lean_ctor_get(x_4, 3); +x_273 = lean_ctor_get(x_4, 4); +x_274 = lean_ctor_get(x_4, 5); +lean_inc(x_274); +lean_inc(x_273); +lean_inc(x_272); +lean_inc(x_271); +lean_inc(x_270); +lean_inc(x_269); +lean_dec(x_4); +x_382 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_382, 0, x_269); +lean_ctor_set(x_382, 1, x_5); +lean_ctor_set(x_382, 2, x_271); +lean_ctor_set(x_382, 3, x_272); +lean_ctor_set(x_382, 4, x_273); +lean_ctor_set(x_382, 5, x_274); +lean_ctor_set(x_3, 0, x_382); +x_383 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_3); +x_384 = lean_ctor_get(x_383, 0); +lean_inc(x_384); +x_385 = lean_ctor_get_uint8(x_384, sizeof(void*)*1); +lean_dec(x_384); +if (x_385 == 0) +{ +lean_object* x_386; uint8_t x_387; +x_386 = lean_ctor_get(x_383, 1); +lean_inc(x_386); +lean_dec(x_383); +x_387 = 0; +x_361 = x_387; +x_362 = x_386; +goto block_381; +} +else +{ +lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; uint8_t x_393; +x_388 = lean_ctor_get(x_383, 1); +lean_inc(x_388); +lean_dec(x_383); +x_389 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_390 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_389, x_2, x_388); +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_unbox(x_391); +lean_dec(x_391); +x_361 = x_393; +x_362 = x_392; +goto block_381; +} +block_335: +{ +if (lean_obj_tag(x_275) == 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; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_dec(x_2); lean_dec(x_1); -x_238 = lean_ctor_get(x_230, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_230, 1); -lean_inc(x_239); -lean_dec(x_230); -x_240 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_240, 0, x_239); -lean_ctor_set(x_240, 1, x_226); -lean_ctor_set(x_240, 2, x_227); -lean_ctor_set(x_240, 3, x_228); -lean_ctor_set(x_240, 4, x_229); -x_11 = x_238; -x_12 = x_240; -goto block_39; -} -} -} -} -} -else -{ -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_277; uint8_t x_334; lean_object* x_335; lean_object* x_354; lean_object* x_355; lean_object* x_356; uint8_t x_357; -x_253 = lean_ctor_get(x_4, 0); -x_254 = lean_ctor_get(x_4, 1); -x_255 = lean_ctor_get(x_4, 2); -x_256 = lean_ctor_get(x_4, 3); -x_257 = lean_ctor_get(x_4, 4); -x_258 = lean_ctor_get(x_4, 5); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_inc(x_254); -lean_inc(x_253); -lean_dec(x_4); -x_354 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_354, 0, x_253); -lean_ctor_set(x_354, 1, x_5); -lean_ctor_set(x_354, 2, x_255); -lean_ctor_set(x_354, 3, x_256); -lean_ctor_set(x_354, 4, x_257); -lean_ctor_set(x_354, 5, x_258); -lean_ctor_set(x_3, 0, x_354); -x_355 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_3); -x_356 = lean_ctor_get(x_355, 0); -lean_inc(x_356); -x_357 = lean_ctor_get_uint8(x_356, sizeof(void*)*1); -lean_dec(x_356); -if (x_357 == 0) -{ -lean_object* x_358; uint8_t x_359; -x_358 = lean_ctor_get(x_355, 1); -lean_inc(x_358); -lean_dec(x_355); -x_359 = 0; -x_334 = x_359; -x_335 = x_358; -goto block_353; -} -else -{ -lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; uint8_t x_365; -x_360 = lean_ctor_get(x_355, 1); -lean_inc(x_360); -lean_dec(x_355); -x_361 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_362 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_361, x_2, x_360); -x_363 = lean_ctor_get(x_362, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_362, 1); -lean_inc(x_364); -lean_dec(x_362); -x_365 = lean_unbox(x_363); -lean_dec(x_363); -x_334 = x_365; -x_335 = x_364; -goto block_353; -} -block_276: -{ -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; -x_261 = lean_ctor_get(x_260, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_260, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_260, 2); -lean_inc(x_263); -x_264 = lean_ctor_get(x_260, 3); -lean_inc(x_264); -x_265 = lean_ctor_get(x_260, 4); -lean_inc(x_265); -if (lean_is_exclusive(x_260)) { - lean_ctor_release(x_260, 0); - lean_ctor_release(x_260, 1); - lean_ctor_release(x_260, 2); - lean_ctor_release(x_260, 3); - lean_ctor_release(x_260, 4); - x_266 = x_260; -} else { - lean_dec_ref(x_260); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_261, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_261, 2); -lean_inc(x_268); -x_269 = lean_ctor_get(x_261, 3); -lean_inc(x_269); -x_270 = lean_ctor_get(x_261, 4); -lean_inc(x_270); -x_271 = lean_ctor_get(x_261, 5); -lean_inc(x_271); -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_272 = x_261; -} else { - lean_dec_ref(x_261); - x_272 = lean_box(0); -} -if (lean_is_scalar(x_272)) { - x_273 = lean_alloc_ctor(0, 6, 0); -} else { - x_273 = x_272; -} -lean_ctor_set(x_273, 0, x_267); -lean_ctor_set(x_273, 1, x_254); -lean_ctor_set(x_273, 2, x_268); -lean_ctor_set(x_273, 3, x_269); -lean_ctor_set(x_273, 4, x_270); -lean_ctor_set(x_273, 5, x_271); -if (lean_is_scalar(x_266)) { - x_274 = lean_alloc_ctor(0, 5, 0); -} else { - x_274 = x_266; -} -lean_ctor_set(x_274, 0, x_273); -lean_ctor_set(x_274, 1, x_262); -lean_ctor_set(x_274, 2, x_263); -lean_ctor_set(x_274, 3, x_264); -lean_ctor_set(x_274, 4, x_265); -x_275 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_275, 0, x_259); -lean_ctor_set(x_275, 1, x_274); -return x_275; -} -block_333: -{ -lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_278 = lean_ctor_get(x_277, 0); +x_277 = lean_ctor_get(x_276, 0); +lean_inc(x_277); +x_278 = lean_ctor_get(x_275, 0); lean_inc(x_278); -x_279 = lean_ctor_get(x_277, 1); +lean_dec(x_275); +x_279 = lean_ctor_get(x_276, 1); lean_inc(x_279); -x_280 = lean_ctor_get(x_277, 2); +x_280 = lean_ctor_get(x_276, 2); lean_inc(x_280); -x_281 = lean_ctor_get(x_277, 3); +x_281 = lean_ctor_get(x_276, 3); lean_inc(x_281); -x_282 = lean_ctor_get(x_277, 4); +x_282 = lean_ctor_get(x_276, 4); lean_inc(x_282); +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); + lean_ctor_release(x_276, 4); + x_283 = x_276; +} else { + lean_dec_ref(x_276); + x_283 = lean_box(0); +} +x_284 = lean_ctor_get(x_277, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_277, 2); +lean_inc(x_285); +x_286 = lean_ctor_get(x_277, 3); +lean_inc(x_286); +x_287 = lean_ctor_get(x_277, 4); +lean_inc(x_287); +x_288 = lean_ctor_get(x_277, 5); +lean_inc(x_288); 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); lean_ctor_release(x_277, 4); - x_283 = x_277; + lean_ctor_release(x_277, 5); + x_289 = x_277; } else { lean_dec_ref(x_277); - x_283 = lean_box(0); + x_289 = lean_box(0); } -x_284 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_278); -x_285 = lean_ctor_get(x_284, 0); -lean_inc(x_285); -x_286 = lean_ctor_get(x_284, 1); -lean_inc(x_286); -lean_dec(x_284); -x_287 = l_Lean_Meta_abstractMVars(x_285, x_2, x_286); -x_288 = lean_ctor_get(x_287, 0); -lean_inc(x_288); -x_289 = lean_ctor_get(x_287, 1); -lean_inc(x_289); -lean_dec(x_287); -x_290 = lean_ctor_get(x_288, 2); -lean_inc(x_290); -lean_inc(x_2); -x_291 = l_Lean_Meta_inferType(x_290, x_2, x_289); -if (lean_obj_tag(x_291) == 0) +if (lean_is_scalar(x_289)) { + x_290 = lean_alloc_ctor(0, 6, 0); +} else { + x_290 = x_289; +} +lean_ctor_set(x_290, 0, x_284); +lean_ctor_set(x_290, 1, x_270); +lean_ctor_set(x_290, 2, x_285); +lean_ctor_set(x_290, 3, x_286); +lean_ctor_set(x_290, 4, x_287); +lean_ctor_set(x_290, 5, x_288); +if (lean_is_scalar(x_283)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_283; +} +lean_ctor_set(x_291, 0, x_290); +lean_ctor_set(x_291, 1, x_279); +lean_ctor_set(x_291, 2, x_280); +lean_ctor_set(x_291, 3, x_281); +lean_ctor_set(x_291, 4, x_282); +x_292 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_292, 0, x_278); +lean_ctor_set(x_292, 1, x_291); +return x_292; +} +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; lean_object* x_304; -x_292 = lean_ctor_get(x_291, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_291, 1); +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; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_293 = lean_ctor_get(x_276, 0); lean_inc(x_293); -lean_dec(x_291); -lean_inc(x_292); -lean_inc(x_288); -x_294 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_294, 0, x_288); -lean_ctor_set(x_294, 1, x_292); -x_295 = lean_ctor_get(x_293, 0); +x_294 = lean_ctor_get(x_275, 0); +lean_inc(x_294); +lean_dec(x_275); +x_295 = lean_ctor_get(x_276, 1); lean_inc(x_295); -x_296 = lean_ctor_get(x_293, 2); +x_296 = lean_ctor_get(x_276, 2); lean_inc(x_296); -x_297 = lean_ctor_get(x_293, 3); +x_297 = lean_ctor_get(x_276, 3); lean_inc(x_297); -x_298 = lean_ctor_get(x_293, 4); +x_298 = lean_ctor_get(x_276, 4); lean_inc(x_298); -x_299 = lean_ctor_get(x_293, 5); -lean_inc(x_299); +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); + lean_ctor_release(x_276, 4); + x_299 = x_276; +} else { + lean_dec_ref(x_276); + x_299 = lean_box(0); +} +x_300 = lean_ctor_get(x_293, 0); +lean_inc(x_300); +x_301 = lean_ctor_get(x_293, 2); +lean_inc(x_301); +x_302 = lean_ctor_get(x_293, 3); +lean_inc(x_302); +x_303 = lean_ctor_get(x_293, 4); +lean_inc(x_303); +x_304 = lean_ctor_get(x_293, 5); +lean_inc(x_304); if (lean_is_exclusive(x_293)) { lean_ctor_release(x_293, 0); lean_ctor_release(x_293, 1); @@ -13690,308 +14700,373 @@ if (lean_is_exclusive(x_293)) { lean_ctor_release(x_293, 3); lean_ctor_release(x_293, 4); lean_ctor_release(x_293, 5); - x_300 = x_293; + x_305 = x_293; } else { lean_dec_ref(x_293); - x_300 = lean_box(0); + x_305 = lean_box(0); } -if (lean_is_scalar(x_300)) { - x_301 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 6, 0); } else { - x_301 = x_300; + x_306 = x_305; } -lean_ctor_set(x_301, 0, x_295); -lean_ctor_set(x_301, 1, x_254); -lean_ctor_set(x_301, 2, x_296); -lean_ctor_set(x_301, 3, x_297); -lean_ctor_set(x_301, 4, x_298); -lean_ctor_set(x_301, 5, x_299); -if (lean_is_scalar(x_283)) { - x_302 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_306, 0, x_300); +lean_ctor_set(x_306, 1, x_270); +lean_ctor_set(x_306, 2, x_301); +lean_ctor_set(x_306, 3, x_302); +lean_ctor_set(x_306, 4, x_303); +lean_ctor_set(x_306, 5, x_304); +if (lean_is_scalar(x_299)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_302 = x_283; + x_307 = x_299; } -lean_ctor_set(x_302, 0, x_301); -lean_ctor_set(x_302, 1, x_279); -lean_ctor_set(x_302, 2, x_280); -lean_ctor_set(x_302, 3, x_281); -lean_ctor_set(x_302, 4, x_282); -x_303 = lean_ctor_get(x_1, 1); -lean_inc(x_303); +lean_ctor_set(x_307, 0, x_306); +lean_ctor_set(x_307, 1, x_295); +lean_ctor_set(x_307, 2, x_296); +lean_ctor_set(x_307, 3, x_297); +lean_ctor_set(x_307, 4, x_298); +x_308 = lean_ctor_get(x_1, 1); +lean_inc(x_308); lean_dec(x_1); lean_inc(x_2); -x_304 = l_Lean_Meta_SynthInstance_getEntry(x_303, x_2, x_302); -if (lean_obj_tag(x_304) == 0) +x_309 = l_Lean_Meta_SynthInstance_getEntry(x_308, x_2, x_307); +if (lean_obj_tag(x_309) == 0) { -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; uint8_t x_311; -x_305 = lean_ctor_get(x_304, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_304, 1); -lean_inc(x_306); -if (lean_is_exclusive(x_304)) { - lean_ctor_release(x_304, 0); - lean_ctor_release(x_304, 1); - x_307 = x_304; +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; +x_310 = lean_ctor_get(x_309, 0); +lean_inc(x_310); +x_311 = lean_ctor_get(x_309, 1); +lean_inc(x_311); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_312 = x_309; } else { - lean_dec_ref(x_304); - x_307 = lean_box(0); + lean_dec_ref(x_309); + x_312 = lean_box(0); } -x_308 = lean_ctor_get(x_305, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_305, 1); -lean_inc(x_309); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - x_310 = x_305; -} else { - lean_dec_ref(x_305); - x_310 = lean_box(0); -} -x_311 = l_Lean_Meta_SynthInstance_isNewAnswer(x_309, x_294); -if (x_311 == 0) -{ -lean_object* x_312; lean_object* x_313; -lean_dec(x_310); -lean_dec(x_309); -lean_dec(x_308); -lean_dec(x_303); -lean_dec(x_294); -lean_dec(x_292); -lean_dec(x_288); -lean_dec(x_2); -x_312 = lean_box(0); -if (lean_is_scalar(x_307)) { - x_313 = lean_alloc_ctor(0, 2, 0); -} else { - x_313 = x_307; -} -lean_ctor_set(x_313, 0, x_312); -lean_ctor_set(x_313, 1, x_306); -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_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -lean_dec(x_307); -x_314 = lean_array_push(x_309, x_294); -lean_inc(x_308); -if (lean_is_scalar(x_310)) { - x_315 = lean_alloc_ctor(0, 2, 0); -} else { +x_313 = lean_ctor_get(x_310, 0); +lean_inc(x_313); +x_314 = lean_ctor_get(x_310, 1); +lean_inc(x_314); +if (lean_is_exclusive(x_310)) { + lean_ctor_release(x_310, 0); + lean_ctor_release(x_310, 1); x_315 = x_310; -} -lean_ctor_set(x_315, 0, x_308); -lean_ctor_set(x_315, 1, x_314); -x_316 = lean_ctor_get(x_306, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_306, 1); -lean_inc(x_317); -x_318 = lean_ctor_get(x_306, 2); -lean_inc(x_318); -x_319 = lean_ctor_get(x_306, 3); -lean_inc(x_319); -x_320 = lean_ctor_get(x_306, 4); -lean_inc(x_320); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - lean_ctor_release(x_306, 3); - lean_ctor_release(x_306, 4); - x_321 = x_306; } else { - lean_dec_ref(x_306); - x_321 = lean_box(0); + lean_dec_ref(x_310); + x_315 = lean_box(0); } -x_322 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_320, x_303, x_315); -if (lean_is_scalar(x_321)) { - x_323 = lean_alloc_ctor(0, 5, 0); -} else { - x_323 = x_321; -} -lean_ctor_set(x_323, 0, x_316); -lean_ctor_set(x_323, 1, x_317); -lean_ctor_set(x_323, 2, x_318); -lean_ctor_set(x_323, 3, x_319); -lean_ctor_set(x_323, 4, x_322); -x_324 = lean_unsigned_to_nat(0u); -x_325 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_288, x_292, x_308, x_324, x_2, x_323); +x_316 = l_Lean_Meta_SynthInstance_isNewAnswer(x_314, x_294); +if (x_316 == 0) +{ +lean_object* x_317; lean_object* x_318; +lean_dec(x_315); +lean_dec(x_314); +lean_dec(x_313); lean_dec(x_308); -return x_325; -} -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -lean_dec(x_303); lean_dec(x_294); -lean_dec(x_292); -lean_dec(x_288); lean_dec(x_2); -x_326 = lean_ctor_get(x_304, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_304, 1); -lean_inc(x_327); -if (lean_is_exclusive(x_304)) { - lean_ctor_release(x_304, 0); - lean_ctor_release(x_304, 1); - x_328 = x_304; +x_317 = lean_box(0); +if (lean_is_scalar(x_312)) { + x_318 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_304); - x_328 = lean_box(0); + x_318 = x_312; } -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_318, 0, x_317); +lean_ctor_set(x_318, 1, x_311); +return x_318; +} +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; lean_object* x_328; lean_object* x_329; lean_object* x_330; +lean_dec(x_312); +lean_inc(x_294); +x_319 = lean_array_push(x_314, x_294); +lean_inc(x_313); +if (lean_is_scalar(x_315)) { + x_320 = lean_alloc_ctor(0, 2, 0); } else { - x_329 = x_328; + x_320 = x_315; } -lean_ctor_set(x_329, 0, x_326); -lean_ctor_set(x_329, 1, x_327); -return x_329; +lean_ctor_set(x_320, 0, x_313); +lean_ctor_set(x_320, 1, x_319); +x_321 = lean_ctor_get(x_311, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_311, 1); +lean_inc(x_322); +x_323 = lean_ctor_get(x_311, 2); +lean_inc(x_323); +x_324 = lean_ctor_get(x_311, 3); +lean_inc(x_324); +x_325 = lean_ctor_get(x_311, 4); +lean_inc(x_325); +if (lean_is_exclusive(x_311)) { + lean_ctor_release(x_311, 0); + lean_ctor_release(x_311, 1); + lean_ctor_release(x_311, 2); + lean_ctor_release(x_311, 3); + lean_ctor_release(x_311, 4); + x_326 = x_311; +} else { + lean_dec_ref(x_311); + x_326 = lean_box(0); +} +x_327 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_325, x_308, x_320); +if (lean_is_scalar(x_326)) { + x_328 = lean_alloc_ctor(0, 5, 0); +} else { + x_328 = x_326; +} +lean_ctor_set(x_328, 0, x_321); +lean_ctor_set(x_328, 1, x_322); +lean_ctor_set(x_328, 2, x_323); +lean_ctor_set(x_328, 3, x_324); +lean_ctor_set(x_328, 4, x_327); +x_329 = lean_unsigned_to_nat(0u); +x_330 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_294, x_313, x_329, x_2, x_328); +lean_dec(x_313); +return x_330; } } else { -lean_object* x_330; lean_object* x_331; lean_object* x_332; -lean_dec(x_288); +lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; +lean_dec(x_308); +lean_dec(x_294); lean_dec(x_2); -lean_dec(x_1); -x_330 = lean_ctor_get(x_291, 0); -lean_inc(x_330); -x_331 = lean_ctor_get(x_291, 1); +x_331 = lean_ctor_get(x_309, 0); lean_inc(x_331); -lean_dec(x_291); -if (lean_is_scalar(x_283)) { - x_332 = lean_alloc_ctor(0, 5, 0); +x_332 = lean_ctor_get(x_309, 1); +lean_inc(x_332); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_333 = x_309; } else { - x_332 = x_283; + lean_dec_ref(x_309); + x_333 = lean_box(0); } -lean_ctor_set(x_332, 0, x_331); -lean_ctor_set(x_332, 1, x_279); -lean_ctor_set(x_332, 2, x_280); -lean_ctor_set(x_332, 3, x_281); -lean_ctor_set(x_332, 4, x_282); -x_259 = x_330; -x_260 = x_332; -goto block_276; +if (lean_is_scalar(x_333)) { + x_334 = lean_alloc_ctor(1, 2, 0); +} else { + x_334 = x_333; +} +lean_ctor_set(x_334, 0, x_331); +lean_ctor_set(x_334, 1, x_332); +return x_334; } } -block_353: +} +block_360: { -if (x_334 == 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; +x_337 = lean_ctor_get(x_336, 0); +lean_inc(x_337); +x_338 = lean_ctor_get(x_336, 1); +lean_inc(x_338); +x_339 = lean_ctor_get(x_336, 2); +lean_inc(x_339); +x_340 = lean_ctor_get(x_336, 3); +lean_inc(x_340); +x_341 = lean_ctor_get(x_336, 4); +lean_inc(x_341); +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); + x_342 = x_336; +} else { + lean_dec_ref(x_336); + x_342 = lean_box(0); +} +x_343 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_337); +x_344 = lean_ctor_get(x_343, 0); +lean_inc(x_344); +x_345 = lean_ctor_get(x_343, 1); +lean_inc(x_345); +lean_dec(x_343); +x_346 = l_Lean_Meta_abstractMVars(x_344, x_2, x_345); +x_347 = lean_ctor_get(x_346, 0); +lean_inc(x_347); +x_348 = lean_ctor_get(x_346, 1); +lean_inc(x_348); +lean_dec(x_346); +x_349 = lean_ctor_get(x_347, 2); +lean_inc(x_349); +lean_inc(x_2); +x_350 = l_Lean_Meta_inferType(x_349, x_2, x_348); +if (lean_obj_tag(x_350) == 0) { -x_277 = x_335; -goto block_333; +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; +x_351 = lean_ctor_get(x_350, 0); +lean_inc(x_351); +x_352 = lean_ctor_get(x_350, 1); +lean_inc(x_352); +lean_dec(x_350); +if (lean_is_scalar(x_342)) { + x_353 = lean_alloc_ctor(0, 5, 0); +} else { + x_353 = x_342; +} +lean_ctor_set(x_353, 0, x_352); +lean_ctor_set(x_353, 1, x_338); +lean_ctor_set(x_353, 2, x_339); +lean_ctor_set(x_353, 3, x_340); +lean_ctor_set(x_353, 4, x_341); +x_354 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_354, 0, x_347); +lean_ctor_set(x_354, 1, x_351); +x_355 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_355, 0, x_354); +x_275 = x_355; +x_276 = x_353; +goto block_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; -x_336 = lean_ctor_get(x_335, 0); -lean_inc(x_336); -x_337 = lean_ctor_get(x_335, 1); -lean_inc(x_337); -x_338 = lean_ctor_get(x_335, 2); -lean_inc(x_338); -x_339 = lean_ctor_get(x_335, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_335, 4); -lean_inc(x_340); -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); - x_341 = x_335; +lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; +lean_dec(x_347); +x_356 = lean_ctor_get(x_350, 0); +lean_inc(x_356); +x_357 = lean_ctor_get(x_350, 1); +lean_inc(x_357); +lean_dec(x_350); +if (lean_is_scalar(x_342)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_335); - x_341 = lean_box(0); + x_358 = x_342; +} +lean_ctor_set(x_358, 0, x_357); +lean_ctor_set(x_358, 1, x_338); +lean_ctor_set(x_358, 2, x_339); +lean_ctor_set(x_358, 3, x_340); +lean_ctor_set(x_358, 4, x_341); +x_359 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_359, 0, x_356); +x_275 = x_359; +x_276 = x_358; +goto block_335; +} +} +block_381: +{ +if (x_361 == 0) +{ +x_336 = x_362; +goto block_360; +} +else +{ +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_363 = lean_ctor_get(x_362, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_362, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_362, 2); +lean_inc(x_365); +x_366 = lean_ctor_get(x_362, 3); +lean_inc(x_366); +x_367 = lean_ctor_get(x_362, 4); +lean_inc(x_367); +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_368 = x_362; +} else { + lean_dec_ref(x_362); + x_368 = lean_box(0); } lean_inc(x_2); lean_inc(x_6); -x_342 = l_Lean_Meta_inferType(x_6, x_2, x_336); -if (lean_obj_tag(x_342) == 0) +x_369 = l_Lean_Meta_inferType(x_6, x_2, x_363); +if (lean_obj_tag(x_369) == 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; -x_343 = lean_ctor_get(x_342, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_342, 1); -lean_inc(x_344); -lean_dec(x_342); -if (lean_is_scalar(x_341)) { - x_345 = lean_alloc_ctor(0, 5, 0); -} else { - x_345 = x_341; -} -lean_ctor_set(x_345, 0, x_344); -lean_ctor_set(x_345, 1, x_337); -lean_ctor_set(x_345, 2, x_338); -lean_ctor_set(x_345, 3, x_339); -lean_ctor_set(x_345, 4, x_340); -x_346 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_346, 0, x_343); -x_347 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_348 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_347, x_346, x_2, x_345); -x_349 = lean_ctor_get(x_348, 1); -lean_inc(x_349); -lean_dec(x_348); -x_277 = x_349; -goto block_333; -} -else -{ -lean_object* x_350; lean_object* x_351; lean_object* x_352; -lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_350 = lean_ctor_get(x_342, 0); -lean_inc(x_350); -x_351 = lean_ctor_get(x_342, 1); -lean_inc(x_351); -lean_dec(x_342); -if (lean_is_scalar(x_341)) { - x_352 = lean_alloc_ctor(0, 5, 0); -} else { - x_352 = x_341; -} -lean_ctor_set(x_352, 0, x_351); -lean_ctor_set(x_352, 1, x_337); -lean_ctor_set(x_352, 2, x_338); -lean_ctor_set(x_352, 3, x_339); -lean_ctor_set(x_352, 4, x_340); -x_259 = x_350; -x_260 = x_352; -goto block_276; -} -} -} -} -} -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_395; uint8_t x_452; lean_object* x_453; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; uint8_t x_476; -x_366 = lean_ctor_get(x_3, 1); -x_367 = lean_ctor_get(x_3, 2); -x_368 = lean_ctor_get(x_3, 3); -x_369 = lean_ctor_get(x_3, 4); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); -lean_dec(x_3); -x_370 = lean_ctor_get(x_4, 0); +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_370 = lean_ctor_get(x_369, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_4, 1); +x_371 = lean_ctor_get(x_369, 1); lean_inc(x_371); -x_372 = lean_ctor_get(x_4, 2); -lean_inc(x_372); -x_373 = lean_ctor_get(x_4, 3); -lean_inc(x_373); -x_374 = lean_ctor_get(x_4, 4); -lean_inc(x_374); -x_375 = lean_ctor_get(x_4, 5); -lean_inc(x_375); +lean_dec(x_369); +if (lean_is_scalar(x_368)) { + x_372 = lean_alloc_ctor(0, 5, 0); +} else { + x_372 = x_368; +} +lean_ctor_set(x_372, 0, x_371); +lean_ctor_set(x_372, 1, x_364); +lean_ctor_set(x_372, 2, x_365); +lean_ctor_set(x_372, 3, x_366); +lean_ctor_set(x_372, 4, x_367); +x_373 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_373, 0, x_370); +x_374 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_375 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_374, x_373, x_2, x_372); +x_376 = lean_ctor_get(x_375, 1); +lean_inc(x_376); +lean_dec(x_375); +x_336 = x_376; +goto block_360; +} +else +{ +lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; +lean_dec(x_6); +x_377 = lean_ctor_get(x_369, 0); +lean_inc(x_377); +x_378 = lean_ctor_get(x_369, 1); +lean_inc(x_378); +lean_dec(x_369); +if (lean_is_scalar(x_368)) { + x_379 = lean_alloc_ctor(0, 5, 0); +} else { + x_379 = x_368; +} +lean_ctor_set(x_379, 0, x_378); +lean_ctor_set(x_379, 1, x_364); +lean_ctor_set(x_379, 2, x_365); +lean_ctor_set(x_379, 3, x_366); +lean_ctor_set(x_379, 4, x_367); +x_380 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_380, 0, x_377); +x_275 = x_380; +x_276 = x_379; +goto block_335; +} +} +} +} +} +else +{ +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_466; uint8_t x_491; lean_object* x_492; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; uint8_t x_516; +x_394 = lean_ctor_get(x_3, 1); +x_395 = lean_ctor_get(x_3, 2); +x_396 = lean_ctor_get(x_3, 3); +x_397 = lean_ctor_get(x_3, 4); +lean_inc(x_397); +lean_inc(x_396); +lean_inc(x_395); +lean_inc(x_394); +lean_dec(x_3); +x_398 = lean_ctor_get(x_4, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_4, 1); +lean_inc(x_399); +x_400 = lean_ctor_get(x_4, 2); +lean_inc(x_400); +x_401 = lean_ctor_get(x_4, 3); +lean_inc(x_401); +x_402 = lean_ctor_get(x_4, 4); +lean_inc(x_402); +x_403 = lean_ctor_get(x_4, 5); +lean_inc(x_403); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); @@ -13999,491 +15074,537 @@ if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); lean_ctor_release(x_4, 5); - x_376 = x_4; + x_404 = x_4; } else { lean_dec_ref(x_4); - x_376 = lean_box(0); + x_404 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_472 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_404)) { + x_512 = lean_alloc_ctor(0, 6, 0); } else { - x_472 = x_376; + x_512 = x_404; } -lean_ctor_set(x_472, 0, x_370); -lean_ctor_set(x_472, 1, x_5); -lean_ctor_set(x_472, 2, x_372); -lean_ctor_set(x_472, 3, x_373); -lean_ctor_set(x_472, 4, x_374); -lean_ctor_set(x_472, 5, x_375); -x_473 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_473, 0, x_472); -lean_ctor_set(x_473, 1, x_366); -lean_ctor_set(x_473, 2, x_367); -lean_ctor_set(x_473, 3, x_368); -lean_ctor_set(x_473, 4, x_369); -x_474 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_473); -x_475 = lean_ctor_get(x_474, 0); -lean_inc(x_475); -x_476 = lean_ctor_get_uint8(x_475, sizeof(void*)*1); -lean_dec(x_475); -if (x_476 == 0) +lean_ctor_set(x_512, 0, x_398); +lean_ctor_set(x_512, 1, x_5); +lean_ctor_set(x_512, 2, x_400); +lean_ctor_set(x_512, 3, x_401); +lean_ctor_set(x_512, 4, x_402); +lean_ctor_set(x_512, 5, x_403); +x_513 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_513, 0, x_512); +lean_ctor_set(x_513, 1, x_394); +lean_ctor_set(x_513, 2, x_395); +lean_ctor_set(x_513, 3, x_396); +lean_ctor_set(x_513, 4, x_397); +x_514 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_513); +x_515 = lean_ctor_get(x_514, 0); +lean_inc(x_515); +x_516 = lean_ctor_get_uint8(x_515, sizeof(void*)*1); +lean_dec(x_515); +if (x_516 == 0) { -lean_object* x_477; uint8_t x_478; -x_477 = lean_ctor_get(x_474, 1); -lean_inc(x_477); -lean_dec(x_474); -x_478 = 0; -x_452 = x_478; -x_453 = x_477; -goto block_471; +lean_object* x_517; uint8_t x_518; +x_517 = lean_ctor_get(x_514, 1); +lean_inc(x_517); +lean_dec(x_514); +x_518 = 0; +x_491 = x_518; +x_492 = x_517; +goto block_511; } else { -lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; uint8_t x_484; -x_479 = lean_ctor_get(x_474, 1); -lean_inc(x_479); -lean_dec(x_474); -x_480 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_481 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_480, x_2, x_479); -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 = lean_unbox(x_482); -lean_dec(x_482); -x_452 = x_484; -x_453 = x_483; -goto block_471; +lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; uint8_t x_524; +x_519 = lean_ctor_get(x_514, 1); +lean_inc(x_519); +lean_dec(x_514); +x_520 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_521 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_520, x_2, x_519); +x_522 = lean_ctor_get(x_521, 0); +lean_inc(x_522); +x_523 = lean_ctor_get(x_521, 1); +lean_inc(x_523); +lean_dec(x_521); +x_524 = lean_unbox(x_522); +lean_dec(x_522); +x_491 = x_524; +x_492 = x_523; +goto block_511; } -block_394: +block_465: { -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_392; lean_object* x_393; -x_379 = lean_ctor_get(x_378, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_378, 1); -lean_inc(x_380); -x_381 = lean_ctor_get(x_378, 2); -lean_inc(x_381); -x_382 = lean_ctor_get(x_378, 3); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 4); -lean_inc(x_383); -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); - lean_ctor_release(x_378, 4); - x_384 = x_378; -} else { - lean_dec_ref(x_378); - x_384 = lean_box(0); -} -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 3); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 4); -lean_inc(x_388); -x_389 = lean_ctor_get(x_379, 5); -lean_inc(x_389); -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_390 = x_379; -} else { - lean_dec_ref(x_379); - x_390 = lean_box(0); -} -if (lean_is_scalar(x_390)) { - x_391 = lean_alloc_ctor(0, 6, 0); -} else { - x_391 = x_390; -} -lean_ctor_set(x_391, 0, x_385); -lean_ctor_set(x_391, 1, x_371); -lean_ctor_set(x_391, 2, x_386); -lean_ctor_set(x_391, 3, x_387); -lean_ctor_set(x_391, 4, x_388); -lean_ctor_set(x_391, 5, x_389); -if (lean_is_scalar(x_384)) { - x_392 = lean_alloc_ctor(0, 5, 0); -} else { - x_392 = x_384; -} -lean_ctor_set(x_392, 0, x_391); -lean_ctor_set(x_392, 1, x_380); -lean_ctor_set(x_392, 2, x_381); -lean_ctor_set(x_392, 3, x_382); -lean_ctor_set(x_392, 4, x_383); -x_393 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_393, 0, x_377); -lean_ctor_set(x_393, 1, x_392); -return x_393; -} -block_451: +if (lean_obj_tag(x_405) == 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; -x_396 = lean_ctor_get(x_395, 0); -lean_inc(x_396); -x_397 = lean_ctor_get(x_395, 1); -lean_inc(x_397); -x_398 = lean_ctor_get(x_395, 2); -lean_inc(x_398); -x_399 = lean_ctor_get(x_395, 3); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 4); -lean_inc(x_400); -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_401 = x_395; -} else { - lean_dec_ref(x_395); - x_401 = lean_box(0); -} -x_402 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_396); -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 = l_Lean_Meta_abstractMVars(x_403, x_2, x_404); -x_406 = lean_ctor_get(x_405, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_405, 1); -lean_inc(x_407); -lean_dec(x_405); -x_408 = lean_ctor_get(x_406, 2); -lean_inc(x_408); -lean_inc(x_2); -x_409 = l_Lean_Meta_inferType(x_408, x_2, x_407); -if (lean_obj_tag(x_409) == 0) -{ -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_410 = lean_ctor_get(x_409, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_409, 1); -lean_inc(x_411); -lean_dec(x_409); -lean_inc(x_410); -lean_inc(x_406); -x_412 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_412, 0, x_406); -lean_ctor_set(x_412, 1, x_410); -x_413 = lean_ctor_get(x_411, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_411, 2); -lean_inc(x_414); -x_415 = lean_ctor_get(x_411, 3); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 4); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 5); -lean_inc(x_417); -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); - lean_ctor_release(x_411, 5); - x_418 = x_411; -} else { - lean_dec_ref(x_411); - x_418 = lean_box(0); -} -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 6, 0); -} else { - x_419 = x_418; -} -lean_ctor_set(x_419, 0, x_413); -lean_ctor_set(x_419, 1, x_371); -lean_ctor_set(x_419, 2, x_414); -lean_ctor_set(x_419, 3, x_415); -lean_ctor_set(x_419, 4, x_416); -lean_ctor_set(x_419, 5, x_417); -if (lean_is_scalar(x_401)) { - x_420 = lean_alloc_ctor(0, 5, 0); -} else { - x_420 = x_401; -} -lean_ctor_set(x_420, 0, x_419); -lean_ctor_set(x_420, 1, x_397); -lean_ctor_set(x_420, 2, x_398); -lean_ctor_set(x_420, 3, x_399); -lean_ctor_set(x_420, 4, x_400); -x_421 = lean_ctor_get(x_1, 1); -lean_inc(x_421); +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; lean_object* x_422; +lean_dec(x_2); lean_dec(x_1); -lean_inc(x_2); -x_422 = l_Lean_Meta_SynthInstance_getEntry(x_421, x_2, x_420); -if (lean_obj_tag(x_422) == 0) -{ -lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; uint8_t x_429; -x_423 = lean_ctor_get(x_422, 0); -lean_inc(x_423); -x_424 = lean_ctor_get(x_422, 1); -lean_inc(x_424); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_425 = x_422; +x_407 = lean_ctor_get(x_406, 0); +lean_inc(x_407); +x_408 = lean_ctor_get(x_405, 0); +lean_inc(x_408); +lean_dec(x_405); +x_409 = lean_ctor_get(x_406, 1); +lean_inc(x_409); +x_410 = lean_ctor_get(x_406, 2); +lean_inc(x_410); +x_411 = lean_ctor_get(x_406, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_406, 4); +lean_inc(x_412); +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_413 = x_406; } else { - lean_dec_ref(x_422); - x_425 = lean_box(0); + lean_dec_ref(x_406); + x_413 = lean_box(0); } -x_426 = lean_ctor_get(x_423, 0); +x_414 = lean_ctor_get(x_407, 0); +lean_inc(x_414); +x_415 = lean_ctor_get(x_407, 2); +lean_inc(x_415); +x_416 = lean_ctor_get(x_407, 3); +lean_inc(x_416); +x_417 = lean_ctor_get(x_407, 4); +lean_inc(x_417); +x_418 = lean_ctor_get(x_407, 5); +lean_inc(x_418); +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); + lean_ctor_release(x_407, 4); + lean_ctor_release(x_407, 5); + x_419 = x_407; +} else { + lean_dec_ref(x_407); + x_419 = lean_box(0); +} +if (lean_is_scalar(x_419)) { + x_420 = lean_alloc_ctor(0, 6, 0); +} else { + x_420 = x_419; +} +lean_ctor_set(x_420, 0, x_414); +lean_ctor_set(x_420, 1, x_399); +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_is_scalar(x_413)) { + x_421 = lean_alloc_ctor(0, 5, 0); +} else { + x_421 = x_413; +} +lean_ctor_set(x_421, 0, x_420); +lean_ctor_set(x_421, 1, x_409); +lean_ctor_set(x_421, 2, x_410); +lean_ctor_set(x_421, 3, x_411); +lean_ctor_set(x_421, 4, x_412); +x_422 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_422, 0, x_408); +lean_ctor_set(x_422, 1, x_421); +return x_422; +} +else +{ +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; lean_object* x_439; +x_423 = lean_ctor_get(x_406, 0); +lean_inc(x_423); +x_424 = lean_ctor_get(x_405, 0); +lean_inc(x_424); +lean_dec(x_405); +x_425 = lean_ctor_get(x_406, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_406, 2); lean_inc(x_426); -x_427 = lean_ctor_get(x_423, 1); +x_427 = lean_ctor_get(x_406, 3); lean_inc(x_427); +x_428 = lean_ctor_get(x_406, 4); +lean_inc(x_428); +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_429 = x_406; +} else { + lean_dec_ref(x_406); + x_429 = lean_box(0); +} +x_430 = lean_ctor_get(x_423, 0); +lean_inc(x_430); +x_431 = lean_ctor_get(x_423, 2); +lean_inc(x_431); +x_432 = lean_ctor_get(x_423, 3); +lean_inc(x_432); +x_433 = lean_ctor_get(x_423, 4); +lean_inc(x_433); +x_434 = lean_ctor_get(x_423, 5); +lean_inc(x_434); if (lean_is_exclusive(x_423)) { lean_ctor_release(x_423, 0); lean_ctor_release(x_423, 1); - x_428 = x_423; + lean_ctor_release(x_423, 2); + lean_ctor_release(x_423, 3); + lean_ctor_release(x_423, 4); + lean_ctor_release(x_423, 5); + x_435 = x_423; } else { lean_dec_ref(x_423); - x_428 = lean_box(0); + x_435 = lean_box(0); } -x_429 = l_Lean_Meta_SynthInstance_isNewAnswer(x_427, x_412); -if (x_429 == 0) -{ -lean_object* x_430; lean_object* x_431; -lean_dec(x_428); -lean_dec(x_427); -lean_dec(x_426); -lean_dec(x_421); -lean_dec(x_412); -lean_dec(x_410); -lean_dec(x_406); -lean_dec(x_2); -x_430 = lean_box(0); -if (lean_is_scalar(x_425)) { - x_431 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_435)) { + x_436 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_425; + x_436 = x_435; } -lean_ctor_set(x_431, 0, x_430); -lean_ctor_set(x_431, 1, x_424); -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_dec(x_425); -x_432 = lean_array_push(x_427, x_412); -lean_inc(x_426); -if (lean_is_scalar(x_428)) { - x_433 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_436, 0, x_430); +lean_ctor_set(x_436, 1, x_399); +lean_ctor_set(x_436, 2, x_431); +lean_ctor_set(x_436, 3, x_432); +lean_ctor_set(x_436, 4, x_433); +lean_ctor_set(x_436, 5, x_434); +if (lean_is_scalar(x_429)) { + x_437 = lean_alloc_ctor(0, 5, 0); } else { - x_433 = x_428; + x_437 = x_429; } -lean_ctor_set(x_433, 0, x_426); -lean_ctor_set(x_433, 1, x_432); -x_434 = lean_ctor_get(x_424, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_424, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_424, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_424, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_424, 4); +lean_ctor_set(x_437, 0, x_436); +lean_ctor_set(x_437, 1, x_425); +lean_ctor_set(x_437, 2, x_426); +lean_ctor_set(x_437, 3, x_427); +lean_ctor_set(x_437, 4, x_428); +x_438 = lean_ctor_get(x_1, 1); lean_inc(x_438); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - lean_ctor_release(x_424, 2); - lean_ctor_release(x_424, 3); - lean_ctor_release(x_424, 4); - x_439 = x_424; -} else { - lean_dec_ref(x_424); - x_439 = lean_box(0); -} -x_440 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_438, x_421, x_433); -if (lean_is_scalar(x_439)) { - x_441 = lean_alloc_ctor(0, 5, 0); -} else { - x_441 = x_439; -} -lean_ctor_set(x_441, 0, x_434); -lean_ctor_set(x_441, 1, x_435); -lean_ctor_set(x_441, 2, x_436); -lean_ctor_set(x_441, 3, x_437); -lean_ctor_set(x_441, 4, x_440); -x_442 = lean_unsigned_to_nat(0u); -x_443 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_406, x_410, x_426, x_442, x_2, x_441); -lean_dec(x_426); -return x_443; -} -} -else -{ -lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; -lean_dec(x_421); -lean_dec(x_412); -lean_dec(x_410); -lean_dec(x_406); -lean_dec(x_2); -x_444 = lean_ctor_get(x_422, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_422, 1); -lean_inc(x_445); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_446 = x_422; -} else { - lean_dec_ref(x_422); - x_446 = lean_box(0); -} -if (lean_is_scalar(x_446)) { - x_447 = lean_alloc_ctor(1, 2, 0); -} else { - x_447 = x_446; -} -lean_ctor_set(x_447, 0, x_444); -lean_ctor_set(x_447, 1, x_445); -return x_447; -} -} -else -{ -lean_object* x_448; lean_object* x_449; lean_object* x_450; -lean_dec(x_406); -lean_dec(x_2); lean_dec(x_1); -x_448 = lean_ctor_get(x_409, 0); -lean_inc(x_448); -x_449 = lean_ctor_get(x_409, 1); -lean_inc(x_449); -lean_dec(x_409); -if (lean_is_scalar(x_401)) { - x_450 = lean_alloc_ctor(0, 5, 0); +lean_inc(x_2); +x_439 = l_Lean_Meta_SynthInstance_getEntry(x_438, x_2, x_437); +if (lean_obj_tag(x_439) == 0) +{ +lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; uint8_t x_446; +x_440 = lean_ctor_get(x_439, 0); +lean_inc(x_440); +x_441 = lean_ctor_get(x_439, 1); +lean_inc(x_441); +if (lean_is_exclusive(x_439)) { + lean_ctor_release(x_439, 0); + lean_ctor_release(x_439, 1); + x_442 = x_439; } else { - x_450 = x_401; + lean_dec_ref(x_439); + x_442 = lean_box(0); } -lean_ctor_set(x_450, 0, x_449); -lean_ctor_set(x_450, 1, x_397); -lean_ctor_set(x_450, 2, x_398); -lean_ctor_set(x_450, 3, x_399); -lean_ctor_set(x_450, 4, x_400); -x_377 = x_448; -x_378 = x_450; -goto block_394; +x_443 = lean_ctor_get(x_440, 0); +lean_inc(x_443); +x_444 = lean_ctor_get(x_440, 1); +lean_inc(x_444); +if (lean_is_exclusive(x_440)) { + lean_ctor_release(x_440, 0); + lean_ctor_release(x_440, 1); + x_445 = x_440; +} else { + lean_dec_ref(x_440); + x_445 = lean_box(0); } -} -block_471: +x_446 = l_Lean_Meta_SynthInstance_isNewAnswer(x_444, x_424); +if (x_446 == 0) { -if (x_452 == 0) -{ -x_395 = x_453; -goto block_451; +lean_object* x_447; lean_object* x_448; +lean_dec(x_445); +lean_dec(x_444); +lean_dec(x_443); +lean_dec(x_438); +lean_dec(x_424); +lean_dec(x_2); +x_447 = lean_box(0); +if (lean_is_scalar(x_442)) { + x_448 = lean_alloc_ctor(0, 2, 0); +} else { + x_448 = x_442; +} +lean_ctor_set(x_448, 0, x_447); +lean_ctor_set(x_448, 1, x_441); +return x_448; } else { -lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; -x_454 = lean_ctor_get(x_453, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_453, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_453, 2); -lean_inc(x_456); -x_457 = lean_ctor_get(x_453, 3); -lean_inc(x_457); -x_458 = lean_ctor_get(x_453, 4); -lean_inc(x_458); -if (lean_is_exclusive(x_453)) { - lean_ctor_release(x_453, 0); - lean_ctor_release(x_453, 1); - lean_ctor_release(x_453, 2); - lean_ctor_release(x_453, 3); - lean_ctor_release(x_453, 4); - x_459 = x_453; +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_dec(x_442); +lean_inc(x_424); +x_449 = lean_array_push(x_444, x_424); +lean_inc(x_443); +if (lean_is_scalar(x_445)) { + x_450 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_453); - x_459 = lean_box(0); + x_450 = x_445; +} +lean_ctor_set(x_450, 0, x_443); +lean_ctor_set(x_450, 1, x_449); +x_451 = lean_ctor_get(x_441, 0); +lean_inc(x_451); +x_452 = lean_ctor_get(x_441, 1); +lean_inc(x_452); +x_453 = lean_ctor_get(x_441, 2); +lean_inc(x_453); +x_454 = lean_ctor_get(x_441, 3); +lean_inc(x_454); +x_455 = lean_ctor_get(x_441, 4); +lean_inc(x_455); +if (lean_is_exclusive(x_441)) { + lean_ctor_release(x_441, 0); + lean_ctor_release(x_441, 1); + lean_ctor_release(x_441, 2); + lean_ctor_release(x_441, 3); + lean_ctor_release(x_441, 4); + x_456 = x_441; +} else { + lean_dec_ref(x_441); + x_456 = lean_box(0); +} +x_457 = l_Std_HashMapImp_insert___at_Lean_Meta_SynthInstance_newSubgoal___spec__1(x_455, x_438, x_450); +if (lean_is_scalar(x_456)) { + x_458 = lean_alloc_ctor(0, 5, 0); +} else { + x_458 = x_456; +} +lean_ctor_set(x_458, 0, x_451); +lean_ctor_set(x_458, 1, x_452); +lean_ctor_set(x_458, 2, x_453); +lean_ctor_set(x_458, 3, x_454); +lean_ctor_set(x_458, 4, x_457); +x_459 = lean_unsigned_to_nat(0u); +x_460 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_424, x_443, x_459, x_2, x_458); +lean_dec(x_443); +return x_460; +} +} +else +{ +lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; +lean_dec(x_438); +lean_dec(x_424); +lean_dec(x_2); +x_461 = lean_ctor_get(x_439, 0); +lean_inc(x_461); +x_462 = lean_ctor_get(x_439, 1); +lean_inc(x_462); +if (lean_is_exclusive(x_439)) { + lean_ctor_release(x_439, 0); + lean_ctor_release(x_439, 1); + x_463 = x_439; +} else { + lean_dec_ref(x_439); + x_463 = lean_box(0); +} +if (lean_is_scalar(x_463)) { + x_464 = lean_alloc_ctor(1, 2, 0); +} else { + x_464 = x_463; +} +lean_ctor_set(x_464, 0, x_461); +lean_ctor_set(x_464, 1, x_462); +return x_464; +} +} +} +block_490: +{ +lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; +x_467 = lean_ctor_get(x_466, 0); +lean_inc(x_467); +x_468 = lean_ctor_get(x_466, 1); +lean_inc(x_468); +x_469 = lean_ctor_get(x_466, 2); +lean_inc(x_469); +x_470 = lean_ctor_get(x_466, 3); +lean_inc(x_470); +x_471 = lean_ctor_get(x_466, 4); +lean_inc(x_471); +if (lean_is_exclusive(x_466)) { + lean_ctor_release(x_466, 0); + lean_ctor_release(x_466, 1); + lean_ctor_release(x_466, 2); + lean_ctor_release(x_466, 3); + lean_ctor_release(x_466, 4); + x_472 = x_466; +} else { + lean_dec_ref(x_466); + x_472 = lean_box(0); +} +x_473 = l_Lean_Meta_instantiateMVars(x_6, x_2, x_467); +x_474 = lean_ctor_get(x_473, 0); +lean_inc(x_474); +x_475 = lean_ctor_get(x_473, 1); +lean_inc(x_475); +lean_dec(x_473); +x_476 = l_Lean_Meta_abstractMVars(x_474, x_2, x_475); +x_477 = lean_ctor_get(x_476, 0); +lean_inc(x_477); +x_478 = lean_ctor_get(x_476, 1); +lean_inc(x_478); +lean_dec(x_476); +x_479 = lean_ctor_get(x_477, 2); +lean_inc(x_479); +lean_inc(x_2); +x_480 = l_Lean_Meta_inferType(x_479, x_2, x_478); +if (lean_obj_tag(x_480) == 0) +{ +lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; +x_481 = lean_ctor_get(x_480, 0); +lean_inc(x_481); +x_482 = lean_ctor_get(x_480, 1); +lean_inc(x_482); +lean_dec(x_480); +if (lean_is_scalar(x_472)) { + x_483 = lean_alloc_ctor(0, 5, 0); +} else { + x_483 = x_472; +} +lean_ctor_set(x_483, 0, x_482); +lean_ctor_set(x_483, 1, x_468); +lean_ctor_set(x_483, 2, x_469); +lean_ctor_set(x_483, 3, x_470); +lean_ctor_set(x_483, 4, x_471); +x_484 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_484, 0, x_477); +lean_ctor_set(x_484, 1, x_481); +x_485 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_485, 0, x_484); +x_405 = x_485; +x_406 = x_483; +goto block_465; +} +else +{ +lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; +lean_dec(x_477); +x_486 = lean_ctor_get(x_480, 0); +lean_inc(x_486); +x_487 = lean_ctor_get(x_480, 1); +lean_inc(x_487); +lean_dec(x_480); +if (lean_is_scalar(x_472)) { + x_488 = lean_alloc_ctor(0, 5, 0); +} else { + x_488 = x_472; +} +lean_ctor_set(x_488, 0, x_487); +lean_ctor_set(x_488, 1, x_468); +lean_ctor_set(x_488, 2, x_469); +lean_ctor_set(x_488, 3, x_470); +lean_ctor_set(x_488, 4, x_471); +x_489 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_489, 0, x_486); +x_405 = x_489; +x_406 = x_488; +goto block_465; +} +} +block_511: +{ +if (x_491 == 0) +{ +x_466 = x_492; +goto block_490; +} +else +{ +lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; +x_493 = lean_ctor_get(x_492, 0); +lean_inc(x_493); +x_494 = lean_ctor_get(x_492, 1); +lean_inc(x_494); +x_495 = lean_ctor_get(x_492, 2); +lean_inc(x_495); +x_496 = lean_ctor_get(x_492, 3); +lean_inc(x_496); +x_497 = lean_ctor_get(x_492, 4); +lean_inc(x_497); +if (lean_is_exclusive(x_492)) { + lean_ctor_release(x_492, 0); + lean_ctor_release(x_492, 1); + lean_ctor_release(x_492, 2); + lean_ctor_release(x_492, 3); + lean_ctor_release(x_492, 4); + x_498 = x_492; +} else { + lean_dec_ref(x_492); + x_498 = lean_box(0); } lean_inc(x_2); lean_inc(x_6); -x_460 = l_Lean_Meta_inferType(x_6, x_2, x_454); -if (lean_obj_tag(x_460) == 0) +x_499 = l_Lean_Meta_inferType(x_6, x_2, x_493); +if (lean_obj_tag(x_499) == 0) { -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; -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); -if (lean_is_scalar(x_459)) { - x_463 = lean_alloc_ctor(0, 5, 0); +lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; +x_500 = lean_ctor_get(x_499, 0); +lean_inc(x_500); +x_501 = lean_ctor_get(x_499, 1); +lean_inc(x_501); +lean_dec(x_499); +if (lean_is_scalar(x_498)) { + x_502 = lean_alloc_ctor(0, 5, 0); } else { - x_463 = x_459; + x_502 = x_498; } -lean_ctor_set(x_463, 0, x_462); -lean_ctor_set(x_463, 1, x_455); -lean_ctor_set(x_463, 2, x_456); -lean_ctor_set(x_463, 3, x_457); -lean_ctor_set(x_463, 4, x_458); -x_464 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_464, 0, x_461); -x_465 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; -x_466 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_465, x_464, x_2, x_463); -x_467 = lean_ctor_get(x_466, 1); -lean_inc(x_467); -lean_dec(x_466); -x_395 = x_467; -goto block_451; +lean_ctor_set(x_502, 0, x_501); +lean_ctor_set(x_502, 1, x_494); +lean_ctor_set(x_502, 2, x_495); +lean_ctor_set(x_502, 3, x_496); +lean_ctor_set(x_502, 4, x_497); +x_503 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_503, 0, x_500); +x_504 = l_Lean_Meta_SynthInstance_addAnswer___closed__2; +x_505 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_504, x_503, x_2, x_502); +x_506 = lean_ctor_get(x_505, 1); +lean_inc(x_506); +lean_dec(x_505); +x_466 = x_506; +goto block_490; } else { -lean_object* x_468; lean_object* x_469; lean_object* x_470; +lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_468 = lean_ctor_get(x_460, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_460, 1); -lean_inc(x_469); -lean_dec(x_460); -if (lean_is_scalar(x_459)) { - x_470 = lean_alloc_ctor(0, 5, 0); +x_507 = lean_ctor_get(x_499, 0); +lean_inc(x_507); +x_508 = lean_ctor_get(x_499, 1); +lean_inc(x_508); +lean_dec(x_499); +if (lean_is_scalar(x_498)) { + x_509 = lean_alloc_ctor(0, 5, 0); } else { - x_470 = x_459; + x_509 = x_498; } -lean_ctor_set(x_470, 0, x_469); -lean_ctor_set(x_470, 1, x_455); -lean_ctor_set(x_470, 2, x_456); -lean_ctor_set(x_470, 3, x_457); -lean_ctor_set(x_470, 4, x_458); -x_377 = x_468; -x_378 = x_470; -goto block_394; +lean_ctor_set(x_509, 0, x_508); +lean_ctor_set(x_509, 1, x_494); +lean_ctor_set(x_509, 2, x_495); +lean_ctor_set(x_509, 3, x_496); +lean_ctor_set(x_509, 4, x_497); +x_510 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_510, 0, x_507); +x_405 = x_510; +x_406 = x_509; +goto block_465; } } } } } } -lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_7; -x_7 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -return x_7; +lean_object* x_6; +x_6 = l_Array_forMAux___main___at_Lean_Meta_SynthInstance_addAnswer___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; } } lean_object* l_Array_iterateMAux___main___at_Lean_Meta_SynthInstance_consume___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { @@ -16371,285 +17492,298 @@ x_33 = lean_ctor_get(x_29, 0); x_34 = !lean_is_exclusive(x_33); if (x_34 == 0) { -lean_object* x_35; lean_object* x_36; lean_object* x_64; lean_object* x_65; uint8_t x_93; lean_object* x_94; lean_object* x_142; lean_object* x_143; uint8_t x_144; +lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_92; lean_object* x_93; lean_object* x_150; lean_object* x_151; uint8_t x_152; x_35 = lean_ctor_get(x_33, 1); lean_ctor_set(x_33, 1, x_31); -x_142 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_29); -x_143 = lean_ctor_get(x_142, 0); -lean_inc(x_143); -x_144 = lean_ctor_get_uint8(x_143, sizeof(void*)*1); -lean_dec(x_143); -if (x_144 == 0) -{ -lean_object* x_145; uint8_t x_146; -x_145 = lean_ctor_get(x_142, 1); -lean_inc(x_145); -lean_dec(x_142); -x_146 = 0; -x_93 = x_146; -x_94 = x_145; -goto block_141; -} -else -{ -lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; uint8_t x_152; -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -lean_dec(x_142); -x_148 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_149 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_148, x_1, x_147); -x_150 = lean_ctor_get(x_149, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_149, 1); +x_150 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_29); +x_151 = lean_ctor_get(x_150, 0); lean_inc(x_151); -lean_dec(x_149); -x_152 = lean_unbox(x_150); +x_152 = lean_ctor_get_uint8(x_151, sizeof(void*)*1); +lean_dec(x_151); +if (x_152 == 0) +{ +lean_object* x_153; uint8_t x_154; +x_153 = lean_ctor_get(x_150, 1); +lean_inc(x_153); lean_dec(x_150); -x_93 = x_152; -x_94 = x_151; -goto block_141; -} -block_63: -{ -uint8_t x_37; -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) -{ -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_36, 0); -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) -{ -lean_object* x_40; lean_object* x_41; -x_40 = lean_ctor_get(x_38, 1); -lean_dec(x_40); -lean_ctor_set(x_38, 1, x_35); -x_41 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_36); -return x_41; +x_154 = 0; +x_92 = x_154; +x_93 = x_153; +goto block_149; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_42 = lean_ctor_get(x_38, 0); -x_43 = lean_ctor_get(x_38, 2); -x_44 = lean_ctor_get(x_38, 3); -x_45 = lean_ctor_get(x_38, 4); -x_46 = lean_ctor_get(x_38, 5); +lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; uint8_t x_160; +x_155 = lean_ctor_get(x_150, 1); +lean_inc(x_155); +lean_dec(x_150); +x_156 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_157 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_156, x_1, x_155); +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_unbox(x_158); +lean_dec(x_158); +x_92 = x_160; +x_93 = x_159; +goto block_149; +} +block_91: +{ +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_38; lean_object* x_39; uint8_t x_40; +lean_dec(x_5); +lean_dec(x_1); +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_36, 0); +lean_inc(x_39); +lean_dec(x_36); +x_40 = !lean_is_exclusive(x_37); +if (x_40 == 0) +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_37, 0); +lean_dec(x_41); +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, 1); +lean_dec(x_43); +lean_ctor_set(x_38, 1, x_35); +if (lean_is_scalar(x_30)) { + x_44 = lean_alloc_ctor(1, 2, 0); +} else { + x_44 = x_30; + lean_ctor_set_tag(x_44, 1); +} +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_37); +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; +x_45 = lean_ctor_get(x_38, 0); +x_46 = lean_ctor_get(x_38, 2); +x_47 = lean_ctor_get(x_38, 3); +x_48 = lean_ctor_get(x_38, 4); +x_49 = lean_ctor_get(x_38, 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_inc(x_43); -lean_inc(x_42); lean_dec(x_38); -x_47 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_47, 0, x_42); -lean_ctor_set(x_47, 1, x_35); -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_47, 5, x_46); -lean_ctor_set(x_36, 0, x_47); -x_48 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_36); -return x_48; +x_50 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_35); +lean_ctor_set(x_50, 2, x_46); +lean_ctor_set(x_50, 3, x_47); +lean_ctor_set(x_50, 4, x_48); +lean_ctor_set(x_50, 5, x_49); +lean_ctor_set(x_37, 0, x_50); +if (lean_is_scalar(x_30)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_30; + lean_ctor_set_tag(x_51, 1); +} +lean_ctor_set(x_51, 0, x_39); +lean_ctor_set(x_51, 1, x_37); +return x_51; } } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_49 = lean_ctor_get(x_36, 0); -x_50 = lean_ctor_get(x_36, 1); -x_51 = lean_ctor_get(x_36, 2); -x_52 = lean_ctor_get(x_36, 3); -x_53 = lean_ctor_get(x_36, 4); +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_37, 1); +x_53 = lean_ctor_get(x_37, 2); +x_54 = lean_ctor_get(x_37, 3); +x_55 = lean_ctor_get(x_37, 4); +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_dec(x_36); -x_54 = lean_ctor_get(x_49, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_49, 2); -lean_inc(x_55); -x_56 = lean_ctor_get(x_49, 3); +lean_dec(x_37); +x_56 = lean_ctor_get(x_38, 0); lean_inc(x_56); -x_57 = lean_ctor_get(x_49, 4); +x_57 = lean_ctor_get(x_38, 2); lean_inc(x_57); -x_58 = lean_ctor_get(x_49, 5); +x_58 = lean_ctor_get(x_38, 3); lean_inc(x_58); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_59 = x_49; +x_59 = lean_ctor_get(x_38, 4); +lean_inc(x_59); +x_60 = lean_ctor_get(x_38, 5); +lean_inc(x_60); +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); + lean_ctor_release(x_38, 5); + x_61 = x_38; } else { - lean_dec_ref(x_49); - x_59 = lean_box(0); + lean_dec_ref(x_38); + x_61 = lean_box(0); } -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(0, 6, 0); } else { - x_60 = x_59; + x_62 = x_61; } -lean_ctor_set(x_60, 0, x_54); -lean_ctor_set(x_60, 1, x_35); -lean_ctor_set(x_60, 2, x_55); -lean_ctor_set(x_60, 3, x_56); -lean_ctor_set(x_60, 4, x_57); -lean_ctor_set(x_60, 5, x_58); -x_61 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_61, 0, x_60); -lean_ctor_set(x_61, 1, x_50); -lean_ctor_set(x_61, 2, x_51); -lean_ctor_set(x_61, 3, x_52); -lean_ctor_set(x_61, 4, x_53); -x_62 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_61); -return x_62; -} -} -block_92: -{ -uint8_t x_66; -x_66 = !lean_is_exclusive(x_65); -if (x_66 == 0) -{ -lean_object* x_67; uint8_t x_68; -x_67 = lean_ctor_get(x_65, 0); -x_68 = !lean_is_exclusive(x_67); -if (x_68 == 0) -{ -lean_object* x_69; lean_object* x_70; -x_69 = lean_ctor_get(x_67, 1); -lean_dec(x_69); -lean_ctor_set(x_67, 1, x_35); +lean_ctor_set(x_62, 0, x_56); +lean_ctor_set(x_62, 1, x_35); +lean_ctor_set(x_62, 2, x_57); +lean_ctor_set(x_62, 3, x_58); +lean_ctor_set(x_62, 4, x_59); +lean_ctor_set(x_62, 5, x_60); +x_63 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_52); +lean_ctor_set(x_63, 2, x_53); +lean_ctor_set(x_63, 3, x_54); +lean_ctor_set(x_63, 4, x_55); if (lean_is_scalar(x_30)) { - x_70 = lean_alloc_ctor(1, 2, 0); + x_64 = lean_alloc_ctor(1, 2, 0); } else { - x_70 = x_30; - lean_ctor_set_tag(x_70, 1); + x_64 = x_30; + lean_ctor_set_tag(x_64, 1); +} +lean_ctor_set(x_64, 0, x_39); +lean_ctor_set(x_64, 1, x_63); +return x_64; } -lean_ctor_set(x_70, 0, x_64); -lean_ctor_set(x_70, 1, x_65); -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_76; lean_object* x_77; -x_71 = lean_ctor_get(x_67, 0); -x_72 = lean_ctor_get(x_67, 2); -x_73 = lean_ctor_get(x_67, 3); -x_74 = lean_ctor_get(x_67, 4); -x_75 = lean_ctor_get(x_67, 5); -lean_inc(x_75); +uint8_t x_65; +lean_dec(x_36); +lean_dec(x_30); +x_65 = !lean_is_exclusive(x_37); +if (x_65 == 0) +{ +lean_object* x_66; uint8_t x_67; +x_66 = lean_ctor_get(x_37, 0); +x_67 = !lean_is_exclusive(x_66); +if (x_67 == 0) +{ +lean_object* x_68; lean_object* x_69; +x_68 = lean_ctor_get(x_66, 1); +lean_dec(x_68); +lean_ctor_set(x_66, 1, x_35); +x_69 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_37); +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; +x_70 = lean_ctor_get(x_66, 0); +x_71 = lean_ctor_get(x_66, 2); +x_72 = lean_ctor_get(x_66, 3); +x_73 = lean_ctor_get(x_66, 4); +x_74 = lean_ctor_get(x_66, 5); lean_inc(x_74); lean_inc(x_73); lean_inc(x_72); lean_inc(x_71); -lean_dec(x_67); -x_76 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_35); -lean_ctor_set(x_76, 2, x_72); -lean_ctor_set(x_76, 3, x_73); -lean_ctor_set(x_76, 4, x_74); -lean_ctor_set(x_76, 5, x_75); -lean_ctor_set(x_65, 0, x_76); -if (lean_is_scalar(x_30)) { - x_77 = lean_alloc_ctor(1, 2, 0); -} else { - x_77 = x_30; - lean_ctor_set_tag(x_77, 1); -} -lean_ctor_set(x_77, 0, x_64); -lean_ctor_set(x_77, 1, x_65); -return x_77; +lean_inc(x_70); +lean_dec(x_66); +x_75 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_75, 0, x_70); +lean_ctor_set(x_75, 1, x_35); +lean_ctor_set(x_75, 2, x_71); +lean_ctor_set(x_75, 3, x_72); +lean_ctor_set(x_75, 4, x_73); +lean_ctor_set(x_75, 5, x_74); +lean_ctor_set(x_37, 0, x_75); +x_76 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_37); +return x_76; } } 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; lean_object* x_90; lean_object* x_91; -x_78 = lean_ctor_get(x_65, 0); -x_79 = lean_ctor_get(x_65, 1); -x_80 = lean_ctor_get(x_65, 2); -x_81 = lean_ctor_get(x_65, 3); -x_82 = lean_ctor_get(x_65, 4); -lean_inc(x_82); +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_77 = lean_ctor_get(x_37, 0); +x_78 = lean_ctor_get(x_37, 1); +x_79 = lean_ctor_get(x_37, 2); +x_80 = lean_ctor_get(x_37, 3); +x_81 = lean_ctor_get(x_37, 4); lean_inc(x_81); lean_inc(x_80); lean_inc(x_79); lean_inc(x_78); -lean_dec(x_65); -x_83 = lean_ctor_get(x_78, 0); +lean_inc(x_77); +lean_dec(x_37); +x_82 = lean_ctor_get(x_77, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_77, 2); lean_inc(x_83); -x_84 = lean_ctor_get(x_78, 2); +x_84 = lean_ctor_get(x_77, 3); lean_inc(x_84); -x_85 = lean_ctor_get(x_78, 3); +x_85 = lean_ctor_get(x_77, 4); lean_inc(x_85); -x_86 = lean_ctor_get(x_78, 4); +x_86 = lean_ctor_get(x_77, 5); lean_inc(x_86); -x_87 = lean_ctor_get(x_78, 5); -lean_inc(x_87); -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); - lean_ctor_release(x_78, 5); - x_88 = x_78; +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_87 = x_77; } else { - lean_dec_ref(x_78); - x_88 = lean_box(0); + lean_dec_ref(x_77); + x_87 = lean_box(0); } -if (lean_is_scalar(x_88)) { - x_89 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_87)) { + x_88 = lean_alloc_ctor(0, 6, 0); } else { - x_89 = x_88; + x_88 = x_87; } -lean_ctor_set(x_89, 0, x_83); -lean_ctor_set(x_89, 1, x_35); -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); -x_90 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_90, 0, x_89); -lean_ctor_set(x_90, 1, x_79); -lean_ctor_set(x_90, 2, x_80); -lean_ctor_set(x_90, 3, x_81); -lean_ctor_set(x_90, 4, x_82); -if (lean_is_scalar(x_30)) { - x_91 = lean_alloc_ctor(1, 2, 0); -} else { - x_91 = x_30; - lean_ctor_set_tag(x_91, 1); -} -lean_ctor_set(x_91, 0, x_64); -lean_ctor_set(x_91, 1, x_90); -return x_91; +lean_ctor_set(x_88, 0, x_82); +lean_ctor_set(x_88, 1, x_35); +lean_ctor_set(x_88, 2, x_83); +lean_ctor_set(x_88, 3, x_84); +lean_ctor_set(x_88, 4, x_85); +lean_ctor_set(x_88, 5, x_86); +x_89 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_89, 0, x_88); +lean_ctor_set(x_89, 1, x_78); +lean_ctor_set(x_89, 2, x_79); +lean_ctor_set(x_89, 3, x_80); +lean_ctor_set(x_89, 4, x_81); +x_90 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_89); +return x_90; } } -block_141: +} +block_149: { -if (x_93 == 0) +if (x_92 == 0) { -lean_dec(x_30); +lean_object* x_94; lean_dec(x_19); lean_dec(x_15); +x_94 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; x_36 = x_94; -goto block_63; +x_37 = x_93; +goto block_91; } else { uint8_t x_95; -x_95 = !lean_is_exclusive(x_94); +x_95 = !lean_is_exclusive(x_93); if (x_95 == 0) { lean_object* x_96; lean_object* x_97; -x_96 = lean_ctor_get(x_94, 0); +x_96 = lean_ctor_get(x_93, 0); lean_inc(x_1); x_97 = l_Lean_Meta_inferType(x_15, x_1, x_96); if (lean_obj_tag(x_97) == 0) @@ -16664,14 +17798,13 @@ lean_inc(x_1); x_100 = l_Lean_Meta_inferType(x_19, x_1, x_99); if (lean_obj_tag(x_100) == 0) { -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_dec(x_30); +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_100, 0); lean_inc(x_101); x_102 = lean_ctor_get(x_100, 1); lean_inc(x_102); lean_dec(x_100); -lean_ctor_set(x_94, 0, x_102); +lean_ctor_set(x_93, 0, x_102); x_103 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_103, 0, x_98); x_104 = l_Lean_Meta_SynthInstance_resume___closed__7; @@ -16684,149 +17817,158 @@ x_107 = lean_alloc_ctor(9, 2, 0); lean_ctor_set(x_107, 0, x_105); lean_ctor_set(x_107, 1, x_106); x_108 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_109 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_108, x_107, x_1, x_94); -x_110 = lean_ctor_get(x_109, 1); +x_109 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_108, x_107, x_1, x_93); +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_109); -x_36 = x_110; -goto block_63; -} -else -{ -lean_object* x_111; lean_object* x_112; -lean_dec(x_98); -lean_dec(x_5); -lean_dec(x_1); -x_111 = lean_ctor_get(x_100, 0); +x_111 = lean_ctor_get(x_109, 1); lean_inc(x_111); -x_112 = lean_ctor_get(x_100, 1); -lean_inc(x_112); -lean_dec(x_100); -lean_ctor_set(x_94, 0, x_112); -x_64 = x_111; -x_65 = x_94; -goto block_92; -} +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_36 = x_112; +x_37 = x_111; +goto block_91; } else { -lean_object* x_113; lean_object* x_114; -lean_dec(x_5); -lean_dec(x_19); -lean_dec(x_1); -x_113 = lean_ctor_get(x_97, 0); +lean_object* x_113; lean_object* x_114; lean_object* x_115; +lean_dec(x_98); +x_113 = lean_ctor_get(x_100, 0); lean_inc(x_113); -x_114 = lean_ctor_get(x_97, 1); +x_114 = lean_ctor_get(x_100, 1); lean_inc(x_114); -lean_dec(x_97); -lean_ctor_set(x_94, 0, x_114); -x_64 = x_113; -x_65 = x_94; -goto block_92; +lean_dec(x_100); +lean_ctor_set(x_93, 0, x_114); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_36 = x_115; +x_37 = x_93; +goto block_91; } } 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; -x_115 = lean_ctor_get(x_94, 0); -x_116 = lean_ctor_get(x_94, 1); -x_117 = lean_ctor_get(x_94, 2); -x_118 = lean_ctor_get(x_94, 3); -x_119 = lean_ctor_get(x_94, 4); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_94); -lean_inc(x_1); -x_120 = l_Lean_Meta_inferType(x_15, x_1, x_115); -if (lean_obj_tag(x_120) == 0) -{ -lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_121 = lean_ctor_get(x_120, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_120, 1); -lean_inc(x_122); -lean_dec(x_120); -lean_inc(x_1); -x_123 = l_Lean_Meta_inferType(x_19, x_1, x_122); -if (lean_obj_tag(x_123) == 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_dec(x_30); -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(0, 5, 0); -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_116); -lean_ctor_set(x_126, 2, x_117); -lean_ctor_set(x_126, 3, x_118); -lean_ctor_set(x_126, 4, x_119); -x_127 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_127, 0, x_121); -x_128 = l_Lean_Meta_SynthInstance_resume___closed__7; -x_129 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_129, 0, x_127); -lean_ctor_set(x_129, 1, x_128); -x_130 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_130, 0, x_124); -x_131 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_131, 0, x_129); -lean_ctor_set(x_131, 1, x_130); -x_132 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_133 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_132, x_131, x_1, x_126); -x_134 = lean_ctor_get(x_133, 1); -lean_inc(x_134); -lean_dec(x_133); -x_36 = x_134; -goto block_63; -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; -lean_dec(x_121); -lean_dec(x_5); -lean_dec(x_1); -x_135 = lean_ctor_get(x_123, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_123, 1); -lean_inc(x_136); -lean_dec(x_123); -x_137 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_137, 0, x_136); -lean_ctor_set(x_137, 1, x_116); -lean_ctor_set(x_137, 2, x_117); -lean_ctor_set(x_137, 3, x_118); -lean_ctor_set(x_137, 4, x_119); -x_64 = x_135; -x_65 = x_137; -goto block_92; -} -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; -lean_dec(x_5); +lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_dec(x_19); -lean_dec(x_1); -x_138 = lean_ctor_get(x_120, 0); +x_116 = lean_ctor_get(x_97, 0); +lean_inc(x_116); +x_117 = lean_ctor_get(x_97, 1); +lean_inc(x_117); +lean_dec(x_97); +lean_ctor_set(x_93, 0, x_117); +x_118 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_36 = x_118; +x_37 = x_93; +goto block_91; +} +} +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_93, 0); +x_120 = lean_ctor_get(x_93, 1); +x_121 = lean_ctor_get(x_93, 2); +x_122 = lean_ctor_get(x_93, 3); +x_123 = lean_ctor_get(x_93, 4); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_inc(x_119); +lean_dec(x_93); +lean_inc(x_1); +x_124 = l_Lean_Meta_inferType(x_15, x_1, x_119); +if (lean_obj_tag(x_124) == 0) +{ +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_124, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_124, 1); +lean_inc(x_126); +lean_dec(x_124); +lean_inc(x_1); +x_127 = l_Lean_Meta_inferType(x_19, x_1, x_126); +if (lean_obj_tag(x_127) == 0) +{ +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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_127, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_127, 1); +lean_inc(x_129); +lean_dec(x_127); +x_130 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_130, 0, x_129); +lean_ctor_set(x_130, 1, x_120); +lean_ctor_set(x_130, 2, x_121); +lean_ctor_set(x_130, 3, x_122); +lean_ctor_set(x_130, 4, x_123); +x_131 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_131, 0, x_125); +x_132 = l_Lean_Meta_SynthInstance_resume___closed__7; +x_133 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_133, 0, x_131); +lean_ctor_set(x_133, 1, x_132); +x_134 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_134, 0, x_128); +x_135 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_135, 0, x_133); +lean_ctor_set(x_135, 1, x_134); +x_136 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_137 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_136, x_135, x_1, x_130); +x_138 = lean_ctor_get(x_137, 0); lean_inc(x_138); -x_139 = lean_ctor_get(x_120, 1); +x_139 = lean_ctor_get(x_137, 1); lean_inc(x_139); -lean_dec(x_120); -x_140 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_140, 0, x_139); -lean_ctor_set(x_140, 1, x_116); -lean_ctor_set(x_140, 2, x_117); -lean_ctor_set(x_140, 3, x_118); -lean_ctor_set(x_140, 4, x_119); -x_64 = x_138; -x_65 = x_140; -goto block_92; +lean_dec(x_137); +x_140 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_140, 0, x_138); +x_36 = x_140; +x_37 = x_139; +goto block_91; +} +else +{ +lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; +lean_dec(x_125); +x_141 = lean_ctor_get(x_127, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_127, 1); +lean_inc(x_142); +lean_dec(x_127); +x_143 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_143, 0, x_142); +lean_ctor_set(x_143, 1, x_120); +lean_ctor_set(x_143, 2, x_121); +lean_ctor_set(x_143, 3, x_122); +lean_ctor_set(x_143, 4, x_123); +x_144 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_144, 0, x_141); +x_36 = x_144; +x_37 = x_143; +goto block_91; +} +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +lean_dec(x_19); +x_145 = lean_ctor_get(x_124, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_124, 1); +lean_inc(x_146); +lean_dec(x_124); +x_147 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_147, 0, x_146); +lean_ctor_set(x_147, 1, x_120); +lean_ctor_set(x_147, 2, x_121); +lean_ctor_set(x_147, 3, x_122); +lean_ctor_set(x_147, 4, x_123); +x_148 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_148, 0, x_145); +x_36 = x_148; +x_37 = x_147; +goto block_91; } } } @@ -16834,344 +17976,360 @@ goto block_92; } else { -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_176; lean_object* x_177; uint8_t x_194; lean_object* x_195; lean_object* x_224; lean_object* x_225; lean_object* x_226; uint8_t x_227; -x_153 = lean_ctor_get(x_33, 0); -x_154 = lean_ctor_get(x_33, 1); -x_155 = lean_ctor_get(x_33, 2); -x_156 = lean_ctor_get(x_33, 3); -x_157 = lean_ctor_get(x_33, 4); -x_158 = lean_ctor_get(x_33, 5); -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_dec(x_33); -x_224 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_224, 0, x_153); -lean_ctor_set(x_224, 1, x_31); -lean_ctor_set(x_224, 2, x_155); -lean_ctor_set(x_224, 3, x_156); -lean_ctor_set(x_224, 4, x_157); -lean_ctor_set(x_224, 5, x_158); -lean_ctor_set(x_29, 0, x_224); -x_225 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_29); -x_226 = lean_ctor_get(x_225, 0); -lean_inc(x_226); -x_227 = lean_ctor_get_uint8(x_226, sizeof(void*)*1); -lean_dec(x_226); -if (x_227 == 0) -{ -lean_object* x_228; uint8_t x_229; -x_228 = lean_ctor_get(x_225, 1); -lean_inc(x_228); -lean_dec(x_225); -x_229 = 0; -x_194 = x_229; -x_195 = x_228; -goto block_223; -} -else -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; uint8_t x_235; -x_230 = lean_ctor_get(x_225, 1); -lean_inc(x_230); -lean_dec(x_225); -x_231 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_232 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_231, x_1, x_230); -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_unbox(x_233); -lean_dec(x_233); -x_194 = x_235; -x_195 = x_234; -goto block_223; -} -block_175: -{ -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; -x_160 = lean_ctor_get(x_159, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_159, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_159, 2); -lean_inc(x_162); -x_163 = lean_ctor_get(x_159, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 4); -lean_inc(x_164); -if (lean_is_exclusive(x_159)) { - lean_ctor_release(x_159, 0); - lean_ctor_release(x_159, 1); - lean_ctor_release(x_159, 2); - lean_ctor_release(x_159, 3); - lean_ctor_release(x_159, 4); - x_165 = x_159; -} else { - lean_dec_ref(x_159); - x_165 = lean_box(0); -} -x_166 = lean_ctor_get(x_160, 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; uint8_t x_201; lean_object* x_202; lean_object* x_236; lean_object* x_237; lean_object* x_238; uint8_t x_239; +x_161 = lean_ctor_get(x_33, 0); +x_162 = lean_ctor_get(x_33, 1); +x_163 = lean_ctor_get(x_33, 2); +x_164 = lean_ctor_get(x_33, 3); +x_165 = lean_ctor_get(x_33, 4); +x_166 = lean_ctor_get(x_33, 5); lean_inc(x_166); -x_167 = lean_ctor_get(x_160, 2); -lean_inc(x_167); -x_168 = lean_ctor_get(x_160, 3); -lean_inc(x_168); -x_169 = lean_ctor_get(x_160, 4); +lean_inc(x_165); +lean_inc(x_164); +lean_inc(x_163); +lean_inc(x_162); +lean_inc(x_161); +lean_dec(x_33); +x_236 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_236, 0, x_161); +lean_ctor_set(x_236, 1, x_31); +lean_ctor_set(x_236, 2, x_163); +lean_ctor_set(x_236, 3, x_164); +lean_ctor_set(x_236, 4, x_165); +lean_ctor_set(x_236, 5, x_166); +lean_ctor_set(x_29, 0, x_236); +x_237 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_29); +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +x_239 = lean_ctor_get_uint8(x_238, sizeof(void*)*1); +lean_dec(x_238); +if (x_239 == 0) +{ +lean_object* x_240; uint8_t x_241; +x_240 = lean_ctor_get(x_237, 1); +lean_inc(x_240); +lean_dec(x_237); +x_241 = 0; +x_201 = x_241; +x_202 = x_240; +goto block_235; +} +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_237, 1); +lean_inc(x_242); +lean_dec(x_237); +x_243 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_244 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_243, x_1, x_242); +x_245 = lean_ctor_get(x_244, 0); +lean_inc(x_245); +x_246 = lean_ctor_get(x_244, 1); +lean_inc(x_246); +lean_dec(x_244); +x_247 = lean_unbox(x_245); +lean_dec(x_245); +x_201 = x_247; +x_202 = x_246; +goto block_235; +} +block_200: +{ +if (lean_obj_tag(x_167) == 0) +{ +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_dec(x_5); +lean_dec(x_1); +x_169 = lean_ctor_get(x_168, 0); lean_inc(x_169); -x_170 = lean_ctor_get(x_160, 5); +x_170 = lean_ctor_get(x_167, 0); lean_inc(x_170); -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_171 = x_160; +lean_dec(x_167); +x_171 = lean_ctor_get(x_168, 1); +lean_inc(x_171); +x_172 = lean_ctor_get(x_168, 2); +lean_inc(x_172); +x_173 = lean_ctor_get(x_168, 3); +lean_inc(x_173); +x_174 = lean_ctor_get(x_168, 4); +lean_inc(x_174); +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); + lean_ctor_release(x_168, 4); + x_175 = x_168; } else { - lean_dec_ref(x_160); - x_171 = lean_box(0); + lean_dec_ref(x_168); + x_175 = lean_box(0); } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 6, 0); -} else { - x_172 = x_171; -} -lean_ctor_set(x_172, 0, x_166); -lean_ctor_set(x_172, 1, x_154); -lean_ctor_set(x_172, 2, x_167); -lean_ctor_set(x_172, 3, x_168); -lean_ctor_set(x_172, 4, x_169); -lean_ctor_set(x_172, 5, x_170); -if (lean_is_scalar(x_165)) { - x_173 = lean_alloc_ctor(0, 5, 0); -} else { - x_173 = x_165; -} -lean_ctor_set(x_173, 0, x_172); -lean_ctor_set(x_173, 1, x_161); -lean_ctor_set(x_173, 2, x_162); -lean_ctor_set(x_173, 3, x_163); -lean_ctor_set(x_173, 4, x_164); -x_174 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_173); -return x_174; -} -block_193: -{ -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_177, 0); +x_176 = lean_ctor_get(x_169, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_169, 2); +lean_inc(x_177); +x_178 = lean_ctor_get(x_169, 3); lean_inc(x_178); -x_179 = lean_ctor_get(x_177, 1); +x_179 = lean_ctor_get(x_169, 4); lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 2); +x_180 = lean_ctor_get(x_169, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_177, 3); -lean_inc(x_181); -x_182 = lean_ctor_get(x_177, 4); -lean_inc(x_182); -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_183 = x_177; +if (lean_is_exclusive(x_169)) { + lean_ctor_release(x_169, 0); + lean_ctor_release(x_169, 1); + lean_ctor_release(x_169, 2); + lean_ctor_release(x_169, 3); + lean_ctor_release(x_169, 4); + lean_ctor_release(x_169, 5); + x_181 = x_169; } else { - lean_dec_ref(x_177); - x_183 = lean_box(0); + lean_dec_ref(x_169); + x_181 = lean_box(0); } -x_184 = lean_ctor_get(x_178, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_178, 3); -lean_inc(x_186); -x_187 = lean_ctor_get(x_178, 4); -lean_inc(x_187); -x_188 = lean_ctor_get(x_178, 5); -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); - lean_ctor_release(x_178, 5); - x_189 = x_178; +if (lean_is_scalar(x_181)) { + x_182 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_178); - x_189 = lean_box(0); + x_182 = x_181; } -if (lean_is_scalar(x_189)) { - x_190 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_182, 0, x_176); +lean_ctor_set(x_182, 1, x_162); +lean_ctor_set(x_182, 2, x_177); +lean_ctor_set(x_182, 3, x_178); +lean_ctor_set(x_182, 4, x_179); +lean_ctor_set(x_182, 5, x_180); +if (lean_is_scalar(x_175)) { + x_183 = lean_alloc_ctor(0, 5, 0); } else { - x_190 = x_189; + x_183 = x_175; } -lean_ctor_set(x_190, 0, x_184); -lean_ctor_set(x_190, 1, x_154); -lean_ctor_set(x_190, 2, x_185); -lean_ctor_set(x_190, 3, x_186); -lean_ctor_set(x_190, 4, x_187); -lean_ctor_set(x_190, 5, x_188); -if (lean_is_scalar(x_183)) { - x_191 = lean_alloc_ctor(0, 5, 0); -} else { - x_191 = x_183; -} -lean_ctor_set(x_191, 0, x_190); -lean_ctor_set(x_191, 1, x_179); -lean_ctor_set(x_191, 2, x_180); -lean_ctor_set(x_191, 3, x_181); -lean_ctor_set(x_191, 4, x_182); +lean_ctor_set(x_183, 0, x_182); +lean_ctor_set(x_183, 1, x_171); +lean_ctor_set(x_183, 2, x_172); +lean_ctor_set(x_183, 3, x_173); +lean_ctor_set(x_183, 4, x_174); if (lean_is_scalar(x_30)) { - x_192 = lean_alloc_ctor(1, 2, 0); + x_184 = lean_alloc_ctor(1, 2, 0); } else { - x_192 = x_30; - lean_ctor_set_tag(x_192, 1); + x_184 = x_30; + lean_ctor_set_tag(x_184, 1); } -lean_ctor_set(x_192, 0, x_176); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_ctor_set(x_184, 0, x_170); +lean_ctor_set(x_184, 1, x_183); +return x_184; } -block_223: -{ -if (x_194 == 0) +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; lean_object* x_197; lean_object* x_198; lean_object* x_199; +lean_dec(x_167); lean_dec(x_30); +x_185 = lean_ctor_get(x_168, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_168, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_168, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_168, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_168, 4); +lean_inc(x_189); +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); + lean_ctor_release(x_168, 4); + x_190 = x_168; +} else { + lean_dec_ref(x_168); + x_190 = lean_box(0); +} +x_191 = lean_ctor_get(x_185, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_185, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_185, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_185, 4); +lean_inc(x_194); +x_195 = lean_ctor_get(x_185, 5); +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); + lean_ctor_release(x_185, 4); + lean_ctor_release(x_185, 5); + 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, 6, 0); +} else { + x_197 = x_196; +} +lean_ctor_set(x_197, 0, x_191); +lean_ctor_set(x_197, 1, x_162); +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_ctor_set(x_197, 5, x_195); +if (lean_is_scalar(x_190)) { + x_198 = lean_alloc_ctor(0, 5, 0); +} else { + x_198 = x_190; +} +lean_ctor_set(x_198, 0, x_197); +lean_ctor_set(x_198, 1, x_186); +lean_ctor_set(x_198, 2, x_187); +lean_ctor_set(x_198, 3, x_188); +lean_ctor_set(x_198, 4, x_189); +x_199 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_198); +return x_199; +} +} +block_235: +{ +if (x_201 == 0) +{ +lean_object* x_203; lean_dec(x_19); lean_dec(x_15); -x_159 = x_195; -goto block_175; +x_203 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_167 = x_203; +x_168 = x_202; +goto block_200; } 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; -x_196 = lean_ctor_get(x_195, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_195, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_195, 2); -lean_inc(x_198); -x_199 = lean_ctor_get(x_195, 3); -lean_inc(x_199); -x_200 = lean_ctor_get(x_195, 4); -lean_inc(x_200); -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_201 = x_195; -} else { - lean_dec_ref(x_195); - x_201 = lean_box(0); -} -lean_inc(x_1); -x_202 = l_Lean_Meta_inferType(x_15, x_1, x_196); -if (lean_obj_tag(x_202) == 0) -{ -lean_object* x_203; lean_object* x_204; lean_object* x_205; -x_203 = lean_ctor_get(x_202, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_202, 1); +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_204 = lean_ctor_get(x_202, 0); lean_inc(x_204); -lean_dec(x_202); -lean_inc(x_1); -x_205 = l_Lean_Meta_inferType(x_19, x_1, x_204); -if (lean_obj_tag(x_205) == 0) -{ -lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; -lean_dec(x_30); -x_206 = lean_ctor_get(x_205, 0); +x_205 = lean_ctor_get(x_202, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_202, 2); lean_inc(x_206); -x_207 = lean_ctor_get(x_205, 1); +x_207 = lean_ctor_get(x_202, 3); lean_inc(x_207); -lean_dec(x_205); -if (lean_is_scalar(x_201)) { - x_208 = lean_alloc_ctor(0, 5, 0); +x_208 = lean_ctor_get(x_202, 4); +lean_inc(x_208); +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); + lean_ctor_release(x_202, 4); + x_209 = x_202; } else { - x_208 = x_201; + lean_dec_ref(x_202); + x_209 = lean_box(0); } -lean_ctor_set(x_208, 0, x_207); -lean_ctor_set(x_208, 1, x_197); -lean_ctor_set(x_208, 2, x_198); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -x_209 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_209, 0, x_203); -x_210 = l_Lean_Meta_SynthInstance_resume___closed__7; -x_211 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_211, 0, x_209); -lean_ctor_set(x_211, 1, x_210); -x_212 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_212, 0, x_206); -x_213 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_213, 0, x_211); -lean_ctor_set(x_213, 1, x_212); -x_214 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_215 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_214, x_213, x_1, x_208); -x_216 = lean_ctor_get(x_215, 1); -lean_inc(x_216); -lean_dec(x_215); -x_159 = x_216; -goto block_175; +lean_inc(x_1); +x_210 = l_Lean_Meta_inferType(x_15, x_1, x_204); +if (lean_obj_tag(x_210) == 0) +{ +lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_211 = lean_ctor_get(x_210, 0); +lean_inc(x_211); +x_212 = lean_ctor_get(x_210, 1); +lean_inc(x_212); +lean_dec(x_210); +lean_inc(x_1); +x_213 = l_Lean_Meta_inferType(x_19, x_1, x_212); +if (lean_obj_tag(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; +x_214 = lean_ctor_get(x_213, 0); +lean_inc(x_214); +x_215 = lean_ctor_get(x_213, 1); +lean_inc(x_215); +lean_dec(x_213); +if (lean_is_scalar(x_209)) { + x_216 = lean_alloc_ctor(0, 5, 0); +} else { + x_216 = x_209; +} +lean_ctor_set(x_216, 0, x_215); +lean_ctor_set(x_216, 1, x_205); +lean_ctor_set(x_216, 2, x_206); +lean_ctor_set(x_216, 3, x_207); +lean_ctor_set(x_216, 4, x_208); +x_217 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_217, 0, x_211); +x_218 = l_Lean_Meta_SynthInstance_resume___closed__7; +x_219 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_219, 0, x_217); +lean_ctor_set(x_219, 1, x_218); +x_220 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_220, 0, x_214); +x_221 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_221, 0, x_219); +lean_ctor_set(x_221, 1, x_220); +x_222 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_223 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_222, x_221, x_1, x_216); +x_224 = lean_ctor_get(x_223, 0); +lean_inc(x_224); +x_225 = lean_ctor_get(x_223, 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_167 = x_226; +x_168 = x_225; +goto block_200; } else { -lean_object* x_217; lean_object* x_218; lean_object* x_219; -lean_dec(x_203); -lean_dec(x_5); -lean_dec(x_1); -x_217 = lean_ctor_get(x_205, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_205, 1); -lean_inc(x_218); -lean_dec(x_205); -if (lean_is_scalar(x_201)) { - x_219 = lean_alloc_ctor(0, 5, 0); +lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; +lean_dec(x_211); +x_227 = lean_ctor_get(x_213, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_213, 1); +lean_inc(x_228); +lean_dec(x_213); +if (lean_is_scalar(x_209)) { + x_229 = lean_alloc_ctor(0, 5, 0); } else { - x_219 = x_201; + x_229 = x_209; } -lean_ctor_set(x_219, 0, x_218); -lean_ctor_set(x_219, 1, x_197); -lean_ctor_set(x_219, 2, x_198); -lean_ctor_set(x_219, 3, x_199); -lean_ctor_set(x_219, 4, x_200); -x_176 = x_217; -x_177 = x_219; -goto block_193; +lean_ctor_set(x_229, 0, x_228); +lean_ctor_set(x_229, 1, x_205); +lean_ctor_set(x_229, 2, x_206); +lean_ctor_set(x_229, 3, x_207); +lean_ctor_set(x_229, 4, x_208); +x_230 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_230, 0, x_227); +x_167 = x_230; +x_168 = x_229; +goto block_200; } } else { -lean_object* x_220; lean_object* x_221; lean_object* x_222; -lean_dec(x_5); +lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_dec(x_19); -lean_dec(x_1); -x_220 = lean_ctor_get(x_202, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_202, 1); -lean_inc(x_221); -lean_dec(x_202); -if (lean_is_scalar(x_201)) { - x_222 = lean_alloc_ctor(0, 5, 0); +x_231 = lean_ctor_get(x_210, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_210, 1); +lean_inc(x_232); +lean_dec(x_210); +if (lean_is_scalar(x_209)) { + x_233 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_201; + x_233 = x_209; } -lean_ctor_set(x_222, 0, x_221); -lean_ctor_set(x_222, 1, x_197); -lean_ctor_set(x_222, 2, x_198); -lean_ctor_set(x_222, 3, x_199); -lean_ctor_set(x_222, 4, x_200); -x_176 = x_220; -x_177 = x_222; -goto block_193; +lean_ctor_set(x_233, 0, x_232); +lean_ctor_set(x_233, 1, x_205); +lean_ctor_set(x_233, 2, x_206); +lean_ctor_set(x_233, 3, x_207); +lean_ctor_set(x_233, 4, x_208); +x_234 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_234, 0, x_231); +x_167 = x_234; +x_168 = x_233; +goto block_200; } } } @@ -17179,375 +18337,391 @@ goto block_193; } else { -lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_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_265; lean_object* x_266; uint8_t x_283; lean_object* x_284; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; uint8_t x_317; -x_236 = lean_ctor_get(x_29, 0); -x_237 = lean_ctor_get(x_29, 1); -x_238 = lean_ctor_get(x_29, 2); -x_239 = lean_ctor_get(x_29, 3); -x_240 = lean_ctor_get(x_29, 4); -lean_inc(x_240); -lean_inc(x_239); -lean_inc(x_238); -lean_inc(x_237); -lean_inc(x_236); -lean_dec(x_29); -x_241 = lean_ctor_get(x_236, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_236, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_236, 2); -lean_inc(x_243); -x_244 = lean_ctor_get(x_236, 3); -lean_inc(x_244); -x_245 = lean_ctor_get(x_236, 4); -lean_inc(x_245); -x_246 = lean_ctor_get(x_236, 5); -lean_inc(x_246); -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_247 = x_236; -} else { - lean_dec_ref(x_236); - x_247 = lean_box(0); -} -if (lean_is_scalar(x_247)) { - x_313 = lean_alloc_ctor(0, 6, 0); -} else { - x_313 = x_247; -} -lean_ctor_set(x_313, 0, x_241); -lean_ctor_set(x_313, 1, x_31); -lean_ctor_set(x_313, 2, x_243); -lean_ctor_set(x_313, 3, x_244); -lean_ctor_set(x_313, 4, x_245); -lean_ctor_set(x_313, 5, x_246); -x_314 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_314, 0, x_313); -lean_ctor_set(x_314, 1, x_237); -lean_ctor_set(x_314, 2, x_238); -lean_ctor_set(x_314, 3, x_239); -lean_ctor_set(x_314, 4, x_240); -x_315 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_314); -x_316 = lean_ctor_get(x_315, 0); -lean_inc(x_316); -x_317 = lean_ctor_get_uint8(x_316, sizeof(void*)*1); -lean_dec(x_316); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_315, 1); -lean_inc(x_318); -lean_dec(x_315); -x_319 = 0; -x_283 = x_319; -x_284 = x_318; -goto block_312; -} -else -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; uint8_t x_325; -x_320 = lean_ctor_get(x_315, 1); -lean_inc(x_320); -lean_dec(x_315); -x_321 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_322 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_321, x_1, x_320); -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_unbox(x_323); -lean_dec(x_323); -x_283 = x_325; -x_284 = x_324; -goto block_312; -} -block_264: -{ -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; -x_249 = lean_ctor_get(x_248, 0); -lean_inc(x_249); -x_250 = lean_ctor_get(x_248, 1); -lean_inc(x_250); -x_251 = lean_ctor_get(x_248, 2); -lean_inc(x_251); -x_252 = lean_ctor_get(x_248, 3); +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; uint8_t x_294; lean_object* x_295; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; uint8_t x_333; +x_248 = lean_ctor_get(x_29, 0); +x_249 = lean_ctor_get(x_29, 1); +x_250 = lean_ctor_get(x_29, 2); +x_251 = lean_ctor_get(x_29, 3); +x_252 = lean_ctor_get(x_29, 4); lean_inc(x_252); -x_253 = lean_ctor_get(x_248, 4); +lean_inc(x_251); +lean_inc(x_250); +lean_inc(x_249); +lean_inc(x_248); +lean_dec(x_29); +x_253 = lean_ctor_get(x_248, 0); lean_inc(x_253); +x_254 = lean_ctor_get(x_248, 1); +lean_inc(x_254); +x_255 = lean_ctor_get(x_248, 2); +lean_inc(x_255); +x_256 = lean_ctor_get(x_248, 3); +lean_inc(x_256); +x_257 = lean_ctor_get(x_248, 4); +lean_inc(x_257); +x_258 = lean_ctor_get(x_248, 5); +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); - x_254 = x_248; + lean_ctor_release(x_248, 5); + x_259 = x_248; } else { lean_dec_ref(x_248); - x_254 = lean_box(0); + x_259 = lean_box(0); } -x_255 = lean_ctor_get(x_249, 0); -lean_inc(x_255); -x_256 = lean_ctor_get(x_249, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_249, 3); -lean_inc(x_257); -x_258 = lean_ctor_get(x_249, 4); -lean_inc(x_258); -x_259 = lean_ctor_get(x_249, 5); -lean_inc(x_259); -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); - lean_ctor_release(x_249, 4); - lean_ctor_release(x_249, 5); - x_260 = x_249; +if (lean_is_scalar(x_259)) { + x_329 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_249); - x_260 = lean_box(0); + x_329 = x_259; } -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 6, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_255); -lean_ctor_set(x_261, 1, x_242); -lean_ctor_set(x_261, 2, x_256); -lean_ctor_set(x_261, 3, x_257); -lean_ctor_set(x_261, 4, x_258); -lean_ctor_set(x_261, 5, x_259); -if (lean_is_scalar(x_254)) { - x_262 = lean_alloc_ctor(0, 5, 0); -} else { - x_262 = x_254; -} -lean_ctor_set(x_262, 0, x_261); -lean_ctor_set(x_262, 1, x_250); -lean_ctor_set(x_262, 2, x_251); -lean_ctor_set(x_262, 3, x_252); -lean_ctor_set(x_262, 4, x_253); -x_263 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_262); -return x_263; -} -block_282: +lean_ctor_set(x_329, 0, x_253); +lean_ctor_set(x_329, 1, x_31); +lean_ctor_set(x_329, 2, x_255); +lean_ctor_set(x_329, 3, x_256); +lean_ctor_set(x_329, 4, x_257); +lean_ctor_set(x_329, 5, x_258); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_329); +lean_ctor_set(x_330, 1, x_249); +lean_ctor_set(x_330, 2, x_250); +lean_ctor_set(x_330, 3, x_251); +lean_ctor_set(x_330, 4, x_252); +x_331 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_330); +x_332 = lean_ctor_get(x_331, 0); +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_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; -x_267 = lean_ctor_get(x_266, 0); +lean_object* x_334; uint8_t x_335; +x_334 = lean_ctor_get(x_331, 1); +lean_inc(x_334); +lean_dec(x_331); +x_335 = 0; +x_294 = x_335; +x_295 = x_334; +goto block_328; +} +else +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; uint8_t x_341; +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_338 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_337, x_1, x_336); +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_unbox(x_339); +lean_dec(x_339); +x_294 = x_341; +x_295 = x_340; +goto block_328; +} +block_293: +{ +if (lean_obj_tag(x_260) == 0) +{ +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_dec(x_5); +lean_dec(x_1); +x_262 = lean_ctor_get(x_261, 0); +lean_inc(x_262); +x_263 = lean_ctor_get(x_260, 0); +lean_inc(x_263); +lean_dec(x_260); +x_264 = lean_ctor_get(x_261, 1); +lean_inc(x_264); +x_265 = lean_ctor_get(x_261, 2); +lean_inc(x_265); +x_266 = lean_ctor_get(x_261, 3); +lean_inc(x_266); +x_267 = lean_ctor_get(x_261, 4); lean_inc(x_267); -x_268 = lean_ctor_get(x_266, 1); -lean_inc(x_268); -x_269 = lean_ctor_get(x_266, 2); +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); + x_268 = x_261; +} else { + lean_dec_ref(x_261); + x_268 = lean_box(0); +} +x_269 = lean_ctor_get(x_262, 0); lean_inc(x_269); -x_270 = lean_ctor_get(x_266, 3); +x_270 = lean_ctor_get(x_262, 2); lean_inc(x_270); -x_271 = lean_ctor_get(x_266, 4); +x_271 = lean_ctor_get(x_262, 3); lean_inc(x_271); -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_272 = x_266; -} else { - lean_dec_ref(x_266); - x_272 = lean_box(0); -} -x_273 = lean_ctor_get(x_267, 0); +x_272 = lean_ctor_get(x_262, 4); +lean_inc(x_272); +x_273 = lean_ctor_get(x_262, 5); lean_inc(x_273); -x_274 = lean_ctor_get(x_267, 2); -lean_inc(x_274); -x_275 = lean_ctor_get(x_267, 3); -lean_inc(x_275); -x_276 = lean_ctor_get(x_267, 4); -lean_inc(x_276); -x_277 = lean_ctor_get(x_267, 5); -lean_inc(x_277); -if (lean_is_exclusive(x_267)) { - lean_ctor_release(x_267, 0); - lean_ctor_release(x_267, 1); - lean_ctor_release(x_267, 2); - lean_ctor_release(x_267, 3); - lean_ctor_release(x_267, 4); - lean_ctor_release(x_267, 5); - x_278 = x_267; +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); + lean_ctor_release(x_262, 5); + x_274 = x_262; } else { - lean_dec_ref(x_267); - x_278 = lean_box(0); + lean_dec_ref(x_262); + x_274 = lean_box(0); } -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 6, 0); } else { - x_279 = x_278; + x_275 = x_274; } -lean_ctor_set(x_279, 0, x_273); -lean_ctor_set(x_279, 1, x_242); -lean_ctor_set(x_279, 2, x_274); -lean_ctor_set(x_279, 3, x_275); -lean_ctor_set(x_279, 4, x_276); -lean_ctor_set(x_279, 5, x_277); -if (lean_is_scalar(x_272)) { - x_280 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_275, 0, x_269); +lean_ctor_set(x_275, 1, x_254); +lean_ctor_set(x_275, 2, x_270); +lean_ctor_set(x_275, 3, x_271); +lean_ctor_set(x_275, 4, x_272); +lean_ctor_set(x_275, 5, x_273); +if (lean_is_scalar(x_268)) { + x_276 = lean_alloc_ctor(0, 5, 0); } else { - x_280 = x_272; + x_276 = x_268; } -lean_ctor_set(x_280, 0, x_279); -lean_ctor_set(x_280, 1, x_268); -lean_ctor_set(x_280, 2, x_269); -lean_ctor_set(x_280, 3, x_270); -lean_ctor_set(x_280, 4, x_271); +lean_ctor_set(x_276, 0, x_275); +lean_ctor_set(x_276, 1, x_264); +lean_ctor_set(x_276, 2, x_265); +lean_ctor_set(x_276, 3, x_266); +lean_ctor_set(x_276, 4, x_267); if (lean_is_scalar(x_30)) { - x_281 = lean_alloc_ctor(1, 2, 0); + x_277 = lean_alloc_ctor(1, 2, 0); } else { - x_281 = x_30; - lean_ctor_set_tag(x_281, 1); + x_277 = x_30; + lean_ctor_set_tag(x_277, 1); } -lean_ctor_set(x_281, 0, x_265); -lean_ctor_set(x_281, 1, x_280); -return x_281; +lean_ctor_set(x_277, 0, x_263); +lean_ctor_set(x_277, 1, x_276); +return x_277; } -block_312: -{ -if (x_283 == 0) +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; 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_dec(x_260); lean_dec(x_30); +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, 2); +lean_inc(x_280); +x_281 = lean_ctor_get(x_261, 3); +lean_inc(x_281); +x_282 = lean_ctor_get(x_261, 4); +lean_inc(x_282); +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); + x_283 = x_261; +} else { + lean_dec_ref(x_261); + x_283 = lean_box(0); +} +x_284 = lean_ctor_get(x_278, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_278, 2); +lean_inc(x_285); +x_286 = lean_ctor_get(x_278, 3); +lean_inc(x_286); +x_287 = lean_ctor_get(x_278, 4); +lean_inc(x_287); +x_288 = lean_ctor_get(x_278, 5); +lean_inc(x_288); +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); + lean_ctor_release(x_278, 4); + lean_ctor_release(x_278, 5); + x_289 = x_278; +} else { + lean_dec_ref(x_278); + x_289 = lean_box(0); +} +if (lean_is_scalar(x_289)) { + x_290 = lean_alloc_ctor(0, 6, 0); +} else { + x_290 = x_289; +} +lean_ctor_set(x_290, 0, x_284); +lean_ctor_set(x_290, 1, x_254); +lean_ctor_set(x_290, 2, x_285); +lean_ctor_set(x_290, 3, x_286); +lean_ctor_set(x_290, 4, x_287); +lean_ctor_set(x_290, 5, x_288); +if (lean_is_scalar(x_283)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_283; +} +lean_ctor_set(x_291, 0, x_290); +lean_ctor_set(x_291, 1, x_279); +lean_ctor_set(x_291, 2, x_280); +lean_ctor_set(x_291, 3, x_281); +lean_ctor_set(x_291, 4, x_282); +x_292 = l_Lean_Meta_SynthInstance_consume(x_5, x_1, x_291); +return x_292; +} +} +block_328: +{ +if (x_294 == 0) +{ +lean_object* x_296; lean_dec(x_19); lean_dec(x_15); -x_248 = x_284; -goto block_264; +x_296 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_260 = x_296; +x_261 = x_295; +goto block_293; } 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; -x_285 = lean_ctor_get(x_284, 0); -lean_inc(x_285); -x_286 = lean_ctor_get(x_284, 1); -lean_inc(x_286); -x_287 = lean_ctor_get(x_284, 2); -lean_inc(x_287); -x_288 = lean_ctor_get(x_284, 3); -lean_inc(x_288); -x_289 = lean_ctor_get(x_284, 4); -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); - x_290 = x_284; +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_297 = lean_ctor_get(x_295, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_295, 1); +lean_inc(x_298); +x_299 = lean_ctor_get(x_295, 2); +lean_inc(x_299); +x_300 = lean_ctor_get(x_295, 3); +lean_inc(x_300); +x_301 = lean_ctor_get(x_295, 4); +lean_inc(x_301); +if (lean_is_exclusive(x_295)) { + lean_ctor_release(x_295, 0); + lean_ctor_release(x_295, 1); + lean_ctor_release(x_295, 2); + lean_ctor_release(x_295, 3); + lean_ctor_release(x_295, 4); + x_302 = x_295; } else { - lean_dec_ref(x_284); - x_290 = lean_box(0); + lean_dec_ref(x_295); + x_302 = lean_box(0); } lean_inc(x_1); -x_291 = l_Lean_Meta_inferType(x_15, x_1, x_285); -if (lean_obj_tag(x_291) == 0) +x_303 = l_Lean_Meta_inferType(x_15, x_1, x_297); +if (lean_obj_tag(x_303) == 0) { -lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_292 = lean_ctor_get(x_291, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_291, 1); -lean_inc(x_293); -lean_dec(x_291); -lean_inc(x_1); -x_294 = l_Lean_Meta_inferType(x_19, x_1, x_293); -if (lean_obj_tag(x_294) == 0) -{ -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; -lean_dec(x_30); -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); -if (lean_is_scalar(x_290)) { - x_297 = lean_alloc_ctor(0, 5, 0); -} else { - x_297 = x_290; -} -lean_ctor_set(x_297, 0, x_296); -lean_ctor_set(x_297, 1, x_286); -lean_ctor_set(x_297, 2, x_287); -lean_ctor_set(x_297, 3, x_288); -lean_ctor_set(x_297, 4, x_289); -x_298 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_298, 0, x_292); -x_299 = l_Lean_Meta_SynthInstance_resume___closed__7; -x_300 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_300, 0, x_298); -lean_ctor_set(x_300, 1, x_299); -x_301 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_301, 0, x_295); -x_302 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_302, 0, x_300); -lean_ctor_set(x_302, 1, x_301); -x_303 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_304 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_303, x_302, x_1, x_297); -x_305 = lean_ctor_get(x_304, 1); +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_304); -x_248 = x_305; -goto block_264; -} -else +lean_dec(x_303); +lean_inc(x_1); +x_306 = l_Lean_Meta_inferType(x_19, x_1, x_305); +if (lean_obj_tag(x_306) == 0) { -lean_object* x_306; lean_object* x_307; lean_object* x_308; -lean_dec(x_292); -lean_dec(x_5); -lean_dec(x_1); -x_306 = lean_ctor_get(x_294, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_294, 1); +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_306, 0); lean_inc(x_307); -lean_dec(x_294); -if (lean_is_scalar(x_290)) { - x_308 = lean_alloc_ctor(0, 5, 0); +x_308 = lean_ctor_get(x_306, 1); +lean_inc(x_308); +lean_dec(x_306); +if (lean_is_scalar(x_302)) { + x_309 = lean_alloc_ctor(0, 5, 0); } else { - x_308 = x_290; + x_309 = x_302; } -lean_ctor_set(x_308, 0, x_307); -lean_ctor_set(x_308, 1, x_286); -lean_ctor_set(x_308, 2, x_287); -lean_ctor_set(x_308, 3, x_288); -lean_ctor_set(x_308, 4, x_289); -x_265 = x_306; -x_266 = x_308; -goto block_282; +lean_ctor_set(x_309, 0, x_308); +lean_ctor_set(x_309, 1, x_298); +lean_ctor_set(x_309, 2, x_299); +lean_ctor_set(x_309, 3, x_300); +lean_ctor_set(x_309, 4, x_301); +x_310 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_310, 0, x_304); +x_311 = l_Lean_Meta_SynthInstance_resume___closed__7; +x_312 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_312, 0, x_310); +lean_ctor_set(x_312, 1, x_311); +x_313 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_313, 0, x_307); +x_314 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_314, 0, x_312); +lean_ctor_set(x_314, 1, x_313); +x_315 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_316 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_315, x_314, x_1, x_309); +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_260 = x_319; +x_261 = x_318; +goto block_293; +} +else +{ +lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; +lean_dec(x_304); +x_320 = lean_ctor_get(x_306, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_306, 1); +lean_inc(x_321); +lean_dec(x_306); +if (lean_is_scalar(x_302)) { + x_322 = lean_alloc_ctor(0, 5, 0); +} else { + x_322 = x_302; +} +lean_ctor_set(x_322, 0, x_321); +lean_ctor_set(x_322, 1, x_298); +lean_ctor_set(x_322, 2, x_299); +lean_ctor_set(x_322, 3, x_300); +lean_ctor_set(x_322, 4, x_301); +x_323 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_323, 0, x_320); +x_260 = x_323; +x_261 = x_322; +goto block_293; } } else { -lean_object* x_309; lean_object* x_310; lean_object* x_311; -lean_dec(x_5); +lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_dec(x_19); -lean_dec(x_1); -x_309 = lean_ctor_get(x_291, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_291, 1); -lean_inc(x_310); -lean_dec(x_291); -if (lean_is_scalar(x_290)) { - x_311 = lean_alloc_ctor(0, 5, 0); +x_324 = lean_ctor_get(x_303, 0); +lean_inc(x_324); +x_325 = lean_ctor_get(x_303, 1); +lean_inc(x_325); +lean_dec(x_303); +if (lean_is_scalar(x_302)) { + x_326 = lean_alloc_ctor(0, 5, 0); } else { - x_311 = x_290; + x_326 = x_302; } -lean_ctor_set(x_311, 0, x_310); -lean_ctor_set(x_311, 1, x_286); -lean_ctor_set(x_311, 2, x_287); -lean_ctor_set(x_311, 3, x_288); -lean_ctor_set(x_311, 4, x_289); -x_265 = x_309; -x_266 = x_311; -goto block_282; +lean_ctor_set(x_326, 0, x_325); +lean_ctor_set(x_326, 1, x_298); +lean_ctor_set(x_326, 2, x_299); +lean_ctor_set(x_326, 3, x_300); +lean_ctor_set(x_326, 4, x_301); +x_327 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_327, 0, x_324); +x_260 = x_327; +x_261 = x_326; +goto block_293; } } } @@ -17556,322 +18730,259 @@ goto block_282; } else { -uint8_t x_326; +uint8_t x_342; lean_dec(x_20); lean_dec(x_19); lean_free_object(x_5); lean_dec(x_16); lean_dec(x_15); lean_dec(x_1); -x_326 = !lean_is_exclusive(x_21); -if (x_326 == 0) +x_342 = !lean_is_exclusive(x_21); +if (x_342 == 0) { return x_21; } else { -lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_327 = lean_ctor_get(x_21, 0); -x_328 = lean_ctor_get(x_21, 1); -lean_inc(x_328); -lean_inc(x_327); +lean_object* x_343; lean_object* x_344; lean_object* x_345; +x_343 = lean_ctor_get(x_21, 0); +x_344 = lean_ctor_get(x_21, 1); +lean_inc(x_344); +lean_inc(x_343); lean_dec(x_21); -x_329 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_329, 0, x_327); -lean_ctor_set(x_329, 1, x_328); -return x_329; +x_345 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_345, 0, x_343); +lean_ctor_set(x_345, 1, x_344); +return x_345; } } } else { -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_330 = lean_ctor_get(x_5, 0); -x_331 = lean_ctor_get(x_5, 1); -x_332 = lean_ctor_get(x_5, 2); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); +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_346 = lean_ctor_get(x_5, 0); +x_347 = lean_ctor_get(x_5, 1); +x_348 = lean_ctor_get(x_5, 2); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); lean_dec(x_5); -x_333 = lean_ctor_get(x_6, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_6, 1); -lean_inc(x_334); +x_349 = lean_ctor_get(x_6, 0); +lean_inc(x_349); +x_350 = lean_ctor_get(x_6, 1); +lean_inc(x_350); lean_dec(x_6); lean_inc(x_1); -lean_inc(x_333); -x_335 = l_Lean_Meta_SynthInstance_tryAnswer(x_332, x_333, x_13, x_1, x_12); -if (lean_obj_tag(x_335) == 0) -{ -lean_object* x_336; -x_336 = lean_ctor_get(x_335, 0); -lean_inc(x_336); -if (lean_obj_tag(x_336) == 0) -{ -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; -lean_dec(x_334); -lean_dec(x_333); -lean_dec(x_331); -lean_dec(x_330); -lean_dec(x_1); -x_337 = lean_ctor_get(x_335, 1); -lean_inc(x_337); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - x_338 = x_335; -} else { - lean_dec_ref(x_335); - x_338 = lean_box(0); -} -x_339 = lean_box(0); -if (lean_is_scalar(x_338)) { - x_340 = lean_alloc_ctor(0, 2, 0); -} else { - x_340 = x_338; -} -lean_ctor_set(x_340, 0, x_339); -lean_ctor_set(x_340, 1, x_337); -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; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_375; lean_object* x_376; uint8_t x_393; lean_object* x_394; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; uint8_t x_427; -x_341 = lean_ctor_get(x_335, 1); -lean_inc(x_341); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - x_342 = x_335; -} else { - lean_dec_ref(x_335); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_336, 0); -lean_inc(x_343); -lean_dec(x_336); -lean_inc(x_343); -lean_inc(x_330); -x_344 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_344, 0, x_330); -lean_ctor_set(x_344, 1, x_331); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_334); -x_345 = lean_ctor_get(x_341, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_341, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_341, 2); -lean_inc(x_347); -x_348 = lean_ctor_get(x_341, 3); -lean_inc(x_348); -x_349 = lean_ctor_get(x_341, 4); lean_inc(x_349); -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); - lean_ctor_release(x_341, 4); - x_350 = x_341; -} else { - lean_dec_ref(x_341); - x_350 = lean_box(0); -} -x_351 = lean_ctor_get(x_345, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_345, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_345, 2); -lean_inc(x_353); -x_354 = lean_ctor_get(x_345, 3); -lean_inc(x_354); -x_355 = lean_ctor_get(x_345, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_345, 5); -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); - lean_ctor_release(x_345, 4); - lean_ctor_release(x_345, 5); - x_357 = x_345; -} else { - lean_dec_ref(x_345); - x_357 = lean_box(0); -} -if (lean_is_scalar(x_357)) { - x_423 = lean_alloc_ctor(0, 6, 0); -} else { - x_423 = x_357; -} -lean_ctor_set(x_423, 0, x_351); -lean_ctor_set(x_423, 1, x_343); -lean_ctor_set(x_423, 2, x_353); -lean_ctor_set(x_423, 3, x_354); -lean_ctor_set(x_423, 4, x_355); -lean_ctor_set(x_423, 5, x_356); -if (lean_is_scalar(x_350)) { - x_424 = lean_alloc_ctor(0, 5, 0); -} else { - x_424 = x_350; -} -lean_ctor_set(x_424, 0, x_423); -lean_ctor_set(x_424, 1, x_346); -lean_ctor_set(x_424, 2, x_347); -lean_ctor_set(x_424, 3, x_348); -lean_ctor_set(x_424, 4, x_349); -x_425 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_424); -x_426 = lean_ctor_get(x_425, 0); -lean_inc(x_426); -x_427 = lean_ctor_get_uint8(x_426, sizeof(void*)*1); -lean_dec(x_426); -if (x_427 == 0) +x_351 = l_Lean_Meta_SynthInstance_tryAnswer(x_348, x_349, x_13, x_1, x_12); +if (lean_obj_tag(x_351) == 0) { -lean_object* x_428; uint8_t x_429; -x_428 = lean_ctor_get(x_425, 1); -lean_inc(x_428); -lean_dec(x_425); -x_429 = 0; -x_393 = x_429; -x_394 = x_428; -goto block_422; +lean_object* x_352; +x_352 = lean_ctor_get(x_351, 0); +lean_inc(x_352); +if (lean_obj_tag(x_352) == 0) +{ +lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; +lean_dec(x_350); +lean_dec(x_349); +lean_dec(x_347); +lean_dec(x_346); +lean_dec(x_1); +x_353 = lean_ctor_get(x_351, 1); +lean_inc(x_353); +if (lean_is_exclusive(x_351)) { + lean_ctor_release(x_351, 0); + lean_ctor_release(x_351, 1); + x_354 = x_351; +} else { + lean_dec_ref(x_351); + x_354 = lean_box(0); +} +x_355 = lean_box(0); +if (lean_is_scalar(x_354)) { + x_356 = lean_alloc_ctor(0, 2, 0); +} else { + x_356 = x_354; +} +lean_ctor_set(x_356, 0, x_355); +lean_ctor_set(x_356, 1, x_353); +return x_356; } else { -lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; uint8_t x_435; -x_430 = lean_ctor_get(x_425, 1); -lean_inc(x_430); -lean_dec(x_425); -x_431 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_432 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_431, x_1, x_430); -x_433 = lean_ctor_get(x_432, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_432, 1); -lean_inc(x_434); -lean_dec(x_432); -x_435 = lean_unbox(x_433); -lean_dec(x_433); -x_393 = x_435; -x_394 = x_434; -goto block_422; +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; lean_object* x_374; lean_object* x_375; uint8_t x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; uint8_t x_447; +x_357 = lean_ctor_get(x_351, 1); +lean_inc(x_357); +if (lean_is_exclusive(x_351)) { + lean_ctor_release(x_351, 0); + lean_ctor_release(x_351, 1); + x_358 = x_351; +} else { + lean_dec_ref(x_351); + x_358 = lean_box(0); } -block_374: -{ -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_359 = lean_ctor_get(x_358, 0); +x_359 = lean_ctor_get(x_352, 0); lean_inc(x_359); -x_360 = lean_ctor_get(x_358, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_358, 2); +lean_dec(x_352); +lean_inc(x_359); +lean_inc(x_346); +x_360 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_347); +lean_ctor_set(x_360, 2, x_359); +lean_ctor_set(x_360, 3, x_350); +x_361 = lean_ctor_get(x_357, 0); lean_inc(x_361); -x_362 = lean_ctor_get(x_358, 3); +x_362 = lean_ctor_get(x_357, 1); lean_inc(x_362); -x_363 = lean_ctor_get(x_358, 4); +x_363 = lean_ctor_get(x_357, 2); lean_inc(x_363); -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); - x_364 = x_358; -} else { - lean_dec_ref(x_358); - x_364 = lean_box(0); -} -x_365 = lean_ctor_get(x_359, 0); +x_364 = lean_ctor_get(x_357, 3); +lean_inc(x_364); +x_365 = lean_ctor_get(x_357, 4); lean_inc(x_365); -x_366 = lean_ctor_get(x_359, 2); -lean_inc(x_366); -x_367 = lean_ctor_get(x_359, 3); +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_366 = x_357; +} else { + lean_dec_ref(x_357); + x_366 = lean_box(0); +} +x_367 = lean_ctor_get(x_361, 0); lean_inc(x_367); -x_368 = lean_ctor_get(x_359, 4); +x_368 = lean_ctor_get(x_361, 1); lean_inc(x_368); -x_369 = lean_ctor_get(x_359, 5); +x_369 = lean_ctor_get(x_361, 2); lean_inc(x_369); -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_370 = x_359; +x_370 = lean_ctor_get(x_361, 3); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 4); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 5); +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); + lean_ctor_release(x_361, 5); + x_373 = x_361; } else { - lean_dec_ref(x_359); - x_370 = lean_box(0); + lean_dec_ref(x_361); + x_373 = lean_box(0); } -if (lean_is_scalar(x_370)) { - x_371 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_373)) { + x_443 = lean_alloc_ctor(0, 6, 0); } else { - x_371 = x_370; + x_443 = x_373; } -lean_ctor_set(x_371, 0, x_365); -lean_ctor_set(x_371, 1, x_352); -lean_ctor_set(x_371, 2, x_366); -lean_ctor_set(x_371, 3, x_367); -lean_ctor_set(x_371, 4, x_368); -lean_ctor_set(x_371, 5, x_369); -if (lean_is_scalar(x_364)) { - x_372 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_443, 0, x_367); +lean_ctor_set(x_443, 1, x_359); +lean_ctor_set(x_443, 2, x_369); +lean_ctor_set(x_443, 3, x_370); +lean_ctor_set(x_443, 4, x_371); +lean_ctor_set(x_443, 5, x_372); +if (lean_is_scalar(x_366)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_372 = x_364; + x_444 = x_366; } -lean_ctor_set(x_372, 0, x_371); -lean_ctor_set(x_372, 1, x_360); -lean_ctor_set(x_372, 2, x_361); -lean_ctor_set(x_372, 3, x_362); -lean_ctor_set(x_372, 4, x_363); -x_373 = l_Lean_Meta_SynthInstance_consume(x_344, x_1, x_372); -return x_373; -} -block_392: +lean_ctor_set(x_444, 0, x_443); +lean_ctor_set(x_444, 1, x_362); +lean_ctor_set(x_444, 2, x_363); +lean_ctor_set(x_444, 3, x_364); +lean_ctor_set(x_444, 4, x_365); +x_445 = l_Lean_Meta_SynthInstance_getTraceState___rarg(x_444); +x_446 = lean_ctor_get(x_445, 0); +lean_inc(x_446); +x_447 = lean_ctor_get_uint8(x_446, sizeof(void*)*1); +lean_dec(x_446); +if (x_447 == 0) { -lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; -x_377 = lean_ctor_get(x_376, 0); +lean_object* x_448; uint8_t x_449; +x_448 = lean_ctor_get(x_445, 1); +lean_inc(x_448); +lean_dec(x_445); +x_449 = 0; +x_408 = x_449; +x_409 = x_448; +goto block_442; +} +else +{ +lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; uint8_t x_455; +x_450 = lean_ctor_get(x_445, 1); +lean_inc(x_450); +lean_dec(x_445); +x_451 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_452 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_SynthInstance_newSubgoal___spec__7(x_451, x_1, x_450); +x_453 = lean_ctor_get(x_452, 0); +lean_inc(x_453); +x_454 = lean_ctor_get(x_452, 1); +lean_inc(x_454); +lean_dec(x_452); +x_455 = lean_unbox(x_453); +lean_dec(x_453); +x_408 = x_455; +x_409 = x_454; +goto block_442; +} +block_407: +{ +if (lean_obj_tag(x_374) == 0) +{ +lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; +lean_dec(x_360); +lean_dec(x_1); +x_376 = lean_ctor_get(x_375, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_374, 0); lean_inc(x_377); -x_378 = lean_ctor_get(x_376, 1); +lean_dec(x_374); +x_378 = lean_ctor_get(x_375, 1); lean_inc(x_378); -x_379 = lean_ctor_get(x_376, 2); +x_379 = lean_ctor_get(x_375, 2); lean_inc(x_379); -x_380 = lean_ctor_get(x_376, 3); +x_380 = lean_ctor_get(x_375, 3); lean_inc(x_380); -x_381 = lean_ctor_get(x_376, 4); +x_381 = lean_ctor_get(x_375, 4); lean_inc(x_381); +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); + lean_ctor_release(x_375, 4); + x_382 = x_375; +} else { + lean_dec_ref(x_375); + x_382 = lean_box(0); +} +x_383 = lean_ctor_get(x_376, 0); +lean_inc(x_383); +x_384 = lean_ctor_get(x_376, 2); +lean_inc(x_384); +x_385 = lean_ctor_get(x_376, 3); +lean_inc(x_385); +x_386 = lean_ctor_get(x_376, 4); +lean_inc(x_386); +x_387 = lean_ctor_get(x_376, 5); +lean_inc(x_387); if (lean_is_exclusive(x_376)) { lean_ctor_release(x_376, 0); lean_ctor_release(x_376, 1); lean_ctor_release(x_376, 2); lean_ctor_release(x_376, 3); lean_ctor_release(x_376, 4); - x_382 = x_376; + lean_ctor_release(x_376, 5); + x_388 = x_376; } else { lean_dec_ref(x_376); - x_382 = lean_box(0); -} -x_383 = lean_ctor_get(x_377, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_377, 2); -lean_inc(x_384); -x_385 = lean_ctor_get(x_377, 3); -lean_inc(x_385); -x_386 = lean_ctor_get(x_377, 4); -lean_inc(x_386); -x_387 = lean_ctor_get(x_377, 5); -lean_inc(x_387); -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_388 = x_377; -} else { - lean_dec_ref(x_377); x_388 = lean_box(0); } if (lean_is_scalar(x_388)) { @@ -17880,7 +18991,7 @@ if (lean_is_scalar(x_388)) { x_389 = x_388; } lean_ctor_set(x_389, 0, x_383); -lean_ctor_set(x_389, 1, x_352); +lean_ctor_set(x_389, 1, x_368); lean_ctor_set(x_389, 2, x_384); lean_ctor_set(x_389, 3, x_385); lean_ctor_set(x_389, 4, x_386); @@ -17895,150 +19006,229 @@ lean_ctor_set(x_390, 1, x_378); lean_ctor_set(x_390, 2, x_379); lean_ctor_set(x_390, 3, x_380); lean_ctor_set(x_390, 4, x_381); -if (lean_is_scalar(x_342)) { +if (lean_is_scalar(x_358)) { x_391 = lean_alloc_ctor(1, 2, 0); } else { - x_391 = x_342; + x_391 = x_358; lean_ctor_set_tag(x_391, 1); } -lean_ctor_set(x_391, 0, x_375); +lean_ctor_set(x_391, 0, x_377); lean_ctor_set(x_391, 1, x_390); return x_391; } -block_422: -{ -if (x_393 == 0) -{ -lean_dec(x_342); -lean_dec(x_333); -lean_dec(x_330); -x_358 = x_394; -goto block_374; -} 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; -x_395 = lean_ctor_get(x_394, 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; +lean_dec(x_374); +lean_dec(x_358); +x_392 = lean_ctor_get(x_375, 0); +lean_inc(x_392); +x_393 = lean_ctor_get(x_375, 1); +lean_inc(x_393); +x_394 = lean_ctor_get(x_375, 2); +lean_inc(x_394); +x_395 = lean_ctor_get(x_375, 3); lean_inc(x_395); -x_396 = lean_ctor_get(x_394, 1); +x_396 = lean_ctor_get(x_375, 4); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_394, 3); +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); + lean_ctor_release(x_375, 4); + x_397 = x_375; +} else { + lean_dec_ref(x_375); + x_397 = lean_box(0); +} +x_398 = lean_ctor_get(x_392, 0); lean_inc(x_398); -x_399 = lean_ctor_get(x_394, 4); +x_399 = lean_ctor_get(x_392, 2); lean_inc(x_399); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - lean_ctor_release(x_394, 2); - lean_ctor_release(x_394, 3); - lean_ctor_release(x_394, 4); - x_400 = x_394; -} else { - lean_dec_ref(x_394); - x_400 = lean_box(0); -} -lean_inc(x_1); -x_401 = l_Lean_Meta_inferType(x_330, x_1, x_395); -if (lean_obj_tag(x_401) == 0) -{ -lean_object* x_402; lean_object* x_403; lean_object* x_404; -x_402 = lean_ctor_get(x_401, 0); +x_400 = lean_ctor_get(x_392, 3); +lean_inc(x_400); +x_401 = lean_ctor_get(x_392, 4); +lean_inc(x_401); +x_402 = lean_ctor_get(x_392, 5); lean_inc(x_402); -x_403 = lean_ctor_get(x_401, 1); -lean_inc(x_403); -lean_dec(x_401); -lean_inc(x_1); -x_404 = l_Lean_Meta_inferType(x_333, x_1, x_403); -if (lean_obj_tag(x_404) == 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_dec(x_342); -x_405 = lean_ctor_get(x_404, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_404, 1); -lean_inc(x_406); -lean_dec(x_404); -if (lean_is_scalar(x_400)) { - x_407 = lean_alloc_ctor(0, 5, 0); +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_403 = x_392; } else { - x_407 = x_400; + lean_dec_ref(x_392); + x_403 = lean_box(0); } -lean_ctor_set(x_407, 0, x_406); -lean_ctor_set(x_407, 1, x_396); -lean_ctor_set(x_407, 2, x_397); -lean_ctor_set(x_407, 3, x_398); -lean_ctor_set(x_407, 4, x_399); -x_408 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_408, 0, x_402); -x_409 = l_Lean_Meta_SynthInstance_resume___closed__7; -x_410 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_410, 0, x_408); -lean_ctor_set(x_410, 1, x_409); -x_411 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_411, 0, x_405); -x_412 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_412, 0, x_410); -lean_ctor_set(x_412, 1, x_411); -x_413 = l_Lean_Meta_SynthInstance_resume___closed__4; -x_414 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_413, x_412, x_1, x_407); -x_415 = lean_ctor_get(x_414, 1); +if (lean_is_scalar(x_403)) { + x_404 = lean_alloc_ctor(0, 6, 0); +} else { + x_404 = x_403; +} +lean_ctor_set(x_404, 0, x_398); +lean_ctor_set(x_404, 1, x_368); +lean_ctor_set(x_404, 2, x_399); +lean_ctor_set(x_404, 3, x_400); +lean_ctor_set(x_404, 4, x_401); +lean_ctor_set(x_404, 5, x_402); +if (lean_is_scalar(x_397)) { + x_405 = lean_alloc_ctor(0, 5, 0); +} else { + x_405 = x_397; +} +lean_ctor_set(x_405, 0, x_404); +lean_ctor_set(x_405, 1, x_393); +lean_ctor_set(x_405, 2, x_394); +lean_ctor_set(x_405, 3, x_395); +lean_ctor_set(x_405, 4, x_396); +x_406 = l_Lean_Meta_SynthInstance_consume(x_360, x_1, x_405); +return x_406; +} +} +block_442: +{ +if (x_408 == 0) +{ +lean_object* x_410; +lean_dec(x_349); +lean_dec(x_346); +x_410 = l_Nat_forMAux___main___at___private_Lean_MetavarContext_10__collectDeps___spec__50___closed__1; +x_374 = x_410; +x_375 = x_409; +goto block_407; +} +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; +x_411 = lean_ctor_get(x_409, 0); +lean_inc(x_411); +x_412 = lean_ctor_get(x_409, 1); +lean_inc(x_412); +x_413 = lean_ctor_get(x_409, 2); +lean_inc(x_413); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -lean_dec(x_414); -x_358 = x_415; -goto block_374; -} -else -{ -lean_object* x_416; lean_object* x_417; lean_object* x_418; -lean_dec(x_402); -lean_dec(x_344); -lean_dec(x_1); -x_416 = lean_ctor_get(x_404, 0); -lean_inc(x_416); -x_417 = lean_ctor_get(x_404, 1); -lean_inc(x_417); -lean_dec(x_404); -if (lean_is_scalar(x_400)) { - x_418 = lean_alloc_ctor(0, 5, 0); +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_416 = x_409; } else { - x_418 = x_400; + lean_dec_ref(x_409); + x_416 = lean_box(0); } -lean_ctor_set(x_418, 0, x_417); -lean_ctor_set(x_418, 1, x_396); -lean_ctor_set(x_418, 2, x_397); -lean_ctor_set(x_418, 3, x_398); -lean_ctor_set(x_418, 4, x_399); -x_375 = x_416; -x_376 = x_418; -goto block_392; -} -} -else +lean_inc(x_1); +x_417 = l_Lean_Meta_inferType(x_346, x_1, x_411); +if (lean_obj_tag(x_417) == 0) { -lean_object* x_419; lean_object* x_420; lean_object* x_421; -lean_dec(x_344); -lean_dec(x_333); -lean_dec(x_1); -x_419 = lean_ctor_get(x_401, 0); +lean_object* x_418; lean_object* x_419; lean_object* x_420; +x_418 = lean_ctor_get(x_417, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_417, 1); lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 1); -lean_inc(x_420); -lean_dec(x_401); -if (lean_is_scalar(x_400)) { - x_421 = lean_alloc_ctor(0, 5, 0); +lean_dec(x_417); +lean_inc(x_1); +x_420 = l_Lean_Meta_inferType(x_349, x_1, x_419); +if (lean_obj_tag(x_420) == 0) +{ +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_421 = lean_ctor_get(x_420, 0); +lean_inc(x_421); +x_422 = lean_ctor_get(x_420, 1); +lean_inc(x_422); +lean_dec(x_420); +if (lean_is_scalar(x_416)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_421 = x_400; + x_423 = x_416; } -lean_ctor_set(x_421, 0, x_420); -lean_ctor_set(x_421, 1, x_396); -lean_ctor_set(x_421, 2, x_397); -lean_ctor_set(x_421, 3, x_398); -lean_ctor_set(x_421, 4, x_399); -x_375 = x_419; -x_376 = x_421; -goto block_392; +lean_ctor_set(x_423, 0, x_422); +lean_ctor_set(x_423, 1, x_412); +lean_ctor_set(x_423, 2, x_413); +lean_ctor_set(x_423, 3, x_414); +lean_ctor_set(x_423, 4, x_415); +x_424 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_424, 0, x_418); +x_425 = l_Lean_Meta_SynthInstance_resume___closed__7; +x_426 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_426, 0, x_424); +lean_ctor_set(x_426, 1, x_425); +x_427 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_427, 0, x_421); +x_428 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_428, 0, x_426); +lean_ctor_set(x_428, 1, x_427); +x_429 = l_Lean_Meta_SynthInstance_resume___closed__4; +x_430 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_SynthInstance_newSubgoal___spec__8(x_429, x_428, x_1, x_423); +x_431 = lean_ctor_get(x_430, 0); +lean_inc(x_431); +x_432 = lean_ctor_get(x_430, 1); +lean_inc(x_432); +lean_dec(x_430); +x_433 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_433, 0, x_431); +x_374 = x_433; +x_375 = x_432; +goto block_407; +} +else +{ +lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; +lean_dec(x_418); +x_434 = lean_ctor_get(x_420, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_420, 1); +lean_inc(x_435); +lean_dec(x_420); +if (lean_is_scalar(x_416)) { + x_436 = lean_alloc_ctor(0, 5, 0); +} else { + x_436 = x_416; +} +lean_ctor_set(x_436, 0, x_435); +lean_ctor_set(x_436, 1, x_412); +lean_ctor_set(x_436, 2, x_413); +lean_ctor_set(x_436, 3, x_414); +lean_ctor_set(x_436, 4, x_415); +x_437 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_437, 0, x_434); +x_374 = x_437; +x_375 = x_436; +goto block_407; +} +} +else +{ +lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; +lean_dec(x_349); +x_438 = lean_ctor_get(x_417, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_417, 1); +lean_inc(x_439); +lean_dec(x_417); +if (lean_is_scalar(x_416)) { + x_440 = lean_alloc_ctor(0, 5, 0); +} else { + x_440 = x_416; +} +lean_ctor_set(x_440, 0, x_439); +lean_ctor_set(x_440, 1, x_412); +lean_ctor_set(x_440, 2, x_413); +lean_ctor_set(x_440, 3, x_414); +lean_ctor_set(x_440, 4, x_415); +x_441 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_441, 0, x_438); +x_374 = x_441; +x_375 = x_440; +goto block_407; } } } @@ -18046,32 +19236,32 @@ goto block_392; } else { -lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; -lean_dec(x_334); -lean_dec(x_333); -lean_dec(x_331); -lean_dec(x_330); +lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; +lean_dec(x_350); +lean_dec(x_349); +lean_dec(x_347); +lean_dec(x_346); lean_dec(x_1); -x_436 = lean_ctor_get(x_335, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_335, 1); -lean_inc(x_437); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - x_438 = x_335; +x_456 = lean_ctor_get(x_351, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_351, 1); +lean_inc(x_457); +if (lean_is_exclusive(x_351)) { + lean_ctor_release(x_351, 0); + lean_ctor_release(x_351, 1); + x_458 = x_351; } else { - lean_dec_ref(x_335); - x_438 = lean_box(0); + lean_dec_ref(x_351); + x_458 = lean_box(0); } -if (lean_is_scalar(x_438)) { - x_439 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_458)) { + x_459 = lean_alloc_ctor(1, 2, 0); } else { - x_439 = x_438; + x_459 = x_458; } -lean_ctor_set(x_439, 0, x_436); -lean_ctor_set(x_439, 1, x_437); -return x_439; +lean_ctor_set(x_459, 0, x_456); +lean_ctor_set(x_459, 1, x_457); +return x_459; } } } @@ -24785,6 +25975,8 @@ l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__4 = _init_l_Lean_ lean_mark_persistent(l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__4); l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__5 = _init_l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__5(); lean_mark_persistent(l_Lean_Meta_SynthInstance_tryResolveCore___lambda__1___closed__5); +l_Lean_Meta_SynthInstance_tryAnswer___closed__1 = _init_l_Lean_Meta_SynthInstance_tryAnswer___closed__1(); +lean_mark_persistent(l_Lean_Meta_SynthInstance_tryAnswer___closed__1); l_Lean_Meta_SynthInstance_wakeUp___closed__1 = _init_l_Lean_Meta_SynthInstance_wakeUp___closed__1(); lean_mark_persistent(l_Lean_Meta_SynthInstance_wakeUp___closed__1); l_Lean_Meta_SynthInstance_wakeUp___closed__2 = _init_l_Lean_Meta_SynthInstance_wakeUp___closed__2(); diff --git a/stage0/stdlib/Lean/Meta/Tactic/Apply.c b/stage0/stdlib/Lean/Meta/Tactic/Apply.c index 9894c2da51..33d0f0f49b 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Apply.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Apply.c @@ -24,7 +24,6 @@ extern lean_object* l_Lean_MessageData_ofList___closed__3; 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*); lean_object* lean_array_fswap(lean_object*, lean_object*, lean_object*); -extern lean_object* l_Array_empty___closed__1; lean_object* l_Lean_Meta_getMVarTag(lean_object*, lean_object*, lean_object*); lean_object* l_List_append___rarg(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Apply_3__throwApplyError___rarg___closed__5; @@ -55,13 +54,13 @@ lean_object* l_Lean_Meta_apply___boxed(lean_object*, lean_object*, lean_object*, lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1; lean_object* l_Lean_Meta_renameMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_FindMVar_main___main___at___private_Lean_Meta_Tactic_Apply_4__dependsOnOthers___spec__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_apply___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_FindMVar_main___main___at___private_Lean_Meta_Tactic_Apply_4__dependsOnOthers___spec__1(lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Apply_3__throwApplyError___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_importModules___closed__1; uint8_t l_Lean_BinderInfo_isInstImplicit(uint8_t); lean_object* l___private_Lean_Meta_Tactic_Apply_1__getExpectedNumArgsAux___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Apply_2__getExpectedNumArgs(lean_object*, lean_object*, lean_object*); @@ -1640,23 +1639,12 @@ return x_47; } } } -lean_object* _init_l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Array_empty___closed__1; -x_2 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_2, 0, x_1); -lean_ctor_set(x_2, 1, x_1); -return x_2; -} -} lean_object* l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = lean_unsigned_to_nat(0u); -x_5 = l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1; +x_5 = l_Lean_importModules___closed__1; x_6 = l_Array_iterateMAux___main___at___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___spec__1(x_1, x_1, x_4, x_5, x_2, x_3); if (lean_obj_tag(x_6) == 0) { @@ -2590,8 +2578,6 @@ l_Nat_forMAux___main___at_Lean_Meta_synthAppInstances___spec__1___closed__2 = _i lean_mark_persistent(l_Nat_forMAux___main___at_Lean_Meta_synthAppInstances___spec__1___closed__2); l_Nat_forMAux___main___at_Lean_Meta_synthAppInstances___spec__1___closed__3 = _init_l_Nat_forMAux___main___at_Lean_Meta_synthAppInstances___spec__1___closed__3(); lean_mark_persistent(l_Nat_forMAux___main___at_Lean_Meta_synthAppInstances___spec__1___closed__3); -l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1 = _init_l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1(); -lean_mark_persistent(l___private_Lean_Meta_Tactic_Apply_5__reorderNonDependentFirst___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/stdlib/Lean/Meta/Tactic/Cases.c b/stage0/stdlib/Lean/Meta/Tactic/Cases.c index 6cfd41d819..a4d247bfc6 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Cases.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Cases.c @@ -82,6 +82,7 @@ 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*); @@ -287,7 +288,6 @@ lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Meta_Tactic_Cases_5 lean_object* l_Array_umapMAux___main___at___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__10(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_getDecl(lean_object*, lean_object*); lean_object* l_List_toArrayAux___main___rarg(lean_object*, lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_anyRangeMAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__41___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -12697,7 +12697,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_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__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; diff --git a/stage0/stdlib/Lean/Meta/Tactic/Intro.c b/stage0/stdlib/Lean/Meta/Tactic/Intro.c index d0b03aa031..0640988d1b 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Intro.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Intro.c @@ -995,2153 +995,1791 @@ goto _start; } case 1: { -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; uint8_t x_29; lean_dec(x_17); x_24 = lean_ctor_get(x_18, 1); lean_inc(x_24); -lean_dec(x_18); -x_25 = lean_ctor_get(x_19, 0); -lean_inc(x_25); +if (lean_is_exclusive(x_18)) { + lean_ctor_release(x_18, 0); + lean_ctor_release(x_18, 1); + x_25 = x_18; +} else { + lean_dec_ref(x_18); + x_25 = lean_box(0); +} +x_26 = lean_ctor_get(x_19, 0); +lean_inc(x_26); lean_dec(x_19); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_5, x_26); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_5, x_27); lean_dec(x_5); -x_28 = !lean_is_exclusive(x_24); -if (x_28 == 0) +x_29 = !lean_is_exclusive(x_24); +if (x_29 == 0) { -lean_object* x_29; uint8_t x_30; -x_29 = lean_ctor_get(x_24, 2); -x_30 = !lean_is_exclusive(x_29); -if (x_30 == 0) +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_24, 2); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) { -lean_object* x_31; lean_object* x_32; uint8_t x_33; -x_31 = lean_ctor_get(x_29, 2); -x_32 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_29, 2, x_32); -x_33 = !lean_is_exclusive(x_6); -if (x_33 == 0) +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_84; uint8_t x_85; +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) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_34 = lean_ctor_get(x_6, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_25); -lean_ctor_set(x_35, 1, x_13); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_6, 2, x_36); -x_37 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_6, x_24); -if (lean_obj_tag(x_37) == 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_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_37, 1); -lean_inc(x_38); -x_39 = lean_ctor_get(x_38, 2); -lean_inc(x_39); -x_40 = !lean_is_exclusive(x_37); -if (x_40 == 0) -{ -lean_object* x_41; uint8_t x_42; -x_41 = lean_ctor_get(x_37, 1); -lean_dec(x_41); -x_42 = !lean_is_exclusive(x_38); -if (x_42 == 0) -{ -lean_object* x_43; uint8_t x_44; -x_43 = lean_ctor_get(x_38, 2); -lean_dec(x_43); -x_44 = !lean_is_exclusive(x_39); -if (x_44 == 0) -{ -lean_object* x_45; -x_45 = lean_ctor_get(x_39, 2); -lean_dec(x_45); -lean_ctor_set(x_39, 2, x_31); -return x_37; +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_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_46 = lean_ctor_get(x_39, 0); -x_47 = lean_ctor_get(x_39, 1); -x_48 = lean_ctor_get(x_39, 3); -lean_inc(x_48); -lean_inc(x_47); -lean_inc(x_46); -lean_dec(x_39); -x_49 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_49, 0, x_46); -lean_ctor_set(x_49, 1, x_47); -lean_ctor_set(x_49, 2, x_31); -lean_ctor_set(x_49, 3, x_48); -lean_ctor_set(x_38, 2, x_49); -return x_37; +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_33 = x_95; +x_34 = x_94; +goto block_83; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_50 = lean_ctor_get(x_38, 0); -x_51 = lean_ctor_get(x_38, 1); -x_52 = lean_ctor_get(x_38, 3); -x_53 = lean_ctor_get(x_38, 4); -x_54 = lean_ctor_get(x_38, 5); -lean_inc(x_54); -lean_inc(x_53); -lean_inc(x_52); +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_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; +} +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_33 = x_110; +x_34 = x_109; +goto block_83; +} +} +block_83: +{ +if (lean_obj_tag(x_33) == 0) +{ +lean_object* x_35; lean_object* x_36; uint8_t x_37; +x_35 = lean_ctor_get(x_34, 2); +lean_inc(x_35); +x_36 = lean_ctor_get(x_33, 0); +lean_inc(x_36); +lean_dec(x_33); +x_37 = !lean_is_exclusive(x_34); +if (x_37 == 0) +{ +lean_object* x_38; uint8_t x_39; +x_38 = lean_ctor_get(x_34, 2); +lean_dec(x_38); +x_39 = !lean_is_exclusive(x_35); +if (x_39 == 0) +{ +lean_object* x_40; lean_object* x_41; +x_40 = lean_ctor_get(x_35, 2); +lean_dec(x_40); +lean_ctor_set(x_35, 2, x_32); +if (lean_is_scalar(x_25)) { + x_41 = lean_alloc_ctor(1, 2, 0); +} else { + x_41 = x_25; + lean_ctor_set_tag(x_41, 1); +} +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_34); +return x_41; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_42 = lean_ctor_get(x_35, 0); +x_43 = lean_ctor_get(x_35, 1); +x_44 = lean_ctor_get(x_35, 3); +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); +if (lean_is_scalar(x_25)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_25; + lean_ctor_set_tag(x_46, 1); +} +lean_ctor_set(x_46, 0, x_36); +lean_ctor_set(x_46, 1, x_34); +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_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_inc(x_51); lean_inc(x_50); -lean_dec(x_38); -x_55 = lean_ctor_get(x_39, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_39, 1); -lean_inc(x_56); -x_57 = lean_ctor_get(x_39, 3); -lean_inc(x_57); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_58 = x_39; +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); +lean_inc(x_53); +x_54 = lean_ctor_get(x_35, 3); +lean_inc(x_54); +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; } else { - lean_dec_ref(x_39); - x_58 = lean_box(0); + lean_dec_ref(x_35); + x_55 = lean_box(0); } -if (lean_is_scalar(x_58)) { - x_59 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 4, 0); } else { - x_59 = x_58; + x_56 = x_55; } -lean_ctor_set(x_59, 0, x_55); -lean_ctor_set(x_59, 1, x_56); -lean_ctor_set(x_59, 2, x_31); -lean_ctor_set(x_59, 3, x_57); -x_60 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_60, 0, x_50); -lean_ctor_set(x_60, 1, x_51); -lean_ctor_set(x_60, 2, x_59); -lean_ctor_set(x_60, 3, x_52); -lean_ctor_set(x_60, 4, x_53); -lean_ctor_set(x_60, 5, x_54); -lean_ctor_set(x_37, 1, x_60); -return x_37; +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); +if (lean_is_scalar(x_25)) { + x_58 = lean_alloc_ctor(1, 2, 0); +} else { + x_58 = x_25; + lean_ctor_set_tag(x_58, 1); +} +lean_ctor_set(x_58, 0, x_36); +lean_ctor_set(x_58, 1, x_57); +return x_58; } } 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; -x_61 = lean_ctor_get(x_37, 0); -lean_inc(x_61); -lean_dec(x_37); -x_62 = lean_ctor_get(x_38, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_38, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_38, 3); -lean_inc(x_64); -x_65 = lean_ctor_get(x_38, 4); -lean_inc(x_65); -x_66 = lean_ctor_get(x_38, 5); -lean_inc(x_66); -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); - lean_ctor_release(x_38, 5); - x_67 = x_38; +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_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); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; +x_64 = lean_ctor_get(x_59, 2); +lean_dec(x_64); +lean_ctor_set(x_59, 2, x_32); +if (lean_is_scalar(x_25)) { + x_65 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_38); - x_67 = lean_box(0); + x_65 = x_25; } -x_68 = lean_ctor_get(x_39, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_34); +return x_65; +} +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_inc(x_68); -x_69 = lean_ctor_get(x_39, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_39, 3); -lean_inc(x_70); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - x_71 = x_39; +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); +if (lean_is_scalar(x_25)) { + x_70 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_39); - x_71 = lean_box(0); + x_70 = x_25; } -if (lean_is_scalar(x_71)) { - x_72 = lean_alloc_ctor(0, 4, 0); -} else { - x_72 = x_71; -} -lean_ctor_set(x_72, 0, x_68); -lean_ctor_set(x_72, 1, x_69); -lean_ctor_set(x_72, 2, x_31); -lean_ctor_set(x_72, 3, x_70); -if (lean_is_scalar(x_67)) { - x_73 = lean_alloc_ctor(0, 6, 0); -} else { - x_73 = x_67; -} -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); -x_74 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_74, 0, x_61); -lean_ctor_set(x_74, 1, x_73); -return x_74; +lean_ctor_set(x_70, 0, x_60); +lean_ctor_set(x_70, 1, x_34); +return x_70; } } else { -lean_object* x_75; lean_object* x_76; uint8_t x_77; -x_75 = lean_ctor_get(x_37, 1); +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_inc(x_75); -x_76 = lean_ctor_get(x_75, 2); +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_is_exclusive(x_37); -if (x_77 == 0) -{ -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_37, 1); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_75); -if (x_79 == 0) -{ -lean_object* x_80; uint8_t x_81; -x_80 = lean_ctor_get(x_75, 2); -lean_dec(x_80); -x_81 = !lean_is_exclusive(x_76); -if (x_81 == 0) -{ -lean_object* x_82; -x_82 = lean_ctor_get(x_76, 2); -lean_dec(x_82); -lean_ctor_set(x_76, 2, x_31); -return x_37; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_83 = lean_ctor_get(x_76, 0); -x_84 = lean_ctor_get(x_76, 1); -x_85 = lean_ctor_get(x_76, 3); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_76); -x_86 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_86, 0, x_83); -lean_ctor_set(x_86, 1, x_84); -lean_ctor_set(x_86, 2, x_31); -lean_ctor_set(x_86, 3, x_85); -lean_ctor_set(x_75, 2, x_86); -return x_37; -} -} -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; -x_87 = lean_ctor_get(x_75, 0); -x_88 = lean_ctor_get(x_75, 1); -x_89 = lean_ctor_get(x_75, 3); -x_90 = lean_ctor_get(x_75, 4); -x_91 = lean_ctor_get(x_75, 5); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_75); -x_92 = lean_ctor_get(x_76, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_76, 1); -lean_inc(x_93); -x_94 = lean_ctor_get(x_76, 3); -lean_inc(x_94); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - x_95 = 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; } else { - lean_dec_ref(x_76); - x_95 = lean_box(0); + lean_dec_ref(x_59); + x_79 = lean_box(0); } -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 4, 0); } else { - x_96 = x_95; + x_80 = x_79; } -lean_ctor_set(x_96, 0, x_92); -lean_ctor_set(x_96, 1, x_93); -lean_ctor_set(x_96, 2, x_31); -lean_ctor_set(x_96, 3, x_94); -x_97 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_97, 0, x_87); -lean_ctor_set(x_97, 1, x_88); -lean_ctor_set(x_97, 2, x_96); -lean_ctor_set(x_97, 3, x_89); -lean_ctor_set(x_97, 4, x_90); -lean_ctor_set(x_97, 5, x_91); -lean_ctor_set(x_37, 1, x_97); -return x_37; -} -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_98 = lean_ctor_get(x_37, 0); -lean_inc(x_98); -lean_dec(x_37); -x_99 = lean_ctor_get(x_75, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_75, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_75, 3); -lean_inc(x_101); -x_102 = lean_ctor_get(x_75, 4); -lean_inc(x_102); -x_103 = lean_ctor_get(x_75, 5); -lean_inc(x_103); -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); - lean_ctor_release(x_75, 5); - x_104 = x_75; +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); +if (lean_is_scalar(x_25)) { + x_82 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_75); - x_104 = lean_box(0); + x_82 = x_25; } -x_105 = lean_ctor_get(x_76, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_76, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_76, 3); -lean_inc(x_107); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - lean_ctor_release(x_76, 1); - lean_ctor_release(x_76, 2); - lean_ctor_release(x_76, 3); - x_108 = x_76; -} else { - lean_dec_ref(x_76); - x_108 = lean_box(0); +lean_ctor_set(x_82, 0, x_60); +lean_ctor_set(x_82, 1, x_81); +return x_82; } -if (lean_is_scalar(x_108)) { - x_109 = lean_alloc_ctor(0, 4, 0); -} else { - x_109 = x_108; -} -lean_ctor_set(x_109, 0, x_105); -lean_ctor_set(x_109, 1, x_106); -lean_ctor_set(x_109, 2, x_31); -lean_ctor_set(x_109, 3, x_107); -if (lean_is_scalar(x_104)) { - x_110 = lean_alloc_ctor(0, 6, 0); -} else { - x_110 = x_104; -} -lean_ctor_set(x_110, 0, x_99); -lean_ctor_set(x_110, 1, x_100); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_101); -lean_ctor_set(x_110, 4, x_102); -lean_ctor_set(x_110, 5, x_103); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_98); -lean_ctor_set(x_111, 1, x_110); -return x_111; } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_112 = lean_ctor_get(x_6, 0); -x_113 = lean_ctor_get(x_6, 1); -x_114 = lean_ctor_get(x_6, 2); -x_115 = lean_ctor_get(x_6, 3); -x_116 = lean_ctor_get(x_6, 4); -lean_inc(x_116); -lean_inc(x_115); +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_dec(x_6); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_25); -lean_ctor_set(x_117, 1, x_13); -x_118 = lean_array_push(x_114, x_117); -x_119 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_119, 0, x_112); -lean_ctor_set(x_119, 1, x_113); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_115); -lean_ctor_set(x_119, 4, x_116); -x_120 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_119, x_24); -if (lean_obj_tag(x_120) == 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_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_120, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_121, 2); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 0); -lean_inc(x_123); -if (lean_is_exclusive(x_120)) { - lean_ctor_release(x_120, 0); - lean_ctor_release(x_120, 1); - x_124 = x_120; +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_120); + 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_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_121, 0); +x_125 = lean_ctor_get(x_117, 0); lean_inc(x_125); -x_126 = lean_ctor_get(x_121, 1); +x_126 = lean_ctor_get(x_117, 1); lean_inc(x_126); -x_127 = lean_ctor_get(x_121, 3); +x_127 = lean_ctor_get(x_117, 3); lean_inc(x_127); -x_128 = lean_ctor_get(x_121, 4); -lean_inc(x_128); -x_129 = lean_ctor_get(x_121, 5); -lean_inc(x_129); -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_130 = x_121; +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_121); - x_130 = lean_box(0); + lean_dec_ref(x_117); + x_128 = lean_box(0); } -x_131 = lean_ctor_get(x_122, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_122, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_122, 3); -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); - x_134 = x_122; +if (lean_is_scalar(x_128)) { + x_129 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_122); - x_134 = lean_box(0); + x_129 = x_128; } -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_31); -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); +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_137 = lean_alloc_ctor(0, 2, 0); + x_130 = lean_alloc_ctor(0, 6, 0); } else { - x_137 = x_124; + x_130 = x_124; } -lean_ctor_set(x_137, 0, x_123); -lean_ctor_set(x_137, 1, x_136); -return x_137; +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_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_138 = lean_ctor_get(x_120, 1); +lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; 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); -x_139 = lean_ctor_get(x_138, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_120, 0); +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); -if (lean_is_exclusive(x_120)) { - lean_ctor_release(x_120, 0); - lean_ctor_release(x_120, 1); - x_141 = x_120; -} else { - lean_dec_ref(x_120); - x_141 = lean_box(0); -} -x_142 = lean_ctor_get(x_138, 0); +x_141 = lean_ctor_get(x_132, 1); +lean_inc(x_141); +x_142 = lean_ctor_get(x_132, 3); lean_inc(x_142); -x_143 = lean_ctor_get(x_138, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_138, 3); -lean_inc(x_144); -x_145 = lean_ctor_get(x_138, 4); -lean_inc(x_145); -x_146 = lean_ctor_get(x_138, 5); -lean_inc(x_146); -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); - lean_ctor_release(x_138, 5); - x_147 = x_138; +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_138); - x_147 = lean_box(0); + lean_dec_ref(x_132); + x_143 = lean_box(0); } -x_148 = lean_ctor_get(x_139, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_139, 3); -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); - x_151 = x_139; +if (lean_is_scalar(x_143)) { + x_144 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_139); - x_151 = lean_box(0); + x_144 = x_143; } -if (lean_is_scalar(x_151)) { - x_152 = lean_alloc_ctor(0, 4, 0); +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_152 = x_151; + x_145 = x_139; } -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_31); -lean_ctor_set(x_152, 3, x_150); -if (lean_is_scalar(x_147)) { - x_153 = lean_alloc_ctor(0, 6, 0); +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_153 = x_147; + x_146 = x_25; } -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_141)) { - x_154 = lean_alloc_ctor(1, 2, 0); -} else { - x_154 = x_141; +lean_ctor_set(x_146, 0, x_133); +lean_ctor_set(x_146, 1, x_145); +return x_146; } -lean_ctor_set(x_154, 0, x_140); -lean_ctor_set(x_154, 1, x_153); -return x_154; } } } else { -lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_155 = lean_ctor_get(x_29, 0); -x_156 = lean_ctor_get(x_29, 1); -x_157 = lean_ctor_get(x_29, 2); -x_158 = lean_ctor_get(x_29, 3); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_inc(x_155); -lean_dec(x_29); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_155); -lean_ctor_set(x_160, 1, x_156); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_158); -lean_ctor_set(x_24, 2, x_160); -x_161 = lean_ctor_get(x_6, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_6, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_6, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_6, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_6, 4); -lean_inc(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_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); 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_166 = x_6; + x_218 = x_6; } else { lean_dec_ref(x_6); - x_166 = lean_box(0); + x_218 = lean_box(0); } -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_25); -lean_ctor_set(x_167, 1, x_13); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 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_221 = lean_alloc_ctor(0, 5, 0); } else { - x_169 = x_166; + x_221 = x_218; } -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_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_169, x_24); -if (lean_obj_tag(x_170) == 0) +lean_ctor_set(x_221, 0, x_213); +lean_ctor_set(x_221, 1, x_214); +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_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_171 = lean_ctor_get(x_170, 1); -lean_inc(x_171); -x_172 = lean_ctor_get(x_171, 2); -lean_inc(x_172); -x_173 = lean_ctor_get(x_170, 0); -lean_inc(x_173); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_174 = x_170; -} else { - lean_dec_ref(x_170); - x_174 = lean_box(0); -} -x_175 = lean_ctor_get(x_171, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_171, 1); -lean_inc(x_176); -x_177 = lean_ctor_get(x_171, 3); -lean_inc(x_177); -x_178 = lean_ctor_get(x_171, 4); -lean_inc(x_178); -x_179 = lean_ctor_get(x_171, 5); -lean_inc(x_179); -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_180 = x_171; -} else { - lean_dec_ref(x_171); - 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); -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_184 = x_172; -} else { - lean_dec_ref(x_172); - x_184 = lean_box(0); -} -if (lean_is_scalar(x_184)) { - x_185 = lean_alloc_ctor(0, 4, 0); -} else { - x_185 = x_184; -} -lean_ctor_set(x_185, 0, x_181); -lean_ctor_set(x_185, 1, x_182); -lean_ctor_set(x_185, 2, x_157); -lean_ctor_set(x_185, 3, x_183); -if (lean_is_scalar(x_180)) { - x_186 = lean_alloc_ctor(0, 6, 0); -} else { - x_186 = x_180; -} -lean_ctor_set(x_186, 0, x_175); -lean_ctor_set(x_186, 1, x_176); -lean_ctor_set(x_186, 2, x_185); -lean_ctor_set(x_186, 3, x_177); -lean_ctor_set(x_186, 4, x_178); -lean_ctor_set(x_186, 5, x_179); -if (lean_is_scalar(x_174)) { - x_187 = lean_alloc_ctor(0, 2, 0); -} else { - x_187 = x_174; -} -lean_ctor_set(x_187, 0, x_173); -lean_ctor_set(x_187, 1, x_186); -return x_187; +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_177 = x_225; +x_178 = x_224; +goto block_209; } 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; -x_188 = lean_ctor_get(x_170, 1); +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_177 = x_228; +x_178 = x_227; +goto block_209; +} +block_209: +{ +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_188, 2); +x_189 = lean_ctor_get(x_179, 3); lean_inc(x_189); -x_190 = lean_ctor_get(x_170, 0); -lean_inc(x_190); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_191 = x_170; +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_170); - x_191 = lean_box(0); + lean_dec_ref(x_179); + x_190 = lean_box(0); } -x_192 = lean_ctor_get(x_188, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_188, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_188, 3); +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; +} +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_188, 4); +x_195 = lean_ctor_get(x_177, 0); lean_inc(x_195); -x_196 = lean_ctor_get(x_188, 5); +lean_dec(x_177); +x_196 = lean_ctor_get(x_178, 0); lean_inc(x_196); -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_197 = x_188; -} else { - lean_dec_ref(x_188); - x_197 = lean_box(0); -} -x_198 = lean_ctor_get(x_189, 0); +x_197 = lean_ctor_get(x_178, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_178, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_189, 1); +x_199 = lean_ctor_get(x_178, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_189, 3); +x_200 = lean_ctor_get(x_178, 5); lean_inc(x_200); -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_201 = x_189; +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; } else { - lean_dec_ref(x_189); + lean_dec_ref(x_178); x_201 = 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; +} else { + lean_dec_ref(x_194); + x_205 = lean_box(0); +} +if (lean_is_scalar(x_205)) { + x_206 = lean_alloc_ctor(0, 4, 0); +} else { + x_206 = x_205; +} +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_202 = lean_alloc_ctor(0, 4, 0); + x_207 = lean_alloc_ctor(0, 6, 0); } else { - x_202 = x_201; + x_207 = 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_157); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_25)) { + x_208 = lean_alloc_ctor(0, 2, 0); } else { - x_203 = x_197; + x_208 = x_25; } -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_191)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_191; +lean_ctor_set(x_208, 0, x_195); +lean_ctor_set(x_208, 1, x_207); +return x_208; } -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; 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_205 = lean_ctor_get(x_24, 2); -x_206 = lean_ctor_get(x_24, 0); -x_207 = lean_ctor_get(x_24, 1); -x_208 = lean_ctor_get(x_24, 3); -x_209 = lean_ctor_get(x_24, 4); -x_210 = lean_ctor_get(x_24, 5); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_208); -lean_inc(x_205); -lean_inc(x_207); -lean_inc(x_206); -lean_dec(x_24); -x_211 = lean_ctor_get(x_205, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_205, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_205, 2); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 3); -lean_inc(x_214); -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_215 = x_205; -} else { - lean_dec_ref(x_205); - x_215 = lean_box(0); -} -x_216 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_215)) { - x_217 = lean_alloc_ctor(0, 4, 0); -} else { - x_217 = x_215; -} -lean_ctor_set(x_217, 0, x_211); -lean_ctor_set(x_217, 1, x_212); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_214); -x_218 = lean_alloc_ctor(0, 6, 0); -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); -x_219 = lean_ctor_get(x_6, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_6, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_6, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_6, 3); -lean_inc(x_222); -x_223 = lean_ctor_get(x_6, 4); -lean_inc(x_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_224 = x_6; -} else { - lean_dec_ref(x_6); - x_224 = lean_box(0); -} -x_225 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_225, 0, x_25); -lean_ctor_set(x_225, 1, x_13); -x_226 = lean_array_push(x_221, x_225); -if (lean_is_scalar(x_224)) { - x_227 = lean_alloc_ctor(0, 5, 0); -} else { - x_227 = x_224; -} -lean_ctor_set(x_227, 0, x_219); -lean_ctor_set(x_227, 1, x_220); -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_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_227, x_218); -if (lean_obj_tag(x_228) == 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; -x_229 = lean_ctor_get(x_228, 1); -lean_inc(x_229); -x_230 = lean_ctor_get(x_229, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_228, 0); -lean_inc(x_231); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - x_232 = x_228; -} else { - lean_dec_ref(x_228); - x_232 = lean_box(0); -} -x_233 = lean_ctor_get(x_229, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_229, 3); -lean_inc(x_235); -x_236 = lean_ctor_get(x_229, 4); -lean_inc(x_236); -x_237 = lean_ctor_get(x_229, 5); -lean_inc(x_237); -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_238 = x_229; -} else { - lean_dec_ref(x_229); - x_238 = lean_box(0); -} -x_239 = lean_ctor_get(x_230, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_230, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_230, 3); -lean_inc(x_241); -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_242 = x_230; -} else { - lean_dec_ref(x_230); - x_242 = lean_box(0); -} -if (lean_is_scalar(x_242)) { - x_243 = lean_alloc_ctor(0, 4, 0); -} else { - x_243 = x_242; -} -lean_ctor_set(x_243, 0, x_239); -lean_ctor_set(x_243, 1, x_240); -lean_ctor_set(x_243, 2, x_213); -lean_ctor_set(x_243, 3, x_241); -if (lean_is_scalar(x_238)) { - x_244 = lean_alloc_ctor(0, 6, 0); -} else { - x_244 = x_238; -} -lean_ctor_set(x_244, 0, x_233); -lean_ctor_set(x_244, 1, x_234); -lean_ctor_set(x_244, 2, x_243); -lean_ctor_set(x_244, 3, x_235); -lean_ctor_set(x_244, 4, x_236); -lean_ctor_set(x_244, 5, x_237); -if (lean_is_scalar(x_232)) { - x_245 = lean_alloc_ctor(0, 2, 0); -} else { - x_245 = x_232; -} -lean_ctor_set(x_245, 0, x_231); -lean_ctor_set(x_245, 1, x_244); -return x_245; -} -else -{ -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; -x_246 = lean_ctor_get(x_228, 1); -lean_inc(x_246); -x_247 = lean_ctor_get(x_246, 2); -lean_inc(x_247); -x_248 = lean_ctor_get(x_228, 0); -lean_inc(x_248); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - x_249 = x_228; -} else { - lean_dec_ref(x_228); - x_249 = lean_box(0); -} -x_250 = lean_ctor_get(x_246, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_246, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_246, 3); -lean_inc(x_252); -x_253 = lean_ctor_get(x_246, 4); -lean_inc(x_253); -x_254 = lean_ctor_get(x_246, 5); -lean_inc(x_254); -if (lean_is_exclusive(x_246)) { - lean_ctor_release(x_246, 0); - lean_ctor_release(x_246, 1); - lean_ctor_release(x_246, 2); - lean_ctor_release(x_246, 3); - lean_ctor_release(x_246, 4); - lean_ctor_release(x_246, 5); - x_255 = x_246; -} else { - lean_dec_ref(x_246); - x_255 = lean_box(0); -} -x_256 = lean_ctor_get(x_247, 0); -lean_inc(x_256); -x_257 = lean_ctor_get(x_247, 1); -lean_inc(x_257); -x_258 = lean_ctor_get(x_247, 3); -lean_inc(x_258); -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_259 = x_247; -} else { - lean_dec_ref(x_247); - x_259 = lean_box(0); -} -if (lean_is_scalar(x_259)) { - x_260 = lean_alloc_ctor(0, 4, 0); -} else { - x_260 = x_259; -} -lean_ctor_set(x_260, 0, x_256); -lean_ctor_set(x_260, 1, x_257); -lean_ctor_set(x_260, 2, x_213); -lean_ctor_set(x_260, 3, x_258); -if (lean_is_scalar(x_255)) { - x_261 = lean_alloc_ctor(0, 6, 0); -} else { - x_261 = x_255; -} -lean_ctor_set(x_261, 0, x_250); -lean_ctor_set(x_261, 1, x_251); -lean_ctor_set(x_261, 2, x_260); -lean_ctor_set(x_261, 3, x_252); -lean_ctor_set(x_261, 4, x_253); -lean_ctor_set(x_261, 5, x_254); -if (lean_is_scalar(x_249)) { - x_262 = lean_alloc_ctor(1, 2, 0); -} else { - x_262 = x_249; -} -lean_ctor_set(x_262, 0, x_248); -lean_ctor_set(x_262, 1, x_261); -return x_262; } } } default: { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_18, 1); -lean_inc(x_263); +lean_object* x_229; lean_object* x_230; +x_229 = lean_ctor_get(x_18, 1); +lean_inc(x_229); lean_dec(x_18); lean_inc(x_6); -x_264 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_263); -if (lean_obj_tag(x_264) == 0) +x_230 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_229); +if (lean_obj_tag(x_230) == 0) { -lean_object* x_265; -x_265 = lean_ctor_get(x_264, 0); -lean_inc(x_265); -if (lean_obj_tag(x_265) == 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_266; lean_object* x_267; lean_object* x_268; +lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_dec(x_13); -x_266 = lean_ctor_get(x_264, 1); -lean_inc(x_266); -lean_dec(x_264); -x_267 = lean_unsigned_to_nat(1u); -x_268 = lean_nat_add(x_5, x_267); +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); lean_dec(x_5); -x_5 = x_268; -x_7 = x_266; +x_5 = x_234; +x_7 = x_232; goto _start; } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_270 = lean_ctor_get(x_264, 1); -lean_inc(x_270); -lean_dec(x_264); -x_271 = lean_ctor_get(x_265, 0); -lean_inc(x_271); -lean_dec(x_265); -x_272 = lean_unsigned_to_nat(1u); -x_273 = lean_nat_add(x_5, x_272); +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; +} else { + lean_dec_ref(x_230); + x_237 = 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_274 = !lean_is_exclusive(x_270); -if (x_274 == 0) +x_241 = !lean_is_exclusive(x_236); +if (x_241 == 0) { -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_270, 2); -x_276 = !lean_is_exclusive(x_275); -if (x_276 == 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_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_275, 2); -x_278 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_275, 2, x_278); -x_279 = !lean_is_exclusive(x_6); -if (x_279 == 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_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_280 = lean_ctor_get(x_6, 2); -x_281 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_281, 0, x_271); -lean_ctor_set(x_281, 1, x_13); -x_282 = lean_array_push(x_280, x_281); -lean_ctor_set(x_6, 2, x_282); -x_283 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_273, x_6, x_270); -if (lean_obj_tag(x_283) == 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_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_283, 1); -lean_inc(x_284); -x_285 = lean_ctor_get(x_284, 2); -lean_inc(x_285); -x_286 = !lean_is_exclusive(x_283); -if (x_286 == 0) -{ -lean_object* x_287; uint8_t x_288; -x_287 = lean_ctor_get(x_283, 1); -lean_dec(x_287); -x_288 = !lean_is_exclusive(x_284); -if (x_288 == 0) -{ -lean_object* x_289; uint8_t x_290; -x_289 = lean_ctor_get(x_284, 2); -lean_dec(x_289); -x_290 = !lean_is_exclusive(x_285); -if (x_290 == 0) -{ -lean_object* x_291; -x_291 = lean_ctor_get(x_285, 2); -lean_dec(x_291); -lean_ctor_set(x_285, 2, x_277); -return x_283; -} -else -{ -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -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_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_277); -lean_ctor_set(x_295, 3, x_294); -lean_ctor_set(x_284, 2, x_295); -return x_283; -} -} -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; -x_296 = lean_ctor_get(x_284, 0); -x_297 = lean_ctor_get(x_284, 1); -x_298 = lean_ctor_get(x_284, 3); -x_299 = lean_ctor_get(x_284, 4); -x_300 = lean_ctor_get(x_284, 5); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_dec(x_284); -x_301 = lean_ctor_get(x_285, 0); -lean_inc(x_301); -x_302 = lean_ctor_get(x_285, 1); +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_285, 3); +x_303 = lean_ctor_get(x_301, 1); lean_inc(x_303); -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_304 = x_285; -} else { - lean_dec_ref(x_285); - x_304 = lean_box(0); +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; } -if (lean_is_scalar(x_304)) { - x_305 = lean_alloc_ctor(0, 4, 0); -} else { - x_305 = x_304; -} -lean_ctor_set(x_305, 0, x_301); -lean_ctor_set(x_305, 1, x_302); -lean_ctor_set(x_305, 2, x_277); -lean_ctor_set(x_305, 3, x_303); -x_306 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_306, 0, x_296); -lean_ctor_set(x_306, 1, x_297); -lean_ctor_set(x_306, 2, x_305); -lean_ctor_set(x_306, 3, x_298); -lean_ctor_set(x_306, 4, x_299); -lean_ctor_set(x_306, 5, x_300); -lean_ctor_set(x_283, 1, x_306); -return x_283; +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_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; lean_object* x_320; -x_307 = lean_ctor_get(x_283, 0); -lean_inc(x_307); -lean_dec(x_283); -x_308 = lean_ctor_get(x_284, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_284, 1); -lean_inc(x_309); -x_310 = lean_ctor_get(x_284, 3); -lean_inc(x_310); -x_311 = lean_ctor_get(x_284, 4); -lean_inc(x_311); -x_312 = lean_ctor_get(x_284, 5); +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); -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_313 = x_284; -} else { - lean_dec_ref(x_284); - x_313 = lean_box(0); -} -x_314 = lean_ctor_get(x_285, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_285, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_285, 3); -lean_inc(x_316); -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_317 = x_285; -} else { - lean_dec_ref(x_285); - x_317 = lean_box(0); -} -if (lean_is_scalar(x_317)) { - x_318 = lean_alloc_ctor(0, 4, 0); -} else { - x_318 = x_317; -} -lean_ctor_set(x_318, 0, x_314); -lean_ctor_set(x_318, 1, x_315); -lean_ctor_set(x_318, 2, x_277); -lean_ctor_set(x_318, 3, x_316); -if (lean_is_scalar(x_313)) { - x_319 = lean_alloc_ctor(0, 6, 0); -} else { - x_319 = x_313; -} -lean_ctor_set(x_319, 0, x_308); -lean_ctor_set(x_319, 1, x_309); -lean_ctor_set(x_319, 2, x_318); -lean_ctor_set(x_319, 3, x_310); -lean_ctor_set(x_319, 4, x_311); -lean_ctor_set(x_319, 5, x_312); -x_320 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_320, 0, x_307); -lean_ctor_set(x_320, 1, x_319); -return x_320; -} -} -else -{ -lean_object* x_321; lean_object* x_322; uint8_t x_323; -x_321 = lean_ctor_get(x_283, 1); -lean_inc(x_321); -x_322 = lean_ctor_get(x_321, 2); -lean_inc(x_322); -x_323 = !lean_is_exclusive(x_283); -if (x_323 == 0) -{ -lean_object* x_324; uint8_t x_325; -x_324 = lean_ctor_get(x_283, 1); -lean_dec(x_324); -x_325 = !lean_is_exclusive(x_321); -if (x_325 == 0) -{ -lean_object* x_326; uint8_t x_327; -x_326 = lean_ctor_get(x_321, 2); -lean_dec(x_326); -x_327 = !lean_is_exclusive(x_322); -if (x_327 == 0) -{ -lean_object* x_328; -x_328 = lean_ctor_get(x_322, 2); -lean_dec(x_328); -lean_ctor_set(x_322, 2, x_277); -return x_283; -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; -x_329 = lean_ctor_get(x_322, 0); -x_330 = lean_ctor_get(x_322, 1); -x_331 = lean_ctor_get(x_322, 3); -lean_inc(x_331); -lean_inc(x_330); -lean_inc(x_329); -lean_dec(x_322); -x_332 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_332, 0, x_329); -lean_ctor_set(x_332, 1, x_330); -lean_ctor_set(x_332, 2, x_277); -lean_ctor_set(x_332, 3, x_331); -lean_ctor_set(x_321, 2, x_332); -return x_283; -} -} -else -{ -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_333 = lean_ctor_get(x_321, 0); -x_334 = lean_ctor_get(x_321, 1); -x_335 = lean_ctor_get(x_321, 3); -x_336 = lean_ctor_get(x_321, 4); -x_337 = lean_ctor_get(x_321, 5); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_inc(x_333); -lean_dec(x_321); -x_338 = lean_ctor_get(x_322, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_322, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_322, 3); -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; -} else { - lean_dec_ref(x_322); - 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_277); -lean_ctor_set(x_342, 3, x_340); -x_343 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_343, 0, x_333); -lean_ctor_set(x_343, 1, x_334); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_335); -lean_ctor_set(x_343, 4, x_336); -lean_ctor_set(x_343, 5, x_337); -lean_ctor_set(x_283, 1, x_343); -return x_283; -} -} -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; -x_344 = lean_ctor_get(x_283, 0); -lean_inc(x_344); -lean_dec(x_283); -x_345 = lean_ctor_get(x_321, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_321, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_321, 3); -lean_inc(x_347); -x_348 = lean_ctor_get(x_321, 4); -lean_inc(x_348); -x_349 = lean_ctor_get(x_321, 5); -lean_inc(x_349); -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_350 = x_321; -} else { - lean_dec_ref(x_321); - x_350 = lean_box(0); -} -x_351 = lean_ctor_get(x_322, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_322, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_322, 3); -lean_inc(x_353); -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_354 = x_322; -} else { - lean_dec_ref(x_322); - 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_277); -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); -x_357 = lean_alloc_ctor(1, 2, 0); -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; -x_358 = lean_ctor_get(x_6, 0); -x_359 = lean_ctor_get(x_6, 1); -x_360 = lean_ctor_get(x_6, 2); -x_361 = lean_ctor_get(x_6, 3); -x_362 = lean_ctor_get(x_6, 4); -lean_inc(x_362); -lean_inc(x_361); -lean_inc(x_360); -lean_inc(x_359); -lean_inc(x_358); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); lean_dec(x_6); -x_363 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_363, 0, x_271); -lean_ctor_set(x_363, 1, x_13); -x_364 = lean_array_push(x_360, x_363); -x_365 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_365, 0, x_358); -lean_ctor_set(x_365, 1, x_359); -lean_ctor_set(x_365, 2, x_364); -lean_ctor_set(x_365, 3, x_361); -lean_ctor_set(x_365, 4, x_362); -x_366 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_273, x_365, x_270); -if (lean_obj_tag(x_366) == 0) +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_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; -x_367 = lean_ctor_get(x_366, 1); -lean_inc(x_367); -x_368 = lean_ctor_get(x_367, 2); -lean_inc(x_368); -x_369 = lean_ctor_get(x_366, 0); -lean_inc(x_369); -if (lean_is_exclusive(x_366)) { - lean_ctor_release(x_366, 0); - lean_ctor_release(x_366, 1); - x_370 = x_366; -} else { - lean_dec_ref(x_366); - x_370 = lean_box(0); -} -x_371 = lean_ctor_get(x_367, 0); -lean_inc(x_371); -x_372 = lean_ctor_get(x_367, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_367, 3); -lean_inc(x_373); -x_374 = lean_ctor_get(x_367, 4); -lean_inc(x_374); -x_375 = lean_ctor_get(x_367, 5); -lean_inc(x_375); -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); - lean_ctor_release(x_367, 5); - x_376 = x_367; -} else { - lean_dec_ref(x_367); - x_376 = lean_box(0); -} -x_377 = lean_ctor_get(x_368, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_368, 1); -lean_inc(x_378); -x_379 = lean_ctor_get(x_368, 3); -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); - 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, 4, 0); -} else { - x_381 = x_380; -} -lean_ctor_set(x_381, 0, x_377); -lean_ctor_set(x_381, 1, x_378); -lean_ctor_set(x_381, 2, x_277); -lean_ctor_set(x_381, 3, x_379); -if (lean_is_scalar(x_376)) { - x_382 = lean_alloc_ctor(0, 6, 0); -} else { - x_382 = x_376; -} -lean_ctor_set(x_382, 0, x_371); -lean_ctor_set(x_382, 1, x_372); -lean_ctor_set(x_382, 2, x_381); -lean_ctor_set(x_382, 3, x_373); -lean_ctor_set(x_382, 4, x_374); -lean_ctor_set(x_382, 5, x_375); -if (lean_is_scalar(x_370)) { - x_383 = lean_alloc_ctor(0, 2, 0); -} else { - x_383 = x_370; -} -lean_ctor_set(x_383, 0, x_369); -lean_ctor_set(x_383, 1, x_382); -return x_383; +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_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_366, 1); -lean_inc(x_384); -x_385 = lean_ctor_get(x_384, 2); -lean_inc(x_385); -x_386 = lean_ctor_get(x_366, 0); -lean_inc(x_386); -if (lean_is_exclusive(x_366)) { - lean_ctor_release(x_366, 0); - lean_ctor_release(x_366, 1); - x_387 = x_366; -} else { - lean_dec_ref(x_366); - x_387 = lean_box(0); +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; } -x_388 = lean_ctor_get(x_384, 0); -lean_inc(x_388); -x_389 = lean_ctor_get(x_384, 1); -lean_inc(x_389); -x_390 = lean_ctor_get(x_384, 3); -lean_inc(x_390); -x_391 = lean_ctor_get(x_384, 4); -lean_inc(x_391); -x_392 = lean_ctor_get(x_384, 5); -lean_inc(x_392); -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); - lean_ctor_release(x_384, 5); - x_393 = x_384; -} else { - lean_dec_ref(x_384); - x_393 = lean_box(0); } -x_394 = lean_ctor_get(x_385, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_385, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_385, 3); -lean_inc(x_396); -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_397 = x_385; +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); +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); +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 { - lean_dec_ref(x_385); - x_397 = lean_box(0); + x_253 = x_237; + lean_ctor_set_tag(x_253, 1); } -if (lean_is_scalar(x_397)) { - x_398 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_253, 0, x_248); +lean_ctor_set(x_253, 1, x_246); +return x_253; +} +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_398 = x_397; + x_258 = x_237; + lean_ctor_set_tag(x_258, 1); } -lean_ctor_set(x_398, 0, x_394); -lean_ctor_set(x_398, 1, x_395); -lean_ctor_set(x_398, 2, x_277); -lean_ctor_set(x_398, 3, x_396); -if (lean_is_scalar(x_393)) { - x_399 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_258, 0, x_248); +lean_ctor_set(x_258, 1, x_246); +return x_258; +} +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; 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_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 { - x_399 = x_393; + lean_dec_ref(x_247); + x_267 = lean_box(0); } -lean_ctor_set(x_399, 0, x_388); -lean_ctor_set(x_399, 1, x_389); -lean_ctor_set(x_399, 2, x_398); -lean_ctor_set(x_399, 3, x_390); -lean_ctor_set(x_399, 4, x_391); -lean_ctor_set(x_399, 5, x_392); -if (lean_is_scalar(x_387)) { - x_400 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_267)) { + x_268 = lean_alloc_ctor(0, 4, 0); } else { - x_400 = x_387; + x_268 = x_267; +} +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, 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); +} else { + x_270 = x_237; + lean_ctor_set_tag(x_270, 1); +} +lean_ctor_set(x_270, 0, x_248); +lean_ctor_set(x_270, 1, x_269); +return x_270; +} +} +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_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_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); +} else { + x_282 = x_237; +} +lean_ctor_set(x_282, 0, x_272); +lean_ctor_set(x_282, 1, x_246); +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_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); +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; +} else { + lean_dec_ref(x_271); + x_291 = lean_box(0); +} +if (lean_is_scalar(x_291)) { + x_292 = lean_alloc_ctor(0, 4, 0); +} else { + x_292 = x_291; +} +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); +} else { + x_294 = x_237; +} +lean_ctor_set(x_294, 0, x_272); +lean_ctor_set(x_294, 1, x_293); +return x_294; } -lean_ctor_set(x_400, 0, x_386); -lean_ctor_set(x_400, 1, x_399); -return x_400; } } } else { -lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_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_401 = lean_ctor_get(x_275, 0); -x_402 = lean_ctor_get(x_275, 1); -x_403 = lean_ctor_get(x_275, 2); -x_404 = lean_ctor_get(x_275, 3); -lean_inc(x_404); -lean_inc(x_403); -lean_inc(x_402); -lean_inc(x_401); -lean_dec(x_275); -x_405 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_406 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_406, 0, x_401); -lean_ctor_set(x_406, 1, x_402); -lean_ctor_set(x_406, 2, x_405); -lean_ctor_set(x_406, 3, x_404); -lean_ctor_set(x_270, 2, x_406); -x_407 = lean_ctor_get(x_6, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_6, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_6, 2); -lean_inc(x_409); -x_410 = lean_ctor_get(x_6, 3); -lean_inc(x_410); -x_411 = lean_ctor_get(x_6, 4); -lean_inc(x_411); +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); 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_412 = x_6; + x_367 = x_6; } else { lean_dec_ref(x_6); - x_412 = lean_box(0); + x_367 = lean_box(0); } -x_413 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_413, 0, x_271); -lean_ctor_set(x_413, 1, x_13); -x_414 = lean_array_push(x_409, x_413); -if (lean_is_scalar(x_412)) { - x_415 = lean_alloc_ctor(0, 5, 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); } else { - x_415 = x_412; + x_370 = x_367; } -lean_ctor_set(x_415, 0, x_407); -lean_ctor_set(x_415, 1, x_408); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_410); -lean_ctor_set(x_415, 4, x_411); -x_416 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_273, x_415, x_270); -if (lean_obj_tag(x_416) == 0) +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_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; lean_object* x_433; -x_417 = lean_ctor_get(x_416, 1); -lean_inc(x_417); -x_418 = lean_ctor_get(x_417, 2); -lean_inc(x_418); -x_419 = lean_ctor_get(x_416, 0); -lean_inc(x_419); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - x_420 = x_416; -} else { - lean_dec_ref(x_416); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_417, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_417, 1); -lean_inc(x_422); -x_423 = lean_ctor_get(x_417, 3); -lean_inc(x_423); -x_424 = lean_ctor_get(x_417, 4); -lean_inc(x_424); -x_425 = lean_ctor_get(x_417, 5); -lean_inc(x_425); -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_426 = x_417; -} else { - lean_dec_ref(x_417); - x_426 = lean_box(0); -} -x_427 = lean_ctor_get(x_418, 0); -lean_inc(x_427); -x_428 = lean_ctor_get(x_418, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_418, 3); -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); - x_430 = x_418; -} else { - lean_dec_ref(x_418); - x_430 = lean_box(0); -} -if (lean_is_scalar(x_430)) { - x_431 = lean_alloc_ctor(0, 4, 0); -} else { - x_431 = x_430; -} -lean_ctor_set(x_431, 0, x_427); -lean_ctor_set(x_431, 1, x_428); -lean_ctor_set(x_431, 2, x_403); -lean_ctor_set(x_431, 3, x_429); -if (lean_is_scalar(x_426)) { - x_432 = lean_alloc_ctor(0, 6, 0); -} else { - x_432 = x_426; -} -lean_ctor_set(x_432, 0, x_421); -lean_ctor_set(x_432, 1, x_422); -lean_ctor_set(x_432, 2, x_431); -lean_ctor_set(x_432, 3, x_423); -lean_ctor_set(x_432, 4, x_424); -lean_ctor_set(x_432, 5, x_425); -if (lean_is_scalar(x_420)) { - x_433 = lean_alloc_ctor(0, 2, 0); -} else { - x_433 = x_420; -} -lean_ctor_set(x_433, 0, x_419); -lean_ctor_set(x_433, 1, x_432); -return x_433; +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; } 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; lean_object* x_450; -x_434 = lean_ctor_get(x_416, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_434, 2); -lean_inc(x_435); -x_436 = lean_ctor_get(x_416, 0); -lean_inc(x_436); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - x_437 = x_416; -} else { - lean_dec_ref(x_416); - x_437 = lean_box(0); +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; } +block_359: +{ +if (lean_obj_tag(x_327) == 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_inc(x_344); +x_345 = lean_ctor_get(x_327, 0); +lean_inc(x_345); +lean_dec(x_327); +x_346 = lean_ctor_get(x_328, 0); +lean_inc(x_346); +x_347 = lean_ctor_get(x_328, 1); +lean_inc(x_347); +x_348 = lean_ctor_get(x_328, 3); +lean_inc(x_348); +x_349 = lean_ctor_get(x_328, 4); +lean_inc(x_349); +x_350 = lean_ctor_get(x_328, 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; +} else { + lean_dec_ref(x_328); + x_351 = lean_box(0); +} +x_352 = lean_ctor_get(x_344, 0); +lean_inc(x_352); +x_353 = lean_ctor_get(x_344, 1); +lean_inc(x_353); +x_354 = lean_ctor_get(x_344, 3); +lean_inc(x_354); +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; +} else { + lean_dec_ref(x_344); + x_355 = lean_box(0); +} +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); +} else { + x_356 = x_355; +} +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); +if (lean_is_scalar(x_351)) { + x_357 = lean_alloc_ctor(0, 6, 0); +} else { + x_357 = 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); +} else { + x_358 = x_237; +} +lean_ctor_set(x_358, 0, x_345); +lean_ctor_set(x_358, 1, x_357); +return x_358; +} +} +} +} +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; +} else { + lean_dec_ref(x_378); + x_388 = 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); +} else { + x_423 = x_388; +} +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); +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; +} else { + lean_dec_ref(x_6); + x_430 = 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); +} else { + x_433 = x_430; +} +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_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; +} +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); -x_440 = lean_ctor_get(x_434, 3); -lean_inc(x_440); -x_441 = lean_ctor_get(x_434, 4); -lean_inc(x_441); -x_442 = lean_ctor_get(x_434, 5); -lean_inc(x_442); -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); - lean_ctor_release(x_434, 5); - x_443 = x_434; +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; +} +block_421: +{ +if (lean_obj_tag(x_389) == 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_434); - x_443 = lean_box(0); + lean_dec_ref(x_390); + x_398 = lean_box(0); } -x_444 = lean_ctor_get(x_435, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_435, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_435, 3); -lean_inc(x_446); -if (lean_is_exclusive(x_435)) { - lean_ctor_release(x_435, 0); - lean_ctor_release(x_435, 1); - lean_ctor_release(x_435, 2); - lean_ctor_release(x_435, 3); - x_447 = x_435; +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_435); - x_447 = lean_box(0); + lean_dec_ref(x_391); + x_402 = lean_box(0); } -if (lean_is_scalar(x_447)) { - x_448 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_402)) { + x_403 = lean_alloc_ctor(0, 4, 0); } else { - x_448 = x_447; + x_403 = x_402; } -lean_ctor_set(x_448, 0, x_444); -lean_ctor_set(x_448, 1, x_445); -lean_ctor_set(x_448, 2, x_403); -lean_ctor_set(x_448, 3, x_446); -if (lean_is_scalar(x_443)) { - x_449 = lean_alloc_ctor(0, 6, 0); +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_449 = x_443; + x_404 = x_398; } -lean_ctor_set(x_449, 0, x_438); -lean_ctor_set(x_449, 1, x_439); -lean_ctor_set(x_449, 2, x_448); -lean_ctor_set(x_449, 3, x_440); -lean_ctor_set(x_449, 4, x_441); -lean_ctor_set(x_449, 5, x_442); -if (lean_is_scalar(x_437)) { - x_450 = lean_alloc_ctor(1, 2, 0); +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_450 = x_437; -} -lean_ctor_set(x_450, 0, x_436); -lean_ctor_set(x_450, 1, x_449); -return x_450; -} + 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_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; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; -x_451 = lean_ctor_get(x_270, 2); -x_452 = lean_ctor_get(x_270, 0); -x_453 = lean_ctor_get(x_270, 1); -x_454 = lean_ctor_get(x_270, 3); -x_455 = lean_ctor_get(x_270, 4); -x_456 = lean_ctor_get(x_270, 5); -lean_inc(x_456); -lean_inc(x_455); -lean_inc(x_454); -lean_inc(x_451); -lean_inc(x_453); -lean_inc(x_452); -lean_dec(x_270); -x_457 = lean_ctor_get(x_451, 0); -lean_inc(x_457); -x_458 = lean_ctor_get(x_451, 1); -lean_inc(x_458); -x_459 = lean_ctor_get(x_451, 2); -lean_inc(x_459); -x_460 = lean_ctor_get(x_451, 3); -lean_inc(x_460); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - lean_ctor_release(x_451, 3); - x_461 = x_451; +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_inc(x_409); +x_410 = lean_ctor_get(x_390, 3); +lean_inc(x_410); +x_411 = lean_ctor_get(x_390, 4); +lean_inc(x_411); +x_412 = lean_ctor_get(x_390, 5); +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_451); - x_461 = lean_box(0); + lean_dec_ref(x_390); + x_413 = lean_box(0); } -x_462 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_461)) { - x_463 = 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); +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; } else { - x_463 = x_461; + lean_dec_ref(x_406); + x_417 = lean_box(0); } -lean_ctor_set(x_463, 0, x_457); -lean_ctor_set(x_463, 1, x_458); -lean_ctor_set(x_463, 2, x_462); -lean_ctor_set(x_463, 3, x_460); -x_464 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_464, 0, x_452); -lean_ctor_set(x_464, 1, x_453); -lean_ctor_set(x_464, 2, x_463); -lean_ctor_set(x_464, 3, x_454); -lean_ctor_set(x_464, 4, x_455); -lean_ctor_set(x_464, 5, x_456); -x_465 = lean_ctor_get(x_6, 0); -lean_inc(x_465); -x_466 = lean_ctor_get(x_6, 1); -lean_inc(x_466); -x_467 = lean_ctor_get(x_6, 2); -lean_inc(x_467); -x_468 = lean_ctor_get(x_6, 3); -lean_inc(x_468); -x_469 = lean_ctor_get(x_6, 4); -lean_inc(x_469); -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_470 = x_6; +if (lean_is_scalar(x_417)) { + x_418 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_6); - x_470 = lean_box(0); + x_418 = x_417; } -x_471 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_471, 0, x_271); -lean_ctor_set(x_471, 1, x_13); -x_472 = lean_array_push(x_467, x_471); -if (lean_is_scalar(x_470)) { - x_473 = lean_alloc_ctor(0, 5, 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); } else { - x_473 = x_470; + x_419 = x_413; } -lean_ctor_set(x_473, 0, x_465); -lean_ctor_set(x_473, 1, x_466); -lean_ctor_set(x_473, 2, x_472); -lean_ctor_set(x_473, 3, x_468); -lean_ctor_set(x_473, 4, x_469); -x_474 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_273, x_473, x_464); -if (lean_obj_tag(x_474) == 0) -{ -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; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; -x_475 = lean_ctor_get(x_474, 1); -lean_inc(x_475); -x_476 = lean_ctor_get(x_475, 2); -lean_inc(x_476); -x_477 = lean_ctor_get(x_474, 0); -lean_inc(x_477); -if (lean_is_exclusive(x_474)) { - lean_ctor_release(x_474, 0); - lean_ctor_release(x_474, 1); - x_478 = x_474; +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); } else { - lean_dec_ref(x_474); - x_478 = lean_box(0); + x_420 = x_237; } -x_479 = lean_ctor_get(x_475, 0); -lean_inc(x_479); -x_480 = lean_ctor_get(x_475, 1); -lean_inc(x_480); -x_481 = lean_ctor_get(x_475, 3); -lean_inc(x_481); -x_482 = lean_ctor_get(x_475, 4); -lean_inc(x_482); -x_483 = lean_ctor_get(x_475, 5); -lean_inc(x_483); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - lean_ctor_release(x_475, 2); - lean_ctor_release(x_475, 3); - lean_ctor_release(x_475, 4); - lean_ctor_release(x_475, 5); - x_484 = x_475; -} else { - lean_dec_ref(x_475); - x_484 = lean_box(0); +lean_ctor_set(x_420, 0, x_407); +lean_ctor_set(x_420, 1, x_419); +return x_420; } -x_485 = lean_ctor_get(x_476, 0); -lean_inc(x_485); -x_486 = lean_ctor_get(x_476, 1); -lean_inc(x_486); -x_487 = lean_ctor_get(x_476, 3); -lean_inc(x_487); -if (lean_is_exclusive(x_476)) { - lean_ctor_release(x_476, 0); - lean_ctor_release(x_476, 1); - lean_ctor_release(x_476, 2); - lean_ctor_release(x_476, 3); - x_488 = x_476; -} else { - lean_dec_ref(x_476); - x_488 = lean_box(0); -} -if (lean_is_scalar(x_488)) { - x_489 = lean_alloc_ctor(0, 4, 0); -} else { - x_489 = x_488; -} -lean_ctor_set(x_489, 0, x_485); -lean_ctor_set(x_489, 1, x_486); -lean_ctor_set(x_489, 2, x_459); -lean_ctor_set(x_489, 3, x_487); -if (lean_is_scalar(x_484)) { - x_490 = lean_alloc_ctor(0, 6, 0); -} else { - x_490 = x_484; -} -lean_ctor_set(x_490, 0, x_479); -lean_ctor_set(x_490, 1, x_480); -lean_ctor_set(x_490, 2, x_489); -lean_ctor_set(x_490, 3, x_481); -lean_ctor_set(x_490, 4, x_482); -lean_ctor_set(x_490, 5, x_483); -if (lean_is_scalar(x_478)) { - x_491 = lean_alloc_ctor(0, 2, 0); -} else { - x_491 = x_478; -} -lean_ctor_set(x_491, 0, x_477); -lean_ctor_set(x_491, 1, x_490); -return x_491; -} -else -{ -lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; -x_492 = lean_ctor_get(x_474, 1); -lean_inc(x_492); -x_493 = lean_ctor_get(x_492, 2); -lean_inc(x_493); -x_494 = lean_ctor_get(x_474, 0); -lean_inc(x_494); -if (lean_is_exclusive(x_474)) { - lean_ctor_release(x_474, 0); - lean_ctor_release(x_474, 1); - x_495 = x_474; -} else { - lean_dec_ref(x_474); - x_495 = lean_box(0); -} -x_496 = lean_ctor_get(x_492, 0); -lean_inc(x_496); -x_497 = lean_ctor_get(x_492, 1); -lean_inc(x_497); -x_498 = lean_ctor_get(x_492, 3); -lean_inc(x_498); -x_499 = lean_ctor_get(x_492, 4); -lean_inc(x_499); -x_500 = lean_ctor_get(x_492, 5); -lean_inc(x_500); -if (lean_is_exclusive(x_492)) { - lean_ctor_release(x_492, 0); - lean_ctor_release(x_492, 1); - lean_ctor_release(x_492, 2); - lean_ctor_release(x_492, 3); - lean_ctor_release(x_492, 4); - lean_ctor_release(x_492, 5); - x_501 = x_492; -} else { - lean_dec_ref(x_492); - x_501 = lean_box(0); -} -x_502 = lean_ctor_get(x_493, 0); -lean_inc(x_502); -x_503 = lean_ctor_get(x_493, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_493, 3); -lean_inc(x_504); -if (lean_is_exclusive(x_493)) { - lean_ctor_release(x_493, 0); - lean_ctor_release(x_493, 1); - lean_ctor_release(x_493, 2); - lean_ctor_release(x_493, 3); - x_505 = x_493; -} else { - lean_dec_ref(x_493); - x_505 = lean_box(0); -} -if (lean_is_scalar(x_505)) { - x_506 = lean_alloc_ctor(0, 4, 0); -} else { - x_506 = x_505; -} -lean_ctor_set(x_506, 0, x_502); -lean_ctor_set(x_506, 1, x_503); -lean_ctor_set(x_506, 2, x_459); -lean_ctor_set(x_506, 3, x_504); -if (lean_is_scalar(x_501)) { - x_507 = lean_alloc_ctor(0, 6, 0); -} else { - x_507 = x_501; -} -lean_ctor_set(x_507, 0, x_496); -lean_ctor_set(x_507, 1, x_497); -lean_ctor_set(x_507, 2, x_506); -lean_ctor_set(x_507, 3, x_498); -lean_ctor_set(x_507, 4, x_499); -lean_ctor_set(x_507, 5, x_500); -if (lean_is_scalar(x_495)) { - x_508 = lean_alloc_ctor(1, 2, 0); -} else { - x_508 = x_495; -} -lean_ctor_set(x_508, 0, x_494); -lean_ctor_set(x_508, 1, x_507); -return x_508; } } } } else { -uint8_t x_509; +uint8_t x_441; 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_509 = !lean_is_exclusive(x_264); -if (x_509 == 0) +x_441 = !lean_is_exclusive(x_230); +if (x_441 == 0) { -return x_264; +return x_230; } else { -lean_object* x_510; lean_object* x_511; lean_object* x_512; -x_510 = lean_ctor_get(x_264, 0); -x_511 = lean_ctor_get(x_264, 1); -lean_inc(x_511); -lean_inc(x_510); -lean_dec(x_264); -x_512 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_512, 0, x_510); -lean_ctor_set(x_512, 1, x_511); -return x_512; +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; } } } @@ -3149,7 +2787,7 @@ return x_512; } else { -uint8_t x_513; +uint8_t x_445; lean_dec(x_17); lean_dec(x_13); lean_dec(x_6); @@ -3157,52 +2795,52 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_513 = !lean_is_exclusive(x_18); -if (x_513 == 0) +x_445 = !lean_is_exclusive(x_18); +if (x_445 == 0) { return x_18; } else { -lean_object* x_514; lean_object* x_515; lean_object* x_516; -x_514 = lean_ctor_get(x_18, 0); -x_515 = lean_ctor_get(x_18, 1); -lean_inc(x_515); -lean_inc(x_514); +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_dec(x_18); -x_516 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_516, 0, x_514); -lean_ctor_set(x_516, 1, x_515); -return x_516; +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; } } } else { -uint8_t x_517; +uint8_t x_449; 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_517 = !lean_is_exclusive(x_14); -if (x_517 == 0) +x_449 = !lean_is_exclusive(x_14); +if (x_449 == 0) { return x_14; } else { -lean_object* x_518; lean_object* x_519; lean_object* x_520; -x_518 = lean_ctor_get(x_14, 0); -x_519 = lean_ctor_get(x_14, 1); -lean_inc(x_519); -lean_inc(x_518); +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_dec(x_14); -x_520 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_520, 0, x_518); -lean_ctor_set(x_520, 1, x_519); -return x_520; +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; } } } @@ -3318,2130 +2956,1768 @@ goto _start; } case 1: { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; lean_dec(x_25); x_32 = lean_ctor_get(x_26, 1); lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_ctor_get(x_27, 0); -lean_inc(x_33); +if (lean_is_exclusive(x_26)) { + lean_ctor_release(x_26, 0); + lean_ctor_release(x_26, 1); + x_33 = x_26; +} else { + lean_dec_ref(x_26); + x_33 = lean_box(0); +} +x_34 = lean_ctor_get(x_27, 0); +lean_inc(x_34); lean_dec(x_27); -x_34 = lean_unsigned_to_nat(1u); -x_35 = lean_nat_add(x_11, x_34); +x_35 = lean_unsigned_to_nat(1u); +x_36 = lean_nat_add(x_11, x_35); lean_dec(x_11); -x_36 = !lean_is_exclusive(x_32); -if (x_36 == 0) +x_37 = !lean_is_exclusive(x_32); +if (x_37 == 0) { -lean_object* x_37; uint8_t x_38; -x_37 = lean_ctor_get(x_32, 2); -x_38 = !lean_is_exclusive(x_37); -if (x_38 == 0) +lean_object* x_38; uint8_t x_39; +x_38 = lean_ctor_get(x_32, 2); +x_39 = !lean_is_exclusive(x_38); +if (x_39 == 0) { -lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_39 = lean_ctor_get(x_37, 2); -x_40 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_40); -x_41 = !lean_is_exclusive(x_12); -if (x_41 == 0) +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_92; uint8_t x_93; +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) { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_12, 2); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_33); -lean_ctor_set(x_43, 1, x_21); -x_44 = lean_array_push(x_42, x_43); -lean_ctor_set(x_12, 2, x_44); -x_45 = 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_35, x_12, x_32); -if (lean_obj_tag(x_45) == 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_46; lean_object* x_47; uint8_t x_48; -x_46 = lean_ctor_get(x_45, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_46, 2); -lean_inc(x_47); -x_48 = !lean_is_exclusive(x_45); -if (x_48 == 0) -{ -lean_object* x_49; uint8_t x_50; -x_49 = lean_ctor_get(x_45, 1); -lean_dec(x_49); -x_50 = !lean_is_exclusive(x_46); -if (x_50 == 0) -{ -lean_object* x_51; uint8_t x_52; -x_51 = lean_ctor_get(x_46, 2); -lean_dec(x_51); -x_52 = !lean_is_exclusive(x_47); -if (x_52 == 0) -{ -lean_object* x_53; -x_53 = lean_ctor_get(x_47, 2); -lean_dec(x_53); -lean_ctor_set(x_47, 2, x_39); -return x_45; +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_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_54 = lean_ctor_get(x_47, 0); -x_55 = lean_ctor_get(x_47, 1); -x_56 = lean_ctor_get(x_47, 3); -lean_inc(x_56); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_47); -x_57 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_57, 0, x_54); -lean_ctor_set(x_57, 1, x_55); -lean_ctor_set(x_57, 2, x_39); -lean_ctor_set(x_57, 3, x_56); -lean_ctor_set(x_46, 2, x_57); -return x_45; +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_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; } } 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; -x_58 = lean_ctor_get(x_46, 0); -x_59 = lean_ctor_get(x_46, 1); -x_60 = lean_ctor_get(x_46, 3); -x_61 = lean_ctor_get(x_46, 4); -x_62 = lean_ctor_get(x_46, 5); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); +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_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; +} +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_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; +} +} +block_91: +{ +if (lean_obj_tag(x_41) == 0) +{ +lean_object* x_43; lean_object* x_44; uint8_t x_45; +x_43 = lean_ctor_get(x_42, 2); +lean_inc(x_43); +x_44 = lean_ctor_get(x_41, 0); +lean_inc(x_44); +lean_dec(x_41); +x_45 = !lean_is_exclusive(x_42); +if (x_45 == 0) +{ +lean_object* x_46; uint8_t x_47; +x_46 = lean_ctor_get(x_42, 2); +lean_dec(x_46); +x_47 = !lean_is_exclusive(x_43); +if (x_47 == 0) +{ +lean_object* x_48; lean_object* x_49; +x_48 = lean_ctor_get(x_43, 2); +lean_dec(x_48); +lean_ctor_set(x_43, 2, x_40); +if (lean_is_scalar(x_33)) { + x_49 = lean_alloc_ctor(1, 2, 0); +} else { + x_49 = x_33; + lean_ctor_set_tag(x_49, 1); +} +lean_ctor_set(x_49, 0, x_44); +lean_ctor_set(x_49, 1, x_42); +return x_49; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_50 = lean_ctor_get(x_43, 0); +x_51 = lean_ctor_get(x_43, 1); +x_52 = lean_ctor_get(x_43, 3); +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); +if (lean_is_scalar(x_33)) { + x_54 = lean_alloc_ctor(1, 2, 0); +} else { + x_54 = x_33; + lean_ctor_set_tag(x_54, 1); +} +lean_ctor_set(x_54, 0, x_44); +lean_ctor_set(x_54, 1, x_42); +return x_54; +} +} +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_inc(x_59); lean_inc(x_58); -lean_dec(x_46); -x_63 = lean_ctor_get(x_47, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_47, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_47, 3); -lean_inc(x_65); -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); - x_66 = x_47; +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); +lean_inc(x_61); +x_62 = lean_ctor_get(x_43, 3); +lean_inc(x_62); +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; } else { - lean_dec_ref(x_47); - x_66 = lean_box(0); + lean_dec_ref(x_43); + x_63 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 4, 0); } else { - x_67 = x_66; + x_64 = x_63; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_39); -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_45, 1, x_68); -return x_45; +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); +if (lean_is_scalar(x_33)) { + x_66 = lean_alloc_ctor(1, 2, 0); +} else { + x_66 = x_33; + lean_ctor_set_tag(x_66, 1); +} +lean_ctor_set(x_66, 0, x_44); +lean_ctor_set(x_66, 1, x_65); +return x_66; } } else { -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_69 = lean_ctor_get(x_45, 0); -lean_inc(x_69); -lean_dec(x_45); -x_70 = lean_ctor_get(x_46, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_46, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_46, 3); -lean_inc(x_72); -x_73 = lean_ctor_get(x_46, 4); -lean_inc(x_73); -x_74 = lean_ctor_get(x_46, 5); -lean_inc(x_74); -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); - lean_ctor_release(x_46, 5); - x_75 = x_46; +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_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); +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_40); +if (lean_is_scalar(x_33)) { + x_73 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_46); - x_75 = lean_box(0); + x_73 = x_33; } -x_76 = lean_ctor_get(x_47, 0); +lean_ctor_set(x_73, 0, x_68); +lean_ctor_set(x_73, 1, x_42); +return x_73; +} +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_inc(x_76); -x_77 = lean_ctor_get(x_47, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_47, 3); -lean_inc(x_78); -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); - x_79 = x_47; +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); +if (lean_is_scalar(x_33)) { + x_78 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_47); - x_79 = lean_box(0); + x_78 = x_33; } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 4, 0); -} else { - x_80 = x_79; -} -lean_ctor_set(x_80, 0, x_76); -lean_ctor_set(x_80, 1, x_77); -lean_ctor_set(x_80, 2, x_39); -lean_ctor_set(x_80, 3, x_78); -if (lean_is_scalar(x_75)) { - x_81 = lean_alloc_ctor(0, 6, 0); -} else { - x_81 = x_75; -} -lean_ctor_set(x_81, 0, x_70); -lean_ctor_set(x_81, 1, x_71); -lean_ctor_set(x_81, 2, x_80); -lean_ctor_set(x_81, 3, x_72); -lean_ctor_set(x_81, 4, x_73); -lean_ctor_set(x_81, 5, x_74); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_69); -lean_ctor_set(x_82, 1, x_81); -return x_82; +lean_ctor_set(x_78, 0, x_68); +lean_ctor_set(x_78, 1, x_42); +return x_78; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_45, 1); +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_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); +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_is_exclusive(x_45); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; -x_86 = lean_ctor_get(x_45, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_83, 2); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_84); -if (x_89 == 0) -{ -lean_object* x_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_39); -return x_45; -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -x_93 = lean_ctor_get(x_84, 3); -lean_inc(x_93); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_94 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_94, 0, x_91); -lean_ctor_set(x_94, 1, x_92); -lean_ctor_set(x_94, 2, x_39); -lean_ctor_set(x_94, 3, x_93); -lean_ctor_set(x_83, 2, x_94); -return x_45; -} -} -else -{ -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; -x_95 = lean_ctor_get(x_83, 0); -x_96 = lean_ctor_get(x_83, 1); -x_97 = lean_ctor_get(x_83, 3); -x_98 = lean_ctor_get(x_83, 4); -x_99 = lean_ctor_get(x_83, 5); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); -lean_dec(x_83); -x_100 = lean_ctor_get(x_84, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_84, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_84, 3); -lean_inc(x_102); -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_103 = 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; } else { - lean_dec_ref(x_84); - x_103 = lean_box(0); + lean_dec_ref(x_67); + x_87 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_87)) { + x_88 = lean_alloc_ctor(0, 4, 0); } else { - x_104 = x_103; + x_88 = x_87; } -lean_ctor_set(x_104, 0, x_100); -lean_ctor_set(x_104, 1, x_101); -lean_ctor_set(x_104, 2, x_39); -lean_ctor_set(x_104, 3, x_102); -x_105 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_105, 0, x_95); -lean_ctor_set(x_105, 1, x_96); -lean_ctor_set(x_105, 2, x_104); -lean_ctor_set(x_105, 3, x_97); -lean_ctor_set(x_105, 4, x_98); -lean_ctor_set(x_105, 5, x_99); -lean_ctor_set(x_45, 1, x_105); -return x_45; -} -} -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; lean_object* x_119; -x_106 = lean_ctor_get(x_45, 0); -lean_inc(x_106); -lean_dec(x_45); -x_107 = lean_ctor_get(x_83, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 1); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 3); -lean_inc(x_109); -x_110 = lean_ctor_get(x_83, 4); -lean_inc(x_110); -x_111 = lean_ctor_get(x_83, 5); -lean_inc(x_111); -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_112 = x_83; +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); +if (lean_is_scalar(x_33)) { + x_90 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_83); - x_112 = lean_box(0); + x_90 = x_33; } -x_113 = lean_ctor_get(x_84, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_84, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_84, 3); -lean_inc(x_115); -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_116 = x_84; -} else { - lean_dec_ref(x_84); - x_116 = lean_box(0); +lean_ctor_set(x_90, 0, x_68); +lean_ctor_set(x_90, 1, x_89); +return x_90; } -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(0, 4, 0); -} else { - x_117 = x_116; -} -lean_ctor_set(x_117, 0, x_113); -lean_ctor_set(x_117, 1, x_114); -lean_ctor_set(x_117, 2, x_39); -lean_ctor_set(x_117, 3, x_115); -if (lean_is_scalar(x_112)) { - x_118 = lean_alloc_ctor(0, 6, 0); -} else { - x_118 = x_112; -} -lean_ctor_set(x_118, 0, x_107); -lean_ctor_set(x_118, 1, x_108); -lean_ctor_set(x_118, 2, x_117); -lean_ctor_set(x_118, 3, x_109); -lean_ctor_set(x_118, 4, x_110); -lean_ctor_set(x_118, 5, x_111); -x_119 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_119, 0, x_106); -lean_ctor_set(x_119, 1, x_118); -return x_119; } } } 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; -x_120 = lean_ctor_get(x_12, 0); -x_121 = lean_ctor_get(x_12, 1); -x_122 = lean_ctor_get(x_12, 2); -x_123 = lean_ctor_get(x_12, 3); -x_124 = lean_ctor_get(x_12, 4); -lean_inc(x_124); -lean_inc(x_123); +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_dec(x_12); -x_125 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_125, 0, x_33); -lean_ctor_set(x_125, 1, x_21); -x_126 = lean_array_push(x_122, x_125); -x_127 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_127, 0, x_120); -lean_ctor_set(x_127, 1, x_121); -lean_ctor_set(x_127, 2, x_126); -lean_ctor_set(x_127, 3, x_123); -lean_ctor_set(x_127, 4, x_124); -x_128 = 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_35, x_127, x_32); -if (lean_obj_tag(x_128) == 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; lean_object* x_145; -x_129 = lean_ctor_get(x_128, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_129, 2); -lean_inc(x_130); -x_131 = lean_ctor_get(x_128, 0); -lean_inc(x_131); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_132 = x_128; +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_128); + 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_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_129, 0); +x_133 = lean_ctor_get(x_125, 0); lean_inc(x_133); -x_134 = lean_ctor_get(x_129, 1); +x_134 = lean_ctor_get(x_125, 1); lean_inc(x_134); -x_135 = lean_ctor_get(x_129, 3); +x_135 = lean_ctor_get(x_125, 3); lean_inc(x_135); -x_136 = lean_ctor_get(x_129, 4); -lean_inc(x_136); -x_137 = lean_ctor_get(x_129, 5); -lean_inc(x_137); -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_138 = x_129; +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_129); - x_138 = lean_box(0); + lean_dec_ref(x_125); + x_136 = lean_box(0); } -x_139 = lean_ctor_get(x_130, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_130, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_130, 3); -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); - x_142 = x_130; +if (lean_is_scalar(x_136)) { + x_137 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_130); - x_142 = lean_box(0); + x_137 = x_136; } -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_39); -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); +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_145 = lean_alloc_ctor(0, 2, 0); + x_138 = lean_alloc_ctor(0, 6, 0); } else { - x_145 = x_132; + x_138 = x_132; } -lean_ctor_set(x_145, 0, x_131); -lean_ctor_set(x_145, 1, x_144); -return x_145; +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_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; -x_146 = lean_ctor_get(x_128, 1); +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); -x_147 = lean_ctor_get(x_146, 2); -lean_inc(x_147); -x_148 = lean_ctor_get(x_128, 0); +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); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_149 = x_128; -} else { - lean_dec_ref(x_128); - x_149 = lean_box(0); -} -x_150 = lean_ctor_get(x_146, 0); +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_146, 1); -lean_inc(x_151); -x_152 = lean_ctor_get(x_146, 3); -lean_inc(x_152); -x_153 = lean_ctor_get(x_146, 4); -lean_inc(x_153); -x_154 = lean_ctor_get(x_146, 5); -lean_inc(x_154); -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); - lean_ctor_release(x_146, 5); - x_155 = x_146; +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_146); - x_155 = lean_box(0); + lean_dec_ref(x_140); + x_151 = lean_box(0); } -x_156 = lean_ctor_get(x_147, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_147, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_147, 3); -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); - x_159 = x_147; +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_147); - x_159 = lean_box(0); + x_152 = x_151; } -if (lean_is_scalar(x_159)) { - x_160 = lean_alloc_ctor(0, 4, 0); +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_160 = x_159; + x_153 = x_147; } -lean_ctor_set(x_160, 0, x_156); -lean_ctor_set(x_160, 1, x_157); -lean_ctor_set(x_160, 2, x_39); -lean_ctor_set(x_160, 3, x_158); -if (lean_is_scalar(x_155)) { - x_161 = lean_alloc_ctor(0, 6, 0); +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_161 = x_155; + x_154 = x_33; } -lean_ctor_set(x_161, 0, x_150); -lean_ctor_set(x_161, 1, x_151); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_152); -lean_ctor_set(x_161, 4, x_153); -lean_ctor_set(x_161, 5, x_154); -if (lean_is_scalar(x_149)) { - x_162 = lean_alloc_ctor(1, 2, 0); -} else { - x_162 = x_149; +lean_ctor_set(x_154, 0, x_141); +lean_ctor_set(x_154, 1, x_153); +return x_154; } -lean_ctor_set(x_162, 0, x_148); -lean_ctor_set(x_162, 1, x_161); -return x_162; } } } else { -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_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_163 = lean_ctor_get(x_37, 0); -x_164 = lean_ctor_get(x_37, 1); -x_165 = lean_ctor_get(x_37, 2); -x_166 = lean_ctor_get(x_37, 3); -lean_inc(x_166); -lean_inc(x_165); -lean_inc(x_164); -lean_inc(x_163); -lean_dec(x_37); -x_167 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_168 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_168, 0, x_163); -lean_ctor_set(x_168, 1, x_164); -lean_ctor_set(x_168, 2, x_167); -lean_ctor_set(x_168, 3, x_166); -lean_ctor_set(x_32, 2, x_168); -x_169 = lean_ctor_get(x_12, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_12, 1); -lean_inc(x_170); -x_171 = lean_ctor_get(x_12, 2); -lean_inc(x_171); -x_172 = lean_ctor_get(x_12, 3); -lean_inc(x_172); -x_173 = lean_ctor_get(x_12, 4); -lean_inc(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_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); 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_174 = x_12; + x_226 = x_12; } else { lean_dec_ref(x_12); - x_174 = lean_box(0); + x_226 = lean_box(0); } -x_175 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_175, 0, x_33); -lean_ctor_set(x_175, 1, x_21); -x_176 = lean_array_push(x_171, x_175); -if (lean_is_scalar(x_174)) { - x_177 = lean_alloc_ctor(0, 5, 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_229 = lean_alloc_ctor(0, 5, 0); } else { - x_177 = x_174; + x_229 = x_226; } -lean_ctor_set(x_177, 0, x_169); -lean_ctor_set(x_177, 1, x_170); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_172); -lean_ctor_set(x_177, 4, x_173); -x_178 = 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_35, x_177, x_32); -if (lean_obj_tag(x_178) == 0) +lean_ctor_set(x_229, 0, x_221); +lean_ctor_set(x_229, 1, x_222); +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_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_179 = lean_ctor_get(x_178, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - x_182 = x_178; -} else { - lean_dec_ref(x_178); - x_182 = lean_box(0); -} -x_183 = lean_ctor_get(x_179, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 3); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 4); -lean_inc(x_186); -x_187 = lean_ctor_get(x_179, 5); -lean_inc(x_187); -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_188 = x_179; -} else { - lean_dec_ref(x_179); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_180, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_180, 3); -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); - x_192 = x_180; -} else { - lean_dec_ref(x_180); - 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_165); -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_182)) { - x_195 = lean_alloc_ctor(0, 2, 0); -} else { - x_195 = x_182; -} -lean_ctor_set(x_195, 0, x_181); -lean_ctor_set(x_195, 1, x_194); -return x_195; +lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_231 = lean_ctor_get(x_230, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_230, 1); +lean_inc(x_232); +lean_dec(x_230); +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_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; -x_196 = lean_ctor_get(x_178, 1); +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_230, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_230, 1); +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; +} +block_217: +{ +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_196, 2); +x_197 = lean_ctor_get(x_187, 3); lean_inc(x_197); -x_198 = lean_ctor_get(x_178, 0); -lean_inc(x_198); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - x_199 = 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); + x_198 = x_187; } else { - lean_dec_ref(x_178); - x_199 = lean_box(0); + lean_dec_ref(x_187); + x_198 = lean_box(0); } -x_200 = lean_ctor_get(x_196, 0); -lean_inc(x_200); -x_201 = lean_ctor_get(x_196, 1); -lean_inc(x_201); -x_202 = lean_ctor_get(x_196, 3); +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; +} +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_196, 4); +x_203 = lean_ctor_get(x_185, 0); lean_inc(x_203); -x_204 = lean_ctor_get(x_196, 5); +lean_dec(x_185); +x_204 = lean_ctor_get(x_186, 0); lean_inc(x_204); -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); - lean_ctor_release(x_196, 5); - x_205 = x_196; -} else { - lean_dec_ref(x_196); - x_205 = lean_box(0); -} -x_206 = lean_ctor_get(x_197, 0); +x_205 = lean_ctor_get(x_186, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_186, 3); lean_inc(x_206); -x_207 = lean_ctor_get(x_197, 1); +x_207 = lean_ctor_get(x_186, 4); lean_inc(x_207); -x_208 = lean_ctor_get(x_197, 3); +x_208 = lean_ctor_get(x_186, 5); lean_inc(x_208); -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); - x_209 = x_197; +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; } else { - lean_dec_ref(x_197); + lean_dec_ref(x_186); x_209 = 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; +} else { + lean_dec_ref(x_202); + x_213 = lean_box(0); +} +if (lean_is_scalar(x_213)) { + x_214 = lean_alloc_ctor(0, 4, 0); +} else { + x_214 = x_213; +} +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_210 = lean_alloc_ctor(0, 4, 0); + x_215 = lean_alloc_ctor(0, 6, 0); } else { - x_210 = x_209; + x_215 = x_209; } -lean_ctor_set(x_210, 0, x_206); -lean_ctor_set(x_210, 1, x_207); -lean_ctor_set(x_210, 2, x_165); -lean_ctor_set(x_210, 3, x_208); -if (lean_is_scalar(x_205)) { - x_211 = lean_alloc_ctor(0, 6, 0); +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); +if (lean_is_scalar(x_33)) { + x_216 = lean_alloc_ctor(0, 2, 0); } else { - x_211 = x_205; + x_216 = x_33; } -lean_ctor_set(x_211, 0, x_200); -lean_ctor_set(x_211, 1, x_201); -lean_ctor_set(x_211, 2, x_210); -lean_ctor_set(x_211, 3, x_202); -lean_ctor_set(x_211, 4, x_203); -lean_ctor_set(x_211, 5, x_204); -if (lean_is_scalar(x_199)) { - x_212 = lean_alloc_ctor(1, 2, 0); -} else { - x_212 = x_199; +lean_ctor_set(x_216, 0, x_203); +lean_ctor_set(x_216, 1, x_215); +return x_216; } -lean_ctor_set(x_212, 0, x_198); -lean_ctor_set(x_212, 1, x_211); -return x_212; -} -} -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; 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; -x_213 = lean_ctor_get(x_32, 2); -x_214 = lean_ctor_get(x_32, 0); -x_215 = lean_ctor_get(x_32, 1); -x_216 = lean_ctor_get(x_32, 3); -x_217 = lean_ctor_get(x_32, 4); -x_218 = lean_ctor_get(x_32, 5); -lean_inc(x_218); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_213); -lean_inc(x_215); -lean_inc(x_214); -lean_dec(x_32); -x_219 = lean_ctor_get(x_213, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_213, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_213, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_213, 3); -lean_inc(x_222); -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); - x_223 = x_213; -} else { - lean_dec_ref(x_213); - x_223 = lean_box(0); -} -x_224 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_223)) { - x_225 = lean_alloc_ctor(0, 4, 0); -} else { - x_225 = x_223; -} -lean_ctor_set(x_225, 0, x_219); -lean_ctor_set(x_225, 1, x_220); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_222); -x_226 = lean_alloc_ctor(0, 6, 0); -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); -x_227 = lean_ctor_get(x_12, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_12, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_12, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_12, 3); -lean_inc(x_230); -x_231 = lean_ctor_get(x_12, 4); -lean_inc(x_231); -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_232 = x_12; -} else { - lean_dec_ref(x_12); - x_232 = lean_box(0); -} -x_233 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_233, 0, x_33); -lean_ctor_set(x_233, 1, x_21); -x_234 = lean_array_push(x_229, x_233); -if (lean_is_scalar(x_232)) { - x_235 = lean_alloc_ctor(0, 5, 0); -} else { - x_235 = x_232; -} -lean_ctor_set(x_235, 0, x_227); -lean_ctor_set(x_235, 1, x_228); -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_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_35, x_235, x_226); -if (lean_obj_tag(x_236) == 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; -x_237 = lean_ctor_get(x_236, 1); -lean_inc(x_237); -x_238 = lean_ctor_get(x_237, 2); -lean_inc(x_238); -x_239 = lean_ctor_get(x_236, 0); -lean_inc(x_239); -if (lean_is_exclusive(x_236)) { - lean_ctor_release(x_236, 0); - lean_ctor_release(x_236, 1); - x_240 = x_236; -} else { - lean_dec_ref(x_236); - x_240 = lean_box(0); -} -x_241 = lean_ctor_get(x_237, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_237, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_237, 3); -lean_inc(x_243); -x_244 = lean_ctor_get(x_237, 4); -lean_inc(x_244); -x_245 = lean_ctor_get(x_237, 5); -lean_inc(x_245); -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_246 = x_237; -} else { - lean_dec_ref(x_237); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_238, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_238, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_238, 3); -lean_inc(x_249); -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); - x_250 = x_238; -} else { - lean_dec_ref(x_238); - x_250 = lean_box(0); -} -if (lean_is_scalar(x_250)) { - x_251 = lean_alloc_ctor(0, 4, 0); -} else { - x_251 = x_250; -} -lean_ctor_set(x_251, 0, x_247); -lean_ctor_set(x_251, 1, x_248); -lean_ctor_set(x_251, 2, x_221); -lean_ctor_set(x_251, 3, x_249); -if (lean_is_scalar(x_246)) { - x_252 = lean_alloc_ctor(0, 6, 0); -} else { - x_252 = x_246; -} -lean_ctor_set(x_252, 0, x_241); -lean_ctor_set(x_252, 1, x_242); -lean_ctor_set(x_252, 2, x_251); -lean_ctor_set(x_252, 3, x_243); -lean_ctor_set(x_252, 4, x_244); -lean_ctor_set(x_252, 5, x_245); -if (lean_is_scalar(x_240)) { - x_253 = lean_alloc_ctor(0, 2, 0); -} else { - x_253 = x_240; -} -lean_ctor_set(x_253, 0, x_239); -lean_ctor_set(x_253, 1, x_252); -return x_253; -} -else -{ -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; -x_254 = lean_ctor_get(x_236, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_254, 2); -lean_inc(x_255); -x_256 = lean_ctor_get(x_236, 0); -lean_inc(x_256); -if (lean_is_exclusive(x_236)) { - lean_ctor_release(x_236, 0); - lean_ctor_release(x_236, 1); - x_257 = x_236; -} else { - lean_dec_ref(x_236); - x_257 = lean_box(0); -} -x_258 = lean_ctor_get(x_254, 0); -lean_inc(x_258); -x_259 = lean_ctor_get(x_254, 1); -lean_inc(x_259); -x_260 = lean_ctor_get(x_254, 3); -lean_inc(x_260); -x_261 = lean_ctor_get(x_254, 4); -lean_inc(x_261); -x_262 = lean_ctor_get(x_254, 5); -lean_inc(x_262); -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); - lean_ctor_release(x_254, 5); - x_263 = x_254; -} else { - lean_dec_ref(x_254); - x_263 = lean_box(0); -} -x_264 = lean_ctor_get(x_255, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_255, 1); -lean_inc(x_265); -x_266 = lean_ctor_get(x_255, 3); -lean_inc(x_266); -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_267 = x_255; -} else { - lean_dec_ref(x_255); - 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_ctor_set(x_268, 0, x_264); -lean_ctor_set(x_268, 1, x_265); -lean_ctor_set(x_268, 2, x_221); -lean_ctor_set(x_268, 3, x_266); -if (lean_is_scalar(x_263)) { - x_269 = lean_alloc_ctor(0, 6, 0); -} else { - x_269 = x_263; -} -lean_ctor_set(x_269, 0, x_258); -lean_ctor_set(x_269, 1, x_259); -lean_ctor_set(x_269, 2, x_268); -lean_ctor_set(x_269, 3, x_260); -lean_ctor_set(x_269, 4, x_261); -lean_ctor_set(x_269, 5, x_262); -if (lean_is_scalar(x_257)) { - x_270 = lean_alloc_ctor(1, 2, 0); -} else { - x_270 = x_257; -} -lean_ctor_set(x_270, 0, x_256); -lean_ctor_set(x_270, 1, x_269); -return x_270; } } } default: { -lean_object* x_271; lean_object* x_272; -x_271 = lean_ctor_get(x_26, 1); -lean_inc(x_271); +lean_object* x_237; lean_object* x_238; +x_237 = lean_ctor_get(x_26, 1); +lean_inc(x_237); lean_dec(x_26); lean_inc(x_12); -x_272 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_271); -if (lean_obj_tag(x_272) == 0) +x_238 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_237); +if (lean_obj_tag(x_238) == 0) { -lean_object* x_273; -x_273 = lean_ctor_get(x_272, 0); -lean_inc(x_273); -if (lean_obj_tag(x_273) == 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_274; lean_object* x_275; lean_object* x_276; +lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_dec(x_21); -x_274 = lean_ctor_get(x_272, 1); -lean_inc(x_274); -lean_dec(x_272); -x_275 = lean_unsigned_to_nat(1u); -x_276 = lean_nat_add(x_11, x_275); +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); lean_dec(x_11); -x_11 = x_276; -x_13 = x_274; +x_11 = x_242; +x_13 = x_240; goto _start; } else { -lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; uint8_t x_282; -x_278 = lean_ctor_get(x_272, 1); -lean_inc(x_278); -lean_dec(x_272); -x_279 = lean_ctor_get(x_273, 0); -lean_inc(x_279); -lean_dec(x_273); -x_280 = lean_unsigned_to_nat(1u); -x_281 = lean_nat_add(x_11, x_280); +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; +} else { + lean_dec_ref(x_238); + x_245 = 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_282 = !lean_is_exclusive(x_278); -if (x_282 == 0) +x_249 = !lean_is_exclusive(x_244); +if (x_249 == 0) { -lean_object* x_283; uint8_t x_284; -x_283 = lean_ctor_get(x_278, 2); -x_284 = !lean_is_exclusive(x_283); -if (x_284 == 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_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_283, 2); -x_286 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_283, 2, x_286); -x_287 = !lean_is_exclusive(x_12); -if (x_287 == 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_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_288 = lean_ctor_get(x_12, 2); -x_289 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_289, 0, x_279); -lean_ctor_set(x_289, 1, x_21); -x_290 = lean_array_push(x_288, x_289); -lean_ctor_set(x_12, 2, x_290); -x_291 = 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_281, x_12, x_278); -if (lean_obj_tag(x_291) == 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_292; lean_object* x_293; uint8_t x_294; -x_292 = lean_ctor_get(x_291, 1); -lean_inc(x_292); -x_293 = lean_ctor_get(x_292, 2); -lean_inc(x_293); -x_294 = !lean_is_exclusive(x_291); -if (x_294 == 0) -{ -lean_object* x_295; uint8_t x_296; -x_295 = lean_ctor_get(x_291, 1); -lean_dec(x_295); -x_296 = !lean_is_exclusive(x_292); -if (x_296 == 0) -{ -lean_object* x_297; uint8_t x_298; -x_297 = lean_ctor_get(x_292, 2); -lean_dec(x_297); -x_298 = !lean_is_exclusive(x_293); -if (x_298 == 0) -{ -lean_object* x_299; -x_299 = lean_ctor_get(x_293, 2); -lean_dec(x_299); -lean_ctor_set(x_293, 2, x_285); -return x_291; -} -else -{ -lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_300 = lean_ctor_get(x_293, 0); -x_301 = lean_ctor_get(x_293, 1); -x_302 = lean_ctor_get(x_293, 3); -lean_inc(x_302); -lean_inc(x_301); -lean_inc(x_300); -lean_dec(x_293); -x_303 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_303, 0, x_300); -lean_ctor_set(x_303, 1, x_301); -lean_ctor_set(x_303, 2, x_285); -lean_ctor_set(x_303, 3, x_302); -lean_ctor_set(x_292, 2, x_303); -return x_291; -} -} -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; -x_304 = lean_ctor_get(x_292, 0); -x_305 = lean_ctor_get(x_292, 1); -x_306 = lean_ctor_get(x_292, 3); -x_307 = lean_ctor_get(x_292, 4); -x_308 = lean_ctor_get(x_292, 5); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_inc(x_304); -lean_dec(x_292); -x_309 = lean_ctor_get(x_293, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_293, 1); +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_293, 3); +x_311 = lean_ctor_get(x_309, 1); lean_inc(x_311); -if (lean_is_exclusive(x_293)) { - lean_ctor_release(x_293, 0); - lean_ctor_release(x_293, 1); - lean_ctor_release(x_293, 2); - lean_ctor_release(x_293, 3); - x_312 = x_293; -} else { - lean_dec_ref(x_293); - x_312 = lean_box(0); +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; } -if (lean_is_scalar(x_312)) { - x_313 = lean_alloc_ctor(0, 4, 0); -} else { - x_313 = x_312; -} -lean_ctor_set(x_313, 0, x_309); -lean_ctor_set(x_313, 1, x_310); -lean_ctor_set(x_313, 2, x_285); -lean_ctor_set(x_313, 3, x_311); -x_314 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_314, 0, x_304); -lean_ctor_set(x_314, 1, x_305); -lean_ctor_set(x_314, 2, x_313); -lean_ctor_set(x_314, 3, x_306); -lean_ctor_set(x_314, 4, x_307); -lean_ctor_set(x_314, 5, x_308); -lean_ctor_set(x_291, 1, x_314); -return x_291; +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_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_315 = lean_ctor_get(x_291, 0); -lean_inc(x_315); -lean_dec(x_291); -x_316 = lean_ctor_get(x_292, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_292, 1); -lean_inc(x_317); -x_318 = lean_ctor_get(x_292, 3); -lean_inc(x_318); -x_319 = lean_ctor_get(x_292, 4); -lean_inc(x_319); -x_320 = lean_ctor_get(x_292, 5); +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); -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); - lean_ctor_release(x_292, 5); - x_321 = x_292; -} else { - lean_dec_ref(x_292); - x_321 = lean_box(0); -} -x_322 = lean_ctor_get(x_293, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_293, 1); -lean_inc(x_323); -x_324 = lean_ctor_get(x_293, 3); -lean_inc(x_324); -if (lean_is_exclusive(x_293)) { - lean_ctor_release(x_293, 0); - lean_ctor_release(x_293, 1); - lean_ctor_release(x_293, 2); - lean_ctor_release(x_293, 3); - x_325 = x_293; -} else { - lean_dec_ref(x_293); - x_325 = lean_box(0); -} -if (lean_is_scalar(x_325)) { - x_326 = lean_alloc_ctor(0, 4, 0); -} else { - x_326 = x_325; -} -lean_ctor_set(x_326, 0, x_322); -lean_ctor_set(x_326, 1, x_323); -lean_ctor_set(x_326, 2, x_285); -lean_ctor_set(x_326, 3, x_324); -if (lean_is_scalar(x_321)) { - x_327 = lean_alloc_ctor(0, 6, 0); -} else { - x_327 = x_321; -} -lean_ctor_set(x_327, 0, x_316); -lean_ctor_set(x_327, 1, x_317); -lean_ctor_set(x_327, 2, x_326); -lean_ctor_set(x_327, 3, x_318); -lean_ctor_set(x_327, 4, x_319); -lean_ctor_set(x_327, 5, x_320); -x_328 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_328, 0, x_315); -lean_ctor_set(x_328, 1, x_327); -return x_328; -} -} -else -{ -lean_object* x_329; lean_object* x_330; uint8_t x_331; -x_329 = lean_ctor_get(x_291, 1); -lean_inc(x_329); -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = !lean_is_exclusive(x_291); -if (x_331 == 0) -{ -lean_object* x_332; uint8_t x_333; -x_332 = lean_ctor_get(x_291, 1); -lean_dec(x_332); -x_333 = !lean_is_exclusive(x_329); -if (x_333 == 0) -{ -lean_object* x_334; uint8_t x_335; -x_334 = lean_ctor_get(x_329, 2); -lean_dec(x_334); -x_335 = !lean_is_exclusive(x_330); -if (x_335 == 0) -{ -lean_object* x_336; -x_336 = lean_ctor_get(x_330, 2); -lean_dec(x_336); -lean_ctor_set(x_330, 2, x_285); -return x_291; -} -else -{ -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; -x_337 = lean_ctor_get(x_330, 0); -x_338 = lean_ctor_get(x_330, 1); -x_339 = lean_ctor_get(x_330, 3); -lean_inc(x_339); -lean_inc(x_338); -lean_inc(x_337); -lean_dec(x_330); -x_340 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_340, 0, x_337); -lean_ctor_set(x_340, 1, x_338); -lean_ctor_set(x_340, 2, x_285); -lean_ctor_set(x_340, 3, x_339); -lean_ctor_set(x_329, 2, x_340); -return x_291; -} -} -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; -x_341 = lean_ctor_get(x_329, 0); -x_342 = lean_ctor_get(x_329, 1); -x_343 = lean_ctor_get(x_329, 3); -x_344 = lean_ctor_get(x_329, 4); -x_345 = lean_ctor_get(x_329, 5); -lean_inc(x_345); -lean_inc(x_344); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_dec(x_329); -x_346 = lean_ctor_get(x_330, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_330, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_330, 3); -lean_inc(x_348); -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_349 = x_330; -} else { - lean_dec_ref(x_330); - 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_285); -lean_ctor_set(x_350, 3, x_348); -x_351 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_351, 0, x_341); -lean_ctor_set(x_351, 1, x_342); -lean_ctor_set(x_351, 2, x_350); -lean_ctor_set(x_351, 3, x_343); -lean_ctor_set(x_351, 4, x_344); -lean_ctor_set(x_351, 5, x_345); -lean_ctor_set(x_291, 1, x_351); -return x_291; -} -} -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; -x_352 = lean_ctor_get(x_291, 0); -lean_inc(x_352); -lean_dec(x_291); -x_353 = lean_ctor_get(x_329, 0); -lean_inc(x_353); -x_354 = lean_ctor_get(x_329, 1); -lean_inc(x_354); -x_355 = lean_ctor_get(x_329, 3); -lean_inc(x_355); -x_356 = lean_ctor_get(x_329, 4); -lean_inc(x_356); -x_357 = lean_ctor_get(x_329, 5); -lean_inc(x_357); -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_358 = x_329; -} else { - lean_dec_ref(x_329); - x_358 = lean_box(0); -} -x_359 = lean_ctor_get(x_330, 0); -lean_inc(x_359); -x_360 = lean_ctor_get(x_330, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_330, 3); -lean_inc(x_361); -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_362 = x_330; -} else { - lean_dec_ref(x_330); - x_362 = lean_box(0); -} -if (lean_is_scalar(x_362)) { - x_363 = lean_alloc_ctor(0, 4, 0); -} else { - x_363 = x_362; -} -lean_ctor_set(x_363, 0, x_359); -lean_ctor_set(x_363, 1, x_360); -lean_ctor_set(x_363, 2, x_285); -lean_ctor_set(x_363, 3, x_361); -if (lean_is_scalar(x_358)) { - x_364 = lean_alloc_ctor(0, 6, 0); -} else { - x_364 = 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); -x_365 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_365, 0, x_352); -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; -x_366 = lean_ctor_get(x_12, 0); -x_367 = lean_ctor_get(x_12, 1); -x_368 = lean_ctor_get(x_12, 2); -x_369 = lean_ctor_get(x_12, 3); -x_370 = lean_ctor_get(x_12, 4); -lean_inc(x_370); -lean_inc(x_369); -lean_inc(x_368); -lean_inc(x_367); -lean_inc(x_366); +lean_inc(x_319); +lean_inc(x_318); +lean_inc(x_317); +lean_inc(x_316); lean_dec(x_12); -x_371 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_371, 0, x_279); -lean_ctor_set(x_371, 1, x_21); -x_372 = lean_array_push(x_368, x_371); -x_373 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_373, 0, x_366); -lean_ctor_set(x_373, 1, x_367); -lean_ctor_set(x_373, 2, x_372); -lean_ctor_set(x_373, 3, x_369); -lean_ctor_set(x_373, 4, x_370); -x_374 = 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_281, x_373, x_278); -if (lean_obj_tag(x_374) == 0) +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_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; lean_object* x_390; lean_object* x_391; -x_375 = lean_ctor_get(x_374, 1); -lean_inc(x_375); -x_376 = lean_ctor_get(x_375, 2); -lean_inc(x_376); -x_377 = lean_ctor_get(x_374, 0); -lean_inc(x_377); -if (lean_is_exclusive(x_374)) { - lean_ctor_release(x_374, 0); - lean_ctor_release(x_374, 1); - x_378 = x_374; -} else { - lean_dec_ref(x_374); - x_378 = lean_box(0); -} -x_379 = lean_ctor_get(x_375, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_375, 1); -lean_inc(x_380); -x_381 = lean_ctor_get(x_375, 3); -lean_inc(x_381); -x_382 = lean_ctor_get(x_375, 4); -lean_inc(x_382); -x_383 = lean_ctor_get(x_375, 5); -lean_inc(x_383); -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); - lean_ctor_release(x_375, 4); - lean_ctor_release(x_375, 5); - x_384 = x_375; -} else { - lean_dec_ref(x_375); - x_384 = lean_box(0); -} -x_385 = lean_ctor_get(x_376, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_376, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_376, 3); -lean_inc(x_387); -if (lean_is_exclusive(x_376)) { - lean_ctor_release(x_376, 0); - lean_ctor_release(x_376, 1); - lean_ctor_release(x_376, 2); - lean_ctor_release(x_376, 3); - x_388 = x_376; -} else { - lean_dec_ref(x_376); - x_388 = lean_box(0); -} -if (lean_is_scalar(x_388)) { - x_389 = lean_alloc_ctor(0, 4, 0); -} else { - x_389 = x_388; -} -lean_ctor_set(x_389, 0, x_385); -lean_ctor_set(x_389, 1, x_386); -lean_ctor_set(x_389, 2, x_285); -lean_ctor_set(x_389, 3, x_387); -if (lean_is_scalar(x_384)) { - x_390 = lean_alloc_ctor(0, 6, 0); -} else { - x_390 = x_384; -} -lean_ctor_set(x_390, 0, x_379); -lean_ctor_set(x_390, 1, x_380); -lean_ctor_set(x_390, 2, x_389); -lean_ctor_set(x_390, 3, x_381); -lean_ctor_set(x_390, 4, x_382); -lean_ctor_set(x_390, 5, x_383); -if (lean_is_scalar(x_378)) { - x_391 = lean_alloc_ctor(0, 2, 0); -} else { - x_391 = x_378; -} -lean_ctor_set(x_391, 0, x_377); -lean_ctor_set(x_391, 1, x_390); -return x_391; +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_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; lean_object* x_407; lean_object* x_408; -x_392 = lean_ctor_get(x_374, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_392, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_374, 0); -lean_inc(x_394); -if (lean_is_exclusive(x_374)) { - lean_ctor_release(x_374, 0); - lean_ctor_release(x_374, 1); - x_395 = x_374; -} else { - lean_dec_ref(x_374); - x_395 = lean_box(0); +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; } -x_396 = lean_ctor_get(x_392, 0); -lean_inc(x_396); -x_397 = lean_ctor_get(x_392, 1); -lean_inc(x_397); -x_398 = lean_ctor_get(x_392, 3); -lean_inc(x_398); -x_399 = lean_ctor_get(x_392, 4); -lean_inc(x_399); -x_400 = lean_ctor_get(x_392, 5); -lean_inc(x_400); -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_401 = x_392; -} else { - lean_dec_ref(x_392); - x_401 = lean_box(0); } -x_402 = lean_ctor_get(x_393, 0); -lean_inc(x_402); -x_403 = lean_ctor_get(x_393, 1); -lean_inc(x_403); -x_404 = lean_ctor_get(x_393, 3); -lean_inc(x_404); -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_405 = x_393; +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); +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); +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 { - lean_dec_ref(x_393); - x_405 = lean_box(0); + x_261 = x_245; + lean_ctor_set_tag(x_261, 1); } -if (lean_is_scalar(x_405)) { - x_406 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_261, 0, x_256); +lean_ctor_set(x_261, 1, x_254); +return x_261; +} +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_406 = x_405; + x_266 = x_245; + lean_ctor_set_tag(x_266, 1); } -lean_ctor_set(x_406, 0, x_402); -lean_ctor_set(x_406, 1, x_403); -lean_ctor_set(x_406, 2, x_285); -lean_ctor_set(x_406, 3, x_404); -if (lean_is_scalar(x_401)) { - x_407 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_266, 0, x_256); +lean_ctor_set(x_266, 1, x_254); +return x_266; +} +} +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_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 { - x_407 = x_401; + lean_dec_ref(x_255); + x_275 = lean_box(0); } -lean_ctor_set(x_407, 0, x_396); -lean_ctor_set(x_407, 1, x_397); -lean_ctor_set(x_407, 2, x_406); -lean_ctor_set(x_407, 3, x_398); -lean_ctor_set(x_407, 4, x_399); -lean_ctor_set(x_407, 5, x_400); -if (lean_is_scalar(x_395)) { - x_408 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_275)) { + x_276 = lean_alloc_ctor(0, 4, 0); } else { - x_408 = x_395; + x_276 = x_275; +} +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, 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); +} else { + x_278 = x_245; + lean_ctor_set_tag(x_278, 1); +} +lean_ctor_set(x_278, 0, x_256); +lean_ctor_set(x_278, 1, x_277); +return x_278; +} +} +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_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_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); +} else { + x_290 = x_245; +} +lean_ctor_set(x_290, 0, x_280); +lean_ctor_set(x_290, 1, x_254); +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_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); +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; +} else { + lean_dec_ref(x_279); + x_299 = lean_box(0); +} +if (lean_is_scalar(x_299)) { + x_300 = lean_alloc_ctor(0, 4, 0); +} else { + x_300 = x_299; +} +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); +} else { + x_302 = x_245; +} +lean_ctor_set(x_302, 0, x_280); +lean_ctor_set(x_302, 1, x_301); +return x_302; } -lean_ctor_set(x_408, 0, x_394); -lean_ctor_set(x_408, 1, x_407); -return x_408; } } } else { -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_283, 0); -x_410 = lean_ctor_get(x_283, 1); -x_411 = lean_ctor_get(x_283, 2); -x_412 = lean_ctor_get(x_283, 3); -lean_inc(x_412); -lean_inc(x_411); -lean_inc(x_410); -lean_inc(x_409); -lean_dec(x_283); -x_413 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_414 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_414, 0, x_409); -lean_ctor_set(x_414, 1, x_410); -lean_ctor_set(x_414, 2, x_413); -lean_ctor_set(x_414, 3, x_412); -lean_ctor_set(x_278, 2, x_414); -x_415 = lean_ctor_get(x_12, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_12, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_12, 2); -lean_inc(x_417); -x_418 = lean_ctor_get(x_12, 3); -lean_inc(x_418); -x_419 = lean_ctor_get(x_12, 4); -lean_inc(x_419); +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); 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_420 = x_12; + x_375 = x_12; } else { lean_dec_ref(x_12); - x_420 = lean_box(0); + x_375 = lean_box(0); } -x_421 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_421, 0, x_279); -lean_ctor_set(x_421, 1, x_21); -x_422 = lean_array_push(x_417, x_421); -if (lean_is_scalar(x_420)) { - x_423 = lean_alloc_ctor(0, 5, 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); } else { - x_423 = x_420; + x_378 = x_375; } -lean_ctor_set(x_423, 0, x_415); -lean_ctor_set(x_423, 1, x_416); -lean_ctor_set(x_423, 2, x_422); -lean_ctor_set(x_423, 3, x_418); -lean_ctor_set(x_423, 4, x_419); -x_424 = 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_281, x_423, x_278); -if (lean_obj_tag(x_424) == 0) +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_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; lean_object* x_441; -x_425 = lean_ctor_get(x_424, 1); -lean_inc(x_425); -x_426 = lean_ctor_get(x_425, 2); -lean_inc(x_426); -x_427 = lean_ctor_get(x_424, 0); -lean_inc(x_427); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - x_428 = x_424; -} else { - lean_dec_ref(x_424); - x_428 = lean_box(0); -} -x_429 = lean_ctor_get(x_425, 0); -lean_inc(x_429); -x_430 = lean_ctor_get(x_425, 1); -lean_inc(x_430); -x_431 = lean_ctor_get(x_425, 3); -lean_inc(x_431); -x_432 = lean_ctor_get(x_425, 4); -lean_inc(x_432); -x_433 = lean_ctor_get(x_425, 5); -lean_inc(x_433); -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); - lean_ctor_release(x_425, 5); - x_434 = x_425; -} else { - lean_dec_ref(x_425); - x_434 = lean_box(0); -} -x_435 = lean_ctor_get(x_426, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_426, 1); -lean_inc(x_436); -x_437 = lean_ctor_get(x_426, 3); -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); - 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, 4, 0); -} else { - x_439 = x_438; -} -lean_ctor_set(x_439, 0, x_435); -lean_ctor_set(x_439, 1, x_436); -lean_ctor_set(x_439, 2, x_411); -lean_ctor_set(x_439, 3, x_437); -if (lean_is_scalar(x_434)) { - x_440 = lean_alloc_ctor(0, 6, 0); -} else { - x_440 = x_434; -} -lean_ctor_set(x_440, 0, x_429); -lean_ctor_set(x_440, 1, x_430); -lean_ctor_set(x_440, 2, x_439); -lean_ctor_set(x_440, 3, x_431); -lean_ctor_set(x_440, 4, x_432); -lean_ctor_set(x_440, 5, x_433); -if (lean_is_scalar(x_428)) { - x_441 = lean_alloc_ctor(0, 2, 0); -} else { - x_441 = x_428; -} -lean_ctor_set(x_441, 0, x_427); -lean_ctor_set(x_441, 1, x_440); -return x_441; +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; } else { -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; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; -x_442 = lean_ctor_get(x_424, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_442, 2); -lean_inc(x_443); -x_444 = lean_ctor_get(x_424, 0); -lean_inc(x_444); -if (lean_is_exclusive(x_424)) { - lean_ctor_release(x_424, 0); - lean_ctor_release(x_424, 1); - x_445 = x_424; -} else { - lean_dec_ref(x_424); - x_445 = lean_box(0); +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; } +block_367: +{ +if (lean_obj_tag(x_335) == 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_inc(x_352); +x_353 = lean_ctor_get(x_335, 0); +lean_inc(x_353); +lean_dec(x_335); +x_354 = lean_ctor_get(x_336, 0); +lean_inc(x_354); +x_355 = lean_ctor_get(x_336, 1); +lean_inc(x_355); +x_356 = lean_ctor_get(x_336, 3); +lean_inc(x_356); +x_357 = lean_ctor_get(x_336, 4); +lean_inc(x_357); +x_358 = lean_ctor_get(x_336, 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; +} else { + lean_dec_ref(x_336); + x_359 = lean_box(0); +} +x_360 = lean_ctor_get(x_352, 0); +lean_inc(x_360); +x_361 = lean_ctor_get(x_352, 1); +lean_inc(x_361); +x_362 = lean_ctor_get(x_352, 3); +lean_inc(x_362); +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; +} else { + lean_dec_ref(x_352); + x_363 = lean_box(0); +} +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 4, 0); +} else { + x_364 = x_363; +} +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); +if (lean_is_scalar(x_359)) { + x_365 = lean_alloc_ctor(0, 6, 0); +} else { + x_365 = 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); +} else { + x_366 = x_245; +} +lean_ctor_set(x_366, 0, x_353); +lean_ctor_set(x_366, 1, x_365); +return x_366; +} +} +} +} +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; +} else { + lean_dec_ref(x_386); + x_396 = 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); +} else { + x_431 = x_396; +} +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); +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; +} else { + lean_dec_ref(x_12); + x_438 = 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); +} else { + x_441 = x_438; +} +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_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; +} +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); -x_448 = lean_ctor_get(x_442, 3); -lean_inc(x_448); -x_449 = lean_ctor_get(x_442, 4); -lean_inc(x_449); -x_450 = lean_ctor_get(x_442, 5); -lean_inc(x_450); -if (lean_is_exclusive(x_442)) { - lean_ctor_release(x_442, 0); - lean_ctor_release(x_442, 1); - lean_ctor_release(x_442, 2); - lean_ctor_release(x_442, 3); - lean_ctor_release(x_442, 4); - lean_ctor_release(x_442, 5); - x_451 = x_442; +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; +} +block_429: +{ +if (lean_obj_tag(x_397) == 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_442); - x_451 = lean_box(0); + lean_dec_ref(x_398); + x_406 = lean_box(0); } -x_452 = lean_ctor_get(x_443, 0); -lean_inc(x_452); -x_453 = lean_ctor_get(x_443, 1); -lean_inc(x_453); -x_454 = lean_ctor_get(x_443, 3); -lean_inc(x_454); -if (lean_is_exclusive(x_443)) { - lean_ctor_release(x_443, 0); - lean_ctor_release(x_443, 1); - lean_ctor_release(x_443, 2); - lean_ctor_release(x_443, 3); - x_455 = x_443; +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_443); - x_455 = lean_box(0); + lean_dec_ref(x_399); + x_410 = lean_box(0); } -if (lean_is_scalar(x_455)) { - x_456 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_410)) { + x_411 = lean_alloc_ctor(0, 4, 0); } else { - x_456 = x_455; + x_411 = x_410; } -lean_ctor_set(x_456, 0, x_452); -lean_ctor_set(x_456, 1, x_453); -lean_ctor_set(x_456, 2, x_411); -lean_ctor_set(x_456, 3, x_454); -if (lean_is_scalar(x_451)) { - x_457 = lean_alloc_ctor(0, 6, 0); +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_457 = x_451; + x_412 = x_406; } -lean_ctor_set(x_457, 0, x_446); -lean_ctor_set(x_457, 1, x_447); -lean_ctor_set(x_457, 2, x_456); -lean_ctor_set(x_457, 3, x_448); -lean_ctor_set(x_457, 4, x_449); -lean_ctor_set(x_457, 5, x_450); -if (lean_is_scalar(x_445)) { - x_458 = lean_alloc_ctor(1, 2, 0); +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_458 = x_445; -} -lean_ctor_set(x_458, 0, x_444); -lean_ctor_set(x_458, 1, x_457); -return x_458; -} + 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_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; 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; lean_object* x_481; lean_object* x_482; -x_459 = lean_ctor_get(x_278, 2); -x_460 = lean_ctor_get(x_278, 0); -x_461 = lean_ctor_get(x_278, 1); -x_462 = lean_ctor_get(x_278, 3); -x_463 = lean_ctor_get(x_278, 4); -x_464 = lean_ctor_get(x_278, 5); -lean_inc(x_464); -lean_inc(x_463); -lean_inc(x_462); -lean_inc(x_459); -lean_inc(x_461); -lean_inc(x_460); -lean_dec(x_278); -x_465 = lean_ctor_get(x_459, 0); -lean_inc(x_465); -x_466 = lean_ctor_get(x_459, 1); -lean_inc(x_466); -x_467 = lean_ctor_get(x_459, 2); -lean_inc(x_467); -x_468 = lean_ctor_get(x_459, 3); -lean_inc(x_468); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - lean_ctor_release(x_459, 2); - lean_ctor_release(x_459, 3); - x_469 = x_459; +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_inc(x_417); +x_418 = lean_ctor_get(x_398, 3); +lean_inc(x_418); +x_419 = lean_ctor_get(x_398, 4); +lean_inc(x_419); +x_420 = lean_ctor_get(x_398, 5); +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_459); - x_469 = lean_box(0); + lean_dec_ref(x_398); + x_421 = lean_box(0); } -x_470 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_469)) { - x_471 = 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); +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; } else { - x_471 = x_469; + lean_dec_ref(x_414); + x_425 = lean_box(0); } -lean_ctor_set(x_471, 0, x_465); -lean_ctor_set(x_471, 1, x_466); -lean_ctor_set(x_471, 2, x_470); -lean_ctor_set(x_471, 3, x_468); -x_472 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_472, 0, x_460); -lean_ctor_set(x_472, 1, x_461); -lean_ctor_set(x_472, 2, x_471); -lean_ctor_set(x_472, 3, x_462); -lean_ctor_set(x_472, 4, x_463); -lean_ctor_set(x_472, 5, x_464); -x_473 = lean_ctor_get(x_12, 0); -lean_inc(x_473); -x_474 = lean_ctor_get(x_12, 1); -lean_inc(x_474); -x_475 = lean_ctor_get(x_12, 2); -lean_inc(x_475); -x_476 = lean_ctor_get(x_12, 3); -lean_inc(x_476); -x_477 = lean_ctor_get(x_12, 4); -lean_inc(x_477); -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_478 = x_12; +if (lean_is_scalar(x_425)) { + x_426 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_12); - x_478 = lean_box(0); + x_426 = x_425; } -x_479 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_479, 0, x_279); -lean_ctor_set(x_479, 1, x_21); -x_480 = lean_array_push(x_475, x_479); -if (lean_is_scalar(x_478)) { - x_481 = lean_alloc_ctor(0, 5, 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); } else { - x_481 = x_478; + x_427 = x_421; } -lean_ctor_set(x_481, 0, x_473); -lean_ctor_set(x_481, 1, x_474); -lean_ctor_set(x_481, 2, x_480); -lean_ctor_set(x_481, 3, x_476); -lean_ctor_set(x_481, 4, x_477); -x_482 = 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_281, x_481, x_472); -if (lean_obj_tag(x_482) == 0) -{ -lean_object* x_483; lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_483 = lean_ctor_get(x_482, 1); -lean_inc(x_483); -x_484 = lean_ctor_get(x_483, 2); -lean_inc(x_484); -x_485 = lean_ctor_get(x_482, 0); -lean_inc(x_485); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - x_486 = x_482; +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); } else { - lean_dec_ref(x_482); - x_486 = lean_box(0); + x_428 = x_245; } -x_487 = lean_ctor_get(x_483, 0); -lean_inc(x_487); -x_488 = lean_ctor_get(x_483, 1); -lean_inc(x_488); -x_489 = lean_ctor_get(x_483, 3); -lean_inc(x_489); -x_490 = lean_ctor_get(x_483, 4); -lean_inc(x_490); -x_491 = lean_ctor_get(x_483, 5); -lean_inc(x_491); -if (lean_is_exclusive(x_483)) { - lean_ctor_release(x_483, 0); - lean_ctor_release(x_483, 1); - lean_ctor_release(x_483, 2); - lean_ctor_release(x_483, 3); - lean_ctor_release(x_483, 4); - lean_ctor_release(x_483, 5); - x_492 = x_483; -} else { - lean_dec_ref(x_483); - x_492 = lean_box(0); +lean_ctor_set(x_428, 0, x_415); +lean_ctor_set(x_428, 1, x_427); +return x_428; } -x_493 = lean_ctor_get(x_484, 0); -lean_inc(x_493); -x_494 = lean_ctor_get(x_484, 1); -lean_inc(x_494); -x_495 = lean_ctor_get(x_484, 3); -lean_inc(x_495); -if (lean_is_exclusive(x_484)) { - lean_ctor_release(x_484, 0); - lean_ctor_release(x_484, 1); - lean_ctor_release(x_484, 2); - lean_ctor_release(x_484, 3); - x_496 = x_484; -} else { - lean_dec_ref(x_484); - x_496 = lean_box(0); -} -if (lean_is_scalar(x_496)) { - x_497 = lean_alloc_ctor(0, 4, 0); -} else { - x_497 = x_496; -} -lean_ctor_set(x_497, 0, x_493); -lean_ctor_set(x_497, 1, x_494); -lean_ctor_set(x_497, 2, x_467); -lean_ctor_set(x_497, 3, x_495); -if (lean_is_scalar(x_492)) { - x_498 = lean_alloc_ctor(0, 6, 0); -} else { - x_498 = x_492; -} -lean_ctor_set(x_498, 0, x_487); -lean_ctor_set(x_498, 1, x_488); -lean_ctor_set(x_498, 2, x_497); -lean_ctor_set(x_498, 3, x_489); -lean_ctor_set(x_498, 4, x_490); -lean_ctor_set(x_498, 5, x_491); -if (lean_is_scalar(x_486)) { - x_499 = lean_alloc_ctor(0, 2, 0); -} else { - x_499 = x_486; -} -lean_ctor_set(x_499, 0, x_485); -lean_ctor_set(x_499, 1, x_498); -return x_499; -} -else -{ -lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; -x_500 = lean_ctor_get(x_482, 1); -lean_inc(x_500); -x_501 = lean_ctor_get(x_500, 2); -lean_inc(x_501); -x_502 = lean_ctor_get(x_482, 0); -lean_inc(x_502); -if (lean_is_exclusive(x_482)) { - lean_ctor_release(x_482, 0); - lean_ctor_release(x_482, 1); - x_503 = x_482; -} else { - lean_dec_ref(x_482); - x_503 = lean_box(0); -} -x_504 = lean_ctor_get(x_500, 0); -lean_inc(x_504); -x_505 = lean_ctor_get(x_500, 1); -lean_inc(x_505); -x_506 = lean_ctor_get(x_500, 3); -lean_inc(x_506); -x_507 = lean_ctor_get(x_500, 4); -lean_inc(x_507); -x_508 = lean_ctor_get(x_500, 5); -lean_inc(x_508); -if (lean_is_exclusive(x_500)) { - lean_ctor_release(x_500, 0); - lean_ctor_release(x_500, 1); - lean_ctor_release(x_500, 2); - lean_ctor_release(x_500, 3); - lean_ctor_release(x_500, 4); - lean_ctor_release(x_500, 5); - x_509 = x_500; -} else { - lean_dec_ref(x_500); - x_509 = lean_box(0); -} -x_510 = lean_ctor_get(x_501, 0); -lean_inc(x_510); -x_511 = lean_ctor_get(x_501, 1); -lean_inc(x_511); -x_512 = lean_ctor_get(x_501, 3); -lean_inc(x_512); -if (lean_is_exclusive(x_501)) { - lean_ctor_release(x_501, 0); - lean_ctor_release(x_501, 1); - lean_ctor_release(x_501, 2); - lean_ctor_release(x_501, 3); - x_513 = x_501; -} else { - lean_dec_ref(x_501); - x_513 = lean_box(0); -} -if (lean_is_scalar(x_513)) { - x_514 = lean_alloc_ctor(0, 4, 0); -} else { - x_514 = x_513; -} -lean_ctor_set(x_514, 0, x_510); -lean_ctor_set(x_514, 1, x_511); -lean_ctor_set(x_514, 2, x_467); -lean_ctor_set(x_514, 3, x_512); -if (lean_is_scalar(x_509)) { - x_515 = lean_alloc_ctor(0, 6, 0); -} else { - x_515 = x_509; -} -lean_ctor_set(x_515, 0, x_504); -lean_ctor_set(x_515, 1, x_505); -lean_ctor_set(x_515, 2, x_514); -lean_ctor_set(x_515, 3, x_506); -lean_ctor_set(x_515, 4, x_507); -lean_ctor_set(x_515, 5, x_508); -if (lean_is_scalar(x_503)) { - x_516 = lean_alloc_ctor(1, 2, 0); -} else { - x_516 = x_503; -} -lean_ctor_set(x_516, 0, x_502); -lean_ctor_set(x_516, 1, x_515); -return x_516; } } } } else { -uint8_t x_517; +uint8_t x_449; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -5451,23 +4727,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_517 = !lean_is_exclusive(x_272); -if (x_517 == 0) +x_449 = !lean_is_exclusive(x_238); +if (x_449 == 0) { -return x_272; +return x_238; } else { -lean_object* x_518; lean_object* x_519; lean_object* x_520; -x_518 = lean_ctor_get(x_272, 0); -x_519 = lean_ctor_get(x_272, 1); -lean_inc(x_519); -lean_inc(x_518); -lean_dec(x_272); -x_520 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_520, 0, x_518); -lean_ctor_set(x_520, 1, x_519); -return x_520; +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; } } } @@ -5475,7 +4751,7 @@ return x_520; } else { -uint8_t x_521; +uint8_t x_453; lean_dec(x_25); lean_dec(x_21); lean_dec(x_12); @@ -5486,29 +4762,29 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_521 = !lean_is_exclusive(x_26); -if (x_521 == 0) +x_453 = !lean_is_exclusive(x_26); +if (x_453 == 0) { return x_26; } else { -lean_object* x_522; lean_object* x_523; lean_object* x_524; -x_522 = lean_ctor_get(x_26, 0); -x_523 = lean_ctor_get(x_26, 1); -lean_inc(x_523); -lean_inc(x_522); +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_dec(x_26); -x_524 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_524, 0, x_522); -lean_ctor_set(x_524, 1, x_523); -return x_524; +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; } } } else { -uint8_t x_525; +uint8_t x_457; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -5518,23 +4794,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_525 = !lean_is_exclusive(x_22); -if (x_525 == 0) +x_457 = !lean_is_exclusive(x_22); +if (x_457 == 0) { return x_22; } else { -lean_object* x_526; lean_object* x_527; lean_object* x_528; -x_526 = lean_ctor_get(x_22, 0); -x_527 = lean_ctor_get(x_22, 1); -lean_inc(x_527); -lean_inc(x_526); +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_dec(x_22); -x_528 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_528, 0, x_526); -lean_ctor_set(x_528, 1, x_527); -return x_528; +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; } } } diff --git a/stage0/stdlib/Lean/Meta/Tactic/Util.c b/stage0/stdlib/Lean/Meta/Tactic/Util.c index 851938e8ae..a9bf453c22 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Util.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Util.c @@ -24,6 +24,7 @@ lean_object* l_Lean_Meta_getMVarTag(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_checkNotAssigned___closed__2; lean_object* l_Lean_Meta_Meta_hasOrelse___closed__1; lean_object* l_Lean_Meta_orelse(lean_object*); +extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* l_Lean_MetavarContext_setMVarUserName(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_throwTacticEx___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_checkNotAssigned___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -41,7 +42,6 @@ lean_object* l_Lean_Meta_Meta_hasOrelse(lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; lean_object* l_Lean_Meta_mkFreshExprSyntheticOpaqueMVar(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; lean_object* l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__1; lean_object* l_Lean_Meta_getMVarTag___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_setMVarTag(lean_object*, lean_object*, lean_object*, lean_object*); @@ -458,7 +458,7 @@ lean_object* _init_l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; x_2 = l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; diff --git a/stage0/stdlib/Lean/MetavarContext.c b/stage0/stdlib/Lean/MetavarContext.c index d9231dee1e..5bd9ede196 100644 --- a/stage0/stdlib/Lean/MetavarContext.c +++ b/stage0/stdlib/Lean/MetavarContext.c @@ -42785,12 +42785,11 @@ return x_4; lean_object* l_Lean_MetavarContext_levelMVarToParam(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; +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_6 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_6, 0, x_4); lean_ctor_set(x_6, 1, x_2); x_7 = l_Array_empty___closed__1; -lean_inc(x_1); x_8 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_8, 0, x_1); lean_ctor_set(x_8, 1, x_7); @@ -42801,17 +42800,19 @@ lean_inc(x_10); x_11 = lean_ctor_get(x_9, 0); lean_inc(x_11); lean_dec(x_9); -x_12 = lean_ctor_get(x_10, 1); +x_12 = lean_ctor_get(x_10, 0); lean_inc(x_12); -x_13 = lean_ctor_get(x_10, 2); +x_13 = lean_ctor_get(x_10, 1); lean_inc(x_13); +x_14 = lean_ctor_get(x_10, 2); +lean_inc(x_14); lean_dec(x_10); -x_14 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_14, 0, x_1); -lean_ctor_set(x_14, 1, x_12); -lean_ctor_set(x_14, 2, x_13); -lean_ctor_set(x_14, 3, x_11); -return x_14; +x_15 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_15, 0, x_12); +lean_ctor_set(x_15, 1, x_13); +lean_ctor_set(x_15, 2, x_14); +lean_ctor_set(x_15, 3, x_11); +return x_15; } } lean_object* initialize_Init(lean_object*); diff --git a/stage0/stdlib/Lean/Parser/Command.c b/stage0/stdlib/Lean/Parser/Command.c index 1b0e22a1bd..8f2eae6d01 100644 --- a/stage0/stdlib/Lean/Parser/Command.c +++ b/stage0/stdlib/Lean/Parser/Command.c @@ -22,6 +22,7 @@ lean_object* l_Lean_Parser_Command_mutual___elambda__1___closed__8; lean_object* l_Lean_Parser_Command_init__quot___closed__3; lean_object* l_Lean_Parser_Command_universes___closed__7; lean_object* l_Lean_Parser_Command_structure___elambda__1___closed__3; +lean_object* l_Lean_Parser_Command_ctor___elambda__1___closed__1; lean_object* l___regBuiltinParser_Lean_Parser_Command_resolve__name(lean_object*); lean_object* l_Lean_Parser_Command_def___closed__5; lean_object* l_Lean_Parser_Command_mutual___elambda__1___closed__9; @@ -41,6 +42,7 @@ lean_object* l_Lean_Parser_Command_structImplicitBinder___closed__9; lean_object* l_Lean_Parser_Command_declModifiers___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_resolve__name___elambda__1___closed__8; lean_object* l_Lean_Parser_Command_extends___elambda__1___closed__3; +lean_object* l_Lean_Parser_Command_ctor; lean_object* l_Lean_Parser_Command_structure___closed__3; lean_object* l_Lean_Parser_Command_def___elambda__1___closed__6; lean_object* l_Lean_Parser_Command_constant___closed__6; @@ -64,6 +66,7 @@ lean_object* l_Lean_Parser_Command_docComment___closed__3; lean_object* l_Lean_Parser_andthenInfo(lean_object*, lean_object*); lean_object* l_Lean_Parser_regBuiltinCommandParserAttr___closed__1; lean_object* l_Lean_Parser_Command_instance___closed__4; +lean_object* l_Lean_Parser_Command_ctor___elambda__1___closed__4; lean_object* l___regBuiltinParser_Lean_Parser_Command_variable(lean_object*); lean_object* l_Lean_Parser_Command_visibility; lean_object* l_Lean_Parser_Command_inductive___elambda__1(lean_object*, lean_object*); @@ -77,9 +80,9 @@ lean_object* l_Lean_Parser_Command_end___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_openRenamingItem___elambda__1___closed__4; lean_object* l_Lean_Parser_Command_extends___closed__1; lean_object* l___regBuiltinParser_Lean_Parser_Command_section(lean_object*); -lean_object* l_Lean_Parser_Command_introRule___elambda__1___closed__1; lean_object* l___private_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Command_declId___elambda__1___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_example___closed__3; +lean_object* l_Lean_Parser_Command_ctor___closed__6; lean_object* l_Lean_Parser_Command_structureTk___closed__4; lean_object* l_Lean_Parser_Command_structImplicitBinder___closed__1; lean_object* l_Lean_Parser_Command_declId___closed__5; @@ -89,7 +92,6 @@ extern lean_object* l_Lean_nullKind; lean_object* l_Lean_Parser_Command_classInductive; lean_object* l_Lean_Parser_Command_check___elambda__1___closed__5; lean_object* l_Lean_Parser_Command_instance___closed__1; -lean_object* l_Lean_Parser_Command_introRule___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_export___closed__3; lean_object* l_Lean_Parser_Command_attribute___closed__7; lean_object* l_Lean_Parser_Command_protected___elambda__1___closed__8; @@ -138,7 +140,6 @@ lean_object* l_Lean_Parser_Command_attrInstance___closed__4; extern lean_object* l___private_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_explicitUniv___elambda__1___spec__2___closed__1; lean_object* l_Lean_Parser_Command_resolve__name___elambda__1___closed__2; lean_object* l_Lean_Parser_manyAux___main___at_Lean_Parser_Command_structFields___elambda__1___spec__1(lean_object*, lean_object*); -lean_object* l_Lean_Parser_Command_introRule___elambda__1___closed__4; lean_object* l_Lean_Parser_Command_init__quot___closed__5; lean_object* l___regBuiltinParser_Lean_Parser_Command_eval(lean_object*); lean_object* l_Lean_Parser_Command_extends___elambda__1___closed__8; @@ -153,6 +154,7 @@ lean_object* l_Lean_Parser_Command_attributes___closed__7; lean_object* l_Lean_Parser_Command_section___closed__5; lean_object* l_Lean_Parser_Command_openSimple___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_extends___elambda__1___closed__1; +lean_object* l_Lean_Parser_Command_ctor___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_exit___closed__1; lean_object* l_Lean_Parser_Command_export___elambda__1___closed__5; lean_object* l_Lean_Parser_Command_declVal___elambda__1(lean_object*, lean_object*); @@ -220,6 +222,7 @@ lean_object* l_Lean_Parser_Command_structure___closed__1; lean_object* l_Lean_Parser_Command_structureTk___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_check___closed__5; lean_object* l_Lean_Parser_Command_def___elambda__1___closed__3; +lean_object* l_Lean_Parser_Command_ctor___closed__3; lean_object* l___private_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Command_openRenaming___elambda__1___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_attrArg___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_classInductive___elambda__1___closed__5; @@ -253,6 +256,7 @@ lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Parser_Command_structFields; lean_object* l_Lean_Parser_Command_abbrev___closed__3; lean_object* l_Lean_Parser_Command_declId___closed__9; +lean_object* l_Lean_Parser_Command_ctor___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_declId___closed__8; lean_object* lean_string_append(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_declValEqns___elambda__1___closed__2; @@ -309,8 +313,8 @@ lean_object* l_Lean_Parser_Command_openOnly___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_attributes___closed__5; lean_object* l_Lean_Parser_Command_universes___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_namespace___closed__5; -lean_object* l_Lean_Parser_Command_introRule; lean_object* l_Lean_Parser_Command_universe___elambda__1___closed__7; +lean_object* l_Lean_Parser_Command_ctor___closed__10; lean_object* l_Lean_Parser_Command_commentBody___closed__2; lean_object* l_Lean_Parser_Command_example___elambda__1___closed__8; lean_object* l_Lean_Parser_Command_classTk___closed__5; @@ -334,9 +338,7 @@ lean_object* l_Lean_Parser_Command_init__quot___elambda__1(lean_object*, lean_ob lean_object* l_Lean_Parser_Command_structExplicitBinder___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_openHiding___closed__5; lean_object* l_Lean_Parser_Command_protected___elambda__1___closed__7; -lean_object* l_Lean_Parser_Command_introRule___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_openSimple___elambda__1___closed__1; -lean_object* l_Lean_Parser_Command_introRule___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_example___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_openRenamingItem___closed__4; lean_object* l_Lean_Parser_Command_open___elambda__1___closed__6; @@ -476,7 +478,6 @@ lean_object* l_Lean_Parser_Command_structInstBinder___elambda__1___closed__3; lean_object* l_Array_shrink___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_export___closed__4; lean_object* l_Lean_Parser_Command_abbrev___elambda__1___closed__8; -lean_object* l_Lean_Parser_Command_introRule___closed__1; lean_object* l_Lean_Parser_Command_openHiding___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_docComment___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_universe___elambda__1___closed__5; @@ -532,7 +533,6 @@ lean_object* l_Lean_Parser_Command_extends___elambda__1(lean_object*, lean_objec lean_object* l___regBuiltinParser_Lean_Parser_Command_check__failure(lean_object*); lean_object* l_Lean_Parser_Command_namespace___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_section___elambda__1___closed__3; -lean_object* l_Lean_Parser_Command_introRule___closed__4; lean_object* l_Lean_Parser_Command_inferMod___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_end___closed__3; lean_object* l_Lean_Parser_Command_extends___elambda__1___closed__5; @@ -552,7 +552,6 @@ lean_object* l_Lean_Parser_Command_structureTk___elambda__1___closed__6; lean_object* l_Lean_Parser_Command_export___closed__1; lean_object* l_Lean_Parser_Command_set__option___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_section___closed__2; -lean_object* l_Lean_Parser_Command_introRule___closed__9; lean_object* l_Lean_Parser_Command_attrInstance___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_structInstBinder___closed__8; lean_object* l_Lean_Parser_Command_theorem; @@ -679,7 +678,6 @@ lean_object* l_Lean_Parser_Command_protected___closed__5; lean_object* l_Lean_Parser_Command_attributes___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_eval___closed__3; lean_object* l_Lean_Parser_Command_partial___elambda__1___closed__8; -lean_object* l_Lean_Parser_Command_introRule___closed__8; lean_object* l_Lean_Parser_Command_noncomputable___elambda__1___closed__7; lean_object* l_Lean_Parser_Command_structFields___elambda__1___closed__4; lean_object* l_Lean_Parser_Command_open___elambda__1___closed__2; @@ -692,6 +690,7 @@ lean_object* l_Lean_Parser_Command_inferMod___elambda__1(lean_object*, lean_obje lean_object* l_Lean_Parser_Command_end___closed__4; lean_object* l_Lean_Parser_Command_variable; lean_object* l_Lean_Parser_Command_structInstBinder___closed__9; +lean_object* l_Lean_Parser_Command_ctor___closed__4; lean_object* l_Lean_Parser_Command_universes___closed__4; extern lean_object* l_Lean_Parser_Term_tacticBlock___closed__2; lean_object* l_Lean_Parser_Command_classTk___elambda__1___closed__4; @@ -700,6 +699,7 @@ extern lean_object* l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_abbrev___closed__9; lean_object* l_Lean_Parser_Command_declSig___elambda__1(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_haveAssign___elambda__1___closed__8; +lean_object* l_Lean_Parser_Command_ctor___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_mutual___elambda__1___closed__7; lean_object* l_Lean_Parser_Command_openSimple___closed__5; lean_object* l_Lean_Parser_Command_theorem___elambda__1___closed__5; @@ -864,6 +864,7 @@ lean_object* l_Lean_Parser_Command_openHiding___elambda__1___closed__5; extern lean_object* l_Lean_Parser_Term_structInstArrayRef___elambda__1___closed__6; lean_object* l_Lean_Parser_Command_resolve__name___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_private___elambda__1___closed__1; +lean_object* l_Lean_Parser_Command_ctor___closed__1; lean_object* l_Lean_Parser_Command_declModifiers___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_check__failure___closed__6; lean_object* l_Lean_Parser_Command_constant___elambda__1___closed__5; @@ -873,6 +874,7 @@ lean_object* l_Lean_Parser_Command_namespace___closed__7; lean_object* l_Lean_Parser_categoryParser(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_check__failure___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_structImplicitBinder___elambda__1(lean_object*, lean_object*); +lean_object* l_Lean_Parser_Command_ctor___closed__2; lean_object* l_Lean_Parser_Command_structure___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_structCtor___closed__3; lean_object* l_Lean_Parser_Command_noncomputable___elambda__1___closed__4; @@ -896,13 +898,13 @@ lean_object* l_Lean_Parser_Command_openOnly___elambda__1___closed__3; lean_object* l_Lean_Parser_Command_check__failure___elambda__1___closed__8; lean_object* l_Lean_Parser_sepBy1Fn___at_Lean_Parser_Command_openRenaming___elambda__1___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_structInstBinder___elambda__1___closed__1; -lean_object* l_Lean_Parser_Command_introRule___closed__6; lean_object* l_Lean_Parser_Command_protected___elambda__1___closed__4; lean_object* l_Lean_Parser_Command_attributes___elambda__1___closed__8; lean_object* l_Lean_Parser_Command_declaration___closed__1; lean_object* l_Lean_Parser_Command_declSig___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_inductive___closed__1; lean_object* l_Lean_Parser_Command_declValSimple___closed__4; +lean_object* l_Lean_Parser_Command_ctor___closed__8; lean_object* l_Lean_Parser_Command_theorem___closed__1; lean_object* l_Lean_Parser_Command_classInductive___elambda__1___closed__8; lean_object* l_Lean_Parser_Command_theorem___closed__4; @@ -919,7 +921,6 @@ lean_object* l_Lean_Parser_Command_docComment; extern lean_object* l_Lean_Parser_Term_explicitUniv___closed__2; lean_object* l_Lean_Parser_Command_structCtor___elambda__1___closed__7; extern lean_object* l_Lean_Parser_epsilonInfo; -lean_object* l_Lean_Parser_Command_introRule___closed__2; lean_object* l_Lean_Parser_Command_def___closed__1; lean_object* l_Lean_Parser_Command_attrInstance___closed__3; lean_object* l_Lean_Parser_Command_export___elambda__1___closed__4; @@ -935,6 +936,7 @@ lean_object* l_Lean_Parser_Command_attribute___closed__8; lean_object* l_Lean_Parser_Command_structureTk___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_open___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_categoryParser___elambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Parser_Command_ctor___closed__9; lean_object* l_Lean_Parser_Command_variable___elambda__1___closed__6; lean_object* l_Lean_Parser_Command_classInductive___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_instance___elambda__1___closed__7; @@ -985,6 +987,7 @@ lean_object* l_Lean_Parser_Command_def___elambda__1___closed__7; lean_object* l_Lean_Parser_Command_inductive___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_export___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_universe___elambda__1___closed__9; +lean_object* l_Lean_Parser_Command_ctor___closed__5; lean_object* l_Lean_Parser_Command_structureTk___closed__3; lean_object* l_Lean_Parser_Command_constant___elambda__1___closed__4; lean_object* l_Lean_Parser_Command_universes___elambda__1___closed__2; @@ -995,7 +998,6 @@ lean_object* l_Lean_Parser_Command_declaration___closed__8; lean_object* l_Lean_Parser_Command_optDeclSig___elambda__1___closed__4; lean_object* l_String_trim(lean_object*); lean_object* l_Lean_Parser_Command_structure___elambda__1(lean_object*, lean_object*); -lean_object* l_Lean_Parser_Command_introRule___closed__3; lean_object* l_Lean_Parser_Command_mutual___elambda__1___closed__6; lean_object* l_Lean_Parser_Command_axiom___closed__4; lean_object* l_Lean_Parser_Command_exit___closed__5; @@ -1022,7 +1024,6 @@ lean_object* l_Lean_Parser_Command_universes___elambda__1___closed__9; extern lean_object* l_Lean_Parser_Term_doPat___elambda__1___closed__9; lean_object* l_Lean_Parser_Command_set__option___closed__1; lean_object* l_Lean_Parser_Command_protected___elambda__1(lean_object*, lean_object*); -lean_object* l_Lean_Parser_Command_introRule___closed__5; lean_object* l_Lean_Parser_Command_set__option___elambda__1___closed__7; lean_object* l_Lean_Parser_Command_unsafe___elambda__1___closed__1; lean_object* l_Lean_Parser_Command_classTk___closed__3; @@ -1201,11 +1202,11 @@ lean_object* l_Lean_Parser_Command_check___closed__4; lean_object* l_Lean_Parser_Command_classTk___elambda__1___closed__2; lean_object* l_Lean_Parser_Command_open___closed__4; lean_object* l_Lean_Parser_Command_attribute___closed__9; -lean_object* l_Lean_Parser_Command_introRule___closed__7; lean_object* l_Lean_Parser_Command_export___closed__10; lean_object* l_Lean_Parser_Command_constant___elambda__1___closed__2; lean_object* l_Lean_Parser_regBuiltinCommandParserAttr___closed__3; lean_object* l_Lean_Parser_unicodeSymbolFnAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Parser_Command_ctor___closed__7; lean_object* l_Lean_Parser_Command_attributes___closed__2; lean_object* l_Lean_Parser_Command_private___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Command_section___elambda__1(lean_object*, lean_object*); @@ -13932,50 +13933,50 @@ x_1 = l_Lean_Parser_Command_inferMod___closed__6; return x_1; } } -lean_object* _init_l_Lean_Parser_Command_introRule___elambda__1___closed__1() { +lean_object* _init_l_Lean_Parser_Command_ctor___elambda__1___closed__1() { _start: { lean_object* x_1; -x_1 = lean_mk_string("introRule"); +x_1 = lean_mk_string("ctor"); return x_1; } } -lean_object* _init_l_Lean_Parser_Command_introRule___elambda__1___closed__2() { +lean_object* _init_l_Lean_Parser_Command_ctor___elambda__1___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_Parser_Command_docComment___elambda__1___closed__2; -x_2 = l_Lean_Parser_Command_introRule___elambda__1___closed__1; +x_2 = l_Lean_Parser_Command_ctor___elambda__1___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule___elambda__1___closed__3() { +lean_object* _init_l_Lean_Parser_Command_ctor___elambda__1___closed__3() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; +x_1 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; x_2 = lean_alloc_ctor(1, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l_Lean_Parser_Command_introRule___elambda__1___closed__4() { +lean_object* _init_l_Lean_Parser_Command_ctor___elambda__1___closed__4() { _start: { lean_object* x_1; lean_object* x_2; uint8_t x_3; lean_object* x_4; -x_1 = l_Lean_Parser_Command_introRule___elambda__1___closed__1; -x_2 = l_Lean_Parser_Command_introRule___elambda__1___closed__3; +x_1 = l_Lean_Parser_Command_ctor___elambda__1___closed__1; +x_2 = l_Lean_Parser_Command_ctor___elambda__1___closed__3; x_3 = 1; x_4 = l_Lean_Parser_mkAntiquot(x_1, x_2, x_3); return x_4; } } -lean_object* l_Lean_Parser_Command_introRule___elambda__1(lean_object* x_1, lean_object* x_2) { +lean_object* l_Lean_Parser_Command_ctor___elambda__1(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; uint8_t x_5; -x_3 = l_Lean_Parser_Command_introRule___elambda__1___closed__4; +x_3 = l_Lean_Parser_Command_ctor___elambda__1___closed__4; x_4 = lean_ctor_get(x_3, 1); lean_inc(x_4); lean_inc(x_2); @@ -13991,68 +13992,68 @@ x_8 = lean_ctor_get(x_7, 3); lean_inc(x_8); if (lean_obj_tag(x_8) == 0) { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_52; lean_object* x_53; lean_object* x_54; +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_9 = lean_ctor_get(x_7, 0); lean_inc(x_9); x_10 = lean_array_get_size(x_9); lean_dec(x_9); -x_52 = lean_ctor_get(x_7, 1); -lean_inc(x_52); +x_56 = lean_ctor_get(x_7, 1); +lean_inc(x_56); lean_inc(x_1); -x_53 = l_Lean_Parser_tokenFn(x_1, x_7); -x_54 = lean_ctor_get(x_53, 3); -lean_inc(x_54); -if (lean_obj_tag(x_54) == 0) +x_57 = l_Lean_Parser_tokenFn(x_1, x_7); +x_58 = lean_ctor_get(x_57, 3); +lean_inc(x_58); +if (lean_obj_tag(x_58) == 0) { -lean_object* x_55; lean_object* x_56; -x_55 = lean_ctor_get(x_53, 0); -lean_inc(x_55); -x_56 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_55); -lean_dec(x_55); -if (lean_obj_tag(x_56) == 2) +lean_object* x_59; lean_object* x_60; +x_59 = lean_ctor_get(x_57, 0); +lean_inc(x_59); +x_60 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_59); +lean_dec(x_59); +if (lean_obj_tag(x_60) == 2) { -lean_object* x_57; lean_object* x_58; uint8_t x_59; -x_57 = lean_ctor_get(x_56, 1); -lean_inc(x_57); -lean_dec(x_56); -x_58 = l_Lean_Parser_Term_doPat___elambda__1___closed__6; -x_59 = lean_string_dec_eq(x_57, x_58); -lean_dec(x_57); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; -x_60 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_61 = l_Lean_Parser_ParserState_mkErrorsAt(x_53, x_60, x_52); -x_11 = x_61; -goto block_51; -} -else -{ -lean_dec(x_52); -x_11 = x_53; -goto block_51; -} -} -else -{ -lean_object* x_62; lean_object* x_63; -lean_dec(x_56); -x_62 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_63 = l_Lean_Parser_ParserState_mkErrorsAt(x_53, x_62, x_52); -x_11 = x_63; -goto block_51; -} -} -else +lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_61 = lean_ctor_get(x_60, 1); +lean_inc(x_61); +lean_dec(x_60); +x_62 = l_Lean_Parser_Term_doPat___elambda__1___closed__6; +x_63 = lean_string_dec_eq(x_61, x_62); +lean_dec(x_61); +if (x_63 == 0) { lean_object* x_64; lean_object* x_65; -lean_dec(x_54); x_64 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_65 = l_Lean_Parser_ParserState_mkErrorsAt(x_53, x_64, x_52); +x_65 = l_Lean_Parser_ParserState_mkErrorsAt(x_57, x_64, x_56); x_11 = x_65; -goto block_51; +goto block_55; } -block_51: +else +{ +lean_dec(x_56); +x_11 = x_57; +goto block_55; +} +} +else +{ +lean_object* x_66; lean_object* x_67; +lean_dec(x_60); +x_66 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; +x_67 = l_Lean_Parser_ParserState_mkErrorsAt(x_57, x_66, x_56); +x_11 = x_67; +goto block_55; +} +} +else +{ +lean_object* x_68; lean_object* x_69; +lean_dec(x_58); +x_68 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; +x_69 = l_Lean_Parser_ParserState_mkErrorsAt(x_57, x_68, x_56); +x_11 = x_69; +goto block_55; +} +block_55: { lean_object* x_12; x_12 = lean_ctor_get(x_11, 3); @@ -14061,128 +14062,145 @@ if (lean_obj_tag(x_12) == 0) { lean_object* x_13; lean_object* x_14; lean_inc(x_1); -x_13 = l_Lean_Parser_ident___elambda__1(x_1, x_11); +x_13 = l_Lean_Parser_Command_declModifiers___elambda__1(x_1, x_11); x_14 = lean_ctor_get(x_13, 3); lean_inc(x_14); if (lean_obj_tag(x_14) == 0) { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_15 = lean_ctor_get(x_13, 0); -lean_inc(x_15); -x_16 = lean_array_get_size(x_15); -lean_dec(x_15); -x_17 = lean_ctor_get(x_13, 1); -lean_inc(x_17); +lean_object* x_15; lean_object* x_16; lean_inc(x_1); -x_18 = l_Lean_Parser_Command_inferMod___elambda__1(x_1, x_13); -x_19 = lean_ctor_get(x_18, 3); -lean_inc(x_19); -if (lean_obj_tag(x_19) == 0) +x_15 = l_Lean_Parser_ident___elambda__1(x_1, x_13); +x_16 = lean_ctor_get(x_15, 3); +lean_inc(x_16); +if (lean_obj_tag(x_16) == 0) { -lean_object* x_20; lean_object* x_21; lean_object* x_22; +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_17 = lean_ctor_get(x_15, 0); +lean_inc(x_17); +x_18 = lean_array_get_size(x_17); lean_dec(x_17); -x_20 = l_Lean_nullKind; -x_21 = l_Lean_Parser_ParserState_mkNode(x_18, x_20, x_16); -x_22 = lean_ctor_get(x_21, 3); -lean_inc(x_22); -if (lean_obj_tag(x_22) == 0) +x_19 = lean_ctor_get(x_15, 1); +lean_inc(x_19); +lean_inc(x_1); +x_20 = l_Lean_Parser_Command_inferMod___elambda__1(x_1, x_15); +x_21 = lean_ctor_get(x_20, 3); +lean_inc(x_21); +if (lean_obj_tag(x_21) == 0) { -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_21); -x_24 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_25 = l_Lean_Parser_ParserState_mkNode(x_23, x_24, x_10); -return x_25; -} -else +lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_dec(x_19); +x_22 = l_Lean_nullKind; +x_23 = l_Lean_Parser_ParserState_mkNode(x_20, x_22, x_18); +x_24 = lean_ctor_get(x_23, 3); +lean_inc(x_24); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_1); -x_26 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_27 = l_Lean_Parser_ParserState_mkNode(x_21, x_26, x_10); +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_23); +x_26 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_27 = l_Lean_Parser_ParserState_mkNode(x_25, x_26, x_10); return x_27; } -} else { -lean_object* x_28; uint8_t x_29; -lean_dec(x_19); -x_28 = lean_ctor_get(x_18, 1); -lean_inc(x_28); -x_29 = lean_nat_dec_eq(x_28, x_17); -lean_dec(x_28); -if (x_29 == 0) -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -lean_dec(x_17); -x_30 = l_Lean_nullKind; -x_31 = l_Lean_Parser_ParserState_mkNode(x_18, x_30, x_16); -x_32 = lean_ctor_get(x_31, 3); -lean_inc(x_32); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_31); -x_34 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_35 = l_Lean_Parser_ParserState_mkNode(x_33, x_34, x_10); -return x_35; -} -else -{ -lean_object* x_36; lean_object* x_37; -lean_dec(x_32); +lean_object* x_28; lean_object* x_29; +lean_dec(x_24); lean_dec(x_1); -x_36 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_37 = l_Lean_Parser_ParserState_mkNode(x_31, x_36, x_10); +x_28 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_29 = l_Lean_Parser_ParserState_mkNode(x_23, x_28, x_10); +return x_29; +} +} +else +{ +lean_object* x_30; uint8_t x_31; +lean_dec(x_21); +x_30 = lean_ctor_get(x_20, 1); +lean_inc(x_30); +x_31 = lean_nat_dec_eq(x_30, x_19); +lean_dec(x_30); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +lean_dec(x_19); +x_32 = l_Lean_nullKind; +x_33 = l_Lean_Parser_ParserState_mkNode(x_20, x_32, x_18); +x_34 = lean_ctor_get(x_33, 3); +lean_inc(x_34); +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_33); +x_36 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_37 = l_Lean_Parser_ParserState_mkNode(x_35, x_36, x_10); return x_37; } -} else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_38 = l_Lean_Parser_ParserState_restore(x_18, x_16, x_17); -x_39 = l_Lean_nullKind; -x_40 = l_Lean_Parser_ParserState_mkNode(x_38, x_39, x_16); -x_41 = lean_ctor_get(x_40, 3); -lean_inc(x_41); -if (lean_obj_tag(x_41) == 0) -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_42 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_40); -x_43 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_44 = l_Lean_Parser_ParserState_mkNode(x_42, x_43, x_10); -return x_44; -} -else -{ -lean_object* x_45; lean_object* x_46; -lean_dec(x_41); +lean_object* x_38; lean_object* x_39; +lean_dec(x_34); lean_dec(x_1); -x_45 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_46 = l_Lean_Parser_ParserState_mkNode(x_40, x_45, x_10); +x_38 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_39 = l_Lean_Parser_ParserState_mkNode(x_33, x_38, x_10); +return x_39; +} +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_40 = l_Lean_Parser_ParserState_restore(x_20, x_18, x_19); +x_41 = l_Lean_nullKind; +x_42 = l_Lean_Parser_ParserState_mkNode(x_40, x_41, x_18); +x_43 = lean_ctor_get(x_42, 3); +lean_inc(x_43); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_42); +x_45 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_46 = l_Lean_Parser_ParserState_mkNode(x_44, x_45, x_10); return x_46; } -} -} -} else { lean_object* x_47; lean_object* x_48; -lean_dec(x_14); +lean_dec(x_43); lean_dec(x_1); -x_47 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_48 = l_Lean_Parser_ParserState_mkNode(x_13, x_47, x_10); +x_47 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_48 = l_Lean_Parser_ParserState_mkNode(x_42, x_47, x_10); return x_48; } } +} +} else { lean_object* x_49; lean_object* x_50; +lean_dec(x_16); +lean_dec(x_1); +x_49 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_50 = l_Lean_Parser_ParserState_mkNode(x_15, x_49, x_10); +return x_50; +} +} +else +{ +lean_object* x_51; lean_object* x_52; +lean_dec(x_14); +lean_dec(x_1); +x_51 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_52 = l_Lean_Parser_ParserState_mkNode(x_13, x_51, x_10); +return x_52; +} +} +else +{ +lean_object* x_53; lean_object* x_54; lean_dec(x_12); lean_dec(x_1); -x_49 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_50 = l_Lean_Parser_ParserState_mkNode(x_11, x_49, x_10); -return x_50; +x_53 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_54 = l_Lean_Parser_ParserState_mkNode(x_11, x_53, x_10); +return x_54; } } } @@ -14195,280 +14213,299 @@ return x_7; } 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_2, 0); -lean_inc(x_66); -x_67 = lean_array_get_size(x_66); -lean_dec(x_66); -x_68 = lean_ctor_get(x_2, 1); -lean_inc(x_68); -lean_inc(x_1); -x_69 = lean_apply_2(x_4, x_1, x_2); -x_70 = lean_ctor_get(x_69, 3); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_70 = lean_ctor_get(x_2, 0); lean_inc(x_70); -if (lean_obj_tag(x_70) == 0) -{ -lean_dec(x_68); -lean_dec(x_67); -lean_dec(x_1); -return x_69; -} -else -{ -lean_object* x_71; lean_object* x_72; uint8_t x_73; -x_71 = lean_ctor_get(x_70, 0); -lean_inc(x_71); +x_71 = lean_array_get_size(x_70); lean_dec(x_70); -x_72 = lean_ctor_get(x_69, 1); +x_72 = lean_ctor_get(x_2, 1); lean_inc(x_72); -x_73 = lean_nat_dec_eq(x_72, x_68); -lean_dec(x_72); -if (x_73 == 0) -{ -lean_dec(x_71); -lean_dec(x_68); -lean_dec(x_67); -lean_dec(x_1); -return x_69; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -lean_inc(x_68); -x_74 = l_Lean_Parser_ParserState_restore(x_69, x_67, x_68); -lean_dec(x_67); -x_75 = lean_unsigned_to_nat(1024u); -x_76 = l_Lean_Parser_checkPrecFn(x_75, x_1, x_74); -x_77 = lean_ctor_get(x_76, 3); -lean_inc(x_77); -if (lean_obj_tag(x_77) == 0) -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_78 = lean_ctor_get(x_76, 0); -lean_inc(x_78); -x_79 = lean_array_get_size(x_78); -lean_dec(x_78); -x_129 = lean_ctor_get(x_76, 1); -lean_inc(x_129); lean_inc(x_1); -x_130 = l_Lean_Parser_tokenFn(x_1, x_76); -x_131 = lean_ctor_get(x_130, 3); -lean_inc(x_131); -if (lean_obj_tag(x_131) == 0) +x_73 = lean_apply_2(x_4, x_1, x_2); +x_74 = lean_ctor_get(x_73, 3); +lean_inc(x_74); +if (lean_obj_tag(x_74) == 0) { -lean_object* x_132; lean_object* x_133; -x_132 = lean_ctor_get(x_130, 0); -lean_inc(x_132); -x_133 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_132); -lean_dec(x_132); -if (lean_obj_tag(x_133) == 2) -{ -lean_object* x_134; lean_object* x_135; uint8_t x_136; -x_134 = lean_ctor_get(x_133, 1); -lean_inc(x_134); -lean_dec(x_133); -x_135 = l_Lean_Parser_Term_doPat___elambda__1___closed__6; -x_136 = lean_string_dec_eq(x_134, x_135); -lean_dec(x_134); -if (x_136 == 0) -{ -lean_object* x_137; lean_object* x_138; -x_137 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_138 = l_Lean_Parser_ParserState_mkErrorsAt(x_130, x_137, x_129); -x_80 = x_138; -goto block_128; +lean_dec(x_72); +lean_dec(x_71); +lean_dec(x_1); +return x_73; } else { -lean_dec(x_129); -x_80 = x_130; -goto block_128; -} +lean_object* x_75; lean_object* x_76; uint8_t x_77; +x_75 = lean_ctor_get(x_74, 0); +lean_inc(x_75); +lean_dec(x_74); +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +x_77 = lean_nat_dec_eq(x_76, x_72); +lean_dec(x_76); +if (x_77 == 0) +{ +lean_dec(x_75); +lean_dec(x_72); +lean_dec(x_71); +lean_dec(x_1); +return x_73; } else { -lean_object* x_139; lean_object* x_140; -lean_dec(x_133); -x_139 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_140 = l_Lean_Parser_ParserState_mkErrorsAt(x_130, x_139, x_129); -x_80 = x_140; -goto block_128; -} -} -else -{ -lean_object* x_141; lean_object* x_142; -lean_dec(x_131); -x_141 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; -x_142 = l_Lean_Parser_ParserState_mkErrorsAt(x_130, x_141, x_129); -x_80 = x_142; -goto block_128; -} -block_128: -{ -lean_object* x_81; +lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +lean_inc(x_72); +x_78 = l_Lean_Parser_ParserState_restore(x_73, x_71, x_72); +lean_dec(x_71); +x_79 = lean_unsigned_to_nat(1024u); +x_80 = l_Lean_Parser_checkPrecFn(x_79, x_1, x_78); x_81 = lean_ctor_get(x_80, 3); lean_inc(x_81); if (lean_obj_tag(x_81) == 0) { -lean_object* x_82; lean_object* x_83; +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_82 = lean_ctor_get(x_80, 0); +lean_inc(x_82); +x_83 = lean_array_get_size(x_82); +lean_dec(x_82); +x_138 = lean_ctor_get(x_80, 1); +lean_inc(x_138); lean_inc(x_1); -x_82 = l_Lean_Parser_ident___elambda__1(x_1, x_80); -x_83 = lean_ctor_get(x_82, 3); -lean_inc(x_83); -if (lean_obj_tag(x_83) == 0) +x_139 = l_Lean_Parser_tokenFn(x_1, x_80); +x_140 = lean_ctor_get(x_139, 3); +lean_inc(x_140); +if (lean_obj_tag(x_140) == 0) { -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_84 = lean_ctor_get(x_82, 0); -lean_inc(x_84); -x_85 = lean_array_get_size(x_84); -lean_dec(x_84); -x_86 = lean_ctor_get(x_82, 1); -lean_inc(x_86); +lean_object* x_141; lean_object* x_142; +x_141 = lean_ctor_get(x_139, 0); +lean_inc(x_141); +x_142 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_141); +lean_dec(x_141); +if (lean_obj_tag(x_142) == 2) +{ +lean_object* x_143; lean_object* x_144; uint8_t x_145; +x_143 = lean_ctor_get(x_142, 1); +lean_inc(x_143); +lean_dec(x_142); +x_144 = l_Lean_Parser_Term_doPat___elambda__1___closed__6; +x_145 = lean_string_dec_eq(x_143, x_144); +lean_dec(x_143); +if (x_145 == 0) +{ +lean_object* x_146; lean_object* x_147; +x_146 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; +x_147 = l_Lean_Parser_ParserState_mkErrorsAt(x_139, x_146, x_138); +x_84 = x_147; +goto block_137; +} +else +{ +lean_dec(x_138); +x_84 = x_139; +goto block_137; +} +} +else +{ +lean_object* x_148; lean_object* x_149; +lean_dec(x_142); +x_148 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; +x_149 = l_Lean_Parser_ParserState_mkErrorsAt(x_139, x_148, x_138); +x_84 = x_149; +goto block_137; +} +} +else +{ +lean_object* x_150; lean_object* x_151; +lean_dec(x_140); +x_150 = l_Lean_Parser_Term_doPat___elambda__1___closed__9; +x_151 = l_Lean_Parser_ParserState_mkErrorsAt(x_139, x_150, x_138); +x_84 = x_151; +goto block_137; +} +block_137: +{ +lean_object* x_85; +x_85 = lean_ctor_get(x_84, 3); +lean_inc(x_85); +if (lean_obj_tag(x_85) == 0) +{ +lean_object* x_86; lean_object* x_87; lean_inc(x_1); -x_87 = l_Lean_Parser_Command_inferMod___elambda__1(x_1, x_82); -x_88 = lean_ctor_get(x_87, 3); -lean_inc(x_88); -if (lean_obj_tag(x_88) == 0) +x_86 = l_Lean_Parser_Command_declModifiers___elambda__1(x_1, x_84); +x_87 = lean_ctor_get(x_86, 3); +lean_inc(x_87); +if (lean_obj_tag(x_87) == 0) { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -lean_dec(x_86); -x_89 = l_Lean_nullKind; -x_90 = l_Lean_Parser_ParserState_mkNode(x_87, x_89, x_85); -x_91 = lean_ctor_get(x_90, 3); -lean_inc(x_91); -if (lean_obj_tag(x_91) == 0) +lean_object* x_88; lean_object* x_89; +lean_inc(x_1); +x_88 = l_Lean_Parser_ident___elambda__1(x_1, x_86); +x_89 = lean_ctor_get(x_88, 3); +lean_inc(x_89); +if (lean_obj_tag(x_89) == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_90); -x_93 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_94 = l_Lean_Parser_ParserState_mkNode(x_92, x_93, x_79); -x_95 = l_Lean_Parser_mergeOrElseErrors(x_94, x_71, x_68); -lean_dec(x_68); -return x_95; +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_90 = lean_ctor_get(x_88, 0); +lean_inc(x_90); +x_91 = lean_array_get_size(x_90); +lean_dec(x_90); +x_92 = lean_ctor_get(x_88, 1); +lean_inc(x_92); +lean_inc(x_1); +x_93 = l_Lean_Parser_Command_inferMod___elambda__1(x_1, x_88); +x_94 = lean_ctor_get(x_93, 3); +lean_inc(x_94); +if (lean_obj_tag(x_94) == 0) +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; +lean_dec(x_92); +x_95 = l_Lean_nullKind; +x_96 = l_Lean_Parser_ParserState_mkNode(x_93, x_95, x_91); +x_97 = lean_ctor_get(x_96, 3); +lean_inc(x_97); +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 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_96); +x_99 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_100 = l_Lean_Parser_ParserState_mkNode(x_98, x_99, x_83); +x_101 = l_Lean_Parser_mergeOrElseErrors(x_100, x_75, x_72); +lean_dec(x_72); +return x_101; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; -lean_dec(x_91); +lean_object* x_102; lean_object* x_103; lean_object* x_104; +lean_dec(x_97); lean_dec(x_1); -x_96 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_97 = l_Lean_Parser_ParserState_mkNode(x_90, x_96, x_79); -x_98 = l_Lean_Parser_mergeOrElseErrors(x_97, x_71, x_68); -lean_dec(x_68); -return x_98; +x_102 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_103 = l_Lean_Parser_ParserState_mkNode(x_96, x_102, x_83); +x_104 = l_Lean_Parser_mergeOrElseErrors(x_103, x_75, x_72); +lean_dec(x_72); +return x_104; } } else { -lean_object* x_99; uint8_t x_100; -lean_dec(x_88); -x_99 = lean_ctor_get(x_87, 1); -lean_inc(x_99); -x_100 = lean_nat_dec_eq(x_99, x_86); -lean_dec(x_99); -if (x_100 == 0) +lean_object* x_105; uint8_t x_106; +lean_dec(x_94); +x_105 = lean_ctor_get(x_93, 1); +lean_inc(x_105); +x_106 = lean_nat_dec_eq(x_105, x_92); +lean_dec(x_105); +if (x_106 == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -lean_dec(x_86); -x_101 = l_Lean_nullKind; -x_102 = l_Lean_Parser_ParserState_mkNode(x_87, x_101, x_85); -x_103 = lean_ctor_get(x_102, 3); -lean_inc(x_103); -if (lean_obj_tag(x_103) == 0) +lean_object* x_107; lean_object* x_108; lean_object* x_109; +lean_dec(x_92); +x_107 = l_Lean_nullKind; +x_108 = l_Lean_Parser_ParserState_mkNode(x_93, x_107, x_91); +x_109 = lean_ctor_get(x_108, 3); +lean_inc(x_109); +if (lean_obj_tag(x_109) == 0) { -lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_104 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_102); -x_105 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_106 = l_Lean_Parser_ParserState_mkNode(x_104, x_105, x_79); -x_107 = l_Lean_Parser_mergeOrElseErrors(x_106, x_71, x_68); -lean_dec(x_68); -return x_107; +lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_110 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_108); +x_111 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_112 = l_Lean_Parser_ParserState_mkNode(x_110, x_111, x_83); +x_113 = l_Lean_Parser_mergeOrElseErrors(x_112, x_75, x_72); +lean_dec(x_72); +return x_113; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -lean_dec(x_103); +lean_object* x_114; lean_object* x_115; lean_object* x_116; +lean_dec(x_109); lean_dec(x_1); -x_108 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_109 = l_Lean_Parser_ParserState_mkNode(x_102, x_108, x_79); -x_110 = l_Lean_Parser_mergeOrElseErrors(x_109, x_71, x_68); -lean_dec(x_68); -return x_110; +x_114 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_115 = l_Lean_Parser_ParserState_mkNode(x_108, x_114, x_83); +x_116 = l_Lean_Parser_mergeOrElseErrors(x_115, x_75, x_72); +lean_dec(x_72); +return x_116; } } else { -lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_111 = l_Lean_Parser_ParserState_restore(x_87, x_85, x_86); -x_112 = l_Lean_nullKind; -x_113 = l_Lean_Parser_ParserState_mkNode(x_111, x_112, x_85); -x_114 = lean_ctor_get(x_113, 3); -lean_inc(x_114); -if (lean_obj_tag(x_114) == 0) +lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_117 = l_Lean_Parser_ParserState_restore(x_93, x_91, x_92); +x_118 = l_Lean_nullKind; +x_119 = l_Lean_Parser_ParserState_mkNode(x_117, x_118, x_91); +x_120 = lean_ctor_get(x_119, 3); +lean_inc(x_120); +if (lean_obj_tag(x_120) == 0) { -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_115 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_113); -x_116 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_117 = l_Lean_Parser_ParserState_mkNode(x_115, x_116, x_79); -x_118 = l_Lean_Parser_mergeOrElseErrors(x_117, x_71, x_68); -lean_dec(x_68); -return x_118; -} -else -{ -lean_object* x_119; lean_object* x_120; lean_object* x_121; -lean_dec(x_114); -lean_dec(x_1); -x_119 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_120 = l_Lean_Parser_ParserState_mkNode(x_113, x_119, x_79); -x_121 = l_Lean_Parser_mergeOrElseErrors(x_120, x_71, x_68); -lean_dec(x_68); -return x_121; -} -} -} -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; -lean_dec(x_83); -lean_dec(x_1); -x_122 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_123 = l_Lean_Parser_ParserState_mkNode(x_82, x_122, x_79); -x_124 = l_Lean_Parser_mergeOrElseErrors(x_123, x_71, x_68); -lean_dec(x_68); +lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_121 = l_Lean_Parser_Command_optDeclSig___elambda__1(x_1, x_119); +x_122 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_123 = l_Lean_Parser_ParserState_mkNode(x_121, x_122, x_83); +x_124 = l_Lean_Parser_mergeOrElseErrors(x_123, x_75, x_72); +lean_dec(x_72); return x_124; } -} else { lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_81); +lean_dec(x_120); lean_dec(x_1); -x_125 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_126 = l_Lean_Parser_ParserState_mkNode(x_80, x_125, x_79); -x_127 = l_Lean_Parser_mergeOrElseErrors(x_126, x_71, x_68); -lean_dec(x_68); +x_125 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_126 = l_Lean_Parser_ParserState_mkNode(x_119, x_125, x_83); +x_127 = l_Lean_Parser_mergeOrElseErrors(x_126, x_75, x_72); +lean_dec(x_72); return x_127; } } } +} else { -lean_object* x_143; -lean_dec(x_77); +lean_object* x_128; lean_object* x_129; lean_object* x_130; +lean_dec(x_89); lean_dec(x_1); -x_143 = l_Lean_Parser_mergeOrElseErrors(x_76, x_71, x_68); -lean_dec(x_68); -return x_143; +x_128 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_129 = l_Lean_Parser_ParserState_mkNode(x_88, x_128, x_83); +x_130 = l_Lean_Parser_mergeOrElseErrors(x_129, x_75, x_72); +lean_dec(x_72); +return x_130; +} +} +else +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; +lean_dec(x_87); +lean_dec(x_1); +x_131 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_132 = l_Lean_Parser_ParserState_mkNode(x_86, x_131, x_83); +x_133 = l_Lean_Parser_mergeOrElseErrors(x_132, x_75, x_72); +lean_dec(x_72); +return x_133; +} +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; +lean_dec(x_85); +lean_dec(x_1); +x_134 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_135 = l_Lean_Parser_ParserState_mkNode(x_84, x_134, x_83); +x_136 = l_Lean_Parser_mergeOrElseErrors(x_135, x_75, x_72); +lean_dec(x_72); +return x_136; +} +} +} +else +{ +lean_object* x_152; +lean_dec(x_81); +lean_dec(x_1); +x_152 = l_Lean_Parser_mergeOrElseErrors(x_80, x_75, x_72); +lean_dec(x_72); +return x_152; } } } } } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__1() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -14479,97 +14516,109 @@ x_3 = l_Lean_Parser_optionaInfo(x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__2() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; x_1 = l_Lean_Parser_Command_optDeclSig; x_2 = lean_ctor_get(x_1, 0); lean_inc(x_2); -x_3 = l_Lean_Parser_Command_introRule___closed__1; +x_3 = l_Lean_Parser_Command_ctor___closed__1; x_4 = l_Lean_Parser_andthenInfo(x_3, x_2); return x_4; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__3() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__3() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; x_1 = l_Lean_Parser_ident; x_2 = lean_ctor_get(x_1, 0); lean_inc(x_2); -x_3 = l_Lean_Parser_Command_introRule___closed__2; +x_3 = l_Lean_Parser_Command_ctor___closed__2; x_4 = l_Lean_Parser_andthenInfo(x_2, x_3); return x_4; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__4() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_Lean_Parser_Command_declModifiers; +x_2 = lean_ctor_get(x_1, 0); +lean_inc(x_2); +x_3 = l_Lean_Parser_Command_ctor___closed__3; +x_4 = l_Lean_Parser_andthenInfo(x_2, x_3); +return x_4; +} +} +lean_object* _init_l_Lean_Parser_Command_ctor___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_Parser_Term_doPat___closed__2; -x_2 = l_Lean_Parser_Command_introRule___closed__3; +x_2 = l_Lean_Parser_Command_ctor___closed__4; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__5() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__6() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___elambda__1___closed__2; -x_2 = l_Lean_Parser_Command_introRule___closed__4; +x_1 = l_Lean_Parser_Command_ctor___elambda__1___closed__2; +x_2 = l_Lean_Parser_Command_ctor___closed__5; x_3 = l_Lean_Parser_nodeInfo(x_1, x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__6() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__7() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_Parser_epsilonInfo; -x_2 = l_Lean_Parser_Command_introRule___closed__5; +x_2 = l_Lean_Parser_Command_ctor___closed__6; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__7() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__8() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; -x_1 = l_Lean_Parser_Command_introRule___elambda__1___closed__4; +x_1 = l_Lean_Parser_Command_ctor___elambda__1___closed__4; x_2 = lean_ctor_get(x_1, 0); lean_inc(x_2); -x_3 = l_Lean_Parser_Command_introRule___closed__6; +x_3 = l_Lean_Parser_Command_ctor___closed__7; x_4 = l_Lean_Parser_orelseInfo(x_2, x_3); return x_4; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__8() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__9() { _start: { lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Parser_Command_introRule___elambda__1), 2, 0); +x_1 = lean_alloc_closure((void*)(l_Lean_Parser_Command_ctor___elambda__1), 2, 0); return x_1; } } -lean_object* _init_l_Lean_Parser_Command_introRule___closed__9() { +lean_object* _init_l_Lean_Parser_Command_ctor___closed__10() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___closed__7; -x_2 = l_Lean_Parser_Command_introRule___closed__8; +x_1 = l_Lean_Parser_Command_ctor___closed__8; +x_2 = l_Lean_Parser_Command_ctor___closed__9; x_3 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_3, 0, x_1); lean_ctor_set(x_3, 1, x_2); return x_3; } } -lean_object* _init_l_Lean_Parser_Command_introRule() { +lean_object* _init_l_Lean_Parser_Command_ctor() { _start: { lean_object* x_1; -x_1 = l_Lean_Parser_Command_introRule___closed__9; +x_1 = l_Lean_Parser_Command_ctor___closed__10; return x_1; } } @@ -14584,7 +14633,7 @@ lean_dec(x_3); x_5 = lean_ctor_get(x_2, 1); lean_inc(x_5); lean_inc(x_1); -x_6 = l_Lean_Parser_Command_introRule___elambda__1(x_1, x_2); +x_6 = l_Lean_Parser_Command_ctor___elambda__1(x_1, x_2); x_7 = lean_ctor_get(x_6, 3); lean_inc(x_7); if (lean_obj_tag(x_7) == 0) @@ -15085,7 +15134,7 @@ lean_object* _init_l_Lean_Parser_Command_inductive___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule; +x_1 = l_Lean_Parser_Command_ctor; x_2 = lean_ctor_get(x_1, 0); lean_inc(x_2); x_3 = l_Lean_Parser_noFirstTokenInfo(x_2); @@ -16872,7 +16921,7 @@ lean_object* _init_l_Lean_Parser_Command_structExplicitBinder___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___closed__1; +x_1 = l_Lean_Parser_Command_ctor___closed__1; x_2 = l_Lean_Parser_Command_structExplicitBinder___closed__4; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; @@ -17606,7 +17655,7 @@ lean_object* _init_l_Lean_Parser_Command_structImplicitBinder___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___closed__1; +x_1 = l_Lean_Parser_Command_ctor___closed__1; x_2 = l_Lean_Parser_Command_structImplicitBinder___closed__1; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; @@ -18340,7 +18389,7 @@ lean_object* _init_l_Lean_Parser_Command_structInstBinder___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___closed__1; +x_1 = l_Lean_Parser_Command_ctor___closed__1; x_2 = l_Lean_Parser_Command_structInstBinder___closed__1; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; @@ -19316,7 +19365,7 @@ lean_object* _init_l_Lean_Parser_Command_structCtor___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Parser_Command_introRule___closed__1; +x_1 = l_Lean_Parser_Command_ctor___closed__1; x_2 = l_Lean_Parser_Command_structCtor___closed__1; x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); return x_3; @@ -37799,34 +37848,36 @@ l_Lean_Parser_Command_inferMod___closed__6 = _init_l_Lean_Parser_Command_inferMo lean_mark_persistent(l_Lean_Parser_Command_inferMod___closed__6); l_Lean_Parser_Command_inferMod = _init_l_Lean_Parser_Command_inferMod(); lean_mark_persistent(l_Lean_Parser_Command_inferMod); -l_Lean_Parser_Command_introRule___elambda__1___closed__1 = _init_l_Lean_Parser_Command_introRule___elambda__1___closed__1(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___elambda__1___closed__1); -l_Lean_Parser_Command_introRule___elambda__1___closed__2 = _init_l_Lean_Parser_Command_introRule___elambda__1___closed__2(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___elambda__1___closed__2); -l_Lean_Parser_Command_introRule___elambda__1___closed__3 = _init_l_Lean_Parser_Command_introRule___elambda__1___closed__3(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___elambda__1___closed__3); -l_Lean_Parser_Command_introRule___elambda__1___closed__4 = _init_l_Lean_Parser_Command_introRule___elambda__1___closed__4(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___elambda__1___closed__4); -l_Lean_Parser_Command_introRule___closed__1 = _init_l_Lean_Parser_Command_introRule___closed__1(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__1); -l_Lean_Parser_Command_introRule___closed__2 = _init_l_Lean_Parser_Command_introRule___closed__2(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__2); -l_Lean_Parser_Command_introRule___closed__3 = _init_l_Lean_Parser_Command_introRule___closed__3(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__3); -l_Lean_Parser_Command_introRule___closed__4 = _init_l_Lean_Parser_Command_introRule___closed__4(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__4); -l_Lean_Parser_Command_introRule___closed__5 = _init_l_Lean_Parser_Command_introRule___closed__5(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__5); -l_Lean_Parser_Command_introRule___closed__6 = _init_l_Lean_Parser_Command_introRule___closed__6(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__6); -l_Lean_Parser_Command_introRule___closed__7 = _init_l_Lean_Parser_Command_introRule___closed__7(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__7); -l_Lean_Parser_Command_introRule___closed__8 = _init_l_Lean_Parser_Command_introRule___closed__8(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__8); -l_Lean_Parser_Command_introRule___closed__9 = _init_l_Lean_Parser_Command_introRule___closed__9(); -lean_mark_persistent(l_Lean_Parser_Command_introRule___closed__9); -l_Lean_Parser_Command_introRule = _init_l_Lean_Parser_Command_introRule(); -lean_mark_persistent(l_Lean_Parser_Command_introRule); +l_Lean_Parser_Command_ctor___elambda__1___closed__1 = _init_l_Lean_Parser_Command_ctor___elambda__1___closed__1(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___elambda__1___closed__1); +l_Lean_Parser_Command_ctor___elambda__1___closed__2 = _init_l_Lean_Parser_Command_ctor___elambda__1___closed__2(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___elambda__1___closed__2); +l_Lean_Parser_Command_ctor___elambda__1___closed__3 = _init_l_Lean_Parser_Command_ctor___elambda__1___closed__3(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___elambda__1___closed__3); +l_Lean_Parser_Command_ctor___elambda__1___closed__4 = _init_l_Lean_Parser_Command_ctor___elambda__1___closed__4(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___elambda__1___closed__4); +l_Lean_Parser_Command_ctor___closed__1 = _init_l_Lean_Parser_Command_ctor___closed__1(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__1); +l_Lean_Parser_Command_ctor___closed__2 = _init_l_Lean_Parser_Command_ctor___closed__2(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__2); +l_Lean_Parser_Command_ctor___closed__3 = _init_l_Lean_Parser_Command_ctor___closed__3(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__3); +l_Lean_Parser_Command_ctor___closed__4 = _init_l_Lean_Parser_Command_ctor___closed__4(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__4); +l_Lean_Parser_Command_ctor___closed__5 = _init_l_Lean_Parser_Command_ctor___closed__5(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__5); +l_Lean_Parser_Command_ctor___closed__6 = _init_l_Lean_Parser_Command_ctor___closed__6(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__6); +l_Lean_Parser_Command_ctor___closed__7 = _init_l_Lean_Parser_Command_ctor___closed__7(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__7); +l_Lean_Parser_Command_ctor___closed__8 = _init_l_Lean_Parser_Command_ctor___closed__8(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__8); +l_Lean_Parser_Command_ctor___closed__9 = _init_l_Lean_Parser_Command_ctor___closed__9(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__9); +l_Lean_Parser_Command_ctor___closed__10 = _init_l_Lean_Parser_Command_ctor___closed__10(); +lean_mark_persistent(l_Lean_Parser_Command_ctor___closed__10); +l_Lean_Parser_Command_ctor = _init_l_Lean_Parser_Command_ctor(); +lean_mark_persistent(l_Lean_Parser_Command_ctor); l_Lean_Parser_Command_inductive___elambda__1___closed__1 = _init_l_Lean_Parser_Command_inductive___elambda__1___closed__1(); lean_mark_persistent(l_Lean_Parser_Command_inductive___elambda__1___closed__1); l_Lean_Parser_Command_inductive___elambda__1___closed__2 = _init_l_Lean_Parser_Command_inductive___elambda__1___closed__2(); diff --git a/stage0/stdlib/Lean/Util.c b/stage0/stdlib/Lean/Util.c index 77d320a3ff..9a847820ee 100644 --- a/stage0/stdlib/Lean/Util.c +++ b/stage0/stdlib/Lean/Util.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Lean.Util -// Imports: Init Lean.Util.CollectFVars Lean.Util.CollectLevelParams Lean.Util.CollectMVars Lean.Util.FindMVar Lean.Util.MonadCache Lean.Util.PPExt Lean.Util.PPGoal Lean.Util.Path Lean.Util.Profile Lean.Util.RecDepth Lean.Util.Sorry Lean.Util.Trace Lean.Util.WHNF Lean.Util.FindExpr Lean.Util.ReplaceExpr Lean.Util.FoldConsts +// Imports: Init Lean.Util.CollectFVars Lean.Util.CollectLevelParams Lean.Util.CollectMVars Lean.Util.FindMVar Lean.Util.MonadCache Lean.Util.PPExt Lean.Util.PPGoal Lean.Util.Path Lean.Util.Profile Lean.Util.RecDepth Lean.Util.Sorry Lean.Util.Trace Lean.Util.WHNF Lean.Util.FindExpr Lean.Util.ReplaceExpr Lean.Util.ReplaceLevel Lean.Util.FoldConsts Lean.Util.Constructions #include #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -29,7 +29,9 @@ lean_object* initialize_Lean_Util_Trace(lean_object*); lean_object* initialize_Lean_Util_WHNF(lean_object*); lean_object* initialize_Lean_Util_FindExpr(lean_object*); lean_object* initialize_Lean_Util_ReplaceExpr(lean_object*); +lean_object* initialize_Lean_Util_ReplaceLevel(lean_object*); lean_object* initialize_Lean_Util_FoldConsts(lean_object*); +lean_object* initialize_Lean_Util_Constructions(lean_object*); static bool _G_initialized = false; lean_object* initialize_Lean_Util(lean_object* w) { lean_object * res; @@ -83,9 +85,15 @@ 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); +res = initialize_Lean_Util_ReplaceLevel(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Lean_Util_FoldConsts(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Lean_Util_Constructions(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/Util/Constructions.c b/stage0/stdlib/Lean/Util/Constructions.c new file mode 100644 index 0000000000..f6693b189e --- /dev/null +++ b/stage0/stdlib/Lean/Util/Constructions.c @@ -0,0 +1,110 @@ +// Lean compiler output +// Module: Lean.Util.Constructions +// Imports: Init Lean.Environment +#include +#if defined(__clang__) +#pragma clang diagnostic ignored "-Wunused-parameter" +#pragma clang diagnostic ignored "-Wunused-label" +#elif defined(__GNUC__) && !defined(__CLANG__) +#pragma GCC diagnostic ignored "-Wunused-parameter" +#pragma GCC diagnostic ignored "-Wunused-label" +#pragma GCC diagnostic ignored "-Wunused-but-set-variable" +#endif +#ifdef __cplusplus +extern "C" { +#endif +lean_object* lean_mk_cases_on(lean_object*, lean_object*); +lean_object* l_Lean_mkRecOn___boxed(lean_object*, lean_object*); +lean_object* lean_mk_ibelow(lean_object*, lean_object*); +lean_object* lean_mk_below(lean_object*, lean_object*); +lean_object* lean_mk_brec_on(lean_object*, lean_object*); +lean_object* l_Lean_mkNoConfusion___boxed(lean_object*, lean_object*); +lean_object* lean_mk_no_confusion(lean_object*, lean_object*); +lean_object* l_Lean_mkIBelow___boxed(lean_object*, lean_object*); +lean_object* lean_mk_binduction_on(lean_object*, lean_object*); +lean_object* l_Lean_mkBelow___boxed(lean_object*, lean_object*); +lean_object* l_Lean_mkCasesOn___boxed(lean_object*, lean_object*); +lean_object* l_Lean_mkBInductionOn___boxed(lean_object*, lean_object*); +lean_object* lean_mk_rec_on(lean_object*, lean_object*); +lean_object* l_Lean_mkBRecOn___boxed(lean_object*, lean_object*); +lean_object* l_Lean_mkCasesOn___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_cases_on(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkRecOn___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_rec_on(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkNoConfusion___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_no_confusion(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkBelow___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_below(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkIBelow___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_ibelow(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkBRecOn___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_brec_on(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_mkBInductionOn___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_mk_binduction_on(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* initialize_Init(lean_object*); +lean_object* initialize_Lean_Environment(lean_object*); +static bool _G_initialized = false; +lean_object* initialize_Lean_Util_Constructions(lean_object* w) { +lean_object * res; +if (_G_initialized) return lean_mk_io_result(lean_box(0)); +_G_initialized = true; +res = initialize_Init(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +res = initialize_Lean_Environment(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 +} +#endif diff --git a/stage0/stdlib/Lean/Util/ReplaceLevel.c b/stage0/stdlib/Lean/Util/ReplaceLevel.c new file mode 100644 index 0000000000..ccf0c7c46b --- /dev/null +++ b/stage0/stdlib/Lean/Util/ReplaceLevel.c @@ -0,0 +1,959 @@ +// Lean compiler output +// Module: Lean.Util.ReplaceLevel +// Imports: Init Lean.Expr +#include +#if defined(__clang__) +#pragma clang diagnostic ignored "-Wunused-parameter" +#pragma clang diagnostic ignored "-Wunused-label" +#elif defined(__GNUC__) && !defined(__CLANG__) +#pragma GCC diagnostic ignored "-Wunused-parameter" +#pragma GCC diagnostic ignored "-Wunused-label" +#pragma GCC diagnostic ignored "-Wunused-but-set-variable" +#endif +#ifdef __cplusplus +extern "C" { +#endif +lean_object* lean_expr_update_forall(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(lean_object*, size_t, 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); +lean_object* lean_expr_update_mdata(lean_object*, lean_object*); +lean_object* lean_array_uset(lean_object*, size_t, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3; +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_cache(size_t, lean_object*, lean_object*, lean_object*); +lean_object* l_List_map___main___rarg(lean_object*, lean_object*); +size_t l_Lean_Expr_ReplaceLevelImpl_cacheSize; +extern lean_object* l_Id_monad; +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1; +lean_object* l_Lean_mkLevelIMax(lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_Inhabited___closed__1; +lean_object* l_Lean_mkLevelMax(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafe(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1; +lean_object* l_Lean_Expr_replaceLevel___main(lean_object*, lean_object*); +lean_object* lean_expr_update_let(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); +lean_object* lean_expr_update_proj(lean_object*, lean_object*); +lean_object* l_Lean_Level_replace(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_cache___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +size_t l_USize_mod(size_t, size_t); +size_t lean_ptr_addr(lean_object*); +lean_object* l_Lean_Expr_replaceLevel(lean_object*, lean_object*); +lean_object* l_Lean_mkLevelSucc(lean_object*); +lean_object* lean_expr_update_sort(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM(lean_object*, size_t, lean_object*, lean_object*); +lean_object* l_StateT_Monad___rarg(lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_initCache; +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2; +lean_object* lean_expr_update_lambda(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_List_map___main___at_Lean_Expr_replaceLevel___main___spec__1(lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_Inhabited; +lean_object* lean_mk_array(lean_object*, lean_object*); +lean_object* l_Lean_Level_replace___main(lean_object*, lean_object*); +lean_object* l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2; +lean_object* lean_expr_update_app(lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_update_const(lean_object*, lean_object*); +lean_object* l_monadInhabited___rarg(lean_object*, lean_object*); +lean_object* l_Lean_Level_replace___main(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +lean_inc(x_1); +lean_inc(x_2); +x_3 = lean_apply_1(x_1, x_2); +if (lean_obj_tag(x_3) == 0) +{ +switch (lean_obj_tag(x_2)) { +case 1: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_4 = lean_ctor_get(x_2, 0); +lean_inc(x_4); +lean_dec(x_2); +x_5 = l_Lean_Level_replace___main(x_1, x_4); +x_6 = l_Lean_mkLevelSucc(x_5); +return x_6; +} +case 2: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_7 = lean_ctor_get(x_2, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_2, 1); +lean_inc(x_8); +lean_dec(x_2); +lean_inc(x_1); +x_9 = l_Lean_Level_replace___main(x_1, x_7); +x_10 = l_Lean_Level_replace___main(x_1, x_8); +x_11 = l_Lean_mkLevelMax(x_9, x_10); +return x_11; +} +case 3: +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_12 = lean_ctor_get(x_2, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_2, 1); +lean_inc(x_13); +lean_dec(x_2); +lean_inc(x_1); +x_14 = l_Lean_Level_replace___main(x_1, x_12); +x_15 = l_Lean_Level_replace___main(x_1, x_13); +x_16 = l_Lean_mkLevelIMax(x_14, x_15); +return x_16; +} +default: +{ +lean_dec(x_1); +return x_2; +} +} +} +else +{ +lean_object* x_17; +lean_dec(x_2); +lean_dec(x_1); +x_17 = lean_ctor_get(x_3, 0); +lean_inc(x_17); +lean_dec(x_3); +return x_17; +} +} +} +lean_object* l_Lean_Level_replace(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Level_replace___main(x_1, x_2); +return x_3; +} +} +size_t _init_l_Lean_Expr_ReplaceLevelImpl_cacheSize() { +_start: +{ +size_t x_1; +x_1 = 8192; +return x_1; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_cache(size_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_array_uset(x_5, x_1, x_2); +x_7 = lean_ctor_get(x_4, 1); +lean_inc(x_7); +lean_dec(x_4); +lean_inc(x_3); +x_8 = lean_array_uset(x_7, x_1, x_3); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_6); +lean_ctor_set(x_9, 1, x_8); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_3); +lean_ctor_set(x_10, 1, x_9); +return x_10; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_cache___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; lean_object* x_6; +x_5 = lean_unbox_usize(x_1); +lean_dec(x_1); +x_6 = l_Lean_Expr_ReplaceLevelImpl_cache(x_5, x_2, x_3, x_4); +return x_6; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Id_monad; +x_2 = l_StateT_Monad___rarg(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1; +x_2 = l_Lean_Expr_Inhabited; +x_3 = l_monadInhabited___rarg(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; size_t x_6; lean_object* x_7; lean_object* x_8; size_t x_9; uint8_t x_10; +x_5 = lean_ptr_addr(x_3); +x_6 = x_2 == 0 ? 0 : x_5 % x_2; +x_7 = lean_ctor_get(x_4, 0); +lean_inc(x_7); +x_8 = lean_array_uget(x_7, x_6); +x_9 = lean_ptr_addr(x_8); +lean_dec(x_8); +x_10 = x_9 == x_5; +if (x_10 == 0) +{ +switch (lean_obj_tag(x_3)) { +case 3: +{ +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; +x_11 = lean_ctor_get(x_3, 0); +lean_inc(x_11); +x_12 = l_Lean_Level_replace___main(x_1, x_11); +lean_inc(x_3); +x_13 = lean_expr_update_sort(x_3, x_12); +x_14 = lean_array_uset(x_7, x_6, x_3); +x_15 = lean_ctor_get(x_4, 1); +lean_inc(x_15); +lean_dec(x_4); +lean_inc(x_13); +x_16 = lean_array_uset(x_15, x_6, x_13); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_14); +lean_ctor_set(x_17, 1, x_16); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +case 4: +{ +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_19 = lean_ctor_get(x_3, 1); +lean_inc(x_19); +x_20 = lean_alloc_closure((void*)(l_Lean_Level_replace), 2, 1); +lean_closure_set(x_20, 0, x_1); +x_21 = l_List_map___main___rarg(x_20, x_19); +lean_inc(x_3); +x_22 = lean_expr_update_const(x_3, x_21); +x_23 = lean_array_uset(x_7, x_6, x_3); +x_24 = lean_ctor_get(x_4, 1); +lean_inc(x_24); +lean_dec(x_4); +lean_inc(x_22); +x_25 = lean_array_uset(x_24, x_6, x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_23); +lean_ctor_set(x_26, 1, x_25); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +case 5: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_7); +x_28 = lean_ctor_get(x_3, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_3, 1); +lean_inc(x_29); +lean_inc(x_1); +x_30 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_28, x_4); +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); +lean_dec(x_30); +x_33 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_29, x_32); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_35 = lean_ctor_get(x_33, 0); +x_36 = lean_ctor_get(x_33, 1); +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +lean_inc(x_3); +x_38 = lean_array_uset(x_37, x_6, x_3); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +lean_dec(x_36); +x_40 = lean_expr_update_app(x_3, x_31, x_35); +lean_inc(x_40); +x_41 = lean_array_uset(x_39, x_6, x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_38); +lean_ctor_set(x_42, 1, x_41); +lean_ctor_set(x_33, 1, x_42); +lean_ctor_set(x_33, 0, x_40); +return x_33; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_43 = lean_ctor_get(x_33, 0); +x_44 = lean_ctor_get(x_33, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_33); +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +lean_inc(x_3); +x_46 = lean_array_uset(x_45, x_6, x_3); +x_47 = lean_ctor_get(x_44, 1); +lean_inc(x_47); +lean_dec(x_44); +x_48 = lean_expr_update_app(x_3, x_31, x_43); +lean_inc(x_48); +x_49 = lean_array_uset(x_47, x_6, x_48); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_46); +lean_ctor_set(x_50, 1, x_49); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_48); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +case 6: +{ +lean_object* x_52; lean_object* x_53; uint64_t x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_59; +lean_dec(x_7); +x_52 = lean_ctor_get(x_3, 1); +lean_inc(x_52); +x_53 = lean_ctor_get(x_3, 2); +lean_inc(x_53); +x_54 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_55 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_52, x_4); +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_53, x_57); +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_ctor_get(x_58, 1); +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +lean_inc(x_3); +x_63 = lean_array_uset(x_62, x_6, x_3); +x_64 = lean_ctor_get(x_61, 1); +lean_inc(x_64); +lean_dec(x_61); +x_65 = (uint8_t)((x_54 << 24) >> 61); +x_66 = lean_expr_update_lambda(x_3, x_65, x_56, x_60); +lean_inc(x_66); +x_67 = lean_array_uset(x_64, x_6, x_66); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_67); +lean_ctor_set(x_58, 1, x_68); +lean_ctor_set(x_58, 0, x_66); +return x_58; +} +else +{ +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_76; lean_object* x_77; lean_object* x_78; +x_69 = lean_ctor_get(x_58, 0); +x_70 = lean_ctor_get(x_58, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_58); +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +lean_inc(x_3); +x_72 = lean_array_uset(x_71, x_6, x_3); +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +lean_dec(x_70); +x_74 = (uint8_t)((x_54 << 24) >> 61); +x_75 = lean_expr_update_lambda(x_3, x_74, x_56, x_69); +lean_inc(x_75); +x_76 = lean_array_uset(x_73, x_6, x_75); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_72); +lean_ctor_set(x_77, 1, x_76); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_75); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +case 7: +{ +lean_object* x_79; lean_object* x_80; uint64_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; +lean_dec(x_7); +x_79 = lean_ctor_get(x_3, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_3, 2); +lean_inc(x_80); +x_81 = lean_ctor_get_uint64(x_3, sizeof(void*)*3); +lean_inc(x_1); +x_82 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_79, x_4); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_82, 1); +lean_inc(x_84); +lean_dec(x_82); +x_85 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_80, x_84); +x_86 = !lean_is_exclusive(x_85); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_87 = lean_ctor_get(x_85, 0); +x_88 = lean_ctor_get(x_85, 1); +x_89 = lean_ctor_get(x_88, 0); +lean_inc(x_89); +lean_inc(x_3); +x_90 = lean_array_uset(x_89, x_6, x_3); +x_91 = lean_ctor_get(x_88, 1); +lean_inc(x_91); +lean_dec(x_88); +x_92 = (uint8_t)((x_81 << 24) >> 61); +x_93 = lean_expr_update_forall(x_3, x_92, x_83, x_87); +lean_inc(x_93); +x_94 = lean_array_uset(x_91, x_6, x_93); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_94); +lean_ctor_set(x_85, 1, x_95); +lean_ctor_set(x_85, 0, x_93); +return x_85; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_96 = lean_ctor_get(x_85, 0); +x_97 = lean_ctor_get(x_85, 1); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_85); +x_98 = lean_ctor_get(x_97, 0); +lean_inc(x_98); +lean_inc(x_3); +x_99 = lean_array_uset(x_98, x_6, x_3); +x_100 = lean_ctor_get(x_97, 1); +lean_inc(x_100); +lean_dec(x_97); +x_101 = (uint8_t)((x_81 << 24) >> 61); +x_102 = lean_expr_update_forall(x_3, x_101, x_83, x_96); +lean_inc(x_102); +x_103 = lean_array_uset(x_100, x_6, x_102); +x_104 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_104, 0, x_99); +lean_ctor_set(x_104, 1, x_103); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_102); +lean_ctor_set(x_105, 1, x_104); +return x_105; +} +} +case 8: +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; uint8_t x_116; +lean_dec(x_7); +x_106 = lean_ctor_get(x_3, 1); +lean_inc(x_106); +x_107 = lean_ctor_get(x_3, 2); +lean_inc(x_107); +x_108 = lean_ctor_get(x_3, 3); +lean_inc(x_108); +lean_inc(x_1); +x_109 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_106, x_4); +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); +lean_inc(x_1); +x_112 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_107, x_111); +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 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_108, x_114); +x_116 = !lean_is_exclusive(x_115); +if (x_116 == 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; +x_117 = lean_ctor_get(x_115, 0); +x_118 = lean_ctor_get(x_115, 1); +x_119 = lean_ctor_get(x_118, 0); +lean_inc(x_119); +lean_inc(x_3); +x_120 = lean_array_uset(x_119, x_6, x_3); +x_121 = lean_ctor_get(x_118, 1); +lean_inc(x_121); +lean_dec(x_118); +x_122 = lean_expr_update_let(x_3, x_110, x_113, x_117); +lean_inc(x_122); +x_123 = lean_array_uset(x_121, x_6, x_122); +x_124 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_124, 0, x_120); +lean_ctor_set(x_124, 1, x_123); +lean_ctor_set(x_115, 1, x_124); +lean_ctor_set(x_115, 0, x_122); +return x_115; +} +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_131; lean_object* x_132; lean_object* x_133; +x_125 = lean_ctor_get(x_115, 0); +x_126 = lean_ctor_get(x_115, 1); +lean_inc(x_126); +lean_inc(x_125); +lean_dec(x_115); +x_127 = lean_ctor_get(x_126, 0); +lean_inc(x_127); +lean_inc(x_3); +x_128 = lean_array_uset(x_127, x_6, x_3); +x_129 = lean_ctor_get(x_126, 1); +lean_inc(x_129); +lean_dec(x_126); +x_130 = lean_expr_update_let(x_3, x_110, x_113, x_125); +lean_inc(x_130); +x_131 = lean_array_uset(x_129, x_6, x_130); +x_132 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_132, 0, x_128); +lean_ctor_set(x_132, 1, x_131); +x_133 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_133, 0, x_130); +lean_ctor_set(x_133, 1, x_132); +return x_133; +} +} +case 10: +{ +lean_object* x_134; lean_object* x_135; uint8_t x_136; +lean_dec(x_7); +x_134 = lean_ctor_get(x_3, 1); +lean_inc(x_134); +x_135 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_134, x_4); +x_136 = !lean_is_exclusive(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; lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_137 = lean_ctor_get(x_135, 0); +x_138 = lean_ctor_get(x_135, 1); +x_139 = lean_ctor_get(x_138, 0); +lean_inc(x_139); +lean_inc(x_3); +x_140 = lean_array_uset(x_139, x_6, x_3); +x_141 = lean_ctor_get(x_138, 1); +lean_inc(x_141); +lean_dec(x_138); +x_142 = lean_expr_update_mdata(x_3, x_137); +lean_inc(x_142); +x_143 = lean_array_uset(x_141, x_6, x_142); +x_144 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_144, 0, x_140); +lean_ctor_set(x_144, 1, x_143); +lean_ctor_set(x_135, 1, x_144); +lean_ctor_set(x_135, 0, x_142); +return x_135; +} +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; +x_145 = lean_ctor_get(x_135, 0); +x_146 = lean_ctor_get(x_135, 1); +lean_inc(x_146); +lean_inc(x_145); +lean_dec(x_135); +x_147 = lean_ctor_get(x_146, 0); +lean_inc(x_147); +lean_inc(x_3); +x_148 = lean_array_uset(x_147, x_6, x_3); +x_149 = lean_ctor_get(x_146, 1); +lean_inc(x_149); +lean_dec(x_146); +x_150 = lean_expr_update_mdata(x_3, x_145); +lean_inc(x_150); +x_151 = lean_array_uset(x_149, x_6, x_150); +x_152 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_152, 0, x_148); +lean_ctor_set(x_152, 1, x_151); +x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_153, 0, x_150); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +case 11: +{ +lean_object* x_154; lean_object* x_155; uint8_t x_156; +lean_dec(x_7); +x_154 = lean_ctor_get(x_3, 2); +lean_inc(x_154); +x_155 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_154, x_4); +x_156 = !lean_is_exclusive(x_155); +if (x_156 == 0) +{ +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_157 = lean_ctor_get(x_155, 0); +x_158 = lean_ctor_get(x_155, 1); +x_159 = lean_ctor_get(x_158, 0); +lean_inc(x_159); +lean_inc(x_3); +x_160 = lean_array_uset(x_159, x_6, x_3); +x_161 = lean_ctor_get(x_158, 1); +lean_inc(x_161); +lean_dec(x_158); +x_162 = lean_expr_update_proj(x_3, x_157); +lean_inc(x_162); +x_163 = lean_array_uset(x_161, x_6, x_162); +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_160); +lean_ctor_set(x_164, 1, x_163); +lean_ctor_set(x_155, 1, x_164); +lean_ctor_set(x_155, 0, x_162); +return x_155; +} +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; +x_165 = lean_ctor_get(x_155, 0); +x_166 = lean_ctor_get(x_155, 1); +lean_inc(x_166); +lean_inc(x_165); +lean_dec(x_155); +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +lean_inc(x_3); +x_168 = lean_array_uset(x_167, x_6, x_3); +x_169 = lean_ctor_get(x_166, 1); +lean_inc(x_169); +lean_dec(x_166); +x_170 = lean_expr_update_proj(x_3, x_165); +lean_inc(x_170); +x_171 = lean_array_uset(x_169, x_6, x_170); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_168); +lean_ctor_set(x_172, 1, x_171); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_170); +lean_ctor_set(x_173, 1, x_172); +return x_173; +} +} +case 12: +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_1); +x_174 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2; +x_175 = l_unreachable_x21___rarg(x_174); +x_176 = lean_apply_1(x_175, x_4); +return x_176; +} +default: +{ +lean_object* x_177; +lean_dec(x_7); +lean_dec(x_1); +x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_177, 0, x_3); +lean_ctor_set(x_177, 1, x_4); +return x_177; +} +} +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_1); +x_178 = lean_ctor_get(x_4, 1); +lean_inc(x_178); +x_179 = lean_array_uget(x_178, x_6); +lean_dec(x_178); +x_180 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_180, 0, x_179); +lean_ctor_set(x_180, 1, x_4); +return x_180; +} +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; lean_object* x_6; +x_5 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_6 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_2, x_3, x_4); +return x_5; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +size_t x_5; lean_object* x_6; +x_5 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_6 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM(x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_unsigned_to_nat(8192u); +x_2 = lean_box(0); +x_3 = lean_mk_array(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_unsigned_to_nat(8192u); +x_2 = l_Lean_Expr_Inhabited___closed__1; +x_3 = lean_mk_array(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1; +x_2 = l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2; +x_3 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_3, 0, x_1); +lean_ctor_set(x_3, 1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_ReplaceLevelImpl_initCache() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3; +return x_1; +} +} +lean_object* l_Lean_Expr_ReplaceLevelImpl_replaceUnsafe(lean_object* x_1, lean_object* x_2) { +_start: +{ +size_t x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_3 = 8192; +x_4 = l_Lean_Expr_ReplaceLevelImpl_initCache; +x_5 = l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main(x_1, x_3, x_2, x_4); +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +lean_dec(x_5); +return x_6; +} +} +lean_object* l_List_map___main___at_Lean_Expr_replaceLevel___main___spec__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +lean_dec(x_1); +x_3 = lean_box(0); +return x_3; +} +else +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_5 = lean_ctor_get(x_2, 0); +x_6 = lean_ctor_get(x_2, 1); +lean_inc(x_1); +x_7 = l_Lean_Level_replace___main(x_1, x_5); +x_8 = l_List_map___main___at_Lean_Expr_replaceLevel___main___spec__1(x_1, x_6); +lean_ctor_set(x_2, 1, x_8); +lean_ctor_set(x_2, 0, x_7); +return x_2; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_ctor_get(x_2, 0); +x_10 = lean_ctor_get(x_2, 1); +lean_inc(x_10); +lean_inc(x_9); +lean_dec(x_2); +lean_inc(x_1); +x_11 = l_Lean_Level_replace___main(x_1, x_9); +x_12 = l_List_map___main___at_Lean_Expr_replaceLevel___main___spec__1(x_1, x_10); +x_13 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_13, 0, x_11); +lean_ctor_set(x_13, 1, x_12); +return x_13; +} +} +} +} +lean_object* l_Lean_Expr_replaceLevel___main(lean_object* x_1, lean_object* x_2) { +_start: +{ +switch (lean_obj_tag(x_2)) { +case 3: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_3 = lean_ctor_get(x_2, 0); +lean_inc(x_3); +x_4 = l_Lean_Level_replace___main(x_1, x_3); +x_5 = lean_expr_update_sort(x_2, x_4); +return x_5; +} +case 4: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_2, 1); +lean_inc(x_6); +x_7 = l_List_map___main___at_Lean_Expr_replaceLevel___main___spec__1(x_1, x_6); +x_8 = lean_expr_update_const(x_2, x_7); +return x_8; +} +case 5: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_ctor_get(x_2, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_2, 1); +lean_inc(x_10); +lean_inc(x_1); +x_11 = l_Lean_Expr_replaceLevel___main(x_1, x_9); +x_12 = l_Lean_Expr_replaceLevel___main(x_1, x_10); +x_13 = lean_expr_update_app(x_2, x_11, x_12); +return x_13; +} +case 6: +{ +lean_object* x_14; lean_object* x_15; uint64_t x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x_20; +x_14 = lean_ctor_get(x_2, 1); +lean_inc(x_14); +x_15 = lean_ctor_get(x_2, 2); +lean_inc(x_15); +x_16 = lean_ctor_get_uint64(x_2, sizeof(void*)*3); +lean_inc(x_1); +x_17 = l_Lean_Expr_replaceLevel___main(x_1, x_14); +x_18 = l_Lean_Expr_replaceLevel___main(x_1, x_15); +x_19 = (uint8_t)((x_16 << 24) >> 61); +x_20 = lean_expr_update_lambda(x_2, x_19, x_17, x_18); +return x_20; +} +case 7: +{ +lean_object* x_21; lean_object* x_22; uint64_t x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_21 = lean_ctor_get(x_2, 1); +lean_inc(x_21); +x_22 = lean_ctor_get(x_2, 2); +lean_inc(x_22); +x_23 = lean_ctor_get_uint64(x_2, sizeof(void*)*3); +lean_inc(x_1); +x_24 = l_Lean_Expr_replaceLevel___main(x_1, x_21); +x_25 = l_Lean_Expr_replaceLevel___main(x_1, x_22); +x_26 = (uint8_t)((x_23 << 24) >> 61); +x_27 = lean_expr_update_forall(x_2, x_26, x_24, x_25); +return x_27; +} +case 8: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_28 = lean_ctor_get(x_2, 1); +lean_inc(x_28); +x_29 = lean_ctor_get(x_2, 2); +lean_inc(x_29); +x_30 = lean_ctor_get(x_2, 3); +lean_inc(x_30); +lean_inc(x_1); +x_31 = l_Lean_Expr_replaceLevel___main(x_1, x_28); +lean_inc(x_1); +x_32 = l_Lean_Expr_replaceLevel___main(x_1, x_29); +x_33 = l_Lean_Expr_replaceLevel___main(x_1, x_30); +x_34 = lean_expr_update_let(x_2, x_31, x_32, x_33); +return x_34; +} +case 10: +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_2, 1); +lean_inc(x_35); +x_36 = l_Lean_Expr_replaceLevel___main(x_1, x_35); +x_37 = lean_expr_update_mdata(x_2, x_36); +return x_37; +} +case 11: +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_2, 2); +lean_inc(x_38); +x_39 = l_Lean_Expr_replaceLevel___main(x_1, x_38); +x_40 = lean_expr_update_proj(x_2, x_39); +return x_40; +} +default: +{ +lean_dec(x_1); +return x_2; +} +} +} +} +lean_object* l_Lean_Expr_replaceLevel(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_replaceLevel___main(x_1, x_2); +return x_3; +} +} +lean_object* initialize_Init(lean_object*); +lean_object* initialize_Lean_Expr(lean_object*); +static bool _G_initialized = false; +lean_object* initialize_Lean_Util_ReplaceLevel(lean_object* w) { +lean_object * res; +if (_G_initialized) return lean_mk_io_result(lean_box(0)); +_G_initialized = true; +res = initialize_Init(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +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); +l_Lean_Expr_ReplaceLevelImpl_cacheSize = _init_l_Lean_Expr_ReplaceLevelImpl_cacheSize(); +l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1 = _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__1); +l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2 = _init_l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_replaceUnsafeM___main___closed__2); +l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1 = _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_initCache___closed__1); +l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2 = _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_initCache___closed__2); +l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3 = _init_l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_initCache___closed__3); +l_Lean_Expr_ReplaceLevelImpl_initCache = _init_l_Lean_Expr_ReplaceLevelImpl_initCache(); +lean_mark_persistent(l_Lean_Expr_ReplaceLevelImpl_initCache); +return lean_mk_io_result(lean_box(0)); +} +#ifdef __cplusplus +} +#endif