diff --git a/stage0/src/Init/Data/Char/Basic.lean b/stage0/src/Init/Data/Char/Basic.lean index f542a845cb..fb504c7486 100644 --- a/stage0/src/Init/Data/Char/Basic.lean +++ b/stage0/src/Init/Data/Char/Basic.lean @@ -39,10 +39,23 @@ UInt32.decLt _ _ instance decLe (a b : Char) : Decidable (a ≤ b) := UInt32.decLe _ _ -axiom isValidChar0 : isValidChar 0 +abbrev isValidCharNat (n : Nat) : Prop := +n < 0xd800 ∨ (0xdfff < n ∧ n < 0x110000) + +theorem isValidUInt32 (n : Nat) (h : isValidCharNat n) : n < uint32Sz := +sorry -- TODO: waiting for new frontend + +theorem isValidCharOfValidNat (n : Nat) (h : isValidCharNat n) : isValidChar (UInt32.ofNat' n (isValidUInt32 n h)) := +sorry -- TODO: waiting for new frontend + +theorem isValidChar0 : isValidChar 0 := +sorry -- TODO: waiting for new frontend @[noinline, matchPattern] def ofNat (n : Nat) : Char := -if h : isValidChar n.toUInt32 then {val := n.toUInt32, valid := h} else {val := 0, valid := isValidChar0} +if h : isValidCharNat n then + { val := UInt32.ofNat' n (isValidUInt32 n h), valid := isValidCharOfValidNat n h } +else + { val := 0, valid := isValidChar0 } @[inline] def toNat (c : Char) : Nat := c.val.toNat diff --git a/stage0/src/Init/Data/UInt.lean b/stage0/src/Init/Data/UInt.lean index c2c3ef5e37..4ed037ca6d 100644 --- a/stage0/src/Init/Data/UInt.lean +++ b/stage0/src/Init/Data/UInt.lean @@ -136,6 +136,8 @@ structure UInt32 := @[extern "lean_uint32_of_nat"] def UInt32.ofNat (n : @& Nat) : UInt32 := ⟨Fin.ofNat n⟩ +@[extern "lean_uint32_of_nat"] +def UInt32.ofNat' (n : Nat) (h : n < uint32Sz) : UInt32 := ⟨⟨n, h⟩⟩ abbrev Nat.toUInt32 := UInt32.ofNat @[extern "lean_uint32_to_nat"] def UInt32.toNat (n : UInt32) : Nat := n.val.val diff --git a/stage0/src/Init/Lean/Elab/Binders.lean b/stage0/src/Init/Lean/Elab/Binders.lean index a402407d7d..6ef90dd445 100644 --- a/stage0/src/Init/Lean/Elab/Binders.lean +++ b/stage0/src/Init/Lean/Elab/Binders.lean @@ -88,24 +88,35 @@ else else throwUnsupportedSyntax +private def getBinderIds (ids : Syntax) : TermElabM (Array Syntax) := +ids.getArgs.mapM $ fun id => + let k := id.getKind; + if k == identKind || k == `Lean.Parser.Term.hole then + pure id + else if k == `Lean.Parser.Term.id && id.getArgs.size == 2 && (id.getArg 1).isNone then + -- The parser never generates this case, but it is convenient when writting macros. + pure (id.getArg 0) + else + throwError id "identifier or `_` expected" + private def matchBinder (stx : Syntax) : TermElabM (Array BinderView) := match stx with | Syntax.node k args => - if k == `Lean.Parser.Term.simpleBinder then + if k == `Lean.Parser.Term.simpleBinder then do -- binderIdent+ - let ids := (args.get! 0).getArgs; + ids ← getBinderIds (args.get! 0); let type := mkHole stx; ids.mapM $ fun id => do id ← expandBinderIdent id; pure { id := id, type := type, bi := BinderInfo.default } else if k == `Lean.Parser.Term.explicitBinder then do -- `(` binderIdent+ binderType (binderDefault <|> binderTactic)? `)` - let ids := (args.get! 1).getArgs; + ids ← getBinderIds (args.get! 1); let type := expandBinderType (args.get! 2); let optModifier := args.get! 3; type ← expandBinderModifier type optModifier; ids.mapM $ fun id => do id ← expandBinderIdent id; pure { id := id, type := type, bi := BinderInfo.default } - else if k == `Lean.Parser.Term.implicitBinder then + else if k == `Lean.Parser.Term.implicitBinder then do -- `{` binderIdent+ binderType `}` - let ids := (args.get! 1).getArgs; + ids ← getBinderIds (args.get! 1); let type := expandBinderType (args.get! 2); ids.mapM $ fun id => do id ← expandBinderIdent id; pure { id := id, type := type, bi := BinderInfo.implicit } else if k == `Lean.Parser.Term.instBinder then do diff --git a/stage0/src/Init/Lean/Elab/BuiltinNotation.lean b/stage0/src/Init/Lean/Elab/BuiltinNotation.lean index 2d71133429..7508912b03 100644 --- a/stage0/src/Init/Lean/Elab/BuiltinNotation.lean +++ b/stage0/src/Init/Lean/Elab/BuiltinNotation.lean @@ -119,14 +119,18 @@ addDecl ref decl; compileDecl ref decl; pure auxName +private def elabClosedTerm (stx : Syntax) (expectedType? : Option Expr) : TermElabM Expr := do +e ← elabTermAndSynthesize stx expectedType?; +when e.hasMVar $ + throwError stx ("invalid macro application, term contains metavariables" ++ indentExpr e); +when e.hasFVar $ + throwError stx ("invalid macro application, term contains free variables" ++ indentExpr e); +pure e + @[builtinTermElab «nativeRefl»] def elabNativeRefl : TermElab := fun stx _ => do let arg := stx.getArg 1; - e ← elabTermAndSynthesize arg none; - when e.hasMVar $ - throwError stx ("invalid `nativeRefl!` macro application, term contains metavariables" ++ indentExpr e); - when e.hasFVar $ - throwError stx ("invalid `nativeRefl!` macro application, term contains free variables" ++ indentExpr e); + e ← elabClosedTerm arg none; type ← inferType stx e; type ← whnf stx type; unless (type.isConstOf `Bool || type.isConstOf `Nat) $ @@ -144,7 +148,41 @@ fun stx _ => do rflPrf ← liftMetaM stx $ Meta.mkEqRefl val; let r := mkApp3 (Lean.mkConst reduceThm) aux val rflPrf; eq ← liftMetaM stx $ Meta.mkEq e val; - pure $ mkApp2 (Lean.mkConst `id [levelZero]) eq r + mkExpectedTypeHint stx r eq + +private def getPropToDecide (ref : Syntax) (arg : Syntax) (expectedType? : Option Expr) : TermElabM Expr := +if arg.isOfKind `Lean.Parser.Term.hole then do + tryPostponeIfNoneOrMVar expectedType?; + match expectedType? with + | none => throwError ref "invalid macro, expected type is not available" + | some expectedType => do + expectedType ← instantiateMVars ref expectedType; + when (expectedType.hasFVar || expectedType.hasMVar) $ + throwError ref ("expected type must not contain free or meta variables" ++ indentExpr expectedType); + pure expectedType +else + let prop := mkSort levelZero; + elabClosedTerm arg prop + +@[builtinTermElab «nativeDecide»] def elabNativeDecide : TermElab := +fun stx expectedType? => do + let arg := stx.getArg 1; + p ← getPropToDecide stx arg expectedType?; + d ← mkAppM stx `Decidable.decide #[p]; + auxDeclName ← mkNativeReflAuxDecl stx (Lean.mkConst `Bool) d; + rflPrf ← liftMetaM stx $ Meta.mkEqRefl (toExpr true); + let r := mkApp3 (Lean.mkConst `Lean.ofReduceBool) (Lean.mkConst auxDeclName) (toExpr true) rflPrf; + mkExpectedTypeHint stx r p + +@[builtinTermElab Lean.Parser.Term.decide] def elabDecide : TermElab := +fun stx expectedType? => do + let arg := stx.getArg 1; + p ← getPropToDecide stx arg expectedType?; + d ← mkAppM stx `Decidable.decide #[p]; + d ← instantiateMVars stx d; + let s := d.appArg!; -- get instance from `d` + rflPrf ← liftMetaM stx $ Meta.mkEqRefl (toExpr true); + pure $ mkApp3 (Lean.mkConst `ofDecideEqTrue) p s rflPrf def elabInfix (f : Syntax) : Macro := fun stx => do diff --git a/stage0/src/Init/Lean/Elab/Term.lean b/stage0/src/Init/Lean/Elab/Term.lean index f3b3064e76..2032351026 100644 --- a/stage0/src/Init/Lean/Elab/Term.lean +++ b/stage0/src/Init/Lean/Elab/Term.lean @@ -200,6 +200,15 @@ logInfo ref $ opts ← getOptions; when (checkTraceOption opts cls) $ logTrace cls ref (msg ()) +def logDbgTrace (msg : MessageData) : TermElabM Unit := do +trace `Elab.debug Syntax.missing $ fun _ => msg + +/-- For testing `TermElabM` methods. The #eval command will sign the error. -/ +def throwErrorIfErrors : TermElabM Unit := do +s ← get; +when s.messages.hasErrors $ + throwError Syntax.missing "Error(s)" + @[inline] def traceAtCmdPos (cls : Name) (msg : Unit → MessageData) : TermElabM Unit := trace cls Syntax.missing msg @@ -255,6 +264,7 @@ def mkLambda (ref : Syntax) (xs : Array Expr) (e : Expr) : TermElabM Expr := lif def mkLet (ref : Syntax) (x : Expr) (e : Expr) : TermElabM Expr := mkLambda ref #[x] e def trySynthInstance (ref : Syntax) (type : Expr) : TermElabM (LOption Expr) := liftMetaM ref $ Meta.trySynthInstance type def mkAppM (ref : Syntax) (constName : Name) (args : Array Expr) : TermElabM Expr := liftMetaM ref $ Meta.mkAppM constName args +def mkExpectedTypeHint (ref : Syntax) (e : Expr) (expectedType : Expr) : TermElabM Expr := liftMetaM ref $ Meta.mkExpectedTypeHint e expectedType def decLevel? (ref : Syntax) (u : Level) : TermElabM (Option Level) := liftMetaM ref $ Meta.decLevel? u def decLevel (ref : Syntax) (u : Level) : TermElabM Level := do @@ -1141,11 +1151,40 @@ fun stx _ => | some val => pure $ toExpr val | none => throwError stx "ill-formed syntax" +instance MetaHasEval {α} [MetaHasEval α] : MetaHasEval (TermElabM α) := +⟨fun env opts x => do + let ctx : Context := { + config := { opts := opts }, + fileName := "", + fileMap := arbitrary _, + cmdPos := 0, + currNamespace := Name.anonymous, + currRecDepth := 0, + maxRecDepth := getMaxRecDepth opts + }; + let showMessages (s : State) : IO Unit := do { + s.messages.forM $ fun m => IO.println $ format m + }; + match x ctx { env := env } with + | EStateM.Result.ok a s => do + showMessages s; + MetaHasEval.eval s.env opts a + | EStateM.Result.error (Exception.ex (Elab.Exception.error err)) s => do + showMessages s; + throw (IO.userError (toString (format err))) + | EStateM.Result.error (Exception.ex Elab.Exception.unsupportedSyntax) s => do + showMessages s; + throw (IO.userError "error: unsupported syntax") + | EStateM.Result.error Exception.postpone s => do + showMessages s; + throw (IO.userError "error: elaborator posponed")⟩ + end Term @[init] private def regTraceClasses : IO Unit := do registerTraceClass `Elab.postpone; registerTraceClass `Elab.coe; +registerTraceClass `Elab.debug; pure () export Term (TermElabM) diff --git a/stage0/src/Init/Lean/Meta/AppBuilder.lean b/stage0/src/Init/Lean/Meta/AppBuilder.lean index 2bb34dbf8f..cb78230245 100644 --- a/stage0/src/Init/Lean/Meta/AppBuilder.lean +++ b/stage0/src/Init/Lean/Meta/AppBuilder.lean @@ -3,34 +3,18 @@ Copyright (c) 2019 Microsoft Corporation. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Authors: Leonardo de Moura -/ +import Init.Lean.Util.Recognizers import Init.Lean.Meta.SynthInstance namespace Lean - -@[inline] def Expr.eq? (p : Expr) : Option (Expr × Expr × Expr) := -if p.isAppOfArity `Eq 3 then - some (p.getArg! 0, p.getArg! 1, p.getArg! 2) -else - none - -@[inline] def Expr.iff? (p : Expr) : Option (Expr × Expr) := -if p.isAppOfArity `Iff 2 then - some (p.getArg! 0, p.getArg! 1) -else - none - -@[inline] def Expr.heq? (p : Expr) : Option (Expr × Expr × Expr × Expr) := -if p.isAppOfArity `HEq 4 then - some (p.getArg! 0, p.getArg! 1, p.getArg! 2, p.getArg! 4) -else - none - -@[inline] def Expr.arrow? : Expr → Option (Expr × Expr) -| Expr.forallE _ α β _ => if β.hasLooseBVars then none else some (α, β) -| _ => none - namespace Meta +/-- Given `e` s.t. `inferType e` is definitionally equal to `expectedType`, return + term `@id expectedType e`. -/ +def mkExpectedTypeHint (e : Expr) (expectedType : Expr) : MetaM Expr := do +u ← getLevel expectedType; +pure $ mkApp2 (mkConst `id [u]) expectedType e + def mkEq (a b : Expr) : MetaM Expr := do aType ← inferType a; u ← getLevel aType; diff --git a/stage0/src/Init/Lean/Meta/Basic.lean b/stage0/src/Init/Lean/Meta/Basic.lean index 5363761b4c..e1946f6420 100644 --- a/stage0/src/Init/Lean/Meta/Basic.lean +++ b/stage0/src/Init/Lean/Meta/Basic.lean @@ -108,6 +108,7 @@ structure Cache := (inferType : PersistentExprStructMap Expr := {}) (funInfo : PersistentHashMap InfoCacheKey FunInfo := {}) (synthInstance : PersistentHashMap Expr (Option Expr) := {}) +(whnfDefault : PersistentExprStructMap Expr := {}) -- cache for closed terms and `TransparencyMode.default` structure Context := (config : Config := {}) @@ -810,8 +811,9 @@ mctx' ← getMCtx; modify $ fun s => { mctx := mctx, .. s }; finally x (modify $ fun s => { mctx := mctx', .. s }) -@[init] private def regTraceClasses : IO Unit := -registerTraceClass `Meta +@[init] private def regTraceClasses : IO Unit := do +registerTraceClass `Meta; +registerTraceClass `Meta.debug def run {α} (env : Environment) (x : MetaM α) (maxRecDepth := 10000) : Except Exception α := match x { maxRecDepth := maxRecDepth, currRecDepth := 0 } { env := env } with diff --git a/stage0/src/Init/Lean/Meta/Tactic/Target.lean b/stage0/src/Init/Lean/Meta/Tactic/Target.lean index a493655c3b..14448439a5 100644 --- a/stage0/src/Init/Lean/Meta/Tactic/Target.lean +++ b/stage0/src/Init/Lean/Meta/Tactic/Target.lean @@ -16,12 +16,12 @@ namespace Meta def replaceTargetEq (mvarId : MVarId) (newTarget : Expr) (eqProof : Expr) : MetaM MVarId := do withMVarContext mvarId $ do checkNotAssigned mvarId `replaceTarget; - tag ← getMVarTag mvarId; - newMVar ← mkFreshExprSyntheticOpaqueMVar newTarget tag; - target ← getMVarType mvarId; - u ← getLevel target; - eq ← mkEq target newTarget; - let newProof := mkApp2 (mkConst `id [levelZero]) eq eqProof; -- checkpoint for eqProof + tag ← getMVarTag mvarId; + newMVar ← mkFreshExprSyntheticOpaqueMVar newTarget tag; + target ← getMVarType mvarId; + u ← getLevel target; + eq ← mkEq target newTarget; + newProof ← mkExpectedTypeHint eqProof eq; let newVal := mkAppN (Lean.mkConst `Eq.mpr [u]) #[target, newTarget, eqProof, newMVar]; assignExprMVar mvarId newMVar; pure newMVar.mvarId! @@ -41,8 +41,7 @@ withMVarContext mvarId $ do else do tag ← getMVarTag mvarId; newMVar ← mkFreshExprSyntheticOpaqueMVar newTarget tag; - u ← getLevel target; - let newVal := mkApp2 (Lean.mkConst `id [u]) target newMVar; + newVal ← mkExpectedTypeHint newMVar target; assignExprMVar mvarId newMVar; pure newMVar.mvarId! diff --git a/stage0/src/Init/Lean/Meta/WHNF.lean b/stage0/src/Init/Lean/Meta/WHNF.lean index f78ac35fae..127912f1a1 100644 --- a/stage0/src/Init/Lean/Meta/WHNF.lean +++ b/stage0/src/Init/Lean/Meta/WHNF.lean @@ -85,21 +85,46 @@ else match e with else pure none | _ => pure none + +@[inline] private def useWHNFCache (e : Expr) : MetaM Bool := do +-- We cache only consed terms +if e.hasFVar then pure false +else do + ctx ← read; + pure $ ctx.config.transparency == TransparencyMode.default + +@[inline] private def cached? (useCache : Bool) (e : Expr) : MetaM (Option Expr) := do +if useCache then do + s ← get; + pure $ s.cache.whnfDefault.find? e +else + pure none + +private def cache (useCache : Bool) (e r : Expr) : MetaM Expr := do +when useCache $ + modify $ fun s => { cache := { whnfDefault := s.cache.whnfDefault.insert e r, .. s.cache }, .. s }; +pure r + partial def whnfImpl : Expr → MetaM Expr | e => Lean.WHNF.whnfEasyCases getLocalDecl getExprMVarAssignment? e $ fun e => do - e ← whnfCore e; - v? ← reduceNat? e; - match v? with - | some v => pure v - | none => do - v? ← reduceNative? e; + useCache ← useWHNFCache e; + e? ← cached? useCache e; + match e? with + | some e' => pure e' + | none => do + e' ← whnfCore e; + v? ← reduceNat? e'; match v? with - | some v => pure v - | none => do - e? ← unfoldDefinition? e; - match e? with - | some e => whnfImpl e - | none => pure e + | some v => cache useCache e v + | none => do + v? ← reduceNative? e'; + match v? with + | some v => cache useCache e v + | none => do + e? ← unfoldDefinition? e'; + match e? with + | some e => whnfImpl e + | none => cache useCache e e' @[init] def setWHNFRef : IO Unit := whnfRef.set whnfImpl diff --git a/stage0/src/Init/Lean/Parser/Term.lean b/stage0/src/Init/Lean/Parser/Term.lean index eafd87cf99..c4b150ad97 100644 --- a/stage0/src/Init/Lean/Parser/Term.lean +++ b/stage0/src/Init/Lean/Parser/Term.lean @@ -210,7 +210,9 @@ def checkIsSort := checkStackTop (fun stx => stx.isOfKind `Lean.Parser.Term.type @[builtinTermParser] def tacticBlock := parser! symbol "begin " appPrec >> Tactic.seq >> "end" @[builtinTermParser] def byTactic := parser! symbol "by " leadPrec >> Tactic.nonEmptySeq -- Use `unboxSingleton` trick similar to the one used at Command.lean for `Term.stxQuot` -@[builtinTermParser] def tacticStxQuot : Parser := node `Lean.Parser.Term.stxQuot $ symbol "`(tactic|" appPrec >> sepBy1 tacticParser "; " true true >> ")" +@[builtinTermParser] def tacticStxQuot : Parser := node `Lean.Parser.Term.stxQuot $ symbol "`(tactic|" appPrec >> sepBy1 tacticParser "; " true true >> ")" +@[builtinTermParser] def levelStxQuot : Parser := node `Lean.Parser.Term.stxQuot $ symbol "`(level|" appPrec >> levelParser >> ")" +@[builtinTermParser] def funBinderStxQuot : Parser := node `Lean.Parser.Term.stxQuot $ symbol "`(funBinder|" appPrec >> funBinder >> ")" end Term end Parser diff --git a/stage0/src/Init/Lean/Util/Recognizers.lean b/stage0/src/Init/Lean/Util/Recognizers.lean new file mode 100644 index 0000000000..cd9bd45a2a --- /dev/null +++ b/stage0/src/Init/Lean/Util/Recognizers.lean @@ -0,0 +1,71 @@ +/- +Copyright (c) 2020 Microsoft Corporation. All rights reserved. +Released under Apache 2.0 license as described in the file LICENSE. +Authors: Leonardo de Moura +-/ +prelude +import Init.Lean.Expr + +namespace Lean +namespace Expr + +@[inline] def app1? (e : Expr) (fName : Name) : Option Expr := +if e.isAppOfArity fName 1 then + some $ e.appArg! +else + none + +@[inline] def app2? (e : Expr) (fName : Name) : Option (Expr × Expr) := +if e.isAppOfArity fName 2 then + some $ (e.appFn!.appArg!, e.appArg!) +else + none + +@[inline] def app3? (e : Expr) (fName : Name) : Option (Expr × Expr × Expr) := +if e.isAppOfArity fName 3 then + some $ (e.appFn!.appFn!.appArg!, e.appFn!.appArg!, e.appArg!) +else + none + +@[inline] def app4? (e : Expr) (fName : Name) : Option (Expr × Expr × Expr × Expr) := +if e.isAppOfArity fName 4 then + some $ (e.appFn!.appFn!.appFn!.appArg!, e.appFn!.appFn!.appArg!, e.appFn!.appArg!, e.appArg!) +else + none + +@[inline] def eq? (p : Expr) : Option (Expr × Expr × Expr) := +p.app3? `Eq + +@[inline] def iff? (p : Expr) : Option (Expr × Expr) := +p.app2? `Iff + +@[inline] def heq? (p : Expr) : Option (Expr × Expr × Expr × Expr) := +p.app4? `HEq + +@[inline] def arrow? : Expr → Option (Expr × Expr) +| Expr.forallE _ α β _ => if β.hasLooseBVars then none else some (α, β) +| _ => none + +partial def listLitAux : Expr → List Expr → Option (List Expr) +| e, acc => + if e.isAppOfArity `List.nil 1 then + some acc.reverse + else if e.isAppOfArity `List.cons 3 then + listLitAux e.appArg! (e.appFn!.appArg! :: acc) + else + none + +def listLit? (e : Expr) : Option (List Expr) := +listLitAux e [] + +def arrayLit? (e : Expr) : Option (List Expr) := +match e.app2? `List.toArray with +| some (_, e) => e.listLit? +| none => none + +/-- Recognize `α × β` -/ +def prod? (e : Expr) : Option (Expr × Expr) := +e.app2? `Prod + +end Expr +end Lean diff --git a/stage0/src/kernel/inductive.cpp b/stage0/src/kernel/inductive.cpp index 91e8dbd9da..573fb4b715 100644 --- a/stage0/src/kernel/inductive.cpp +++ b/stage0/src/kernel/inductive.cpp @@ -1126,7 +1126,7 @@ expr nat_lit_to_constructor(expr const & e) { } expr string_lit_to_constructor(expr const & e) { - lean_assert(is_str_lit(e)); + lean_assert(is_string_lit(e)); string_ref const & s = lit_value(e).get_string(); buffer cs; utf8_decode(s.to_std_string(), cs); diff --git a/stage0/stdlib/CMakeLists.txt b/stage0/stdlib/CMakeLists.txt index f694618097..6a07d3366f 100644 --- a/stage0/stdlib/CMakeLists.txt +++ b/stage0/stdlib/CMakeLists.txt @@ -1 +1 @@ -add_library (stage0 OBJECT 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/AssocList.c Init/./Data/Basic.c Init/./Data/BinomialHeap.c Init/./Data/BinomialHeap/Basic.c Init/./Data/ByteArray.c Init/./Data/ByteArray/Basic.c Init/./Data/Char.c Init/./Data/Char/Basic.c Init/./Data/DList.c Init/./Data/Fin.c Init/./Data/Fin/Basic.c Init/./Data/HashMap.c Init/./Data/HashMap/Basic.c Init/./Data/HashSet.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/PersistentArray.c Init/./Data/PersistentArray/Basic.c Init/./Data/PersistentHashMap.c Init/./Data/PersistentHashMap/Basic.c Init/./Data/PersistentHashSet.c Init/./Data/Queue.c Init/./Data/Queue/Basic.c Init/./Data/RBMap.c Init/./Data/RBMap/Basic.c Init/./Data/RBMap/BasicAux.c Init/./Data/RBTree.c Init/./Data/RBTree/Basic.c Init/./Data/Random.c Init/./Data/Repr.c Init/./Data/Stack.c Init/./Data/Stack/Basic.c Init/./Data/String.c Init/./Data/String/Basic.c Init/./Data/ToString.c Init/./Data/UInt.c Init/./Default.c Init/./Fix.c Init/./HasCoe.c Init/./Lean.c Init/./Lean/Attributes.c Init/./Lean/AuxRecursor.c Init/./Lean/Class.c Init/./Lean/Compiler.c Init/./Lean/Compiler/ClosedTermCache.c Init/./Lean/Compiler/ConstFolding.c Init/./Lean/Compiler/ExportAttr.c Init/./Lean/Compiler/ExternAttr.c Init/./Lean/Compiler/IR.c Init/./Lean/Compiler/IR/Basic.c Init/./Lean/Compiler/IR/Borrow.c Init/./Lean/Compiler/IR/Boxing.c Init/./Lean/Compiler/IR/Checker.c Init/./Lean/Compiler/IR/CompilerM.c Init/./Lean/Compiler/IR/CtorLayout.c Init/./Lean/Compiler/IR/ElimDeadBranches.c Init/./Lean/Compiler/IR/ElimDeadVars.c Init/./Lean/Compiler/IR/EmitC.c Init/./Lean/Compiler/IR/EmitUtil.c Init/./Lean/Compiler/IR/ExpandResetReuse.c Init/./Lean/Compiler/IR/Format.c Init/./Lean/Compiler/IR/FreeVars.c Init/./Lean/Compiler/IR/LiveVars.c Init/./Lean/Compiler/IR/NormIds.c Init/./Lean/Compiler/IR/PushProj.c Init/./Lean/Compiler/IR/RC.c Init/./Lean/Compiler/IR/ResetReuse.c Init/./Lean/Compiler/IR/SimpCase.c Init/./Lean/Compiler/IR/UnboxResult.c Init/./Lean/Compiler/ImplementedByAttr.c Init/./Lean/Compiler/InitAttr.c Init/./Lean/Compiler/InlineAttrs.c Init/./Lean/Compiler/NameMangling.c Init/./Lean/Compiler/NeverExtractAttr.c Init/./Lean/Compiler/Specialize.c Init/./Lean/Compiler/Util.c Init/./Lean/Data/Format.c Init/./Lean/Data/KVMap.c Init/./Lean/Data/LBool.c Init/./Lean/Data/LOption.c Init/./Lean/Data/Name.c Init/./Lean/Data/Occurrences.c Init/./Lean/Data/Options.c Init/./Lean/Data/Position.c Init/./Lean/Data/SMap.c Init/./Lean/Data/Trie.c Init/./Lean/Declaration.c Init/./Lean/Elab.c Init/./Lean/Elab/Alias.c Init/./Lean/Elab/App.c Init/./Lean/Elab/Binders.c Init/./Lean/Elab/BuiltinNotation.c Init/./Lean/Elab/Command.c Init/./Lean/Elab/DeclModifiers.c Init/./Lean/Elab/Declaration.c Init/./Lean/Elab/Definition.c Init/./Lean/Elab/DoNotation.c Init/./Lean/Elab/Exception.c Init/./Lean/Elab/Frontend.c Init/./Lean/Elab/Import.c Init/./Lean/Elab/Level.c Init/./Lean/Elab/Log.c Init/./Lean/Elab/Match.c Init/./Lean/Elab/Quotation.c Init/./Lean/Elab/ResolveName.c Init/./Lean/Elab/StrategyAttrs.c Init/./Lean/Elab/StructInst.c Init/./Lean/Elab/Syntax.c Init/./Lean/Elab/SyntheticMVars.c Init/./Lean/Elab/Tactic.c Init/./Lean/Elab/Tactic/Basic.c Init/./Lean/Elab/Tactic/ElabTerm.c Init/./Lean/Elab/Tactic/Generalize.c Init/./Lean/Elab/Tactic/Induction.c Init/./Lean/Elab/Tactic/Injection.c Init/./Lean/Elab/Term.c Init/./Lean/Elab/Util.c Init/./Lean/Environment.c Init/./Lean/EqnCompiler.c Init/./Lean/EqnCompiler/MatchPattern.c Init/./Lean/Eval.c Init/./Lean/Expr.c Init/./Lean/HeadIndex.c Init/./Lean/Hygiene.c Init/./Lean/KeyedDeclsAttribute.c Init/./Lean/Level.c Init/./Lean/Linter.c Init/./Lean/LocalContext.c Init/./Lean/Message.c Init/./Lean/Meta.c Init/./Lean/Meta/AbstractMVars.c Init/./Lean/Meta/AppBuilder.c Init/./Lean/Meta/Basic.c Init/./Lean/Meta/Check.c Init/./Lean/Meta/DiscrTree.c Init/./Lean/Meta/DiscrTreeTypes.c Init/./Lean/Meta/Exception.c Init/./Lean/Meta/ExprDefEq.c Init/./Lean/Meta/FunInfo.c Init/./Lean/Meta/InferType.c Init/./Lean/Meta/Instances.c Init/./Lean/Meta/KAbstract.c Init/./Lean/Meta/LevelDefEq.c Init/./Lean/Meta/Message.c Init/./Lean/Meta/Offset.c Init/./Lean/Meta/RecursorInfo.c Init/./Lean/Meta/Reduce.c Init/./Lean/Meta/SynthInstance.c Init/./Lean/Meta/Tactic.c Init/./Lean/Meta/Tactic/Apply.c Init/./Lean/Meta/Tactic/Assert.c Init/./Lean/Meta/Tactic/Assumption.c Init/./Lean/Meta/Tactic/Cases.c Init/./Lean/Meta/Tactic/Clear.c Init/./Lean/Meta/Tactic/FVarSubst.c Init/./Lean/Meta/Tactic/Generalize.c Init/./Lean/Meta/Tactic/Induction.c Init/./Lean/Meta/Tactic/Injection.c Init/./Lean/Meta/Tactic/Intro.c Init/./Lean/Meta/Tactic/LocalDecl.c Init/./Lean/Meta/Tactic/Revert.c Init/./Lean/Meta/Tactic/Rewrite.c Init/./Lean/Meta/Tactic/Subst.c Init/./Lean/Meta/Tactic/Target.c Init/./Lean/Meta/Tactic/Util.c Init/./Lean/Meta/WHNF.c Init/./Lean/MetavarContext.c Init/./Lean/Modifiers.c Init/./Lean/Parser.c Init/./Lean/Parser/Command.c Init/./Lean/Parser/Level.c Init/./Lean/Parser/Module.c Init/./Lean/Parser/Parser.c Init/./Lean/Parser/Syntax.c Init/./Lean/Parser/Tactic.c Init/./Lean/Parser/Term.c Init/./Lean/Parser/Transform.c Init/./Lean/ProjFns.c Init/./Lean/ReducibilityAttrs.c Init/./Lean/Runtime.c Init/./Lean/Scopes.c Init/./Lean/Structure.c Init/./Lean/Syntax.c Init/./Lean/ToExpr.c Init/./Lean/Util.c Init/./Lean/Util/CollectFVars.c Init/./Lean/Util/CollectLevelParams.c Init/./Lean/Util/CollectMVars.c Init/./Lean/Util/FindExpr.c Init/./Lean/Util/FindMVar.c Init/./Lean/Util/FoldConsts.c Init/./Lean/Util/MonadCache.c Init/./Lean/Util/PPExt.c Init/./Lean/Util/PPGoal.c Init/./Lean/Util/Path.c Init/./Lean/Util/Profile.c Init/./Lean/Util/RecDepth.c Init/./Lean/Util/ReplaceExpr.c Init/./Lean/Util/Sorry.c Init/./Lean/Util/Trace.c Init/./Lean/Util/WHNF.c Init/./LeanInit.c Init/./ShareCommon.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) +add_library (stage0 OBJECT 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/AssocList.c Init/./Data/Basic.c Init/./Data/BinomialHeap.c Init/./Data/BinomialHeap/Basic.c Init/./Data/ByteArray.c Init/./Data/ByteArray/Basic.c Init/./Data/Char.c Init/./Data/Char/Basic.c Init/./Data/DList.c Init/./Data/Fin.c Init/./Data/Fin/Basic.c Init/./Data/HashMap.c Init/./Data/HashMap/Basic.c Init/./Data/HashSet.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/PersistentArray.c Init/./Data/PersistentArray/Basic.c Init/./Data/PersistentHashMap.c Init/./Data/PersistentHashMap/Basic.c Init/./Data/PersistentHashSet.c Init/./Data/Queue.c Init/./Data/Queue/Basic.c Init/./Data/RBMap.c Init/./Data/RBMap/Basic.c Init/./Data/RBMap/BasicAux.c Init/./Data/RBTree.c Init/./Data/RBTree/Basic.c Init/./Data/Random.c Init/./Data/Repr.c Init/./Data/Stack.c Init/./Data/Stack/Basic.c Init/./Data/String.c Init/./Data/String/Basic.c Init/./Data/ToString.c Init/./Data/UInt.c Init/./Default.c Init/./Fix.c Init/./HasCoe.c Init/./Lean.c Init/./Lean/Attributes.c Init/./Lean/AuxRecursor.c Init/./Lean/Class.c Init/./Lean/Compiler.c Init/./Lean/Compiler/ClosedTermCache.c Init/./Lean/Compiler/ConstFolding.c Init/./Lean/Compiler/ExportAttr.c Init/./Lean/Compiler/ExternAttr.c Init/./Lean/Compiler/IR.c Init/./Lean/Compiler/IR/Basic.c Init/./Lean/Compiler/IR/Borrow.c Init/./Lean/Compiler/IR/Boxing.c Init/./Lean/Compiler/IR/Checker.c Init/./Lean/Compiler/IR/CompilerM.c Init/./Lean/Compiler/IR/CtorLayout.c Init/./Lean/Compiler/IR/ElimDeadBranches.c Init/./Lean/Compiler/IR/ElimDeadVars.c Init/./Lean/Compiler/IR/EmitC.c Init/./Lean/Compiler/IR/EmitUtil.c Init/./Lean/Compiler/IR/ExpandResetReuse.c Init/./Lean/Compiler/IR/Format.c Init/./Lean/Compiler/IR/FreeVars.c Init/./Lean/Compiler/IR/LiveVars.c Init/./Lean/Compiler/IR/NormIds.c Init/./Lean/Compiler/IR/PushProj.c Init/./Lean/Compiler/IR/RC.c Init/./Lean/Compiler/IR/ResetReuse.c Init/./Lean/Compiler/IR/SimpCase.c Init/./Lean/Compiler/IR/UnboxResult.c Init/./Lean/Compiler/ImplementedByAttr.c Init/./Lean/Compiler/InitAttr.c Init/./Lean/Compiler/InlineAttrs.c Init/./Lean/Compiler/NameMangling.c Init/./Lean/Compiler/NeverExtractAttr.c Init/./Lean/Compiler/Specialize.c Init/./Lean/Compiler/Util.c Init/./Lean/Data/Format.c Init/./Lean/Data/KVMap.c Init/./Lean/Data/LBool.c Init/./Lean/Data/LOption.c Init/./Lean/Data/Name.c Init/./Lean/Data/Occurrences.c Init/./Lean/Data/Options.c Init/./Lean/Data/Position.c Init/./Lean/Data/SMap.c Init/./Lean/Data/Trie.c Init/./Lean/Declaration.c Init/./Lean/Elab.c Init/./Lean/Elab/Alias.c Init/./Lean/Elab/App.c Init/./Lean/Elab/Binders.c Init/./Lean/Elab/BuiltinNotation.c Init/./Lean/Elab/Command.c Init/./Lean/Elab/DeclModifiers.c Init/./Lean/Elab/Declaration.c Init/./Lean/Elab/Definition.c Init/./Lean/Elab/DoNotation.c Init/./Lean/Elab/Exception.c Init/./Lean/Elab/Frontend.c Init/./Lean/Elab/Import.c Init/./Lean/Elab/Level.c Init/./Lean/Elab/Log.c Init/./Lean/Elab/Match.c Init/./Lean/Elab/Quotation.c Init/./Lean/Elab/ResolveName.c Init/./Lean/Elab/StrategyAttrs.c Init/./Lean/Elab/StructInst.c Init/./Lean/Elab/Syntax.c Init/./Lean/Elab/SyntheticMVars.c Init/./Lean/Elab/Tactic.c Init/./Lean/Elab/Tactic/Basic.c Init/./Lean/Elab/Tactic/ElabTerm.c Init/./Lean/Elab/Tactic/Generalize.c Init/./Lean/Elab/Tactic/Induction.c Init/./Lean/Elab/Tactic/Injection.c Init/./Lean/Elab/Term.c Init/./Lean/Elab/Util.c Init/./Lean/Environment.c Init/./Lean/EqnCompiler.c Init/./Lean/EqnCompiler/MatchPattern.c Init/./Lean/Eval.c Init/./Lean/Expr.c Init/./Lean/HeadIndex.c Init/./Lean/Hygiene.c Init/./Lean/KeyedDeclsAttribute.c Init/./Lean/Level.c Init/./Lean/Linter.c Init/./Lean/LocalContext.c Init/./Lean/Message.c Init/./Lean/Meta.c Init/./Lean/Meta/AbstractMVars.c Init/./Lean/Meta/AppBuilder.c Init/./Lean/Meta/Basic.c Init/./Lean/Meta/Check.c Init/./Lean/Meta/DiscrTree.c Init/./Lean/Meta/DiscrTreeTypes.c Init/./Lean/Meta/Exception.c Init/./Lean/Meta/ExprDefEq.c Init/./Lean/Meta/FunInfo.c Init/./Lean/Meta/InferType.c Init/./Lean/Meta/Instances.c Init/./Lean/Meta/KAbstract.c Init/./Lean/Meta/LevelDefEq.c Init/./Lean/Meta/Message.c Init/./Lean/Meta/Offset.c Init/./Lean/Meta/RecursorInfo.c Init/./Lean/Meta/Reduce.c Init/./Lean/Meta/SynthInstance.c Init/./Lean/Meta/Tactic.c Init/./Lean/Meta/Tactic/Apply.c Init/./Lean/Meta/Tactic/Assert.c Init/./Lean/Meta/Tactic/Assumption.c Init/./Lean/Meta/Tactic/Cases.c Init/./Lean/Meta/Tactic/Clear.c Init/./Lean/Meta/Tactic/FVarSubst.c Init/./Lean/Meta/Tactic/Generalize.c Init/./Lean/Meta/Tactic/Induction.c Init/./Lean/Meta/Tactic/Injection.c Init/./Lean/Meta/Tactic/Intro.c Init/./Lean/Meta/Tactic/LocalDecl.c Init/./Lean/Meta/Tactic/Revert.c Init/./Lean/Meta/Tactic/Rewrite.c Init/./Lean/Meta/Tactic/Subst.c Init/./Lean/Meta/Tactic/Target.c Init/./Lean/Meta/Tactic/Util.c Init/./Lean/Meta/WHNF.c Init/./Lean/MetavarContext.c Init/./Lean/Modifiers.c Init/./Lean/Parser.c Init/./Lean/Parser/Command.c Init/./Lean/Parser/Level.c Init/./Lean/Parser/Module.c Init/./Lean/Parser/Parser.c Init/./Lean/Parser/Syntax.c Init/./Lean/Parser/Tactic.c Init/./Lean/Parser/Term.c Init/./Lean/Parser/Transform.c Init/./Lean/ProjFns.c Init/./Lean/ReducibilityAttrs.c Init/./Lean/Runtime.c Init/./Lean/Scopes.c Init/./Lean/Structure.c Init/./Lean/Syntax.c Init/./Lean/ToExpr.c Init/./Lean/Util.c Init/./Lean/Util/CollectFVars.c Init/./Lean/Util/CollectLevelParams.c Init/./Lean/Util/CollectMVars.c Init/./Lean/Util/FindExpr.c Init/./Lean/Util/FindMVar.c Init/./Lean/Util/FoldConsts.c Init/./Lean/Util/MonadCache.c Init/./Lean/Util/PPExt.c Init/./Lean/Util/PPGoal.c Init/./Lean/Util/Path.c Init/./Lean/Util/Profile.c Init/./Lean/Util/RecDepth.c Init/./Lean/Util/Recognizers.c Init/./Lean/Util/ReplaceExpr.c Init/./Lean/Util/Sorry.c Init/./Lean/Util/Trace.c Init/./Lean/Util/WHNF.c Init/./LeanInit.c Init/./ShareCommon.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) diff --git a/stage0/stdlib/Init/Data/Char/Basic.c b/stage0/stdlib/Init/Data/Char/Basic.c index 03d72df59e..5661259e90 100644 --- a/stage0/stdlib/Init/Data/Char/Basic.c +++ b/stage0/stdlib/Init/Data/Char/Basic.c @@ -20,7 +20,6 @@ uint8_t l_Char_isUpper(uint32_t); uint8_t l_Char_isDigit(uint32_t); uint8_t l_Char_isWhitespace(uint32_t); lean_object* l_Char_toNat___boxed(lean_object*); -uint32_t lean_uint32_of_nat(lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); uint8_t l_Char_lt(uint32_t, uint32_t); lean_object* l_Char_toNat(uint32_t); @@ -33,6 +32,7 @@ uint8_t l_Char_isLower(uint32_t); lean_object* l_Char_HasSizeof(uint32_t); lean_object* l_Char_isAlphanum___boxed(lean_object*); uint32_t l_Char_Inhabited; +uint32_t lean_uint32_of_nat(lean_object*); lean_object* l_Char_isWhitespace___boxed(lean_object*); uint8_t l_Char_isAlpha(uint32_t); lean_object* l_Char_decLt___boxed(lean_object*, lean_object*); @@ -52,6 +52,7 @@ uint8_t l_UInt32_decLe(uint32_t, uint32_t); lean_object* lean_uint32_to_nat(uint32_t); lean_object* l_Char_decLe___boxed(lean_object*, lean_object*); uint32_t l_Char_ofNat(lean_object*); +uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Char_isDigit___boxed(lean_object*); lean_object* l_Char_HasSizeof(uint32_t x_1) { _start: @@ -206,41 +207,46 @@ return x_6; uint32_t l_Char_ofNat(lean_object* x_1) { _start: { -uint32_t x_2; uint32_t x_3; uint8_t x_4; -x_2 = lean_uint32_of_nat(x_1); -x_3 = 55296; -x_4 = x_2 < x_3; -if (x_4 == 0) +lean_object* x_2; uint8_t x_3; +x_2 = lean_unsigned_to_nat(55296u); +x_3 = lean_nat_dec_lt(x_1, x_2); +if (x_3 == 0) { -uint32_t x_5; uint8_t x_6; -x_5 = 57343; -x_6 = x_5 < x_2; -if (x_6 == 0) +lean_object* x_4; uint8_t x_5; +x_4 = lean_unsigned_to_nat(57343u); +x_5 = lean_nat_dec_lt(x_4, x_1); +if (x_5 == 0) { -uint32_t x_7; -x_7 = 0; -return x_7; +uint32_t x_6; +lean_dec(x_1); +x_6 = 0; +return x_6; } else { -uint32_t x_8; uint8_t x_9; -x_8 = 1114112; -x_9 = x_2 < x_8; -if (x_9 == 0) +lean_object* x_7; uint8_t x_8; +x_7 = lean_unsigned_to_nat(1114112u); +x_8 = lean_nat_dec_lt(x_1, x_7); +if (x_8 == 0) +{ +uint32_t x_9; +lean_dec(x_1); +x_9 = 0; +return x_9; +} +else { uint32_t x_10; -x_10 = 0; +x_10 = lean_uint32_of_nat(x_1); return x_10; } -else -{ -return x_2; -} } } else { -return x_2; +uint32_t x_11; +x_11 = lean_uint32_of_nat(x_1); +return x_11; } } } @@ -249,7 +255,6 @@ _start: { uint32_t x_2; lean_object* x_3; x_2 = l_Char_ofNat(x_1); -lean_dec(x_1); x_3 = lean_box_uint32(x_2); return x_3; } @@ -530,7 +535,6 @@ x_7 = lean_unsigned_to_nat(32u); x_8 = lean_nat_add(x_2, x_7); lean_dec(x_2); x_9 = l_Char_ofNat(x_8); -lean_dec(x_8); return x_9; } } diff --git a/stage0/stdlib/Init/Data/UInt.c b/stage0/stdlib/Init/Data/UInt.c index fd70e2ab18..8dc8f4eff3 100644 --- a/stage0/stdlib/Init/Data/UInt.c +++ b/stage0/stdlib/Init/Data/UInt.c @@ -105,6 +105,7 @@ lean_object* l_UInt8_ofNat___boxed(lean_object*); uint32_t l_UInt32_add(uint32_t, uint32_t); size_t l_UInt64_toUSize(uint64_t); uint32_t l_UInt32_div(uint32_t, uint32_t); +lean_object* l_UInt32_ofNat_x27___boxed(lean_object*, lean_object*); lean_object* l_USize_ofNat___boxed(lean_object*); lean_object* l_UInt32_HasDiv___closed__1; lean_object* l_USize_shiftRight___boxed(lean_object*, lean_object*); @@ -173,6 +174,7 @@ lean_object* l_UInt32_div___boxed(lean_object*, lean_object*); lean_object* l_USize_hasDecidableLt___boxed(lean_object*, lean_object*); uint64_t l_UInt64_mod(uint64_t, uint64_t); lean_object* l_UInt16_add___boxed(lean_object*, lean_object*); +uint32_t lean_uint32_of_nat(lean_object*); uint64_t l_UInt64_mul(uint64_t, uint64_t); lean_object* l_UInt32_HasMod___closed__1; size_t l_USize_land(size_t, size_t); @@ -1139,6 +1141,15 @@ x_3 = lean_box_uint32(x_2); return x_3; } } +lean_object* l_UInt32_ofNat_x27___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint32_t x_3; lean_object* x_4; +x_3 = lean_uint32_of_nat(x_1); +x_4 = lean_box_uint32(x_3); +return x_4; +} +} uint32_t l_Nat_toUInt32(lean_object* x_1) { _start: { diff --git a/stage0/stdlib/Init/Lean/Elab/Binders.c b/stage0/stdlib/Init/Lean/Elab/Binders.c index 23a1d846aa..4165622e6f 100644 --- a/stage0/stdlib/Init/Lean/Elab/Binders.c +++ b/stage0/stdlib/Init/Lean/Elab/Binders.c @@ -13,12 +13,15 @@ #ifdef __cplusplus extern "C" { #endif +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__6; lean_object* l_Lean_Elab_Term_elabBinder___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinders(lean_object*); lean_object* l_Lean_Elab_Term_mkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4; lean_object* l___private_Init_Lean_Elab_Binders_2__expandBinderIdent___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDecl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_registerTraceClass(lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__23; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__13; @@ -32,18 +35,15 @@ extern lean_object* l_Lean_nullKind; lean_object* l_Lean_Elab_Term_elabDepArrow(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabArrow___closed__1; lean_object* l_Lean_Elab_Term_declareTacticSyntax___closed__5; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabDepArrow___closed__1; -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3; +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__6; extern lean_object* l_Lean_List_format___rarg___closed__2; uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabFunCore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_mk_let_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_1__expandBinderType___boxed(lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinder___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabFun(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_forall___elambda__1___closed__2; @@ -51,16 +51,18 @@ extern lean_object* l_Lean_identKind___closed__2; lean_object* l_Lean_Elab_Term_elabForall___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_typeAscription___elambda__1___closed__1; extern lean_object* l_Lean_Parser_Term_match___elambda__1___closed__1; +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3; extern lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__8; extern lean_object* l___private_Init_Lean_Elab_Term_5__expandCDot___main___closed__3; -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5; lean_object* l_Lean_Elab_Term_expandFunBinders___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; lean_object* l_Lean_Elab_Term_FunBinders_elabFunBindersAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_declareTacticSyntax___closed__1; lean_object* l_Lean_Elab_Term_elabLetDeclAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); uint8_t l_Lean_checkTraceOption(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__3; +lean_object* l___private_Init_Lean_Elab_Binders_6__matchBinder___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__56; lean_object* l___regBuiltin_Lean_Elab_Term_elabArrow___closed__1; lean_object* l_Lean_Elab_Term_elabFunBinders___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); @@ -70,6 +72,7 @@ extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main__ lean_object* l_Lean_Elab_Term_compileDecl(lean_object*, 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_expr_instantiate1(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; lean_object* lean_array_push(lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__1; lean_object* lean_array_get_size(lean_object*); @@ -79,85 +82,83 @@ extern lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Elab_Quo extern lean_object* l___private_Init_Lean_Elab_Term_5__expandCDot___main___closed__2; lean_object* l_Lean_Elab_Term_declareTacticSyntax___closed__3; lean_object* lean_string_utf8_byte_size(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withLetDecl___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getMainModule___rarg(lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_11__letBindRhss___main___closed__17; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_1__expandBinderType(lean_object*); lean_object* l___private_Init_Lean_Elab_Quotation_1__quoteName___main(lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__5; -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__8; extern lean_object* l_Lean_mkAppStx___closed__7; lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1; -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_ensureHasType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_quoteAutoTactic___main___spec__1___closed__2; +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkFreshAnonymousIdent(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_binderTactic___elambda__1___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabArrow(lean_object*); lean_object* l_Lean_Elab_Term_mkLet(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getOptions(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkTermIdFromIdent___closed__2; lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__8; lean_object* l_Lean_Syntax_isSimpleTermId_x3f(lean_object*, uint8_t); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__4; -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6; lean_object* l_Lean_Elab_Term_elabFunCore___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_FunBinders_elabFunBindersAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_quoteAutoTactic___main___closed__3; lean_object* lean_array_fget(lean_object*, lean_object*); extern lean_object* l_Lean_Expr_getOptParamDefault_x3f___closed__2; +lean_object* l___private_Init_Lean_Elab_Binders_5__getBinderIds(lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___closed__2; lean_object* l_Lean_Elab_Term_quoteAutoTactic___main___closed__1; -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2; +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkFreshFVarId___rarg(lean_object*); lean_object* l_Lean_Elab_Term_declareTacticSyntax(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(lean_object*); extern lean_object* l_Lean_Parser_Term_implicitBinder___elambda__1___closed__1; -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3; +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___closed__1; extern lean_object* l_Lean_Parser_Term_instBinder___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabFun___closed__1; lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_quoteAutoTactic___main___spec__1___closed__1; lean_object* l_Lean_Elab_Term_elabTerm(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1; extern lean_object* l___private_Init_Lean_Elab_Util_1__evalSyntaxConstantUnsafe___closed__1; lean_object* l_Lean_Elab_Term_elabForall___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_quoteAutoTactic___main___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; extern lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkTypesAndAssign___closed__7; -lean_object* l___private_Init_Lean_Elab_Binders_14__regTraceClasses(lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabFunCore___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__29; -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6; -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_15__regTraceClasses(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_quoteAutoTactic___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabLetBangDecl(lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; extern lean_object* l___private_Init_Lean_Elab_Quotation_7__getHeadInfo___elambda__3___closed__2; lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Term_expandCDot_x3f___closed__3; lean_object* l_Lean_Elab_Term_logTrace(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabArrow___lambda__1___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_explicitBinder___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabForall___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__2; lean_object* l_Lean_Syntax_getId(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_13__propagateExpectedType___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__1; lean_object* l_Lean_Elab_Term_elabFunBinders(lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__11; @@ -175,12 +176,15 @@ lean_object* l_Lean_Elab_Term_withLocalDecl___rarg(lean_object*, lean_object*, u extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__31; lean_object* l___regBuiltin_Lean_Elab_Term_elabForall(lean_object*); extern lean_object* l_Lean_mkAppStx___closed__6; +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__1; uint8_t l_Array_isEmpty___rarg(lean_object*); extern lean_object* l_Lean_Parser_Term_arrow___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabArrow___lambda__1___closed__4; extern lean_object* l_Lean_Parser_Term_let___elambda__1___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getLocalInsts(lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__2; lean_object* l_Lean_Elab_Term_mkFreshInstanceName___rarg(lean_object*); lean_object* l_Lean_Elab_Term_isClass(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*); @@ -189,21 +193,21 @@ lean_object* l_Lean_Elab_Term_elabLetBangDecl___closed__1; lean_object* l_Lean_mkFVar(lean_object*); extern lean_object* l_Lean_Expr_getAutoParamTactic_x3f___closed__1; lean_object* l_Lean_Elab_Term_quoteAutoTactic(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetBangDecl___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1; lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isAutoParam(lean_object*); extern lean_object* l_Lean_Expr_getAutoParamTactic_x3f___closed__2; lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_5__getBinderIds___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_addMacroScope(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_5__matchBinder(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_6__matchBinder(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinders___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandOptType___boxed(lean_object*, lean_object*); extern lean_object* l_Lean_nullKind___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_FunBinders_elabFunBindersAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Term_termElabAttribute; lean_object* l___regBuiltin_Lean_Elab_Term_elabLetBangDecl___closed__1; @@ -212,55 +216,61 @@ lean_object* l_Lean_Elab_Term_isDefEq(lean_object*, lean_object*, lean_object*, extern lean_object* l_Lean_mkAppStx___closed__3; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__4; lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_identKind; +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_implicitBinder___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Term_str___elambda__1___closed__2; extern lean_object* l_Lean_Syntax_inhabited; lean_object* l_Lean_Elab_Term_elabArrow(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; lean_object* l_Lean_Elab_Term_elabArrow___lambda__1___closed__5; +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__5; extern lean_object* l_Lean_Parser_Level_paren___elambda__1___closed__3; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__8; lean_object* l_Lean_Syntax_getNumArgs(lean_object*); lean_object* l_Lean_mkHole(lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1; lean_object* l_Lean_Elab_Term_getLCtx(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabFunBinders___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_getOptParamDefault_x3f___closed__1; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; lean_object* l_Lean_Elab_Term_elabLetDecl___closed__2; extern lean_object* l_Lean_Parser_Term_match___elambda__1___closed__2; +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2; lean_object* l_Lean_mkApp(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_isTermId_x3f(lean_object*, uint8_t); extern lean_object* l_Lean_Parser_Term_let___elambda__1___closed__1; lean_object* l_Lean_Syntax_getArgs(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8; uint8_t l_Lean_BinderInfo_isExplicit(uint8_t); lean_object* l_Lean_Syntax_getKind(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; lean_object* l_Lean_Elab_Term_elabLetDecl___closed__1; lean_object* l_Lean_Elab_Term_quoteAutoTactic___main___closed__2; lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6; extern lean_object* l___private_Init_Util_1__mkPanicMessage___closed__2; extern lean_object* l_Lean_mkHole___closed__1; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__40; lean_object* l_Lean_Elab_Term_mkExplicitBinder(lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_adaptExpander(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkStxStrLit(lean_object*, lean_object*); uint8_t l_Lean_Elab_Term_Quotation_isAntiquotSplice(lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__7; lean_object* l_Lean_Elab_Term_FunBinders_elabFunBindersAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3; lean_object* l_Lean_Elab_Term_elabType(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_letIdDecl___closed__2; extern lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_expandFunBinders(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetBangDecl(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_5__matchBinder___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_whnfForall(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9; uint8_t l_Lean_Syntax_isNone(lean_object*); lean_object* l_Lean_Elab_Term_resetSynthInstanceCache___rarg(lean_object*); lean_object* l_Lean_mkTermIdFrom(lean_object*, lean_object*); @@ -268,25 +278,24 @@ extern lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___a extern lean_object* l___private_Init_Lean_Elab_Quotation_7__getHeadInfo___elambda__3___closed__10; extern lean_object* l_Lean_Parser_Term_matchAlt___closed__2; extern lean_object* l_Lean_Parser_Term_binderDefault___elambda__1___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_Inhabited; +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at_Lean_Elab_Term_quoteAutoTactic___main___spec__1___closed__3; uint8_t l_Lean_Syntax_isOfKind(lean_object*, lean_object*); uint8_t l_Lean_Expr_isOptParam(lean_object*); extern lean_object* l_Lean_mkHole___closed__2; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; lean_object* l_Lean_Elab_Term_elabBinders___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9; +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabLetDeclAux___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); extern lean_object* l_Lean_mkOptionalNode___closed__2; lean_object* l_Lean_Elab_Term_declareTacticSyntax___closed__4; -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8; extern lean_object* l_Lean_Parser_Term_typeSpec___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabLetDecl(lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Term_5__expandCDot___main___closed__4; +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___spec__1___closed__4; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__28; lean_object* l_Lean_Elab_Term_elabArrow___lambda__1(lean_object*, lean_object*, lean_object*); @@ -296,25 +305,23 @@ extern lean_object* l_Lean_arrayToExpr___rarg___closed__2; lean_object* l_Lean_Elab_Term_elabLetDeclAux___closed__3; lean_object* l_Lean_Elab_Term_elabForall(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabArrow___lambda__1___closed__3; -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_quoteAutoTactic___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Term_simpleBinder___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Term_forall___elambda__1___closed__1; +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__26; lean_object* l_Lean_mkConst(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4; +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5; extern lean_object* l_Lean_mkAppStx___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabLetDecl___closed__1; -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabFunCore(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_AbstractMVars_abstractExprMVars___main___closed__1; -lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6; lean_object* l___regBuiltin_Lean_Elab_Term_elabDepArrow(lean_object*); lean_object* l___private_Init_Lean_Elab_Binders_3__expandOptIdent(lean_object*, lean_object*, lean_object*); uint8_t lean_string_dec_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Elab_Binders_12__propagateExpectedType___boxed(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_Meta_AbstractMVars_abstractExprMVars___main___closed__2; lean_object* l_Lean_Elab_Term_elabBinder(lean_object*); @@ -2574,7 +2581,241 @@ lean_dec(x_2); return x_5; } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* _init_l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("identifier or `_` expected"); +return x_1; +} +} +lean_object* _init_l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___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_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___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_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___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_dec(x_3); +lean_dec(x_1); +x_7 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_7, 0, x_2); +lean_ctor_set(x_7, 1, x_4); +return x_7; +} +else +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_8 = lean_array_fget(x_2, x_1); +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_array_fset(x_2, x_1, x_9); +x_11 = x_8; +lean_inc(x_11); +x_12 = l_Lean_Syntax_getKind(x_11); +x_13 = l_Lean_identKind; +x_14 = lean_name_eq(x_12, x_13); +if (x_14 == 0) +{ +lean_object* x_15; uint8_t x_16; +x_15 = l_Lean_mkHole___closed__2; +x_16 = lean_name_eq(x_12, x_15); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; +x_17 = l_Lean_mkTermIdFromIdent___closed__2; +x_18 = lean_name_eq(x_12, x_17); +lean_dec(x_12); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; uint8_t x_21; +lean_dec(x_10); +lean_dec(x_1); +x_19 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3; +x_20 = l_Lean_Elab_Term_throwError___rarg(x_11, x_19, x_3, x_4); +lean_dec(x_11); +x_21 = !lean_is_exclusive(x_20); +if (x_21 == 0) +{ +return x_20; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_20, 0); +x_23 = lean_ctor_get(x_20, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_20); +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; lean_object* x_27; uint8_t x_28; +x_25 = l_Lean_Syntax_getArgs(x_11); +x_26 = lean_array_get_size(x_25); +lean_dec(x_25); +x_27 = lean_unsigned_to_nat(2u); +x_28 = lean_nat_dec_eq(x_26, x_27); +lean_dec(x_26); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; +lean_dec(x_10); +lean_dec(x_1); +x_29 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3; +x_30 = l_Lean_Elab_Term_throwError___rarg(x_11, x_29, x_3, x_4); +lean_dec(x_11); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) +{ +return x_30; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_30, 0); +x_33 = lean_ctor_get(x_30, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_30); +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 +{ +lean_object* x_35; lean_object* x_36; uint8_t x_37; +x_35 = lean_unsigned_to_nat(1u); +x_36 = l_Lean_Syntax_getArg(x_11, x_35); +x_37 = l_Lean_Syntax_isNone(x_36); +lean_dec(x_36); +if (x_37 == 0) +{ +lean_object* x_38; lean_object* x_39; uint8_t x_40; +lean_dec(x_10); +lean_dec(x_1); +x_38 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3; +x_39 = l_Lean_Elab_Term_throwError___rarg(x_11, x_38, x_3, x_4); +lean_dec(x_11); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) +{ +return x_39; +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_39, 0); +x_42 = lean_ctor_get(x_39, 1); +lean_inc(x_42); +lean_inc(x_41); +lean_dec(x_39); +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_object* x_45; lean_object* x_46; lean_object* x_47; +x_44 = l_Lean_Syntax_getArg(x_11, x_9); +lean_dec(x_11); +x_45 = lean_nat_add(x_1, x_35); +x_46 = x_44; +x_47 = lean_array_fset(x_10, x_1, x_46); +lean_dec(x_1); +x_1 = x_45; +x_2 = x_47; +goto _start; +} +} +} +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_12); +x_49 = lean_unsigned_to_nat(1u); +x_50 = lean_nat_add(x_1, x_49); +x_51 = x_11; +x_52 = lean_array_fset(x_10, x_1, x_51); +lean_dec(x_1); +x_1 = x_50; +x_2 = x_52; +goto _start; +} +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +lean_dec(x_12); +x_54 = lean_unsigned_to_nat(1u); +x_55 = lean_nat_add(x_1, x_54); +x_56 = x_11; +x_57 = lean_array_fset(x_10, x_1, x_56); +lean_dec(x_1); +x_1 = x_55; +x_2 = x_57; +goto _start; +} +} +} +} +lean_object* l___private_Init_Lean_Elab_Binders_5__getBinderIds(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_Syntax_getArgs(x_1); +x_5 = x_4; +x_6 = lean_unsigned_to_nat(0u); +x_7 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1), 4, 2); +lean_closure_set(x_7, 0, x_6); +lean_closure_set(x_7, 1, x_5); +x_8 = x_7; +x_9 = lean_apply_2(x_8, x_2, x_3); +return x_9; +} +} +lean_object* l___private_Init_Lean_Elab_Binders_5__getBinderIds___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Elab_Binders_5__getBinderIds(x_1, x_2, x_3); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___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; @@ -2622,7 +2863,7 @@ goto _start; } } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___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; uint8_t x_7; @@ -2670,7 +2911,7 @@ goto _start; } } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; uint8_t x_7; @@ -2718,7 +2959,7 @@ goto _start; } } } -lean_object* l___private_Init_Lean_Elab_Binders_5__matchBinder(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Elab_Binders_6__matchBinder(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { if (lean_obj_tag(x_1) == 1) @@ -2802,153 +3043,252 @@ 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_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; x_36 = l_Lean_Syntax_inhabited; x_37 = lean_unsigned_to_nat(1u); x_38 = lean_array_get(x_36, x_5, x_37); -x_39 = l_Lean_Syntax_getArgs(x_38); +lean_inc(x_2); +x_39 = l___private_Init_Lean_Elab_Binders_5__getBinderIds(x_38, x_2, x_3); lean_dec(x_38); -x_40 = lean_unsigned_to_nat(2u); -x_41 = lean_array_get(x_36, x_5, x_40); -x_42 = l___private_Init_Lean_Elab_Binders_1__expandBinderType(x_41); -lean_dec(x_41); -x_43 = x_39; -x_44 = lean_unsigned_to_nat(0u); -x_45 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1___boxed), 5, 3); -lean_closure_set(x_45, 0, x_42); -lean_closure_set(x_45, 1, x_44); -lean_closure_set(x_45, 2, x_43); -x_46 = x_45; -x_47 = lean_apply_2(x_46, x_2, x_3); -return x_47; +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; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_40 = lean_ctor_get(x_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_unsigned_to_nat(2u); +x_43 = lean_array_get(x_36, x_5, x_42); +x_44 = l___private_Init_Lean_Elab_Binders_1__expandBinderType(x_43); +lean_dec(x_43); +x_45 = x_40; +x_46 = lean_unsigned_to_nat(0u); +x_47 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__1___boxed), 5, 3); +lean_closure_set(x_47, 0, x_44); +lean_closure_set(x_47, 1, x_46); +lean_closure_set(x_47, 2, x_45); +x_48 = x_47; +x_49 = lean_apply_2(x_48, x_2, x_41); +return x_49; +} +else +{ +uint8_t x_50; +lean_dec(x_2); +x_50 = !lean_is_exclusive(x_39); +if (x_50 == 0) +{ +return x_39; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_39, 0); +x_52 = lean_ctor_get(x_39, 1); +lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_39); +x_53 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_53, 0, x_51); +lean_ctor_set(x_53, 1, x_52); +return x_53; +} +} } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_48 = l_Lean_Syntax_inhabited; -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_array_get(x_48, x_5, x_49); -x_51 = l_Lean_Syntax_getArgs(x_50); -lean_dec(x_50); -x_52 = lean_unsigned_to_nat(2u); -x_53 = lean_array_get(x_48, x_5, x_52); -x_54 = l___private_Init_Lean_Elab_Binders_1__expandBinderType(x_53); -lean_dec(x_53); -x_55 = lean_unsigned_to_nat(3u); -x_56 = lean_array_get(x_48, x_5, x_55); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_54 = l_Lean_Syntax_inhabited; +x_55 = lean_unsigned_to_nat(1u); +x_56 = lean_array_get(x_54, x_5, x_55); lean_inc(x_2); -x_57 = l___private_Init_Lean_Elab_Binders_4__expandBinderModifier(x_54, x_56, x_2, x_3); +x_57 = l___private_Init_Lean_Elab_Binders_5__getBinderIds(x_56, x_2, x_3); lean_dec(x_56); if (lean_obj_tag(x_57) == 0) { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +lean_object* x_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_57, 0); lean_inc(x_58); x_59 = lean_ctor_get(x_57, 1); lean_inc(x_59); lean_dec(x_57); -x_60 = x_51; -x_61 = lean_unsigned_to_nat(0u); -x_62 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2___boxed), 5, 3); -lean_closure_set(x_62, 0, x_58); -lean_closure_set(x_62, 1, x_61); -lean_closure_set(x_62, 2, x_60); -x_63 = x_62; -x_64 = lean_apply_2(x_63, x_2, x_59); -return x_64; +x_60 = lean_unsigned_to_nat(2u); +x_61 = lean_array_get(x_54, x_5, x_60); +x_62 = l___private_Init_Lean_Elab_Binders_1__expandBinderType(x_61); +lean_dec(x_61); +x_63 = lean_unsigned_to_nat(3u); +x_64 = lean_array_get(x_54, x_5, x_63); +lean_inc(x_2); +x_65 = l___private_Init_Lean_Elab_Binders_4__expandBinderModifier(x_62, x_64, x_2, x_59); +lean_dec(x_64); +if (lean_obj_tag(x_65) == 0) +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +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 = x_58; +x_69 = lean_unsigned_to_nat(0u); +x_70 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__2___boxed), 5, 3); +lean_closure_set(x_70, 0, x_66); +lean_closure_set(x_70, 1, x_69); +lean_closure_set(x_70, 2, x_68); +x_71 = x_70; +x_72 = lean_apply_2(x_71, x_2, x_67); +return x_72; } else { -uint8_t x_65; -lean_dec(x_51); +uint8_t x_73; +lean_dec(x_58); lean_dec(x_2); -x_65 = !lean_is_exclusive(x_57); -if (x_65 == 0) +x_73 = !lean_is_exclusive(x_65); +if (x_73 == 0) +{ +return x_65; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_65, 0); +x_75 = lean_ctor_get(x_65, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_65); +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_2); +x_77 = !lean_is_exclusive(x_57); +if (x_77 == 0) { return x_57; } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_57, 0); -x_67 = lean_ctor_get(x_57, 1); -lean_inc(x_67); -lean_inc(x_66); +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_57, 0); +x_79 = lean_ctor_get(x_57, 1); +lean_inc(x_79); +lean_inc(x_78); lean_dec(x_57); -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_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_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_69 = l_Lean_Syntax_inhabited; -x_70 = lean_unsigned_to_nat(0u); -x_71 = lean_array_get(x_69, x_5, x_70); -x_72 = l_Lean_Syntax_getArgs(x_71); -lean_dec(x_71); -x_73 = l_Lean_mkHole(x_1); -x_74 = x_72; -x_75 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3___boxed), 5, 3); -lean_closure_set(x_75, 0, x_73); -lean_closure_set(x_75, 1, x_70); -lean_closure_set(x_75, 2, x_74); -x_76 = x_75; -x_77 = lean_apply_2(x_76, x_2, x_3); -return x_77; -} +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_81 = l_Lean_Syntax_inhabited; +x_82 = lean_unsigned_to_nat(0u); +x_83 = lean_array_get(x_81, x_5, x_82); +lean_inc(x_2); +x_84 = l___private_Init_Lean_Elab_Binders_5__getBinderIds(x_83, x_2, x_3); +lean_dec(x_83); +if (lean_obj_tag(x_84) == 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; +x_85 = lean_ctor_get(x_84, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_84, 1); +lean_inc(x_86); +lean_dec(x_84); +x_87 = l_Lean_mkHole(x_1); +x_88 = x_85; +x_89 = lean_alloc_closure((void*)(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3___boxed), 5, 3); +lean_closure_set(x_89, 0, x_87); +lean_closure_set(x_89, 1, x_82); +lean_closure_set(x_89, 2, x_88); +x_90 = x_89; +x_91 = lean_apply_2(x_90, x_2, x_86); +return x_91; } else { -lean_object* x_78; +uint8_t x_92; lean_dec(x_2); -x_78 = l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(x_3); -return x_78; +x_92 = !lean_is_exclusive(x_84); +if (x_92 == 0) +{ +return x_84; +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_84, 0); +x_94 = lean_ctor_get(x_84, 1); +lean_inc(x_94); +lean_inc(x_93); +lean_dec(x_84); +x_95 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_95, 0, x_93); +lean_ctor_set(x_95, 1, x_94); +return x_95; } } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +} +else +{ +lean_object* x_96; +lean_dec(x_2); +x_96 = l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(x_3); +return x_96; +} +} +} +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___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_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__1(x_1, x_2, x_3, x_4, x_5); +x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__1(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_6; } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___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_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__2(x_1, x_2, x_3, x_4, x_5); +x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__2(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_6; } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__matchBinder___spec__3(x_1, x_2, x_3, x_4, x_5); +x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_6__matchBinder___spec__3(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_6; } } -lean_object* l___private_Init_Lean_Elab_Binders_5__matchBinder___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Elab_Binders_6__matchBinder___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Elab_Binders_5__matchBinder(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Elab_Binders_6__matchBinder(x_1, x_2, x_3); lean_dec(x_1); return x_4; } } -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; uint8_t x_9; @@ -3518,33 +3858,33 @@ return x_147; } } } -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); return x_8; } } -lean_object* l___private_Init_Lean_Elab_Binders_6__elabBinderViews___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_7__elabBinderViews___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_6__elabBinderViews(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_7__elabBinderViews(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; uint8_t x_9; @@ -3572,7 +3912,7 @@ else lean_object* x_13; lean_object* x_14; x_13 = lean_array_fget(x_1, x_2); lean_inc(x_6); -x_14 = l___private_Init_Lean_Elab_Binders_5__matchBinder(x_13, x_6, x_7); +x_14 = l___private_Init_Lean_Elab_Binders_6__matchBinder(x_13, x_6, x_7); lean_dec(x_13); if (lean_obj_tag(x_14) == 0) { @@ -3584,7 +3924,7 @@ lean_inc(x_16); lean_dec(x_14); x_17 = lean_unsigned_to_nat(0u); lean_inc(x_6); -x_18 = l___private_Init_Lean_Elab_Binders_6__elabBinderViews___main(x_15, x_17, x_3, x_4, x_5, x_6, x_16); +x_18 = l___private_Init_Lean_Elab_Binders_7__elabBinderViews___main(x_15, x_17, x_3, x_4, x_5, x_6, x_16); lean_dec(x_15); if (lean_obj_tag(x_18) == 0) { @@ -3669,28 +4009,28 @@ return x_35; } } } -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_8__elabBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); return x_8; } } -lean_object* l___private_Init_Lean_Elab_Binders_7__elabBindersAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Elab_Binders_8__elabBindersAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Elab_Binders_7__elabBindersAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Elab_Binders_8__elabBindersAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_1); return x_8; } @@ -3719,7 +4059,7 @@ x_12 = lean_unsigned_to_nat(0u); x_13 = l_Array_empty___closed__1; lean_inc(x_3); lean_inc(x_10); -x_14 = l___private_Init_Lean_Elab_Binders_7__elabBindersAux___main(x_1, x_12, x_13, x_7, x_10, x_3, x_11); +x_14 = l___private_Init_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; @@ -3930,90 +4270,97 @@ return x_66; } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; +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_inc(x_80); lean_inc(x_79); lean_inc(x_78); lean_dec(x_69); -x_80 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -lean_ctor_set(x_80, 2, x_57); -lean_ctor_set(x_68, 2, x_80); +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_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_81 = lean_ctor_get(x_68, 0); -x_82 = lean_ctor_get(x_68, 1); -x_83 = lean_ctor_get(x_68, 3); -x_84 = lean_ctor_get(x_68, 4); -x_85 = lean_ctor_get(x_68, 5); +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +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_82); -lean_inc(x_81); lean_dec(x_68); -x_86 = lean_ctor_get(x_69, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_69, 1); +x_87 = lean_ctor_get(x_69, 0); lean_inc(x_87); +x_88 = lean_ctor_get(x_69, 1); +lean_inc(x_88); +x_89 = lean_ctor_get(x_69, 3); +lean_inc(x_89); if (lean_is_exclusive(x_69)) { lean_ctor_release(x_69, 0); lean_ctor_release(x_69, 1); lean_ctor_release(x_69, 2); - x_88 = x_69; + lean_ctor_release(x_69, 3); + x_90 = x_69; } else { lean_dec_ref(x_69); - x_88 = lean_box(0); + x_90 = lean_box(0); } -if (lean_is_scalar(x_88)) { - x_89 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 4, 0); } else { - x_89 = x_88; + x_91 = x_90; } -lean_ctor_set(x_89, 0, x_86); -lean_ctor_set(x_89, 1, x_87); -lean_ctor_set(x_89, 2, x_57); -x_90 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_90, 0, x_81); -lean_ctor_set(x_90, 1, x_82); -lean_ctor_set(x_90, 2, x_89); -lean_ctor_set(x_90, 3, x_83); -lean_ctor_set(x_90, 4, x_84); -lean_ctor_set(x_90, 5, x_85); -lean_ctor_set(x_67, 0, 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_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_67, 1); -x_92 = lean_ctor_get(x_67, 2); -x_93 = lean_ctor_get(x_67, 3); -x_94 = lean_ctor_get(x_67, 4); -x_95 = lean_ctor_get(x_67, 5); +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_93); -lean_inc(x_92); -lean_inc(x_91); lean_dec(x_67); -x_96 = lean_ctor_get(x_68, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_68, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_68, 3); +x_98 = lean_ctor_get(x_68, 0); lean_inc(x_98); -x_99 = lean_ctor_get(x_68, 4); +x_99 = lean_ctor_get(x_68, 1); lean_inc(x_99); -x_100 = lean_ctor_get(x_68, 5); +x_100 = lean_ctor_get(x_68, 3); lean_inc(x_100); +x_101 = lean_ctor_get(x_68, 4); +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); @@ -4021,70 +4368,74 @@ if (lean_is_exclusive(x_68)) { lean_ctor_release(x_68, 3); lean_ctor_release(x_68, 4); lean_ctor_release(x_68, 5); - x_101 = x_68; + x_103 = x_68; } else { lean_dec_ref(x_68); - x_101 = lean_box(0); + x_103 = lean_box(0); } -x_102 = lean_ctor_get(x_69, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_69, 1); -lean_inc(x_103); +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); - x_104 = x_69; + lean_ctor_release(x_69, 3); + x_107 = x_69; } else { lean_dec_ref(x_69); - x_104 = lean_box(0); + x_107 = lean_box(0); } -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_107)) { + x_108 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_104; + x_108 = x_107; } -lean_ctor_set(x_105, 0, x_102); -lean_ctor_set(x_105, 1, x_103); -lean_ctor_set(x_105, 2, x_57); -if (lean_is_scalar(x_101)) { - x_106 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_106 = x_101; + x_109 = x_103; } -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); -x_107 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_91); -lean_ctor_set(x_107, 2, x_92); -lean_ctor_set(x_107, 3, x_93); -lean_ctor_set(x_107, 4, x_94); -lean_ctor_set(x_107, 5, x_95); -lean_ctor_set(x_66, 1, x_107); +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; } } 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; lean_object* x_126; lean_object* x_127; -x_108 = lean_ctor_get(x_66, 0); -lean_inc(x_108); -lean_dec(x_66); -x_109 = lean_ctor_get(x_67, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_67, 2); -lean_inc(x_110); -x_111 = lean_ctor_get(x_67, 3); +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); -x_112 = lean_ctor_get(x_67, 4); +lean_dec(x_66); +x_112 = lean_ctor_get(x_67, 1); lean_inc(x_112); -x_113 = lean_ctor_get(x_67, 5); +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); @@ -4092,21 +4443,21 @@ if (lean_is_exclusive(x_67)) { lean_ctor_release(x_67, 3); lean_ctor_release(x_67, 4); lean_ctor_release(x_67, 5); - x_114 = x_67; + x_117 = x_67; } else { lean_dec_ref(x_67); - x_114 = lean_box(0); + x_117 = lean_box(0); } -x_115 = lean_ctor_get(x_68, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_68, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_68, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_68, 4); +x_118 = lean_ctor_get(x_68, 0); lean_inc(x_118); -x_119 = lean_ctor_get(x_68, 5); +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); @@ -4114,919 +4465,954 @@ if (lean_is_exclusive(x_68)) { lean_ctor_release(x_68, 3); lean_ctor_release(x_68, 4); lean_ctor_release(x_68, 5); - x_120 = x_68; + x_123 = x_68; } else { lean_dec_ref(x_68); - x_120 = lean_box(0); + x_123 = lean_box(0); } -x_121 = lean_ctor_get(x_69, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_69, 1); -lean_inc(x_122); +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); - x_123 = x_69; + lean_ctor_release(x_69, 3); + x_127 = x_69; } else { lean_dec_ref(x_69); - x_123 = lean_box(0); + 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_124 = lean_alloc_ctor(0, 3, 0); + x_129 = lean_alloc_ctor(0, 6, 0); } else { - x_124 = x_123; + x_129 = x_123; } -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_122); -lean_ctor_set(x_124, 2, x_57); -if (lean_is_scalar(x_120)) { - x_125 = 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); +if (lean_is_scalar(x_117)) { + x_130 = lean_alloc_ctor(0, 6, 0); } else { - x_125 = x_120; + x_130 = x_117; } -lean_ctor_set(x_125, 0, x_115); -lean_ctor_set(x_125, 1, x_116); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_117); -lean_ctor_set(x_125, 4, x_118); -lean_ctor_set(x_125, 5, x_119); -if (lean_is_scalar(x_114)) { - x_126 = lean_alloc_ctor(0, 6, 0); -} else { - x_126 = x_114; -} -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_109); -lean_ctor_set(x_126, 2, x_110); -lean_ctor_set(x_126, 3, x_111); -lean_ctor_set(x_126, 4, x_112); -lean_ctor_set(x_126, 5, x_113); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_108); -lean_ctor_set(x_127, 1, x_126); -return x_127; +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_128; lean_object* x_129; lean_object* x_130; uint8_t x_131; -x_128 = lean_ctor_get(x_66, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_129, 2); -lean_inc(x_130); -x_131 = !lean_is_exclusive(x_66); -if (x_131 == 0) -{ -lean_object* x_132; uint8_t x_133; +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_dec(x_132); -x_133 = !lean_is_exclusive(x_128); -if (x_133 == 0) -{ -lean_object* x_134; uint8_t x_135; -x_134 = lean_ctor_get(x_128, 0); -lean_dec(x_134); -x_135 = !lean_is_exclusive(x_129); +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_129, 2); +x_136 = lean_ctor_get(x_66, 1); lean_dec(x_136); -x_137 = !lean_is_exclusive(x_130); +x_137 = !lean_is_exclusive(x_132); if (x_137 == 0) { -lean_object* x_138; -x_138 = lean_ctor_get(x_130, 2); +lean_object* x_138; uint8_t x_139; +x_138 = lean_ctor_get(x_132, 0); lean_dec(x_138); -lean_ctor_set(x_130, 2, x_57); +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_139; lean_object* x_140; lean_object* x_141; -x_139 = lean_ctor_get(x_130, 0); -x_140 = lean_ctor_get(x_130, 1); -lean_inc(x_140); -lean_inc(x_139); -lean_dec(x_130); -x_141 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_141, 0, x_139); -lean_ctor_set(x_141, 1, x_140); -lean_ctor_set(x_141, 2, x_57); -lean_ctor_set(x_129, 2, x_141); -return x_66; -} -} -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; -x_142 = lean_ctor_get(x_129, 0); -x_143 = lean_ctor_get(x_129, 1); -x_144 = lean_ctor_get(x_129, 3); -x_145 = lean_ctor_get(x_129, 4); -x_146 = lean_ctor_get(x_129, 5); -lean_inc(x_146); +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_inc(x_142); -lean_dec(x_129); -x_147 = lean_ctor_get(x_130, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_130, 1); +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); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - x_149 = x_130; -} else { - lean_dec_ref(x_130); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 3, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_147); -lean_ctor_set(x_150, 1, x_148); -lean_ctor_set(x_150, 2, x_57); -x_151 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_151, 0, x_142); -lean_ctor_set(x_151, 1, x_143); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_144); -lean_ctor_set(x_151, 4, x_145); -lean_ctor_set(x_151, 5, x_146); -lean_ctor_set(x_128, 0, x_151); -return x_66; -} -} -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_128, 1); -x_153 = lean_ctor_get(x_128, 2); -x_154 = lean_ctor_get(x_128, 3); -x_155 = lean_ctor_get(x_128, 4); -x_156 = lean_ctor_get(x_128, 5); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); +lean_inc(x_147); +lean_dec(x_133); +x_152 = lean_ctor_get(x_134, 0); lean_inc(x_152); -lean_dec(x_128); -x_157 = lean_ctor_get(x_129, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_129, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_129, 3); -lean_inc(x_159); -x_160 = lean_ctor_get(x_129, 4); -lean_inc(x_160); -x_161 = lean_ctor_get(x_129, 5); -lean_inc(x_161); -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_162 = x_129; +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_129); - x_162 = lean_box(0); + lean_dec_ref(x_134); + x_155 = lean_box(0); } -x_163 = lean_ctor_get(x_130, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_130, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - x_165 = x_130; +if (lean_is_scalar(x_155)) { + x_156 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_130); - x_165 = lean_box(0); + x_156 = x_155; } -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(0, 3, 0); -} else { - x_166 = x_165; -} -lean_ctor_set(x_166, 0, x_163); -lean_ctor_set(x_166, 1, x_164); -lean_ctor_set(x_166, 2, x_57); -if (lean_is_scalar(x_162)) { - x_167 = lean_alloc_ctor(0, 6, 0); -} else { - x_167 = x_162; -} -lean_ctor_set(x_167, 0, x_157); -lean_ctor_set(x_167, 1, x_158); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_159); -lean_ctor_set(x_167, 4, x_160); -lean_ctor_set(x_167, 5, x_161); -x_168 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_168, 0, x_167); -lean_ctor_set(x_168, 1, x_152); -lean_ctor_set(x_168, 2, x_153); -lean_ctor_set(x_168, 3, x_154); -lean_ctor_set(x_168, 4, x_155); -lean_ctor_set(x_168, 5, x_156); -lean_ctor_set(x_66, 1, x_168); +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_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; -x_169 = lean_ctor_get(x_66, 0); +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); -lean_dec(x_66); -x_170 = lean_ctor_get(x_128, 1); +x_170 = lean_ctor_get(x_134, 1); lean_inc(x_170); -x_171 = lean_ctor_get(x_128, 2); +x_171 = lean_ctor_get(x_134, 3); lean_inc(x_171); -x_172 = lean_ctor_get(x_128, 3); -lean_inc(x_172); -x_173 = lean_ctor_get(x_128, 4); -lean_inc(x_173); -x_174 = lean_ctor_get(x_128, 5); -lean_inc(x_174); -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_175 = x_128; +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_128); - x_175 = lean_box(0); + lean_dec_ref(x_134); + x_172 = lean_box(0); } -x_176 = lean_ctor_get(x_129, 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); -x_177 = lean_ctor_get(x_129, 1); +lean_dec(x_66); +x_177 = lean_ctor_get(x_132, 1); lean_inc(x_177); -x_178 = lean_ctor_get(x_129, 3); +x_178 = lean_ctor_get(x_132, 2); lean_inc(x_178); -x_179 = lean_ctor_get(x_129, 4); +x_179 = lean_ctor_get(x_132, 3); lean_inc(x_179); -x_180 = lean_ctor_get(x_129, 5); +x_180 = lean_ctor_get(x_132, 4); lean_inc(x_180); -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_181 = x_129; +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_129); - x_181 = lean_box(0); + lean_dec_ref(x_132); + x_182 = lean_box(0); } -x_182 = lean_ctor_get(x_130, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_130, 1); +x_183 = lean_ctor_get(x_133, 0); lean_inc(x_183); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - x_184 = x_130; +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_130); - x_184 = lean_box(0); + lean_dec_ref(x_133); + x_188 = lean_box(0); } -if (lean_is_scalar(x_184)) { - x_185 = lean_alloc_ctor(0, 3, 0); -} else { - x_185 = x_184; -} -lean_ctor_set(x_185, 0, x_182); -lean_ctor_set(x_185, 1, x_183); -lean_ctor_set(x_185, 2, x_57); -if (lean_is_scalar(x_181)) { - x_186 = lean_alloc_ctor(0, 6, 0); -} else { - x_186 = x_181; -} -lean_ctor_set(x_186, 0, x_176); -lean_ctor_set(x_186, 1, x_177); -lean_ctor_set(x_186, 2, x_185); -lean_ctor_set(x_186, 3, x_178); -lean_ctor_set(x_186, 4, x_179); -lean_ctor_set(x_186, 5, x_180); -if (lean_is_scalar(x_175)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_175; -} -lean_ctor_set(x_187, 0, x_186); -lean_ctor_set(x_187, 1, x_170); -lean_ctor_set(x_187, 2, x_171); -lean_ctor_set(x_187, 3, x_172); -lean_ctor_set(x_187, 4, x_173); -lean_ctor_set(x_187, 5, x_174); -x_188 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_188, 0, x_169); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -} -} -else -{ -lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; -x_189 = lean_ctor_get(x_59, 0); -x_190 = lean_ctor_get(x_59, 3); -x_191 = lean_ctor_get(x_59, 4); -lean_inc(x_191); -lean_inc(x_190); +x_189 = lean_ctor_get(x_134, 0); lean_inc(x_189); -lean_dec(x_59); -x_192 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_19); -lean_ctor_set(x_192, 2, x_20); -lean_ctor_set(x_192, 3, x_190); -lean_ctor_set(x_192, 4, x_191); -lean_ctor_set(x_3, 0, x_192); -x_193 = lean_apply_3(x_2, x_18, x_3, x_60); -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; -x_194 = lean_ctor_get(x_193, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_194, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_195, 2); -lean_inc(x_196); -x_197 = lean_ctor_get(x_193, 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; +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_193); - x_198 = lean_box(0); + lean_dec_ref(x_134); + x_192 = lean_box(0); } -x_199 = lean_ctor_get(x_194, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_194, 2); -lean_inc(x_200); -x_201 = lean_ctor_get(x_194, 3); -lean_inc(x_201); -x_202 = lean_ctor_get(x_194, 4); -lean_inc(x_202); -x_203 = lean_ctor_get(x_194, 5); -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; +if (lean_is_scalar(x_192)) { + x_193 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_194); - x_204 = lean_box(0); + x_193 = x_192; } -x_205 = lean_ctor_get(x_195, 0); -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; +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 { - lean_dec_ref(x_195); - x_210 = lean_box(0); + x_194 = x_188; } -x_211 = lean_ctor_get(x_196, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_196, 1); -lean_inc(x_212); -if (lean_is_exclusive(x_196)) { - lean_ctor_release(x_196, 0); - lean_ctor_release(x_196, 1); - lean_ctor_release(x_196, 2); - x_213 = x_196; +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 { - lean_dec_ref(x_196); - x_213 = lean_box(0); + x_195 = x_182; } -if (lean_is_scalar(x_213)) { - x_214 = lean_alloc_ctor(0, 3, 0); -} else { - x_214 = x_213; +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; } -lean_ctor_set(x_214, 0, x_211); -lean_ctor_set(x_214, 1, x_212); -lean_ctor_set(x_214, 2, x_57); -if (lean_is_scalar(x_210)) { - x_215 = lean_alloc_ctor(0, 6, 0); -} else { - x_215 = x_210; } -lean_ctor_set(x_215, 0, x_205); -lean_ctor_set(x_215, 1, x_206); -lean_ctor_set(x_215, 2, x_214); -lean_ctor_set(x_215, 3, x_207); -lean_ctor_set(x_215, 4, x_208); -lean_ctor_set(x_215, 5, x_209); -if (lean_is_scalar(x_204)) { - x_216 = lean_alloc_ctor(0, 6, 0); -} else { - x_216 = x_204; -} -lean_ctor_set(x_216, 0, x_215); -lean_ctor_set(x_216, 1, x_199); -lean_ctor_set(x_216, 2, x_200); -lean_ctor_set(x_216, 3, x_201); -lean_ctor_set(x_216, 4, x_202); -lean_ctor_set(x_216, 5, x_203); -if (lean_is_scalar(x_198)) { - x_217 = lean_alloc_ctor(0, 2, 0); -} else { - x_217 = x_198; -} -lean_ctor_set(x_217, 0, x_197); -lean_ctor_set(x_217, 1, x_216); -return x_217; } else { -lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; -x_218 = lean_ctor_get(x_193, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_219, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_193, 0); -lean_inc(x_221); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - x_222 = x_193; +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_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) +{ +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; } else { - lean_dec_ref(x_193); + lean_dec_ref(x_201); + x_206 = lean_box(0); +} +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); } -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 3); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 4); -lean_inc(x_226); -x_227 = lean_ctor_get(x_218, 5); +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; +} +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); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_228 = x_218; -} else { - lean_dec_ref(x_218); - x_228 = lean_box(0); -} -x_229 = lean_ctor_get(x_219, 0); +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_219, 1); +x_230 = lean_ctor_get(x_201, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_219, 3); -lean_inc(x_231); -x_232 = lean_ctor_get(x_219, 4); -lean_inc(x_232); -x_233 = lean_ctor_get(x_219, 5); -lean_inc(x_233); -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_234 = x_219; +if (lean_is_exclusive(x_201)) { + lean_ctor_release(x_201, 0); + lean_ctor_release(x_201, 1); + x_231 = x_201; } else { - lean_dec_ref(x_219); - x_234 = lean_box(0); + lean_dec_ref(x_201); + x_231 = lean_box(0); } -x_235 = lean_ctor_get(x_220, 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_220, 1); +x_236 = lean_ctor_get(x_227, 5); lean_inc(x_236); -if (lean_is_exclusive(x_220)) { - lean_ctor_release(x_220, 0); - lean_ctor_release(x_220, 1); - lean_ctor_release(x_220, 2); - x_237 = x_220; +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_220); + 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_238 = lean_alloc_ctor(0, 3, 0); + x_250 = lean_alloc_ctor(0, 6, 0); } else { - x_238 = x_237; + x_250 = x_237; } -lean_ctor_set(x_238, 0, x_235); -lean_ctor_set(x_238, 1, x_236); -lean_ctor_set(x_238, 2, x_57); -if (lean_is_scalar(x_234)) { - x_239 = lean_alloc_ctor(0, 6, 0); +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_239 = x_234; + x_251 = x_231; } -lean_ctor_set(x_239, 0, x_229); -lean_ctor_set(x_239, 1, x_230); -lean_ctor_set(x_239, 2, x_238); -lean_ctor_set(x_239, 3, x_231); -lean_ctor_set(x_239, 4, x_232); -lean_ctor_set(x_239, 5, x_233); -if (lean_is_scalar(x_228)) { - x_240 = lean_alloc_ctor(0, 6, 0); -} else { - x_240 = x_228; -} -lean_ctor_set(x_240, 0, x_239); -lean_ctor_set(x_240, 1, x_223); -lean_ctor_set(x_240, 2, x_224); -lean_ctor_set(x_240, 3, x_225); -lean_ctor_set(x_240, 4, x_226); -lean_ctor_set(x_240, 5, x_227); -if (lean_is_scalar(x_222)) { - x_241 = lean_alloc_ctor(1, 2, 0); -} else { - x_241 = x_222; -} -lean_ctor_set(x_241, 0, x_221); -lean_ctor_set(x_241, 1, x_240); -return x_241; +lean_ctor_set(x_251, 0, x_230); +lean_ctor_set(x_251, 1, x_250); +return x_251; } } } else { -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; uint8_t x_251; uint8_t x_252; uint8_t x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; -x_242 = lean_ctor_get(x_3, 1); -x_243 = lean_ctor_get(x_3, 2); -x_244 = lean_ctor_get(x_3, 3); -x_245 = lean_ctor_get(x_3, 4); -x_246 = lean_ctor_get(x_3, 5); -x_247 = lean_ctor_get(x_3, 6); -x_248 = lean_ctor_get(x_3, 7); -x_249 = lean_ctor_get(x_3, 8); -x_250 = lean_ctor_get(x_3, 9); -x_251 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_252 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_253 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -lean_inc(x_250); -lean_inc(x_249); -lean_inc(x_248); -lean_inc(x_247); -lean_inc(x_246); -lean_inc(x_245); -lean_inc(x_244); -lean_inc(x_243); -lean_inc(x_242); -lean_dec(x_3); -x_254 = lean_ctor_get(x_59, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_59, 3); -lean_inc(x_255); -x_256 = lean_ctor_get(x_59, 4); +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_257 = x_59; + x_267 = x_59; } else { lean_dec_ref(x_59); - x_257 = lean_box(0); + x_267 = lean_box(0); } -if (lean_is_scalar(x_257)) { - x_258 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_267)) { + x_268 = lean_alloc_ctor(0, 5, 0); } else { - x_258 = x_257; + x_268 = x_267; } -lean_ctor_set(x_258, 0, x_254); -lean_ctor_set(x_258, 1, x_19); -lean_ctor_set(x_258, 2, x_20); -lean_ctor_set(x_258, 3, x_255); -lean_ctor_set(x_258, 4, x_256); -x_259 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_259, 0, x_258); -lean_ctor_set(x_259, 1, x_242); -lean_ctor_set(x_259, 2, x_243); -lean_ctor_set(x_259, 3, x_244); -lean_ctor_set(x_259, 4, x_245); -lean_ctor_set(x_259, 5, x_246); -lean_ctor_set(x_259, 6, x_247); -lean_ctor_set(x_259, 7, x_248); -lean_ctor_set(x_259, 8, x_249); -lean_ctor_set(x_259, 9, x_250); -lean_ctor_set_uint8(x_259, sizeof(void*)*10, x_251); -lean_ctor_set_uint8(x_259, sizeof(void*)*10 + 1, x_252); -lean_ctor_set_uint8(x_259, sizeof(void*)*10 + 2, x_253); -x_260 = lean_apply_3(x_2, x_18, x_259, x_60); -if (lean_obj_tag(x_260) == 0) +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_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_261 = lean_ctor_get(x_260, 1); -lean_inc(x_261); -x_262 = lean_ctor_get(x_261, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_262, 2); -lean_inc(x_263); -x_264 = lean_ctor_get(x_260, 0); -lean_inc(x_264); -if (lean_is_exclusive(x_260)) { - lean_ctor_release(x_260, 0); - lean_ctor_release(x_260, 1); - x_265 = x_260; -} else { - lean_dec_ref(x_260); - x_265 = lean_box(0); -} -x_266 = lean_ctor_get(x_261, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_261, 2); -lean_inc(x_267); -x_268 = lean_ctor_get(x_261, 3); -lean_inc(x_268); -x_269 = lean_ctor_get(x_261, 4); -lean_inc(x_269); -x_270 = lean_ctor_get(x_261, 5); -lean_inc(x_270); -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_271 = x_261; -} else { - lean_dec_ref(x_261); - x_271 = lean_box(0); -} -x_272 = lean_ctor_get(x_262, 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_262, 1); +x_273 = lean_ctor_get(x_272, 2); lean_inc(x_273); -x_274 = lean_ctor_get(x_262, 3); +x_274 = lean_ctor_get(x_270, 0); lean_inc(x_274); -x_275 = lean_ctor_get(x_262, 4); -lean_inc(x_275); -x_276 = lean_ctor_get(x_262, 5); +if (lean_is_exclusive(x_270)) { + lean_ctor_release(x_270, 0); + lean_ctor_release(x_270, 1); + x_275 = x_270; +} else { + lean_dec_ref(x_270); + x_275 = lean_box(0); +} +x_276 = lean_ctor_get(x_271, 1); lean_inc(x_276); -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_277 = x_262; -} else { - lean_dec_ref(x_262); - x_277 = lean_box(0); -} -x_278 = lean_ctor_get(x_263, 0); +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_263, 1); +x_279 = lean_ctor_get(x_271, 4); lean_inc(x_279); -if (lean_is_exclusive(x_263)) { - lean_ctor_release(x_263, 0); - lean_ctor_release(x_263, 1); - lean_ctor_release(x_263, 2); - x_280 = x_263; +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_263); - x_280 = lean_box(0); + lean_dec_ref(x_271); + x_281 = lean_box(0); } -if (lean_is_scalar(x_280)) { - x_281 = lean_alloc_ctor(0, 3, 0); -} else { - x_281 = x_280; -} -lean_ctor_set(x_281, 0, x_278); -lean_ctor_set(x_281, 1, x_279); -lean_ctor_set(x_281, 2, x_57); -if (lean_is_scalar(x_277)) { - x_282 = lean_alloc_ctor(0, 6, 0); -} else { - x_282 = x_277; -} -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_273); -lean_ctor_set(x_282, 2, x_281); -lean_ctor_set(x_282, 3, x_274); -lean_ctor_set(x_282, 4, x_275); -lean_ctor_set(x_282, 5, x_276); -if (lean_is_scalar(x_271)) { - x_283 = lean_alloc_ctor(0, 6, 0); -} else { - x_283 = x_271; -} -lean_ctor_set(x_283, 0, x_282); -lean_ctor_set(x_283, 1, x_266); -lean_ctor_set(x_283, 2, x_267); -lean_ctor_set(x_283, 3, x_268); -lean_ctor_set(x_283, 4, x_269); -lean_ctor_set(x_283, 5, x_270); -if (lean_is_scalar(x_265)) { - x_284 = lean_alloc_ctor(0, 2, 0); -} else { - x_284 = x_265; -} -lean_ctor_set(x_284, 0, x_264); -lean_ctor_set(x_284, 1, x_283); -return x_284; -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; 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_285 = lean_ctor_get(x_260, 1); +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_285, 0); +x_286 = lean_ctor_get(x_272, 5); lean_inc(x_286); -x_287 = lean_ctor_get(x_286, 2); -lean_inc(x_287); -x_288 = lean_ctor_get(x_260, 0); +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); -if (lean_is_exclusive(x_260)) { - lean_ctor_release(x_260, 0); - lean_ctor_release(x_260, 1); - x_289 = x_260; -} else { - lean_dec_ref(x_260); - x_289 = lean_box(0); -} -x_290 = lean_ctor_get(x_285, 1); +x_289 = lean_ctor_get(x_273, 1); +lean_inc(x_289); +x_290 = lean_ctor_get(x_273, 3); lean_inc(x_290); -x_291 = lean_ctor_get(x_285, 2); -lean_inc(x_291); -x_292 = lean_ctor_get(x_285, 3); -lean_inc(x_292); -x_293 = lean_ctor_get(x_285, 4); -lean_inc(x_293); -x_294 = lean_ctor_get(x_285, 5); -lean_inc(x_294); -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_295 = x_285; +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_285); - x_295 = lean_box(0); + lean_dec_ref(x_273); + x_291 = lean_box(0); } -x_296 = lean_ctor_get(x_286, 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_286, 1); +x_297 = lean_ctor_get(x_296, 0); lean_inc(x_297); -x_298 = lean_ctor_get(x_286, 3); +x_298 = lean_ctor_get(x_297, 2); lean_inc(x_298); -x_299 = lean_ctor_get(x_286, 4); +x_299 = lean_ctor_get(x_270, 0); lean_inc(x_299); -x_300 = lean_ctor_get(x_286, 5); -lean_inc(x_300); -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_301 = x_286; +if (lean_is_exclusive(x_270)) { + lean_ctor_release(x_270, 0); + lean_ctor_release(x_270, 1); + x_300 = x_270; } else { - lean_dec_ref(x_286); - x_301 = lean_box(0); + lean_dec_ref(x_270); + x_300 = lean_box(0); } -x_302 = lean_ctor_get(x_287, 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_287, 1); +x_303 = lean_ctor_get(x_296, 3); lean_inc(x_303); -if (lean_is_exclusive(x_287)) { - lean_ctor_release(x_287, 0); - lean_ctor_release(x_287, 1); - lean_ctor_release(x_287, 2); - x_304 = x_287; +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; } else { - lean_dec_ref(x_287); - x_304 = lean_box(0); + lean_dec_ref(x_296); + x_306 = lean_box(0); } -if (lean_is_scalar(x_304)) { - x_305 = lean_alloc_ctor(0, 3, 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; } else { - x_305 = x_304; + lean_dec_ref(x_297); + x_312 = lean_box(0); } -lean_ctor_set(x_305, 0, x_302); -lean_ctor_set(x_305, 1, x_303); -lean_ctor_set(x_305, 2, x_57); -if (lean_is_scalar(x_301)) { - x_306 = lean_alloc_ctor(0, 6, 0); +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; } else { - x_306 = x_301; + lean_dec_ref(x_298); + x_316 = lean_box(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); -if (lean_is_scalar(x_295)) { - x_307 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_316)) { + x_317 = lean_alloc_ctor(0, 4, 0); } else { - x_307 = x_295; + x_317 = x_316; } -lean_ctor_set(x_307, 0, x_306); -lean_ctor_set(x_307, 1, x_290); -lean_ctor_set(x_307, 2, x_291); -lean_ctor_set(x_307, 3, x_292); -lean_ctor_set(x_307, 4, x_293); -lean_ctor_set(x_307, 5, x_294); -if (lean_is_scalar(x_289)) { - x_308 = lean_alloc_ctor(1, 2, 0); +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_308 = x_289; + x_318 = x_312; } -lean_ctor_set(x_308, 0, x_288); -lean_ctor_set(x_308, 1, x_307); -return x_308; +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_309; +uint8_t x_321; lean_dec(x_10); lean_dec(x_3); lean_dec(x_2); -x_309 = !lean_is_exclusive(x_14); -if (x_309 == 0) +x_321 = !lean_is_exclusive(x_14); +if (x_321 == 0) { return x_14; } else { -lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_310 = lean_ctor_get(x_14, 0); -x_311 = lean_ctor_get(x_14, 1); -lean_inc(x_311); -lean_inc(x_310); +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_dec(x_14); -x_312 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_312, 0, x_310); -lean_ctor_set(x_312, 1, x_311); -return x_312; +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; } } } else { -lean_object* x_313; lean_object* x_314; -x_313 = l_Array_empty___closed__1; -x_314 = lean_apply_3(x_2, x_313, x_3, x_4); -return x_314; +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; } } } @@ -5531,7 +5917,7 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(uint8_t 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_95; uint8_t x_96; @@ -5824,7 +6210,7 @@ lean_object* x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; x_80 = l_Lean_Syntax_getArg(x_50, x_47); lean_dec(x_50); x_81 = 0; -x_82 = l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(x_81, x_48, x_3, x_4, x_5); +x_82 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(x_81, x_48, x_3, x_4, x_5); x_83 = lean_ctor_get(x_82, 0); lean_inc(x_83); if (lean_obj_tag(x_83) == 0) @@ -5886,56 +6272,56 @@ return x_93; } } } -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; lean_object* x_7; x_6 = lean_unbox(x_1); lean_dec(x_1); -x_7 = l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(x_6, x_2, x_3, x_4, x_5); +x_7 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(x_6, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_7; } } -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(x_1, x_2, x_3, x_4, x_5); return x_6; } } -lean_object* l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; lean_object* x_7; x_6 = lean_unbox(x_1); lean_dec(x_1); -x_7 = l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f(x_6, x_2, x_3, x_4, x_5); +x_7 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f(x_6, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_7; } } -lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { uint8_t x_4; lean_object* x_5; lean_object* x_6; x_4 = 0; x_5 = l_Array_empty___closed__1; -x_6 = l___private_Init_Lean_Elab_Binders_8__getFunBinderIdsAux_x3f___main(x_4, x_1, x_5, x_2, x_3); +x_6 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIdsAux_x3f___main(x_4, x_1, x_5, x_2, x_3); return x_6; } } -lean_object* l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_1, x_2, x_3); lean_dec(x_2); return x_4; } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_5; @@ -5968,7 +6354,7 @@ goto _start; } } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -5980,17 +6366,17 @@ lean_ctor_set(x_3, 1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Array_empty___closed__1; -x_2 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1; +x_2 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1; x_3 = lean_array_push(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3() { _start: { lean_object* x_1; @@ -5998,19 +6384,19 @@ x_1 = lean_mk_string("with"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3; +x_2 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3; x_3 = lean_alloc_ctor(2, 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___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -6022,29 +6408,29 @@ lean_ctor_set(x_3, 1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Array_empty___closed__1; -x_2 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_2 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_3 = lean_array_push(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_nullKind___closed__2; -x_2 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6; +x_2 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6; x_3 = lean_alloc_ctor(1, 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___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8() { _start: { lean_object* x_1; @@ -6052,27 +6438,27 @@ x_1 = lean_mk_string("invalid binder, simple identifier expected"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8; +x_1 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9; +x_1 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___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* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___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; @@ -6189,7 +6575,7 @@ lean_inc(x_35); x_40 = l_Lean_Elab_Term_mkExplicitBinder(x_35, x_39); x_41 = lean_array_push(x_4, x_40); lean_inc(x_5); -x_42 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_38, x_41, x_5, x_36); +x_42 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_38, x_41, x_5, x_36); if (lean_obj_tag(x_42) == 0) { lean_object* x_43; lean_object* x_44; uint8_t x_45; @@ -6228,12 +6614,12 @@ x_59 = l_Lean_nullKind___closed__2; x_60 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_60, 0, x_59); lean_ctor_set(x_60, 1, x_58); -x_61 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_61 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_62 = lean_array_push(x_61, x_60); x_63 = lean_array_push(x_62, x_54); -x_64 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_64 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_65 = lean_array_push(x_63, x_64); -x_66 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_66 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_67 = lean_array_push(x_65, x_66); lean_inc(x_11); x_68 = lean_array_push(x_52, x_11); @@ -6316,12 +6702,12 @@ x_103 = l_Lean_nullKind___closed__2; x_104 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_104, 0, x_103); lean_ctor_set(x_104, 1, x_102); -x_105 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_105 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_106 = lean_array_push(x_105, x_104); x_107 = lean_array_push(x_106, x_98); -x_108 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_108 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_109 = lean_array_push(x_107, x_108); -x_110 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_110 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_111 = lean_array_push(x_109, x_110); lean_inc(x_11); x_112 = lean_array_push(x_96, x_11); @@ -6401,12 +6787,12 @@ x_141 = l_Lean_nullKind___closed__2; x_142 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_142, 0, x_141); lean_ctor_set(x_142, 1, x_140); -x_143 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_143 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_144 = lean_array_push(x_143, x_142); x_145 = lean_array_push(x_144, x_136); -x_146 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_146 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_147 = lean_array_push(x_145, x_146); -x_148 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_148 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_149 = lean_array_push(x_147, x_148); lean_inc(x_11); x_150 = lean_array_push(x_134, x_11); @@ -6501,7 +6887,7 @@ lean_dec(x_171); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_174 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_174 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_175 = l_Lean_Elab_Term_throwError___rarg(x_11, x_174, x_5, x_6); lean_dec(x_11); x_176 = !lean_is_exclusive(x_175); @@ -6572,7 +6958,7 @@ lean_inc(x_192); x_197 = l_Lean_Elab_Term_mkExplicitBinder(x_192, x_196); x_198 = lean_array_push(x_4, x_197); lean_inc(x_5); -x_199 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_195, x_198, x_5, x_193); +x_199 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_195, x_198, x_5, x_193); if (lean_obj_tag(x_199) == 0) { lean_object* x_200; lean_object* x_201; uint8_t x_202; @@ -6611,12 +6997,12 @@ x_216 = l_Lean_nullKind___closed__2; x_217 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_217, 0, x_216); lean_ctor_set(x_217, 1, x_215); -x_218 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_218 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_219 = lean_array_push(x_218, x_217); x_220 = lean_array_push(x_219, x_211); -x_221 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_221 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_222 = lean_array_push(x_220, x_221); -x_223 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_223 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_224 = lean_array_push(x_222, x_223); lean_inc(x_11); x_225 = lean_array_push(x_209, x_11); @@ -6699,12 +7085,12 @@ x_260 = l_Lean_nullKind___closed__2; x_261 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_261, 0, x_260); lean_ctor_set(x_261, 1, x_259); -x_262 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_262 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_263 = lean_array_push(x_262, x_261); x_264 = lean_array_push(x_263, x_255); -x_265 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_265 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_266 = lean_array_push(x_264, x_265); -x_267 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_267 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_268 = lean_array_push(x_266, x_267); lean_inc(x_11); x_269 = lean_array_push(x_253, x_11); @@ -6784,12 +7170,12 @@ x_298 = l_Lean_nullKind___closed__2; x_299 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_299, 0, x_298); lean_ctor_set(x_299, 1, x_297); -x_300 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_300 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_301 = lean_array_push(x_300, x_299); x_302 = lean_array_push(x_301, x_293); -x_303 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_303 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_304 = lean_array_push(x_302, x_303); -x_305 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_305 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_306 = lean_array_push(x_304, x_305); lean_inc(x_11); x_307 = lean_array_push(x_291, x_11); @@ -6885,7 +7271,7 @@ lean_dec(x_328); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_331 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_331 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_332 = l_Lean_Elab_Term_throwError___rarg(x_188, x_331, x_5, x_6); lean_dec(x_188); x_333 = !lean_is_exclusive(x_332); @@ -6958,7 +7344,7 @@ lean_inc(x_349); x_354 = l_Lean_Elab_Term_mkExplicitBinder(x_349, x_353); x_355 = lean_array_push(x_4, x_354); lean_inc(x_5); -x_356 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_352, x_355, x_5, x_350); +x_356 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_352, x_355, x_5, x_350); if (lean_obj_tag(x_356) == 0) { lean_object* x_357; lean_object* x_358; uint8_t x_359; @@ -6997,12 +7383,12 @@ x_373 = l_Lean_nullKind___closed__2; x_374 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_374, 0, x_373); lean_ctor_set(x_374, 1, x_372); -x_375 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_375 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_376 = lean_array_push(x_375, x_374); x_377 = lean_array_push(x_376, x_368); -x_378 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_378 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_379 = lean_array_push(x_377, x_378); -x_380 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_380 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_381 = lean_array_push(x_379, x_380); lean_inc(x_11); x_382 = lean_array_push(x_366, x_11); @@ -7085,12 +7471,12 @@ x_417 = l_Lean_nullKind___closed__2; x_418 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_418, 0, x_417); lean_ctor_set(x_418, 1, x_416); -x_419 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_419 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_420 = lean_array_push(x_419, x_418); x_421 = lean_array_push(x_420, x_412); -x_422 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_422 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_423 = lean_array_push(x_421, x_422); -x_424 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_424 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_425 = lean_array_push(x_423, x_424); lean_inc(x_11); x_426 = lean_array_push(x_410, x_11); @@ -7170,12 +7556,12 @@ x_455 = l_Lean_nullKind___closed__2; x_456 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_456, 0, x_455); lean_ctor_set(x_456, 1, x_454); -x_457 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_457 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_458 = lean_array_push(x_457, x_456); x_459 = lean_array_push(x_458, x_450); -x_460 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_460 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_461 = lean_array_push(x_459, x_460); -x_462 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_462 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_463 = lean_array_push(x_461, x_462); lean_inc(x_11); x_464 = lean_array_push(x_448, x_11); @@ -7271,7 +7657,7 @@ lean_dec(x_485); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_488 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_488 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_489 = l_Lean_Elab_Term_throwError___rarg(x_345, x_488, x_5, x_6); lean_dec(x_345); x_490 = !lean_is_exclusive(x_489); @@ -7360,7 +7746,7 @@ lean_inc(x_512); x_517 = l_Lean_Elab_Term_mkExplicitBinder(x_512, x_516); x_518 = lean_array_push(x_4, x_517); lean_inc(x_5); -x_519 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_515, x_518, x_5, x_513); +x_519 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_515, x_518, x_5, x_513); if (lean_obj_tag(x_519) == 0) { lean_object* x_520; lean_object* x_521; uint8_t x_522; @@ -7399,12 +7785,12 @@ x_536 = l_Lean_nullKind___closed__2; x_537 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_537, 0, x_536); lean_ctor_set(x_537, 1, x_535); -x_538 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_538 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_539 = lean_array_push(x_538, x_537); x_540 = lean_array_push(x_539, x_531); -x_541 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_541 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_542 = lean_array_push(x_540, x_541); -x_543 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_543 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_544 = lean_array_push(x_542, x_543); lean_inc(x_11); x_545 = lean_array_push(x_529, x_11); @@ -7487,12 +7873,12 @@ x_580 = l_Lean_nullKind___closed__2; x_581 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_581, 0, x_580); lean_ctor_set(x_581, 1, x_579); -x_582 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_582 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_583 = lean_array_push(x_582, x_581); x_584 = lean_array_push(x_583, x_575); -x_585 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_585 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_586 = lean_array_push(x_584, x_585); -x_587 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_587 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_588 = lean_array_push(x_586, x_587); lean_inc(x_11); x_589 = lean_array_push(x_573, x_11); @@ -7572,12 +7958,12 @@ x_618 = l_Lean_nullKind___closed__2; x_619 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_619, 0, x_618); lean_ctor_set(x_619, 1, x_617); -x_620 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_620 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_621 = lean_array_push(x_620, x_619); x_622 = lean_array_push(x_621, x_613); -x_623 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_623 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_624 = lean_array_push(x_622, x_623); -x_625 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_625 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_626 = lean_array_push(x_624, x_625); lean_inc(x_11); x_627 = lean_array_push(x_611, x_11); @@ -7673,7 +8059,7 @@ lean_dec(x_648); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_651 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_651 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_652 = l_Lean_Elab_Term_throwError___rarg(x_508, x_651, x_5, x_6); lean_dec(x_508); x_653 = !lean_is_exclusive(x_652); @@ -7764,7 +8150,7 @@ lean_inc(x_679); x_683 = l_Lean_Elab_Term_mkExplicitBinder(x_679, x_682); x_684 = lean_array_push(x_4, x_683); lean_inc(x_5); -x_685 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_681, x_684, x_5, x_680); +x_685 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_681, x_684, x_5, x_680); if (lean_obj_tag(x_685) == 0) { lean_object* x_686; lean_object* x_687; uint8_t x_688; @@ -7803,12 +8189,12 @@ x_702 = l_Lean_nullKind___closed__2; x_703 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_703, 0, x_702); lean_ctor_set(x_703, 1, x_701); -x_704 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_704 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_705 = lean_array_push(x_704, x_703); x_706 = lean_array_push(x_705, x_697); -x_707 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_707 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_708 = lean_array_push(x_706, x_707); -x_709 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_709 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_710 = lean_array_push(x_708, x_709); lean_inc(x_11); x_711 = lean_array_push(x_695, x_11); @@ -7891,12 +8277,12 @@ x_746 = l_Lean_nullKind___closed__2; x_747 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_747, 0, x_746); lean_ctor_set(x_747, 1, x_745); -x_748 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_748 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_749 = lean_array_push(x_748, x_747); x_750 = lean_array_push(x_749, x_741); -x_751 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_751 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_752 = lean_array_push(x_750, x_751); -x_753 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_753 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_754 = lean_array_push(x_752, x_753); lean_inc(x_11); x_755 = lean_array_push(x_739, x_11); @@ -7976,12 +8362,12 @@ x_784 = l_Lean_nullKind___closed__2; x_785 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_785, 0, x_784); lean_ctor_set(x_785, 1, x_783); -x_786 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_786 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_787 = lean_array_push(x_786, x_785); x_788 = lean_array_push(x_787, x_779); -x_789 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_789 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_790 = lean_array_push(x_788, x_789); -x_791 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_791 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_792 = lean_array_push(x_790, x_791); lean_inc(x_11); x_793 = lean_array_push(x_777, x_11); @@ -8061,7 +8447,7 @@ else lean_object* x_813; lean_object* x_814; lean_object* x_815; x_813 = l_Lean_Syntax_getArg(x_670, x_663); lean_dec(x_670); -x_814 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_667, x_5, x_6); +x_814 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_667, x_5, x_6); x_815 = lean_ctor_get(x_814, 0); lean_inc(x_815); if (lean_obj_tag(x_815) == 0) @@ -8084,7 +8470,7 @@ lean_inc(x_818); x_822 = l_Lean_Elab_Term_mkExplicitBinder(x_818, x_821); x_823 = lean_array_push(x_4, x_822); lean_inc(x_5); -x_824 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_820, x_823, x_5, x_819); +x_824 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_820, x_823, x_5, x_819); if (lean_obj_tag(x_824) == 0) { lean_object* x_825; lean_object* x_826; uint8_t x_827; @@ -8123,12 +8509,12 @@ x_841 = l_Lean_nullKind___closed__2; x_842 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_842, 0, x_841); lean_ctor_set(x_842, 1, x_840); -x_843 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_843 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_844 = lean_array_push(x_843, x_842); x_845 = lean_array_push(x_844, x_836); -x_846 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_846 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_847 = lean_array_push(x_845, x_846); -x_848 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_848 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_849 = lean_array_push(x_847, x_848); lean_inc(x_11); x_850 = lean_array_push(x_834, x_11); @@ -8211,12 +8597,12 @@ x_885 = l_Lean_nullKind___closed__2; x_886 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_886, 0, x_885); lean_ctor_set(x_886, 1, x_884); -x_887 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_887 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_888 = lean_array_push(x_887, x_886); x_889 = lean_array_push(x_888, x_880); -x_890 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_890 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_891 = lean_array_push(x_889, x_890); -x_892 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_892 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_893 = lean_array_push(x_891, x_892); lean_inc(x_11); x_894 = lean_array_push(x_878, x_11); @@ -8296,12 +8682,12 @@ x_923 = l_Lean_nullKind___closed__2; x_924 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_924, 0, x_923); lean_ctor_set(x_924, 1, x_922); -x_925 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_925 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_926 = lean_array_push(x_925, x_924); x_927 = lean_array_push(x_926, x_918); -x_928 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_928 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_929 = lean_array_push(x_927, x_928); -x_930 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_930 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_931 = lean_array_push(x_929, x_930); lean_inc(x_11); x_932 = lean_array_push(x_916, x_11); @@ -8389,7 +8775,7 @@ lean_dec(x_815); x_954 = lean_nat_add(x_3, x_663); lean_dec(x_3); x_955 = x_953; -x_956 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(x_813, x_666, x_955); +x_956 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(x_813, x_666, x_955); x_957 = x_956; x_958 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_957, x_957, x_666, x_4); lean_dec(x_957); @@ -8418,7 +8804,7 @@ lean_inc(x_961); x_965 = l_Lean_Elab_Term_mkExplicitBinder(x_961, x_964); x_966 = lean_array_push(x_4, x_965); lean_inc(x_5); -x_967 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_963, x_966, x_5, x_962); +x_967 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_963, x_966, x_5, x_962); if (lean_obj_tag(x_967) == 0) { lean_object* x_968; lean_object* x_969; uint8_t x_970; @@ -8457,12 +8843,12 @@ x_984 = l_Lean_nullKind___closed__2; x_985 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_985, 0, x_984); lean_ctor_set(x_985, 1, x_983); -x_986 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_986 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_987 = lean_array_push(x_986, x_985); x_988 = lean_array_push(x_987, x_979); -x_989 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_989 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_990 = lean_array_push(x_988, x_989); -x_991 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_991 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_992 = lean_array_push(x_990, x_991); lean_inc(x_11); x_993 = lean_array_push(x_977, x_11); @@ -8545,12 +8931,12 @@ x_1028 = l_Lean_nullKind___closed__2; x_1029 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1029, 0, x_1028); lean_ctor_set(x_1029, 1, x_1027); -x_1030 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1030 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1031 = lean_array_push(x_1030, x_1029); x_1032 = lean_array_push(x_1031, x_1023); -x_1033 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1033 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1034 = lean_array_push(x_1032, x_1033); -x_1035 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1035 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1036 = lean_array_push(x_1034, x_1035); lean_inc(x_11); x_1037 = lean_array_push(x_1021, x_11); @@ -8630,12 +9016,12 @@ x_1066 = l_Lean_nullKind___closed__2; x_1067 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1067, 0, x_1066); lean_ctor_set(x_1067, 1, x_1065); -x_1068 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1068 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1069 = lean_array_push(x_1068, x_1067); x_1070 = lean_array_push(x_1069, x_1061); -x_1071 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1071 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1072 = lean_array_push(x_1070, x_1071); -x_1073 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1073 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1074 = lean_array_push(x_1072, x_1073); lean_inc(x_11); x_1075 = lean_array_push(x_1059, x_11); @@ -8728,7 +9114,7 @@ lean_inc(x_1096); x_1100 = l_Lean_Elab_Term_mkExplicitBinder(x_1096, x_1099); x_1101 = lean_array_push(x_4, x_1100); lean_inc(x_5); -x_1102 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1098, x_1101, x_5, x_1097); +x_1102 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1098, x_1101, x_5, x_1097); if (lean_obj_tag(x_1102) == 0) { lean_object* x_1103; lean_object* x_1104; uint8_t x_1105; @@ -8767,12 +9153,12 @@ x_1119 = l_Lean_nullKind___closed__2; x_1120 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1120, 0, x_1119); lean_ctor_set(x_1120, 1, x_1118); -x_1121 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1121 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1122 = lean_array_push(x_1121, x_1120); x_1123 = lean_array_push(x_1122, x_1114); -x_1124 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1124 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1125 = lean_array_push(x_1123, x_1124); -x_1126 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1126 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1127 = lean_array_push(x_1125, x_1126); lean_inc(x_11); x_1128 = lean_array_push(x_1112, x_11); @@ -8855,12 +9241,12 @@ x_1163 = l_Lean_nullKind___closed__2; x_1164 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1164, 0, x_1163); lean_ctor_set(x_1164, 1, x_1162); -x_1165 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1165 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1166 = lean_array_push(x_1165, x_1164); x_1167 = lean_array_push(x_1166, x_1158); -x_1168 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1168 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1169 = lean_array_push(x_1167, x_1168); -x_1170 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1170 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1171 = lean_array_push(x_1169, x_1170); lean_inc(x_11); x_1172 = lean_array_push(x_1156, x_11); @@ -8940,12 +9326,12 @@ x_1201 = l_Lean_nullKind___closed__2; x_1202 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1202, 0, x_1201); lean_ctor_set(x_1202, 1, x_1200); -x_1203 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1203 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1204 = lean_array_push(x_1203, x_1202); x_1205 = lean_array_push(x_1204, x_1196); -x_1206 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1206 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1207 = lean_array_push(x_1205, x_1206); -x_1208 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1208 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1209 = lean_array_push(x_1207, x_1208); lean_inc(x_11); x_1210 = lean_array_push(x_1194, x_11); @@ -9127,7 +9513,7 @@ lean_inc(x_1253); x_1258 = l_Lean_Elab_Term_mkExplicitBinder(x_1253, x_1257); x_1259 = lean_array_push(x_4, x_1258); lean_inc(x_5); -x_1260 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1256, x_1259, x_5, x_1254); +x_1260 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1256, x_1259, x_5, x_1254); if (lean_obj_tag(x_1260) == 0) { lean_object* x_1261; lean_object* x_1262; lean_object* x_1263; lean_object* x_1264; lean_object* x_1265; lean_object* x_1266; lean_object* x_1267; lean_object* x_1268; lean_object* x_1269; lean_object* x_1270; lean_object* x_1271; lean_object* x_1272; lean_object* x_1273; lean_object* x_1274; lean_object* x_1275; lean_object* x_1276; lean_object* x_1277; lean_object* x_1278; lean_object* x_1279; lean_object* x_1280; lean_object* x_1281; lean_object* x_1282; lean_object* x_1283; lean_object* x_1284; lean_object* x_1285; lean_object* x_1286; lean_object* x_1287; lean_object* x_1288; lean_object* x_1289; lean_object* x_1290; lean_object* x_1291; lean_object* x_1292; lean_object* x_1293; lean_object* x_1294; lean_object* x_1295; lean_object* x_1296; lean_object* x_1297; lean_object* x_1298; lean_object* x_1299; lean_object* x_1300; lean_object* x_1301; lean_object* x_1302; @@ -9177,12 +9563,12 @@ x_1278 = l_Lean_nullKind___closed__2; x_1279 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1279, 0, x_1278); lean_ctor_set(x_1279, 1, x_1277); -x_1280 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1280 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1281 = lean_array_push(x_1280, x_1279); x_1282 = lean_array_push(x_1281, x_1273); -x_1283 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1283 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1284 = lean_array_push(x_1282, x_1283); -x_1285 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1285 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1286 = lean_array_push(x_1284, x_1285); lean_inc(x_11); x_1287 = lean_array_push(x_1271, x_11); @@ -9282,7 +9668,7 @@ lean_dec(x_1308); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1311 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1311 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1312 = l_Lean_Elab_Term_throwError___rarg(x_11, x_1311, x_5, x_6); lean_dec(x_11); x_1313 = lean_ctor_get(x_1312, 0); @@ -9359,7 +9745,7 @@ lean_inc(x_1330); x_1335 = l_Lean_Elab_Term_mkExplicitBinder(x_1330, x_1334); x_1336 = lean_array_push(x_4, x_1335); lean_inc(x_5); -x_1337 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1333, x_1336, x_5, x_1331); +x_1337 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1333, x_1336, x_5, x_1331); if (lean_obj_tag(x_1337) == 0) { lean_object* x_1338; lean_object* x_1339; lean_object* x_1340; lean_object* x_1341; lean_object* x_1342; lean_object* x_1343; lean_object* x_1344; lean_object* x_1345; lean_object* x_1346; lean_object* x_1347; lean_object* x_1348; lean_object* x_1349; lean_object* x_1350; lean_object* x_1351; lean_object* x_1352; lean_object* x_1353; lean_object* x_1354; lean_object* x_1355; lean_object* x_1356; lean_object* x_1357; lean_object* x_1358; lean_object* x_1359; lean_object* x_1360; lean_object* x_1361; lean_object* x_1362; lean_object* x_1363; lean_object* x_1364; lean_object* x_1365; lean_object* x_1366; lean_object* x_1367; lean_object* x_1368; lean_object* x_1369; lean_object* x_1370; lean_object* x_1371; lean_object* x_1372; lean_object* x_1373; lean_object* x_1374; lean_object* x_1375; lean_object* x_1376; lean_object* x_1377; lean_object* x_1378; lean_object* x_1379; @@ -9409,12 +9795,12 @@ x_1355 = l_Lean_nullKind___closed__2; x_1356 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1356, 0, x_1355); lean_ctor_set(x_1356, 1, x_1354); -x_1357 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1357 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1358 = lean_array_push(x_1357, x_1356); x_1359 = lean_array_push(x_1358, x_1350); -x_1360 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1360 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1361 = lean_array_push(x_1359, x_1360); -x_1362 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1362 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1363 = lean_array_push(x_1361, x_1362); lean_inc(x_11); x_1364 = lean_array_push(x_1348, x_11); @@ -9515,7 +9901,7 @@ lean_dec(x_1385); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1388 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1388 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1389 = l_Lean_Elab_Term_throwError___rarg(x_1326, x_1388, x_5, x_6); lean_dec(x_1326); x_1390 = lean_ctor_get(x_1389, 0); @@ -9594,7 +9980,7 @@ lean_inc(x_1407); x_1412 = l_Lean_Elab_Term_mkExplicitBinder(x_1407, x_1411); x_1413 = lean_array_push(x_4, x_1412); lean_inc(x_5); -x_1414 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1410, x_1413, x_5, x_1408); +x_1414 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1410, x_1413, x_5, x_1408); if (lean_obj_tag(x_1414) == 0) { lean_object* x_1415; lean_object* x_1416; lean_object* x_1417; lean_object* x_1418; lean_object* x_1419; lean_object* x_1420; lean_object* x_1421; lean_object* x_1422; lean_object* x_1423; lean_object* x_1424; lean_object* x_1425; lean_object* x_1426; lean_object* x_1427; lean_object* x_1428; lean_object* x_1429; lean_object* x_1430; lean_object* x_1431; lean_object* x_1432; lean_object* x_1433; lean_object* x_1434; lean_object* x_1435; lean_object* x_1436; lean_object* x_1437; lean_object* x_1438; lean_object* x_1439; lean_object* x_1440; lean_object* x_1441; lean_object* x_1442; lean_object* x_1443; lean_object* x_1444; lean_object* x_1445; lean_object* x_1446; lean_object* x_1447; lean_object* x_1448; lean_object* x_1449; lean_object* x_1450; lean_object* x_1451; lean_object* x_1452; lean_object* x_1453; lean_object* x_1454; lean_object* x_1455; lean_object* x_1456; @@ -9644,12 +10030,12 @@ x_1432 = l_Lean_nullKind___closed__2; x_1433 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1433, 0, x_1432); lean_ctor_set(x_1433, 1, x_1431); -x_1434 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1434 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1435 = lean_array_push(x_1434, x_1433); x_1436 = lean_array_push(x_1435, x_1427); -x_1437 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1437 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1438 = lean_array_push(x_1436, x_1437); -x_1439 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1439 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1440 = lean_array_push(x_1438, x_1439); lean_inc(x_11); x_1441 = lean_array_push(x_1425, x_11); @@ -9750,7 +10136,7 @@ lean_dec(x_1462); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1465 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1465 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1466 = l_Lean_Elab_Term_throwError___rarg(x_1403, x_1465, x_5, x_6); lean_dec(x_1403); x_1467 = lean_ctor_get(x_1466, 0); @@ -9845,7 +10231,7 @@ lean_inc(x_1490); x_1495 = l_Lean_Elab_Term_mkExplicitBinder(x_1490, x_1494); x_1496 = lean_array_push(x_4, x_1495); lean_inc(x_5); -x_1497 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1493, x_1496, x_5, x_1491); +x_1497 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1493, x_1496, x_5, x_1491); if (lean_obj_tag(x_1497) == 0) { lean_object* x_1498; lean_object* x_1499; lean_object* x_1500; lean_object* x_1501; lean_object* x_1502; lean_object* x_1503; lean_object* x_1504; lean_object* x_1505; lean_object* x_1506; lean_object* x_1507; lean_object* x_1508; lean_object* x_1509; lean_object* x_1510; lean_object* x_1511; lean_object* x_1512; lean_object* x_1513; lean_object* x_1514; lean_object* x_1515; lean_object* x_1516; lean_object* x_1517; lean_object* x_1518; lean_object* x_1519; lean_object* x_1520; lean_object* x_1521; lean_object* x_1522; lean_object* x_1523; lean_object* x_1524; lean_object* x_1525; lean_object* x_1526; lean_object* x_1527; lean_object* x_1528; lean_object* x_1529; lean_object* x_1530; lean_object* x_1531; lean_object* x_1532; lean_object* x_1533; lean_object* x_1534; lean_object* x_1535; lean_object* x_1536; lean_object* x_1537; lean_object* x_1538; lean_object* x_1539; @@ -9895,12 +10281,12 @@ x_1515 = l_Lean_nullKind___closed__2; x_1516 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1516, 0, x_1515); lean_ctor_set(x_1516, 1, x_1514); -x_1517 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1517 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1518 = lean_array_push(x_1517, x_1516); x_1519 = lean_array_push(x_1518, x_1510); -x_1520 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1520 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1521 = lean_array_push(x_1519, x_1520); -x_1522 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1522 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1523 = lean_array_push(x_1521, x_1522); lean_inc(x_11); x_1524 = lean_array_push(x_1508, x_11); @@ -10001,7 +10387,7 @@ lean_dec(x_1545); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1548 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1548 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1549 = l_Lean_Elab_Term_throwError___rarg(x_1486, x_1548, x_5, x_6); lean_dec(x_1486); x_1550 = lean_ctor_get(x_1549, 0); @@ -10093,7 +10479,7 @@ lean_inc(x_1576); x_1580 = l_Lean_Elab_Term_mkExplicitBinder(x_1576, x_1579); x_1581 = lean_array_push(x_4, x_1580); lean_inc(x_5); -x_1582 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1578, x_1581, x_5, x_1577); +x_1582 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1578, x_1581, x_5, x_1577); if (lean_obj_tag(x_1582) == 0) { lean_object* x_1583; lean_object* x_1584; lean_object* x_1585; lean_object* x_1586; lean_object* x_1587; lean_object* x_1588; lean_object* x_1589; lean_object* x_1590; lean_object* x_1591; lean_object* x_1592; lean_object* x_1593; lean_object* x_1594; lean_object* x_1595; lean_object* x_1596; lean_object* x_1597; lean_object* x_1598; lean_object* x_1599; lean_object* x_1600; lean_object* x_1601; lean_object* x_1602; lean_object* x_1603; lean_object* x_1604; lean_object* x_1605; lean_object* x_1606; lean_object* x_1607; lean_object* x_1608; lean_object* x_1609; lean_object* x_1610; lean_object* x_1611; lean_object* x_1612; lean_object* x_1613; lean_object* x_1614; lean_object* x_1615; lean_object* x_1616; lean_object* x_1617; lean_object* x_1618; lean_object* x_1619; lean_object* x_1620; lean_object* x_1621; lean_object* x_1622; lean_object* x_1623; lean_object* x_1624; @@ -10143,12 +10529,12 @@ x_1600 = l_Lean_nullKind___closed__2; x_1601 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1601, 0, x_1600); lean_ctor_set(x_1601, 1, x_1599); -x_1602 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1602 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1603 = lean_array_push(x_1602, x_1601); x_1604 = lean_array_push(x_1603, x_1595); -x_1605 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1605 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1606 = lean_array_push(x_1604, x_1605); -x_1607 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1607 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1608 = lean_array_push(x_1606, x_1607); lean_inc(x_11); x_1609 = lean_array_push(x_1593, x_11); @@ -10233,7 +10619,7 @@ else lean_object* x_1629; lean_object* x_1630; lean_object* x_1631; x_1629 = l_Lean_Syntax_getArg(x_1567, x_1560); lean_dec(x_1567); -x_1630 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_1564, x_5, x_6); +x_1630 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_1564, x_5, x_6); x_1631 = lean_ctor_get(x_1630, 0); lean_inc(x_1631); if (lean_obj_tag(x_1631) == 0) @@ -10256,7 +10642,7 @@ lean_inc(x_1634); x_1638 = l_Lean_Elab_Term_mkExplicitBinder(x_1634, x_1637); x_1639 = lean_array_push(x_4, x_1638); lean_inc(x_5); -x_1640 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1636, x_1639, x_5, x_1635); +x_1640 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1636, x_1639, x_5, x_1635); if (lean_obj_tag(x_1640) == 0) { lean_object* x_1641; lean_object* x_1642; lean_object* x_1643; lean_object* x_1644; lean_object* x_1645; lean_object* x_1646; lean_object* x_1647; lean_object* x_1648; lean_object* x_1649; lean_object* x_1650; lean_object* x_1651; lean_object* x_1652; lean_object* x_1653; lean_object* x_1654; lean_object* x_1655; lean_object* x_1656; lean_object* x_1657; lean_object* x_1658; lean_object* x_1659; lean_object* x_1660; lean_object* x_1661; lean_object* x_1662; lean_object* x_1663; lean_object* x_1664; lean_object* x_1665; lean_object* x_1666; lean_object* x_1667; lean_object* x_1668; lean_object* x_1669; lean_object* x_1670; lean_object* x_1671; lean_object* x_1672; lean_object* x_1673; lean_object* x_1674; lean_object* x_1675; lean_object* x_1676; lean_object* x_1677; lean_object* x_1678; lean_object* x_1679; lean_object* x_1680; lean_object* x_1681; lean_object* x_1682; @@ -10306,12 +10692,12 @@ x_1658 = l_Lean_nullKind___closed__2; x_1659 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1659, 0, x_1658); lean_ctor_set(x_1659, 1, x_1657); -x_1660 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1660 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1661 = lean_array_push(x_1660, x_1659); x_1662 = lean_array_push(x_1661, x_1653); -x_1663 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1663 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1664 = lean_array_push(x_1662, x_1663); -x_1665 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1665 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1666 = lean_array_push(x_1664, x_1665); lean_inc(x_11); x_1667 = lean_array_push(x_1651, x_11); @@ -10404,7 +10790,7 @@ lean_dec(x_1631); x_1689 = lean_nat_add(x_3, x_1560); lean_dec(x_3); x_1690 = x_1688; -x_1691 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(x_1629, x_1563, x_1690); +x_1691 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(x_1629, x_1563, x_1690); x_1692 = x_1691; x_1693 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_1692, x_1692, x_1563, x_4); lean_dec(x_1692); @@ -10433,7 +10819,7 @@ lean_inc(x_1696); x_1700 = l_Lean_Elab_Term_mkExplicitBinder(x_1696, x_1699); x_1701 = lean_array_push(x_4, x_1700); lean_inc(x_5); -x_1702 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1698, x_1701, x_5, x_1697); +x_1702 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1698, x_1701, x_5, x_1697); if (lean_obj_tag(x_1702) == 0) { lean_object* x_1703; lean_object* x_1704; lean_object* x_1705; lean_object* x_1706; lean_object* x_1707; lean_object* x_1708; lean_object* x_1709; lean_object* x_1710; lean_object* x_1711; lean_object* x_1712; lean_object* x_1713; lean_object* x_1714; lean_object* x_1715; lean_object* x_1716; lean_object* x_1717; lean_object* x_1718; lean_object* x_1719; lean_object* x_1720; lean_object* x_1721; lean_object* x_1722; lean_object* x_1723; lean_object* x_1724; lean_object* x_1725; lean_object* x_1726; lean_object* x_1727; lean_object* x_1728; lean_object* x_1729; lean_object* x_1730; lean_object* x_1731; lean_object* x_1732; lean_object* x_1733; lean_object* x_1734; lean_object* x_1735; lean_object* x_1736; lean_object* x_1737; lean_object* x_1738; lean_object* x_1739; lean_object* x_1740; lean_object* x_1741; lean_object* x_1742; lean_object* x_1743; lean_object* x_1744; @@ -10483,12 +10869,12 @@ x_1720 = l_Lean_nullKind___closed__2; x_1721 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1721, 0, x_1720); lean_ctor_set(x_1721, 1, x_1719); -x_1722 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1722 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1723 = lean_array_push(x_1722, x_1721); x_1724 = lean_array_push(x_1723, x_1715); -x_1725 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1725 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1726 = lean_array_push(x_1724, x_1725); -x_1727 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1727 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1728 = lean_array_push(x_1726, x_1727); lean_inc(x_11); x_1729 = lean_array_push(x_1713, x_11); @@ -10586,7 +10972,7 @@ lean_inc(x_1750); x_1754 = l_Lean_Elab_Term_mkExplicitBinder(x_1750, x_1753); x_1755 = lean_array_push(x_4, x_1754); lean_inc(x_5); -x_1756 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1752, x_1755, x_5, x_1751); +x_1756 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1752, x_1755, x_5, x_1751); if (lean_obj_tag(x_1756) == 0) { lean_object* x_1757; lean_object* x_1758; lean_object* x_1759; lean_object* x_1760; lean_object* x_1761; lean_object* x_1762; lean_object* x_1763; lean_object* x_1764; lean_object* x_1765; lean_object* x_1766; lean_object* x_1767; lean_object* x_1768; lean_object* x_1769; lean_object* x_1770; lean_object* x_1771; lean_object* x_1772; lean_object* x_1773; lean_object* x_1774; lean_object* x_1775; lean_object* x_1776; lean_object* x_1777; lean_object* x_1778; lean_object* x_1779; lean_object* x_1780; lean_object* x_1781; lean_object* x_1782; lean_object* x_1783; lean_object* x_1784; lean_object* x_1785; lean_object* x_1786; lean_object* x_1787; lean_object* x_1788; lean_object* x_1789; lean_object* x_1790; lean_object* x_1791; lean_object* x_1792; lean_object* x_1793; lean_object* x_1794; lean_object* x_1795; lean_object* x_1796; lean_object* x_1797; lean_object* x_1798; @@ -10636,12 +11022,12 @@ x_1774 = l_Lean_nullKind___closed__2; x_1775 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1775, 0, x_1774); lean_ctor_set(x_1775, 1, x_1773); -x_1776 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1776 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1777 = lean_array_push(x_1776, x_1775); x_1778 = lean_array_push(x_1777, x_1769); -x_1779 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1779 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1780 = lean_array_push(x_1778, x_1779); -x_1781 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1781 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1782 = lean_array_push(x_1780, x_1781); lean_inc(x_11); x_1783 = lean_array_push(x_1767, x_11); @@ -10837,7 +11223,7 @@ lean_inc(x_1829); x_1834 = l_Lean_Elab_Term_mkExplicitBinder(x_1829, x_1833); x_1835 = lean_array_push(x_4, x_1834); lean_inc(x_5); -x_1836 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1832, x_1835, x_5, x_1830); +x_1836 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1832, x_1835, x_5, x_1830); if (lean_obj_tag(x_1836) == 0) { lean_object* x_1837; lean_object* x_1838; lean_object* x_1839; lean_object* x_1840; lean_object* x_1841; lean_object* x_1842; lean_object* x_1843; lean_object* x_1844; lean_object* x_1845; lean_object* x_1846; lean_object* x_1847; lean_object* x_1848; lean_object* x_1849; lean_object* x_1850; lean_object* x_1851; lean_object* x_1852; lean_object* x_1853; lean_object* x_1854; lean_object* x_1855; lean_object* x_1856; lean_object* x_1857; lean_object* x_1858; lean_object* x_1859; lean_object* x_1860; lean_object* x_1861; lean_object* x_1862; lean_object* x_1863; lean_object* x_1864; lean_object* x_1865; lean_object* x_1866; lean_object* x_1867; lean_object* x_1868; lean_object* x_1869; lean_object* x_1870; lean_object* x_1871; lean_object* x_1872; lean_object* x_1873; lean_object* x_1874; lean_object* x_1875; lean_object* x_1876; lean_object* x_1877; lean_object* x_1878; @@ -10887,12 +11273,12 @@ x_1854 = l_Lean_nullKind___closed__2; x_1855 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1855, 0, x_1854); lean_ctor_set(x_1855, 1, x_1853); -x_1856 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1856 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1857 = lean_array_push(x_1856, x_1855); x_1858 = lean_array_push(x_1857, x_1849); -x_1859 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1859 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1860 = lean_array_push(x_1858, x_1859); -x_1861 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1861 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1862 = lean_array_push(x_1860, x_1861); lean_inc(x_11); x_1863 = lean_array_push(x_1847, x_11); @@ -10992,7 +11378,7 @@ lean_dec(x_1884); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1887 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1887 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1888 = l_Lean_Elab_Term_throwError___rarg(x_11, x_1887, x_5, x_6); lean_dec(x_11); x_1889 = lean_ctor_get(x_1888, 0); @@ -11077,7 +11463,7 @@ lean_inc(x_1907); x_1912 = l_Lean_Elab_Term_mkExplicitBinder(x_1907, x_1911); x_1913 = lean_array_push(x_4, x_1912); lean_inc(x_5); -x_1914 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1910, x_1913, x_5, x_1908); +x_1914 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1910, x_1913, x_5, x_1908); if (lean_obj_tag(x_1914) == 0) { lean_object* x_1915; lean_object* x_1916; lean_object* x_1917; lean_object* x_1918; lean_object* x_1919; lean_object* x_1920; lean_object* x_1921; lean_object* x_1922; lean_object* x_1923; lean_object* x_1924; lean_object* x_1925; lean_object* x_1926; lean_object* x_1927; lean_object* x_1928; lean_object* x_1929; lean_object* x_1930; lean_object* x_1931; lean_object* x_1932; lean_object* x_1933; lean_object* x_1934; lean_object* x_1935; lean_object* x_1936; lean_object* x_1937; lean_object* x_1938; lean_object* x_1939; lean_object* x_1940; lean_object* x_1941; lean_object* x_1942; lean_object* x_1943; lean_object* x_1944; lean_object* x_1945; lean_object* x_1946; lean_object* x_1947; lean_object* x_1948; lean_object* x_1949; lean_object* x_1950; lean_object* x_1951; lean_object* x_1952; lean_object* x_1953; lean_object* x_1954; lean_object* x_1955; lean_object* x_1956; @@ -11127,12 +11513,12 @@ x_1932 = l_Lean_nullKind___closed__2; x_1933 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_1933, 0, x_1932); lean_ctor_set(x_1933, 1, x_1931); -x_1934 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_1934 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_1935 = lean_array_push(x_1934, x_1933); x_1936 = lean_array_push(x_1935, x_1927); -x_1937 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_1937 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_1938 = lean_array_push(x_1936, x_1937); -x_1939 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_1939 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_1940 = lean_array_push(x_1938, x_1939); lean_inc(x_11); x_1941 = lean_array_push(x_1925, x_11); @@ -11233,7 +11619,7 @@ lean_dec(x_1962); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_1965 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_1965 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_1966 = l_Lean_Elab_Term_throwError___rarg(x_1903, x_1965, x_5, x_6); lean_dec(x_1903); x_1967 = lean_ctor_get(x_1966, 0); @@ -11319,7 +11705,7 @@ lean_inc(x_1985); x_1990 = l_Lean_Elab_Term_mkExplicitBinder(x_1985, x_1989); x_1991 = lean_array_push(x_4, x_1990); lean_inc(x_5); -x_1992 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_1988, x_1991, x_5, x_1986); +x_1992 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_1988, x_1991, x_5, x_1986); if (lean_obj_tag(x_1992) == 0) { lean_object* x_1993; lean_object* x_1994; lean_object* x_1995; lean_object* x_1996; lean_object* x_1997; lean_object* x_1998; lean_object* x_1999; lean_object* x_2000; lean_object* x_2001; lean_object* x_2002; lean_object* x_2003; lean_object* x_2004; lean_object* x_2005; lean_object* x_2006; lean_object* x_2007; lean_object* x_2008; lean_object* x_2009; lean_object* x_2010; lean_object* x_2011; lean_object* x_2012; lean_object* x_2013; lean_object* x_2014; lean_object* x_2015; lean_object* x_2016; lean_object* x_2017; lean_object* x_2018; lean_object* x_2019; lean_object* x_2020; lean_object* x_2021; lean_object* x_2022; lean_object* x_2023; lean_object* x_2024; lean_object* x_2025; lean_object* x_2026; lean_object* x_2027; lean_object* x_2028; lean_object* x_2029; lean_object* x_2030; lean_object* x_2031; lean_object* x_2032; lean_object* x_2033; lean_object* x_2034; @@ -11369,12 +11755,12 @@ x_2010 = l_Lean_nullKind___closed__2; x_2011 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2011, 0, x_2010); lean_ctor_set(x_2011, 1, x_2009); -x_2012 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2012 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2013 = lean_array_push(x_2012, x_2011); x_2014 = lean_array_push(x_2013, x_2005); -x_2015 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2015 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2016 = lean_array_push(x_2014, x_2015); -x_2017 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2017 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2018 = lean_array_push(x_2016, x_2017); lean_inc(x_11); x_2019 = lean_array_push(x_2003, x_11); @@ -11475,7 +11861,7 @@ lean_dec(x_2040); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2043 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2043 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2044 = l_Lean_Elab_Term_throwError___rarg(x_1981, x_2043, x_5, x_6); lean_dec(x_1981); x_2045 = lean_ctor_get(x_2044, 0); @@ -11577,7 +11963,7 @@ lean_inc(x_2069); x_2074 = l_Lean_Elab_Term_mkExplicitBinder(x_2069, x_2073); x_2075 = lean_array_push(x_4, x_2074); lean_inc(x_5); -x_2076 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2072, x_2075, x_5, x_2070); +x_2076 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2072, x_2075, x_5, x_2070); if (lean_obj_tag(x_2076) == 0) { lean_object* x_2077; lean_object* x_2078; lean_object* x_2079; lean_object* x_2080; lean_object* x_2081; lean_object* x_2082; lean_object* x_2083; lean_object* x_2084; lean_object* x_2085; lean_object* x_2086; lean_object* x_2087; lean_object* x_2088; lean_object* x_2089; lean_object* x_2090; lean_object* x_2091; lean_object* x_2092; lean_object* x_2093; lean_object* x_2094; lean_object* x_2095; lean_object* x_2096; lean_object* x_2097; lean_object* x_2098; lean_object* x_2099; lean_object* x_2100; lean_object* x_2101; lean_object* x_2102; lean_object* x_2103; lean_object* x_2104; lean_object* x_2105; lean_object* x_2106; lean_object* x_2107; lean_object* x_2108; lean_object* x_2109; lean_object* x_2110; lean_object* x_2111; lean_object* x_2112; lean_object* x_2113; lean_object* x_2114; lean_object* x_2115; lean_object* x_2116; lean_object* x_2117; lean_object* x_2118; @@ -11627,12 +12013,12 @@ x_2094 = l_Lean_nullKind___closed__2; x_2095 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2095, 0, x_2094); lean_ctor_set(x_2095, 1, x_2093); -x_2096 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2096 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2097 = lean_array_push(x_2096, x_2095); x_2098 = lean_array_push(x_2097, x_2089); -x_2099 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2099 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2100 = lean_array_push(x_2098, x_2099); -x_2101 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2101 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2102 = lean_array_push(x_2100, x_2101); lean_inc(x_11); x_2103 = lean_array_push(x_2087, x_11); @@ -11733,7 +12119,7 @@ lean_dec(x_2124); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2127 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2127 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2128 = l_Lean_Elab_Term_throwError___rarg(x_2065, x_2127, x_5, x_6); lean_dec(x_2065); x_2129 = lean_ctor_get(x_2128, 0); @@ -11825,7 +12211,7 @@ lean_inc(x_2155); x_2159 = l_Lean_Elab_Term_mkExplicitBinder(x_2155, x_2158); x_2160 = lean_array_push(x_4, x_2159); lean_inc(x_5); -x_2161 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2157, x_2160, x_5, x_2156); +x_2161 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2157, x_2160, x_5, x_2156); if (lean_obj_tag(x_2161) == 0) { lean_object* x_2162; lean_object* x_2163; lean_object* x_2164; lean_object* x_2165; lean_object* x_2166; lean_object* x_2167; lean_object* x_2168; lean_object* x_2169; lean_object* x_2170; lean_object* x_2171; lean_object* x_2172; lean_object* x_2173; lean_object* x_2174; lean_object* x_2175; lean_object* x_2176; lean_object* x_2177; lean_object* x_2178; lean_object* x_2179; lean_object* x_2180; lean_object* x_2181; lean_object* x_2182; lean_object* x_2183; lean_object* x_2184; lean_object* x_2185; lean_object* x_2186; lean_object* x_2187; lean_object* x_2188; lean_object* x_2189; lean_object* x_2190; lean_object* x_2191; lean_object* x_2192; lean_object* x_2193; lean_object* x_2194; lean_object* x_2195; lean_object* x_2196; lean_object* x_2197; lean_object* x_2198; lean_object* x_2199; lean_object* x_2200; lean_object* x_2201; lean_object* x_2202; lean_object* x_2203; @@ -11875,12 +12261,12 @@ x_2179 = l_Lean_nullKind___closed__2; x_2180 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2180, 0, x_2179); lean_ctor_set(x_2180, 1, x_2178); -x_2181 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2181 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2182 = lean_array_push(x_2181, x_2180); x_2183 = lean_array_push(x_2182, x_2174); -x_2184 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2184 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2185 = lean_array_push(x_2183, x_2184); -x_2186 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2186 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2187 = lean_array_push(x_2185, x_2186); lean_inc(x_11); x_2188 = lean_array_push(x_2172, x_11); @@ -11965,7 +12351,7 @@ else lean_object* x_2208; lean_object* x_2209; lean_object* x_2210; x_2208 = l_Lean_Syntax_getArg(x_2146, x_2139); lean_dec(x_2146); -x_2209 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_2143, x_5, x_6); +x_2209 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_2143, x_5, x_6); x_2210 = lean_ctor_get(x_2209, 0); lean_inc(x_2210); if (lean_obj_tag(x_2210) == 0) @@ -11988,7 +12374,7 @@ lean_inc(x_2213); x_2217 = l_Lean_Elab_Term_mkExplicitBinder(x_2213, x_2216); x_2218 = lean_array_push(x_4, x_2217); lean_inc(x_5); -x_2219 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2215, x_2218, x_5, x_2214); +x_2219 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2215, x_2218, x_5, x_2214); if (lean_obj_tag(x_2219) == 0) { lean_object* x_2220; lean_object* x_2221; lean_object* x_2222; lean_object* x_2223; lean_object* x_2224; lean_object* x_2225; lean_object* x_2226; lean_object* x_2227; lean_object* x_2228; lean_object* x_2229; lean_object* x_2230; lean_object* x_2231; lean_object* x_2232; lean_object* x_2233; lean_object* x_2234; lean_object* x_2235; lean_object* x_2236; lean_object* x_2237; lean_object* x_2238; lean_object* x_2239; lean_object* x_2240; lean_object* x_2241; lean_object* x_2242; lean_object* x_2243; lean_object* x_2244; lean_object* x_2245; lean_object* x_2246; lean_object* x_2247; lean_object* x_2248; lean_object* x_2249; lean_object* x_2250; lean_object* x_2251; lean_object* x_2252; lean_object* x_2253; lean_object* x_2254; lean_object* x_2255; lean_object* x_2256; lean_object* x_2257; lean_object* x_2258; lean_object* x_2259; lean_object* x_2260; lean_object* x_2261; @@ -12038,12 +12424,12 @@ x_2237 = l_Lean_nullKind___closed__2; x_2238 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2238, 0, x_2237); lean_ctor_set(x_2238, 1, x_2236); -x_2239 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2239 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2240 = lean_array_push(x_2239, x_2238); x_2241 = lean_array_push(x_2240, x_2232); -x_2242 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2242 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2243 = lean_array_push(x_2241, x_2242); -x_2244 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2244 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2245 = lean_array_push(x_2243, x_2244); lean_inc(x_11); x_2246 = lean_array_push(x_2230, x_11); @@ -12136,7 +12522,7 @@ lean_dec(x_2210); x_2268 = lean_nat_add(x_3, x_2139); lean_dec(x_3); x_2269 = x_2267; -x_2270 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(x_2208, x_2142, x_2269); +x_2270 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(x_2208, x_2142, x_2269); x_2271 = x_2270; x_2272 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_2271, x_2271, x_2142, x_4); lean_dec(x_2271); @@ -12165,7 +12551,7 @@ lean_inc(x_2275); x_2279 = l_Lean_Elab_Term_mkExplicitBinder(x_2275, x_2278); x_2280 = lean_array_push(x_4, x_2279); lean_inc(x_5); -x_2281 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2277, x_2280, x_5, x_2276); +x_2281 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2277, x_2280, x_5, x_2276); if (lean_obj_tag(x_2281) == 0) { lean_object* x_2282; lean_object* x_2283; lean_object* x_2284; lean_object* x_2285; lean_object* x_2286; lean_object* x_2287; lean_object* x_2288; lean_object* x_2289; lean_object* x_2290; lean_object* x_2291; lean_object* x_2292; lean_object* x_2293; lean_object* x_2294; lean_object* x_2295; lean_object* x_2296; lean_object* x_2297; lean_object* x_2298; lean_object* x_2299; lean_object* x_2300; lean_object* x_2301; lean_object* x_2302; lean_object* x_2303; lean_object* x_2304; lean_object* x_2305; lean_object* x_2306; lean_object* x_2307; lean_object* x_2308; lean_object* x_2309; lean_object* x_2310; lean_object* x_2311; lean_object* x_2312; lean_object* x_2313; lean_object* x_2314; lean_object* x_2315; lean_object* x_2316; lean_object* x_2317; lean_object* x_2318; lean_object* x_2319; lean_object* x_2320; lean_object* x_2321; lean_object* x_2322; lean_object* x_2323; @@ -12215,12 +12601,12 @@ x_2299 = l_Lean_nullKind___closed__2; x_2300 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2300, 0, x_2299); lean_ctor_set(x_2300, 1, x_2298); -x_2301 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2301 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2302 = lean_array_push(x_2301, x_2300); x_2303 = lean_array_push(x_2302, x_2294); -x_2304 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2304 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2305 = lean_array_push(x_2303, x_2304); -x_2306 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2306 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2307 = lean_array_push(x_2305, x_2306); lean_inc(x_11); x_2308 = lean_array_push(x_2292, x_11); @@ -12318,7 +12704,7 @@ lean_inc(x_2329); x_2333 = l_Lean_Elab_Term_mkExplicitBinder(x_2329, x_2332); x_2334 = lean_array_push(x_4, x_2333); lean_inc(x_5); -x_2335 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2331, x_2334, x_5, x_2330); +x_2335 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2331, x_2334, x_5, x_2330); if (lean_obj_tag(x_2335) == 0) { lean_object* x_2336; lean_object* x_2337; lean_object* x_2338; lean_object* x_2339; lean_object* x_2340; lean_object* x_2341; lean_object* x_2342; lean_object* x_2343; lean_object* x_2344; lean_object* x_2345; lean_object* x_2346; lean_object* x_2347; lean_object* x_2348; lean_object* x_2349; lean_object* x_2350; lean_object* x_2351; lean_object* x_2352; lean_object* x_2353; lean_object* x_2354; lean_object* x_2355; lean_object* x_2356; lean_object* x_2357; lean_object* x_2358; lean_object* x_2359; lean_object* x_2360; lean_object* x_2361; lean_object* x_2362; lean_object* x_2363; lean_object* x_2364; lean_object* x_2365; lean_object* x_2366; lean_object* x_2367; lean_object* x_2368; lean_object* x_2369; lean_object* x_2370; lean_object* x_2371; lean_object* x_2372; lean_object* x_2373; lean_object* x_2374; lean_object* x_2375; lean_object* x_2376; lean_object* x_2377; @@ -12368,12 +12754,12 @@ x_2353 = l_Lean_nullKind___closed__2; x_2354 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2354, 0, x_2353); lean_ctor_set(x_2354, 1, x_2352); -x_2355 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2355 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2356 = lean_array_push(x_2355, x_2354); x_2357 = lean_array_push(x_2356, x_2348); -x_2358 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2358 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2359 = lean_array_push(x_2357, x_2358); -x_2360 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2360 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2361 = lean_array_push(x_2359, x_2360); lean_inc(x_11); x_2362 = lean_array_push(x_2346, x_11); @@ -12580,7 +12966,7 @@ lean_inc(x_2411); x_2416 = l_Lean_Elab_Term_mkExplicitBinder(x_2411, x_2415); x_2417 = lean_array_push(x_4, x_2416); lean_inc(x_5); -x_2418 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2414, x_2417, x_5, x_2412); +x_2418 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2414, x_2417, x_5, x_2412); if (lean_obj_tag(x_2418) == 0) { lean_object* x_2419; lean_object* x_2420; lean_object* x_2421; lean_object* x_2422; lean_object* x_2423; lean_object* x_2424; lean_object* x_2425; lean_object* x_2426; lean_object* x_2427; lean_object* x_2428; lean_object* x_2429; lean_object* x_2430; lean_object* x_2431; lean_object* x_2432; lean_object* x_2433; lean_object* x_2434; lean_object* x_2435; lean_object* x_2436; lean_object* x_2437; lean_object* x_2438; lean_object* x_2439; lean_object* x_2440; lean_object* x_2441; lean_object* x_2442; lean_object* x_2443; lean_object* x_2444; lean_object* x_2445; lean_object* x_2446; lean_object* x_2447; lean_object* x_2448; lean_object* x_2449; lean_object* x_2450; lean_object* x_2451; lean_object* x_2452; lean_object* x_2453; lean_object* x_2454; lean_object* x_2455; lean_object* x_2456; lean_object* x_2457; lean_object* x_2458; lean_object* x_2459; lean_object* x_2460; @@ -12630,12 +13016,12 @@ x_2436 = l_Lean_nullKind___closed__2; x_2437 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2437, 0, x_2436); lean_ctor_set(x_2437, 1, x_2435); -x_2438 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2438 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2439 = lean_array_push(x_2438, x_2437); x_2440 = lean_array_push(x_2439, x_2431); -x_2441 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2441 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2442 = lean_array_push(x_2440, x_2441); -x_2443 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2443 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2444 = lean_array_push(x_2442, x_2443); lean_inc(x_11); x_2445 = lean_array_push(x_2429, x_11); @@ -12735,7 +13121,7 @@ lean_dec(x_2466); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2469 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2469 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2470 = l_Lean_Elab_Term_throwError___rarg(x_11, x_2469, x_5, x_6); lean_dec(x_11); x_2471 = lean_ctor_get(x_2470, 0); @@ -12828,7 +13214,7 @@ lean_inc(x_2490); x_2495 = l_Lean_Elab_Term_mkExplicitBinder(x_2490, x_2494); x_2496 = lean_array_push(x_4, x_2495); lean_inc(x_5); -x_2497 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2493, x_2496, x_5, x_2491); +x_2497 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2493, x_2496, x_5, x_2491); if (lean_obj_tag(x_2497) == 0) { lean_object* x_2498; lean_object* x_2499; lean_object* x_2500; lean_object* x_2501; lean_object* x_2502; lean_object* x_2503; lean_object* x_2504; lean_object* x_2505; lean_object* x_2506; lean_object* x_2507; lean_object* x_2508; lean_object* x_2509; lean_object* x_2510; lean_object* x_2511; lean_object* x_2512; lean_object* x_2513; lean_object* x_2514; lean_object* x_2515; lean_object* x_2516; lean_object* x_2517; lean_object* x_2518; lean_object* x_2519; lean_object* x_2520; lean_object* x_2521; lean_object* x_2522; lean_object* x_2523; lean_object* x_2524; lean_object* x_2525; lean_object* x_2526; lean_object* x_2527; lean_object* x_2528; lean_object* x_2529; lean_object* x_2530; lean_object* x_2531; lean_object* x_2532; lean_object* x_2533; lean_object* x_2534; lean_object* x_2535; lean_object* x_2536; lean_object* x_2537; lean_object* x_2538; lean_object* x_2539; @@ -12878,12 +13264,12 @@ x_2515 = l_Lean_nullKind___closed__2; x_2516 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2516, 0, x_2515); lean_ctor_set(x_2516, 1, x_2514); -x_2517 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2517 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2518 = lean_array_push(x_2517, x_2516); x_2519 = lean_array_push(x_2518, x_2510); -x_2520 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2520 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2521 = lean_array_push(x_2519, x_2520); -x_2522 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2522 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2523 = lean_array_push(x_2521, x_2522); lean_inc(x_11); x_2524 = lean_array_push(x_2508, x_11); @@ -12984,7 +13370,7 @@ lean_dec(x_2545); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2548 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2548 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2549 = l_Lean_Elab_Term_throwError___rarg(x_2486, x_2548, x_5, x_6); lean_dec(x_2486); x_2550 = lean_ctor_get(x_2549, 0); @@ -13078,7 +13464,7 @@ lean_inc(x_2569); x_2574 = l_Lean_Elab_Term_mkExplicitBinder(x_2569, x_2573); x_2575 = lean_array_push(x_4, x_2574); lean_inc(x_5); -x_2576 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2572, x_2575, x_5, x_2570); +x_2576 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2572, x_2575, x_5, x_2570); if (lean_obj_tag(x_2576) == 0) { lean_object* x_2577; lean_object* x_2578; lean_object* x_2579; lean_object* x_2580; lean_object* x_2581; lean_object* x_2582; lean_object* x_2583; lean_object* x_2584; lean_object* x_2585; lean_object* x_2586; lean_object* x_2587; lean_object* x_2588; lean_object* x_2589; lean_object* x_2590; lean_object* x_2591; lean_object* x_2592; lean_object* x_2593; lean_object* x_2594; lean_object* x_2595; lean_object* x_2596; lean_object* x_2597; lean_object* x_2598; lean_object* x_2599; lean_object* x_2600; lean_object* x_2601; lean_object* x_2602; lean_object* x_2603; lean_object* x_2604; lean_object* x_2605; lean_object* x_2606; lean_object* x_2607; lean_object* x_2608; lean_object* x_2609; lean_object* x_2610; lean_object* x_2611; lean_object* x_2612; lean_object* x_2613; lean_object* x_2614; lean_object* x_2615; lean_object* x_2616; lean_object* x_2617; lean_object* x_2618; @@ -13128,12 +13514,12 @@ x_2594 = l_Lean_nullKind___closed__2; x_2595 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2595, 0, x_2594); lean_ctor_set(x_2595, 1, x_2593); -x_2596 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2596 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2597 = lean_array_push(x_2596, x_2595); x_2598 = lean_array_push(x_2597, x_2589); -x_2599 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2599 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2600 = lean_array_push(x_2598, x_2599); -x_2601 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2601 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2602 = lean_array_push(x_2600, x_2601); lean_inc(x_11); x_2603 = lean_array_push(x_2587, x_11); @@ -13234,7 +13620,7 @@ lean_dec(x_2624); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2627 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2627 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2628 = l_Lean_Elab_Term_throwError___rarg(x_2565, x_2627, x_5, x_6); lean_dec(x_2565); x_2629 = lean_ctor_get(x_2628, 0); @@ -13343,7 +13729,7 @@ lean_inc(x_2654); x_2659 = l_Lean_Elab_Term_mkExplicitBinder(x_2654, x_2658); x_2660 = lean_array_push(x_4, x_2659); lean_inc(x_5); -x_2661 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2657, x_2660, x_5, x_2655); +x_2661 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2657, x_2660, x_5, x_2655); if (lean_obj_tag(x_2661) == 0) { lean_object* x_2662; lean_object* x_2663; lean_object* x_2664; lean_object* x_2665; lean_object* x_2666; lean_object* x_2667; lean_object* x_2668; lean_object* x_2669; lean_object* x_2670; lean_object* x_2671; lean_object* x_2672; lean_object* x_2673; lean_object* x_2674; lean_object* x_2675; lean_object* x_2676; lean_object* x_2677; lean_object* x_2678; lean_object* x_2679; lean_object* x_2680; lean_object* x_2681; lean_object* x_2682; lean_object* x_2683; lean_object* x_2684; lean_object* x_2685; lean_object* x_2686; lean_object* x_2687; lean_object* x_2688; lean_object* x_2689; lean_object* x_2690; lean_object* x_2691; lean_object* x_2692; lean_object* x_2693; lean_object* x_2694; lean_object* x_2695; lean_object* x_2696; lean_object* x_2697; lean_object* x_2698; lean_object* x_2699; lean_object* x_2700; lean_object* x_2701; lean_object* x_2702; lean_object* x_2703; @@ -13393,12 +13779,12 @@ x_2679 = l_Lean_nullKind___closed__2; x_2680 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2680, 0, x_2679); lean_ctor_set(x_2680, 1, x_2678); -x_2681 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2681 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2682 = lean_array_push(x_2681, x_2680); x_2683 = lean_array_push(x_2682, x_2674); -x_2684 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2684 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2685 = lean_array_push(x_2683, x_2684); -x_2686 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2686 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2687 = lean_array_push(x_2685, x_2686); lean_inc(x_11); x_2688 = lean_array_push(x_2672, x_11); @@ -13499,7 +13885,7 @@ lean_dec(x_2709); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_2712 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_2712 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_2713 = l_Lean_Elab_Term_throwError___rarg(x_2650, x_2712, x_5, x_6); lean_dec(x_2650); x_2714 = lean_ctor_get(x_2713, 0); @@ -13591,7 +13977,7 @@ lean_inc(x_2740); x_2744 = l_Lean_Elab_Term_mkExplicitBinder(x_2740, x_2743); x_2745 = lean_array_push(x_4, x_2744); lean_inc(x_5); -x_2746 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2742, x_2745, x_5, x_2741); +x_2746 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2742, x_2745, x_5, x_2741); if (lean_obj_tag(x_2746) == 0) { lean_object* x_2747; lean_object* x_2748; lean_object* x_2749; lean_object* x_2750; lean_object* x_2751; lean_object* x_2752; lean_object* x_2753; lean_object* x_2754; lean_object* x_2755; lean_object* x_2756; lean_object* x_2757; lean_object* x_2758; lean_object* x_2759; lean_object* x_2760; lean_object* x_2761; lean_object* x_2762; lean_object* x_2763; lean_object* x_2764; lean_object* x_2765; lean_object* x_2766; lean_object* x_2767; lean_object* x_2768; lean_object* x_2769; lean_object* x_2770; lean_object* x_2771; lean_object* x_2772; lean_object* x_2773; lean_object* x_2774; lean_object* x_2775; lean_object* x_2776; lean_object* x_2777; lean_object* x_2778; lean_object* x_2779; lean_object* x_2780; lean_object* x_2781; lean_object* x_2782; lean_object* x_2783; lean_object* x_2784; lean_object* x_2785; lean_object* x_2786; lean_object* x_2787; lean_object* x_2788; @@ -13641,12 +14027,12 @@ x_2764 = l_Lean_nullKind___closed__2; x_2765 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2765, 0, x_2764); lean_ctor_set(x_2765, 1, x_2763); -x_2766 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2766 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2767 = lean_array_push(x_2766, x_2765); x_2768 = lean_array_push(x_2767, x_2759); -x_2769 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2769 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2770 = lean_array_push(x_2768, x_2769); -x_2771 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2771 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2772 = lean_array_push(x_2770, x_2771); lean_inc(x_11); x_2773 = lean_array_push(x_2757, x_11); @@ -13731,7 +14117,7 @@ else lean_object* x_2793; lean_object* x_2794; lean_object* x_2795; x_2793 = l_Lean_Syntax_getArg(x_2731, x_2724); lean_dec(x_2731); -x_2794 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_2728, x_5, x_6); +x_2794 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_2728, x_5, x_6); x_2795 = lean_ctor_get(x_2794, 0); lean_inc(x_2795); if (lean_obj_tag(x_2795) == 0) @@ -13754,7 +14140,7 @@ lean_inc(x_2798); x_2802 = l_Lean_Elab_Term_mkExplicitBinder(x_2798, x_2801); x_2803 = lean_array_push(x_4, x_2802); lean_inc(x_5); -x_2804 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2800, x_2803, x_5, x_2799); +x_2804 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2800, x_2803, x_5, x_2799); if (lean_obj_tag(x_2804) == 0) { lean_object* x_2805; lean_object* x_2806; lean_object* x_2807; lean_object* x_2808; lean_object* x_2809; lean_object* x_2810; lean_object* x_2811; lean_object* x_2812; lean_object* x_2813; lean_object* x_2814; lean_object* x_2815; lean_object* x_2816; lean_object* x_2817; lean_object* x_2818; lean_object* x_2819; lean_object* x_2820; lean_object* x_2821; lean_object* x_2822; lean_object* x_2823; lean_object* x_2824; lean_object* x_2825; lean_object* x_2826; lean_object* x_2827; lean_object* x_2828; lean_object* x_2829; lean_object* x_2830; lean_object* x_2831; lean_object* x_2832; lean_object* x_2833; lean_object* x_2834; lean_object* x_2835; lean_object* x_2836; lean_object* x_2837; lean_object* x_2838; lean_object* x_2839; lean_object* x_2840; lean_object* x_2841; lean_object* x_2842; lean_object* x_2843; lean_object* x_2844; lean_object* x_2845; lean_object* x_2846; @@ -13804,12 +14190,12 @@ x_2822 = l_Lean_nullKind___closed__2; x_2823 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2823, 0, x_2822); lean_ctor_set(x_2823, 1, x_2821); -x_2824 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2824 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2825 = lean_array_push(x_2824, x_2823); x_2826 = lean_array_push(x_2825, x_2817); -x_2827 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2827 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2828 = lean_array_push(x_2826, x_2827); -x_2829 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2829 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2830 = lean_array_push(x_2828, x_2829); lean_inc(x_11); x_2831 = lean_array_push(x_2815, x_11); @@ -13902,7 +14288,7 @@ lean_dec(x_2795); x_2853 = lean_nat_add(x_3, x_2724); lean_dec(x_3); x_2854 = x_2852; -x_2855 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(x_2793, x_2727, x_2854); +x_2855 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(x_2793, x_2727, x_2854); x_2856 = x_2855; x_2857 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_2856, x_2856, x_2727, x_4); lean_dec(x_2856); @@ -13931,7 +14317,7 @@ lean_inc(x_2860); x_2864 = l_Lean_Elab_Term_mkExplicitBinder(x_2860, x_2863); x_2865 = lean_array_push(x_4, x_2864); lean_inc(x_5); -x_2866 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2862, x_2865, x_5, x_2861); +x_2866 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2862, x_2865, x_5, x_2861); if (lean_obj_tag(x_2866) == 0) { lean_object* x_2867; lean_object* x_2868; lean_object* x_2869; lean_object* x_2870; lean_object* x_2871; lean_object* x_2872; lean_object* x_2873; lean_object* x_2874; lean_object* x_2875; lean_object* x_2876; lean_object* x_2877; lean_object* x_2878; lean_object* x_2879; lean_object* x_2880; lean_object* x_2881; lean_object* x_2882; lean_object* x_2883; lean_object* x_2884; lean_object* x_2885; lean_object* x_2886; lean_object* x_2887; lean_object* x_2888; lean_object* x_2889; lean_object* x_2890; lean_object* x_2891; lean_object* x_2892; lean_object* x_2893; lean_object* x_2894; lean_object* x_2895; lean_object* x_2896; lean_object* x_2897; lean_object* x_2898; lean_object* x_2899; lean_object* x_2900; lean_object* x_2901; lean_object* x_2902; lean_object* x_2903; lean_object* x_2904; lean_object* x_2905; lean_object* x_2906; lean_object* x_2907; lean_object* x_2908; @@ -13981,12 +14367,12 @@ x_2884 = l_Lean_nullKind___closed__2; x_2885 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2885, 0, x_2884); lean_ctor_set(x_2885, 1, x_2883); -x_2886 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2886 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2887 = lean_array_push(x_2886, x_2885); x_2888 = lean_array_push(x_2887, x_2879); -x_2889 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2889 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2890 = lean_array_push(x_2888, x_2889); -x_2891 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2891 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2892 = lean_array_push(x_2890, x_2891); lean_inc(x_11); x_2893 = lean_array_push(x_2877, x_11); @@ -14084,7 +14470,7 @@ lean_inc(x_2914); x_2918 = l_Lean_Elab_Term_mkExplicitBinder(x_2914, x_2917); x_2919 = lean_array_push(x_4, x_2918); lean_inc(x_5); -x_2920 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_2916, x_2919, x_5, x_2915); +x_2920 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_2916, x_2919, x_5, x_2915); if (lean_obj_tag(x_2920) == 0) { lean_object* x_2921; lean_object* x_2922; lean_object* x_2923; lean_object* x_2924; lean_object* x_2925; lean_object* x_2926; lean_object* x_2927; lean_object* x_2928; lean_object* x_2929; lean_object* x_2930; lean_object* x_2931; lean_object* x_2932; lean_object* x_2933; lean_object* x_2934; lean_object* x_2935; lean_object* x_2936; lean_object* x_2937; lean_object* x_2938; lean_object* x_2939; lean_object* x_2940; lean_object* x_2941; lean_object* x_2942; lean_object* x_2943; lean_object* x_2944; lean_object* x_2945; lean_object* x_2946; lean_object* x_2947; lean_object* x_2948; lean_object* x_2949; lean_object* x_2950; lean_object* x_2951; lean_object* x_2952; lean_object* x_2953; lean_object* x_2954; lean_object* x_2955; lean_object* x_2956; lean_object* x_2957; lean_object* x_2958; lean_object* x_2959; lean_object* x_2960; lean_object* x_2961; lean_object* x_2962; @@ -14134,12 +14520,12 @@ x_2938 = l_Lean_nullKind___closed__2; x_2939 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_2939, 0, x_2938); lean_ctor_set(x_2939, 1, x_2937); -x_2940 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_2940 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_2941 = lean_array_push(x_2940, x_2939); x_2942 = lean_array_push(x_2941, x_2933); -x_2943 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_2943 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_2944 = lean_array_push(x_2942, x_2943); -x_2945 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2945 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_2946 = lean_array_push(x_2944, x_2945); lean_inc(x_11); x_2947 = lean_array_push(x_2931, x_11); @@ -14357,7 +14743,7 @@ lean_inc(x_2999); x_3004 = l_Lean_Elab_Term_mkExplicitBinder(x_2999, x_3003); x_3005 = lean_array_push(x_4, x_3004); lean_inc(x_5); -x_3006 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3002, x_3005, x_5, x_3000); +x_3006 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3002, x_3005, x_5, x_3000); if (lean_obj_tag(x_3006) == 0) { lean_object* x_3007; lean_object* x_3008; lean_object* x_3009; lean_object* x_3010; lean_object* x_3011; lean_object* x_3012; lean_object* x_3013; lean_object* x_3014; lean_object* x_3015; lean_object* x_3016; lean_object* x_3017; lean_object* x_3018; lean_object* x_3019; lean_object* x_3020; lean_object* x_3021; lean_object* x_3022; lean_object* x_3023; lean_object* x_3024; lean_object* x_3025; lean_object* x_3026; lean_object* x_3027; lean_object* x_3028; lean_object* x_3029; lean_object* x_3030; lean_object* x_3031; lean_object* x_3032; lean_object* x_3033; lean_object* x_3034; lean_object* x_3035; lean_object* x_3036; lean_object* x_3037; lean_object* x_3038; lean_object* x_3039; lean_object* x_3040; lean_object* x_3041; lean_object* x_3042; lean_object* x_3043; lean_object* x_3044; lean_object* x_3045; lean_object* x_3046; lean_object* x_3047; lean_object* x_3048; @@ -14407,12 +14793,12 @@ x_3024 = l_Lean_nullKind___closed__2; x_3025 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3025, 0, x_3024); lean_ctor_set(x_3025, 1, x_3023); -x_3026 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3026 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3027 = lean_array_push(x_3026, x_3025); x_3028 = lean_array_push(x_3027, x_3019); -x_3029 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3029 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3030 = lean_array_push(x_3028, x_3029); -x_3031 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3031 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3032 = lean_array_push(x_3030, x_3031); lean_inc(x_11); x_3033 = lean_array_push(x_3017, x_11); @@ -14512,7 +14898,7 @@ lean_dec(x_3054); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3057 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3057 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3058 = l_Lean_Elab_Term_throwError___rarg(x_11, x_3057, x_5, x_6); lean_dec(x_11); x_3059 = lean_ctor_get(x_3058, 0); @@ -14612,7 +14998,7 @@ lean_inc(x_3079); x_3084 = l_Lean_Elab_Term_mkExplicitBinder(x_3079, x_3083); x_3085 = lean_array_push(x_4, x_3084); lean_inc(x_5); -x_3086 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3082, x_3085, x_5, x_3080); +x_3086 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3082, x_3085, x_5, x_3080); if (lean_obj_tag(x_3086) == 0) { lean_object* x_3087; lean_object* x_3088; lean_object* x_3089; lean_object* x_3090; lean_object* x_3091; lean_object* x_3092; lean_object* x_3093; lean_object* x_3094; lean_object* x_3095; lean_object* x_3096; lean_object* x_3097; lean_object* x_3098; lean_object* x_3099; lean_object* x_3100; lean_object* x_3101; lean_object* x_3102; lean_object* x_3103; lean_object* x_3104; lean_object* x_3105; lean_object* x_3106; lean_object* x_3107; lean_object* x_3108; lean_object* x_3109; lean_object* x_3110; lean_object* x_3111; lean_object* x_3112; lean_object* x_3113; lean_object* x_3114; lean_object* x_3115; lean_object* x_3116; lean_object* x_3117; lean_object* x_3118; lean_object* x_3119; lean_object* x_3120; lean_object* x_3121; lean_object* x_3122; lean_object* x_3123; lean_object* x_3124; lean_object* x_3125; lean_object* x_3126; lean_object* x_3127; lean_object* x_3128; @@ -14662,12 +15048,12 @@ x_3104 = l_Lean_nullKind___closed__2; x_3105 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3105, 0, x_3104); lean_ctor_set(x_3105, 1, x_3103); -x_3106 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3106 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3107 = lean_array_push(x_3106, x_3105); x_3108 = lean_array_push(x_3107, x_3099); -x_3109 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3109 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3110 = lean_array_push(x_3108, x_3109); -x_3111 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3111 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3112 = lean_array_push(x_3110, x_3111); lean_inc(x_11); x_3113 = lean_array_push(x_3097, x_11); @@ -14768,7 +15154,7 @@ lean_dec(x_3134); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3137 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3137 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3138 = l_Lean_Elab_Term_throwError___rarg(x_3075, x_3137, x_5, x_6); lean_dec(x_3075); x_3139 = lean_ctor_get(x_3138, 0); @@ -14869,7 +15255,7 @@ lean_inc(x_3159); x_3164 = l_Lean_Elab_Term_mkExplicitBinder(x_3159, x_3163); x_3165 = lean_array_push(x_4, x_3164); lean_inc(x_5); -x_3166 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3162, x_3165, x_5, x_3160); +x_3166 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3162, x_3165, x_5, x_3160); if (lean_obj_tag(x_3166) == 0) { lean_object* x_3167; lean_object* x_3168; lean_object* x_3169; lean_object* x_3170; lean_object* x_3171; lean_object* x_3172; lean_object* x_3173; lean_object* x_3174; lean_object* x_3175; lean_object* x_3176; lean_object* x_3177; lean_object* x_3178; lean_object* x_3179; lean_object* x_3180; lean_object* x_3181; lean_object* x_3182; lean_object* x_3183; lean_object* x_3184; lean_object* x_3185; lean_object* x_3186; lean_object* x_3187; lean_object* x_3188; lean_object* x_3189; lean_object* x_3190; lean_object* x_3191; lean_object* x_3192; lean_object* x_3193; lean_object* x_3194; lean_object* x_3195; lean_object* x_3196; lean_object* x_3197; lean_object* x_3198; lean_object* x_3199; lean_object* x_3200; lean_object* x_3201; lean_object* x_3202; lean_object* x_3203; lean_object* x_3204; lean_object* x_3205; lean_object* x_3206; lean_object* x_3207; lean_object* x_3208; @@ -14919,12 +15305,12 @@ x_3184 = l_Lean_nullKind___closed__2; x_3185 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3185, 0, x_3184); lean_ctor_set(x_3185, 1, x_3183); -x_3186 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3186 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3187 = lean_array_push(x_3186, x_3185); x_3188 = lean_array_push(x_3187, x_3179); -x_3189 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3189 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3190 = lean_array_push(x_3188, x_3189); -x_3191 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3191 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3192 = lean_array_push(x_3190, x_3191); lean_inc(x_11); x_3193 = lean_array_push(x_3177, x_11); @@ -15025,7 +15411,7 @@ lean_dec(x_3214); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3217 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3217 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3218 = l_Lean_Elab_Term_throwError___rarg(x_3155, x_3217, x_5, x_6); lean_dec(x_3155); x_3219 = lean_ctor_get(x_3218, 0); @@ -15141,7 +15527,7 @@ lean_inc(x_3245); x_3250 = l_Lean_Elab_Term_mkExplicitBinder(x_3245, x_3249); x_3251 = lean_array_push(x_4, x_3250); lean_inc(x_5); -x_3252 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3248, x_3251, x_5, x_3246); +x_3252 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3248, x_3251, x_5, x_3246); if (lean_obj_tag(x_3252) == 0) { lean_object* x_3253; lean_object* x_3254; lean_object* x_3255; lean_object* x_3256; lean_object* x_3257; lean_object* x_3258; lean_object* x_3259; lean_object* x_3260; lean_object* x_3261; lean_object* x_3262; lean_object* x_3263; lean_object* x_3264; lean_object* x_3265; lean_object* x_3266; lean_object* x_3267; lean_object* x_3268; lean_object* x_3269; lean_object* x_3270; lean_object* x_3271; lean_object* x_3272; lean_object* x_3273; lean_object* x_3274; lean_object* x_3275; lean_object* x_3276; lean_object* x_3277; lean_object* x_3278; lean_object* x_3279; lean_object* x_3280; lean_object* x_3281; lean_object* x_3282; lean_object* x_3283; lean_object* x_3284; lean_object* x_3285; lean_object* x_3286; lean_object* x_3287; lean_object* x_3288; lean_object* x_3289; lean_object* x_3290; lean_object* x_3291; lean_object* x_3292; lean_object* x_3293; lean_object* x_3294; @@ -15191,12 +15577,12 @@ x_3270 = l_Lean_nullKind___closed__2; x_3271 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3271, 0, x_3270); lean_ctor_set(x_3271, 1, x_3269); -x_3272 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3272 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3273 = lean_array_push(x_3272, x_3271); x_3274 = lean_array_push(x_3273, x_3265); -x_3275 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3275 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3276 = lean_array_push(x_3274, x_3275); -x_3277 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3277 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3278 = lean_array_push(x_3276, x_3277); lean_inc(x_11); x_3279 = lean_array_push(x_3263, x_11); @@ -15297,7 +15683,7 @@ lean_dec(x_3300); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3303 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3303 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3304 = l_Lean_Elab_Term_throwError___rarg(x_3241, x_3303, x_5, x_6); lean_dec(x_3241); x_3305 = lean_ctor_get(x_3304, 0); @@ -15389,7 +15775,7 @@ lean_inc(x_3331); x_3335 = l_Lean_Elab_Term_mkExplicitBinder(x_3331, x_3334); x_3336 = lean_array_push(x_4, x_3335); lean_inc(x_5); -x_3337 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3333, x_3336, x_5, x_3332); +x_3337 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3333, x_3336, x_5, x_3332); if (lean_obj_tag(x_3337) == 0) { lean_object* x_3338; lean_object* x_3339; lean_object* x_3340; lean_object* x_3341; lean_object* x_3342; lean_object* x_3343; lean_object* x_3344; lean_object* x_3345; lean_object* x_3346; lean_object* x_3347; lean_object* x_3348; lean_object* x_3349; lean_object* x_3350; lean_object* x_3351; lean_object* x_3352; lean_object* x_3353; lean_object* x_3354; lean_object* x_3355; lean_object* x_3356; lean_object* x_3357; lean_object* x_3358; lean_object* x_3359; lean_object* x_3360; lean_object* x_3361; lean_object* x_3362; lean_object* x_3363; lean_object* x_3364; lean_object* x_3365; lean_object* x_3366; lean_object* x_3367; lean_object* x_3368; lean_object* x_3369; lean_object* x_3370; lean_object* x_3371; lean_object* x_3372; lean_object* x_3373; lean_object* x_3374; lean_object* x_3375; lean_object* x_3376; lean_object* x_3377; lean_object* x_3378; lean_object* x_3379; @@ -15439,12 +15825,12 @@ x_3355 = l_Lean_nullKind___closed__2; x_3356 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3356, 0, x_3355); lean_ctor_set(x_3356, 1, x_3354); -x_3357 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3357 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3358 = lean_array_push(x_3357, x_3356); x_3359 = lean_array_push(x_3358, x_3350); -x_3360 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3360 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3361 = lean_array_push(x_3359, x_3360); -x_3362 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3362 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3363 = lean_array_push(x_3361, x_3362); lean_inc(x_11); x_3364 = lean_array_push(x_3348, x_11); @@ -15529,7 +15915,7 @@ else lean_object* x_3384; lean_object* x_3385; lean_object* x_3386; x_3384 = l_Lean_Syntax_getArg(x_3322, x_3315); lean_dec(x_3322); -x_3385 = l___private_Init_Lean_Elab_Binders_9__getFunBinderIds_x3f(x_3319, x_5, x_6); +x_3385 = l___private_Init_Lean_Elab_Binders_10__getFunBinderIds_x3f(x_3319, x_5, x_6); x_3386 = lean_ctor_get(x_3385, 0); lean_inc(x_3386); if (lean_obj_tag(x_3386) == 0) @@ -15552,7 +15938,7 @@ lean_inc(x_3389); x_3393 = l_Lean_Elab_Term_mkExplicitBinder(x_3389, x_3392); x_3394 = lean_array_push(x_4, x_3393); lean_inc(x_5); -x_3395 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3391, x_3394, x_5, x_3390); +x_3395 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3391, x_3394, x_5, x_3390); if (lean_obj_tag(x_3395) == 0) { lean_object* x_3396; lean_object* x_3397; lean_object* x_3398; lean_object* x_3399; lean_object* x_3400; lean_object* x_3401; lean_object* x_3402; lean_object* x_3403; lean_object* x_3404; lean_object* x_3405; lean_object* x_3406; lean_object* x_3407; lean_object* x_3408; lean_object* x_3409; lean_object* x_3410; lean_object* x_3411; lean_object* x_3412; lean_object* x_3413; lean_object* x_3414; lean_object* x_3415; lean_object* x_3416; lean_object* x_3417; lean_object* x_3418; lean_object* x_3419; lean_object* x_3420; lean_object* x_3421; lean_object* x_3422; lean_object* x_3423; lean_object* x_3424; lean_object* x_3425; lean_object* x_3426; lean_object* x_3427; lean_object* x_3428; lean_object* x_3429; lean_object* x_3430; lean_object* x_3431; lean_object* x_3432; lean_object* x_3433; lean_object* x_3434; lean_object* x_3435; lean_object* x_3436; lean_object* x_3437; @@ -15602,12 +15988,12 @@ x_3413 = l_Lean_nullKind___closed__2; x_3414 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3414, 0, x_3413); lean_ctor_set(x_3414, 1, x_3412); -x_3415 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3415 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3416 = lean_array_push(x_3415, x_3414); x_3417 = lean_array_push(x_3416, x_3408); -x_3418 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3418 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3419 = lean_array_push(x_3417, x_3418); -x_3420 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3420 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3421 = lean_array_push(x_3419, x_3420); lean_inc(x_11); x_3422 = lean_array_push(x_3406, x_11); @@ -15700,7 +16086,7 @@ lean_dec(x_3386); x_3444 = lean_nat_add(x_3, x_3315); lean_dec(x_3); x_3445 = x_3443; -x_3446 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___spec__1(x_3384, x_3318, x_3445); +x_3446 = l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___spec__1(x_3384, x_3318, x_3445); x_3447 = x_3446; x_3448 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_3447, x_3447, x_3318, x_4); lean_dec(x_3447); @@ -15729,7 +16115,7 @@ lean_inc(x_3451); x_3455 = l_Lean_Elab_Term_mkExplicitBinder(x_3451, x_3454); x_3456 = lean_array_push(x_4, x_3455); lean_inc(x_5); -x_3457 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3453, x_3456, x_5, x_3452); +x_3457 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3453, x_3456, x_5, x_3452); if (lean_obj_tag(x_3457) == 0) { lean_object* x_3458; lean_object* x_3459; lean_object* x_3460; lean_object* x_3461; lean_object* x_3462; lean_object* x_3463; lean_object* x_3464; lean_object* x_3465; lean_object* x_3466; lean_object* x_3467; lean_object* x_3468; lean_object* x_3469; lean_object* x_3470; lean_object* x_3471; lean_object* x_3472; lean_object* x_3473; lean_object* x_3474; lean_object* x_3475; lean_object* x_3476; lean_object* x_3477; lean_object* x_3478; lean_object* x_3479; lean_object* x_3480; lean_object* x_3481; lean_object* x_3482; lean_object* x_3483; lean_object* x_3484; lean_object* x_3485; lean_object* x_3486; lean_object* x_3487; lean_object* x_3488; lean_object* x_3489; lean_object* x_3490; lean_object* x_3491; lean_object* x_3492; lean_object* x_3493; lean_object* x_3494; lean_object* x_3495; lean_object* x_3496; lean_object* x_3497; lean_object* x_3498; lean_object* x_3499; @@ -15779,12 +16165,12 @@ x_3475 = l_Lean_nullKind___closed__2; x_3476 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3476, 0, x_3475); lean_ctor_set(x_3476, 1, x_3474); -x_3477 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3477 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3478 = lean_array_push(x_3477, x_3476); x_3479 = lean_array_push(x_3478, x_3470); -x_3480 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3480 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3481 = lean_array_push(x_3479, x_3480); -x_3482 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3482 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3483 = lean_array_push(x_3481, x_3482); lean_inc(x_11); x_3484 = lean_array_push(x_3468, x_11); @@ -15882,7 +16268,7 @@ lean_inc(x_3505); x_3509 = l_Lean_Elab_Term_mkExplicitBinder(x_3505, x_3508); x_3510 = lean_array_push(x_4, x_3509); lean_inc(x_5); -x_3511 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3507, x_3510, x_5, x_3506); +x_3511 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3507, x_3510, x_5, x_3506); if (lean_obj_tag(x_3511) == 0) { lean_object* x_3512; lean_object* x_3513; lean_object* x_3514; lean_object* x_3515; lean_object* x_3516; lean_object* x_3517; lean_object* x_3518; lean_object* x_3519; lean_object* x_3520; lean_object* x_3521; lean_object* x_3522; lean_object* x_3523; lean_object* x_3524; lean_object* x_3525; lean_object* x_3526; lean_object* x_3527; lean_object* x_3528; lean_object* x_3529; lean_object* x_3530; lean_object* x_3531; lean_object* x_3532; lean_object* x_3533; lean_object* x_3534; lean_object* x_3535; lean_object* x_3536; lean_object* x_3537; lean_object* x_3538; lean_object* x_3539; lean_object* x_3540; lean_object* x_3541; lean_object* x_3542; lean_object* x_3543; lean_object* x_3544; lean_object* x_3545; lean_object* x_3546; lean_object* x_3547; lean_object* x_3548; lean_object* x_3549; lean_object* x_3550; lean_object* x_3551; lean_object* x_3552; lean_object* x_3553; @@ -15932,12 +16318,12 @@ x_3529 = l_Lean_nullKind___closed__2; x_3530 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3530, 0, x_3529); lean_ctor_set(x_3530, 1, x_3528); -x_3531 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3531 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3532 = lean_array_push(x_3531, x_3530); x_3533 = lean_array_push(x_3532, x_3524); -x_3534 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3534 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3535 = lean_array_push(x_3533, x_3534); -x_3536 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3536 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3537 = lean_array_push(x_3535, x_3536); lean_inc(x_11); x_3538 = lean_array_push(x_3522, x_11); @@ -16110,7 +16496,7 @@ lean_inc(x_3577); x_3582 = l_Lean_Elab_Term_mkExplicitBinder(x_3577, x_3581); x_3583 = lean_array_push(x_4, x_3582); lean_inc(x_5); -x_3584 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3580, x_3583, x_5, x_3578); +x_3584 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3580, x_3583, x_5, x_3578); if (lean_obj_tag(x_3584) == 0) { lean_object* x_3585; lean_object* x_3586; uint8_t x_3587; @@ -16149,12 +16535,12 @@ x_3601 = l_Lean_nullKind___closed__2; x_3602 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3602, 0, x_3601); lean_ctor_set(x_3602, 1, x_3600); -x_3603 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3603 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3604 = lean_array_push(x_3603, x_3602); x_3605 = lean_array_push(x_3604, x_3596); -x_3606 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3606 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3607 = lean_array_push(x_3605, x_3606); -x_3608 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3608 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3609 = lean_array_push(x_3607, x_3608); lean_inc(x_11); x_3610 = lean_array_push(x_3594, x_11); @@ -16237,12 +16623,12 @@ x_3645 = l_Lean_nullKind___closed__2; x_3646 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3646, 0, x_3645); lean_ctor_set(x_3646, 1, x_3644); -x_3647 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3647 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3648 = lean_array_push(x_3647, x_3646); x_3649 = lean_array_push(x_3648, x_3640); -x_3650 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3650 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3651 = lean_array_push(x_3649, x_3650); -x_3652 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3652 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3653 = lean_array_push(x_3651, x_3652); lean_inc(x_11); x_3654 = lean_array_push(x_3638, x_11); @@ -16322,12 +16708,12 @@ x_3683 = l_Lean_nullKind___closed__2; x_3684 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3684, 0, x_3683); lean_ctor_set(x_3684, 1, x_3682); -x_3685 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3685 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3686 = lean_array_push(x_3685, x_3684); x_3687 = lean_array_push(x_3686, x_3678); -x_3688 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3688 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3689 = lean_array_push(x_3687, x_3688); -x_3690 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3690 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3691 = lean_array_push(x_3689, x_3690); lean_inc(x_11); x_3692 = lean_array_push(x_3676, x_11); @@ -16422,7 +16808,7 @@ lean_dec(x_3713); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3716 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3716 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3717 = l_Lean_Elab_Term_throwError___rarg(x_11, x_3716, x_5, x_6); lean_dec(x_11); x_3718 = !lean_is_exclusive(x_3717); @@ -16488,7 +16874,7 @@ lean_inc(x_3731); x_3736 = l_Lean_Elab_Term_mkExplicitBinder(x_3731, x_3735); x_3737 = lean_array_push(x_4, x_3736); lean_inc(x_5); -x_3738 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3734, x_3737, x_5, x_3732); +x_3738 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3734, x_3737, x_5, x_3732); if (lean_obj_tag(x_3738) == 0) { lean_object* x_3739; lean_object* x_3740; uint8_t x_3741; @@ -16527,12 +16913,12 @@ x_3755 = l_Lean_nullKind___closed__2; x_3756 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3756, 0, x_3755); lean_ctor_set(x_3756, 1, x_3754); -x_3757 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3757 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3758 = lean_array_push(x_3757, x_3756); x_3759 = lean_array_push(x_3758, x_3750); -x_3760 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3760 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3761 = lean_array_push(x_3759, x_3760); -x_3762 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3762 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3763 = lean_array_push(x_3761, x_3762); lean_inc(x_11); x_3764 = lean_array_push(x_3748, x_11); @@ -16615,12 +17001,12 @@ x_3799 = l_Lean_nullKind___closed__2; x_3800 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3800, 0, x_3799); lean_ctor_set(x_3800, 1, x_3798); -x_3801 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3801 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3802 = lean_array_push(x_3801, x_3800); x_3803 = lean_array_push(x_3802, x_3794); -x_3804 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3804 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3805 = lean_array_push(x_3803, x_3804); -x_3806 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3806 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3807 = lean_array_push(x_3805, x_3806); lean_inc(x_11); x_3808 = lean_array_push(x_3792, x_11); @@ -16700,12 +17086,12 @@ x_3837 = l_Lean_nullKind___closed__2; x_3838 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3838, 0, x_3837); lean_ctor_set(x_3838, 1, x_3836); -x_3839 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3839 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3840 = lean_array_push(x_3839, x_3838); x_3841 = lean_array_push(x_3840, x_3832); -x_3842 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3842 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3843 = lean_array_push(x_3841, x_3842); -x_3844 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3844 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3845 = lean_array_push(x_3843, x_3844); lean_inc(x_11); x_3846 = lean_array_push(x_3830, x_11); @@ -16800,7 +17186,7 @@ lean_dec(x_3867); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_3870 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_3870 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_3871 = l_Lean_Elab_Term_throwError___rarg(x_11, x_3870, x_5, x_6); lean_dec(x_11); x_3872 = !lean_is_exclusive(x_3871); @@ -16865,7 +17251,7 @@ lean_inc(x_3885); x_3890 = l_Lean_Elab_Term_mkExplicitBinder(x_3885, x_3889); x_3891 = lean_array_push(x_4, x_3890); lean_inc(x_5); -x_3892 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3888, x_3891, x_5, x_3886); +x_3892 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3888, x_3891, x_5, x_3886); if (lean_obj_tag(x_3892) == 0) { lean_object* x_3893; lean_object* x_3894; uint8_t x_3895; @@ -16904,12 +17290,12 @@ x_3909 = l_Lean_nullKind___closed__2; x_3910 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3910, 0, x_3909); lean_ctor_set(x_3910, 1, x_3908); -x_3911 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3911 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3912 = lean_array_push(x_3911, x_3910); x_3913 = lean_array_push(x_3912, x_3904); -x_3914 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3914 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3915 = lean_array_push(x_3913, x_3914); -x_3916 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3916 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3917 = lean_array_push(x_3915, x_3916); lean_inc(x_11); x_3918 = lean_array_push(x_3902, x_11); @@ -16992,12 +17378,12 @@ x_3953 = l_Lean_nullKind___closed__2; x_3954 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3954, 0, x_3953); lean_ctor_set(x_3954, 1, x_3952); -x_3955 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3955 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3956 = lean_array_push(x_3955, x_3954); x_3957 = lean_array_push(x_3956, x_3948); -x_3958 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3958 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3959 = lean_array_push(x_3957, x_3958); -x_3960 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3960 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3961 = lean_array_push(x_3959, x_3960); lean_inc(x_11); x_3962 = lean_array_push(x_3946, x_11); @@ -17077,12 +17463,12 @@ x_3991 = l_Lean_nullKind___closed__2; x_3992 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3992, 0, x_3991); lean_ctor_set(x_3992, 1, x_3990); -x_3993 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_3993 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_3994 = lean_array_push(x_3993, x_3992); x_3995 = lean_array_push(x_3994, x_3986); -x_3996 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_3996 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_3997 = lean_array_push(x_3995, x_3996); -x_3998 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_3998 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3999 = lean_array_push(x_3997, x_3998); lean_inc(x_11); x_4000 = lean_array_push(x_3984, x_11); @@ -17177,7 +17563,7 @@ lean_dec(x_4021); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_4024 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_4024 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_4025 = l_Lean_Elab_Term_throwError___rarg(x_11, x_4024, x_5, x_6); lean_dec(x_11); x_4026 = !lean_is_exclusive(x_4025); @@ -17241,7 +17627,7 @@ lean_inc(x_4039); x_4044 = l_Lean_Elab_Term_mkExplicitBinder(x_4039, x_4043); x_4045 = lean_array_push(x_4, x_4044); lean_inc(x_5); -x_4046 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_4042, x_4045, x_5, x_4040); +x_4046 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_4042, x_4045, x_5, x_4040); if (lean_obj_tag(x_4046) == 0) { lean_object* x_4047; lean_object* x_4048; uint8_t x_4049; @@ -17280,12 +17666,12 @@ x_4063 = l_Lean_nullKind___closed__2; x_4064 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4064, 0, x_4063); lean_ctor_set(x_4064, 1, x_4062); -x_4065 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4065 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4066 = lean_array_push(x_4065, x_4064); x_4067 = lean_array_push(x_4066, x_4058); -x_4068 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4068 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4069 = lean_array_push(x_4067, x_4068); -x_4070 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4070 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4071 = lean_array_push(x_4069, x_4070); lean_inc(x_11); x_4072 = lean_array_push(x_4056, x_11); @@ -17368,12 +17754,12 @@ x_4107 = l_Lean_nullKind___closed__2; x_4108 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4108, 0, x_4107); lean_ctor_set(x_4108, 1, x_4106); -x_4109 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4109 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4110 = lean_array_push(x_4109, x_4108); x_4111 = lean_array_push(x_4110, x_4102); -x_4112 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4112 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4113 = lean_array_push(x_4111, x_4112); -x_4114 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4114 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4115 = lean_array_push(x_4113, x_4114); lean_inc(x_11); x_4116 = lean_array_push(x_4100, x_11); @@ -17453,12 +17839,12 @@ x_4145 = l_Lean_nullKind___closed__2; x_4146 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4146, 0, x_4145); lean_ctor_set(x_4146, 1, x_4144); -x_4147 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4147 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4148 = lean_array_push(x_4147, x_4146); x_4149 = lean_array_push(x_4148, x_4140); -x_4150 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4150 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4151 = lean_array_push(x_4149, x_4150); -x_4152 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4152 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4153 = lean_array_push(x_4151, x_4152); lean_inc(x_11); x_4154 = lean_array_push(x_4138, x_11); @@ -17553,7 +17939,7 @@ lean_dec(x_4175); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_4178 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_4178 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_4179 = l_Lean_Elab_Term_throwError___rarg(x_11, x_4178, x_5, x_6); lean_dec(x_11); x_4180 = !lean_is_exclusive(x_4179); @@ -17616,7 +18002,7 @@ lean_inc(x_4193); x_4198 = l_Lean_Elab_Term_mkExplicitBinder(x_4193, x_4197); x_4199 = lean_array_push(x_4, x_4198); lean_inc(x_5); -x_4200 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_4196, x_4199, x_5, x_4194); +x_4200 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_4196, x_4199, x_5, x_4194); if (lean_obj_tag(x_4200) == 0) { lean_object* x_4201; lean_object* x_4202; uint8_t x_4203; @@ -17655,12 +18041,12 @@ x_4217 = l_Lean_nullKind___closed__2; x_4218 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4218, 0, x_4217); lean_ctor_set(x_4218, 1, x_4216); -x_4219 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4219 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4220 = lean_array_push(x_4219, x_4218); x_4221 = lean_array_push(x_4220, x_4212); -x_4222 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4222 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4223 = lean_array_push(x_4221, x_4222); -x_4224 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4224 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4225 = lean_array_push(x_4223, x_4224); lean_inc(x_11); x_4226 = lean_array_push(x_4210, x_11); @@ -17743,12 +18129,12 @@ x_4261 = l_Lean_nullKind___closed__2; x_4262 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4262, 0, x_4261); lean_ctor_set(x_4262, 1, x_4260); -x_4263 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4263 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4264 = lean_array_push(x_4263, x_4262); x_4265 = lean_array_push(x_4264, x_4256); -x_4266 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4266 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4267 = lean_array_push(x_4265, x_4266); -x_4268 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4268 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4269 = lean_array_push(x_4267, x_4268); lean_inc(x_11); x_4270 = lean_array_push(x_4254, x_11); @@ -17828,12 +18214,12 @@ x_4299 = l_Lean_nullKind___closed__2; x_4300 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4300, 0, x_4299); lean_ctor_set(x_4300, 1, x_4298); -x_4301 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4301 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4302 = lean_array_push(x_4301, x_4300); x_4303 = lean_array_push(x_4302, x_4294); -x_4304 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4304 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4305 = lean_array_push(x_4303, x_4304); -x_4306 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4306 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4307 = lean_array_push(x_4305, x_4306); lean_inc(x_11); x_4308 = lean_array_push(x_4292, x_11); @@ -17928,7 +18314,7 @@ lean_dec(x_4329); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_4332 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_4332 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_4333 = l_Lean_Elab_Term_throwError___rarg(x_11, x_4332, x_5, x_6); lean_dec(x_11); x_4334 = !lean_is_exclusive(x_4333); @@ -17990,7 +18376,7 @@ lean_inc(x_4347); x_4352 = l_Lean_Elab_Term_mkExplicitBinder(x_4347, x_4351); x_4353 = lean_array_push(x_4, x_4352); lean_inc(x_5); -x_4354 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_4350, x_4353, x_5, x_4348); +x_4354 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_4350, x_4353, x_5, x_4348); if (lean_obj_tag(x_4354) == 0) { lean_object* x_4355; lean_object* x_4356; uint8_t x_4357; @@ -18029,12 +18415,12 @@ x_4371 = l_Lean_nullKind___closed__2; x_4372 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4372, 0, x_4371); lean_ctor_set(x_4372, 1, x_4370); -x_4373 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4373 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4374 = lean_array_push(x_4373, x_4372); x_4375 = lean_array_push(x_4374, x_4366); -x_4376 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4376 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4377 = lean_array_push(x_4375, x_4376); -x_4378 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4378 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4379 = lean_array_push(x_4377, x_4378); lean_inc(x_11); x_4380 = lean_array_push(x_4364, x_11); @@ -18118,12 +18504,12 @@ x_4415 = l_Lean_nullKind___closed__2; x_4416 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4416, 0, x_4415); lean_ctor_set(x_4416, 1, x_4414); -x_4417 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4417 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4418 = lean_array_push(x_4417, x_4416); x_4419 = lean_array_push(x_4418, x_4410); -x_4420 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4420 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4421 = lean_array_push(x_4419, x_4420); -x_4422 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4422 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4423 = lean_array_push(x_4421, x_4422); lean_inc(x_11); x_4424 = lean_array_push(x_4408, x_11); @@ -18204,12 +18590,12 @@ x_4453 = l_Lean_nullKind___closed__2; x_4454 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4454, 0, x_4453); lean_ctor_set(x_4454, 1, x_4452); -x_4455 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4455 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4456 = lean_array_push(x_4455, x_4454); x_4457 = lean_array_push(x_4456, x_4448); -x_4458 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4458 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4459 = lean_array_push(x_4457, x_4458); -x_4460 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4460 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4461 = lean_array_push(x_4459, x_4460); lean_inc(x_11); x_4462 = lean_array_push(x_4446, x_11); @@ -18305,7 +18691,7 @@ lean_dec(x_4483); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_4486 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_4486 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_4487 = l_Lean_Elab_Term_throwError___rarg(x_11, x_4486, x_5, x_6); lean_dec(x_11); x_4488 = !lean_is_exclusive(x_4487); @@ -18366,7 +18752,7 @@ lean_inc(x_4501); x_4506 = l_Lean_Elab_Term_mkExplicitBinder(x_4501, x_4505); x_4507 = lean_array_push(x_4, x_4506); lean_inc(x_5); -x_4508 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_4504, x_4507, x_5, x_4502); +x_4508 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_4504, x_4507, x_5, x_4502); if (lean_obj_tag(x_4508) == 0) { lean_object* x_4509; lean_object* x_4510; uint8_t x_4511; @@ -18405,12 +18791,12 @@ x_4525 = l_Lean_nullKind___closed__2; x_4526 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4526, 0, x_4525); lean_ctor_set(x_4526, 1, x_4524); -x_4527 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4527 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4528 = lean_array_push(x_4527, x_4526); x_4529 = lean_array_push(x_4528, x_4520); -x_4530 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4530 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4531 = lean_array_push(x_4529, x_4530); -x_4532 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4532 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4533 = lean_array_push(x_4531, x_4532); x_4534 = lean_array_push(x_4518, x_11); x_4535 = lean_alloc_ctor(1, 2, 0); @@ -18456,12 +18842,12 @@ x_4555 = l_Lean_nullKind___closed__2; x_4556 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4556, 0, x_4555); lean_ctor_set(x_4556, 1, x_4554); -x_4557 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4557 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4558 = lean_array_push(x_4557, x_4556); x_4559 = lean_array_push(x_4558, x_4550); -x_4560 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4560 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4561 = lean_array_push(x_4559, x_4560); -x_4562 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4562 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4563 = lean_array_push(x_4561, x_4562); x_4564 = lean_array_push(x_4548, x_11); x_4565 = lean_alloc_ctor(1, 2, 0); @@ -18528,12 +18914,12 @@ x_4592 = l_Lean_nullKind___closed__2; x_4593 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_4593, 0, x_4592); lean_ctor_set(x_4593, 1, x_4591); -x_4594 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_4594 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_4595 = lean_array_push(x_4594, x_4593); x_4596 = lean_array_push(x_4595, x_4587); -x_4597 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_4597 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_4598 = lean_array_push(x_4596, x_4597); -x_4599 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_4599 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_4600 = lean_array_push(x_4598, x_4599); x_4601 = lean_array_push(x_4585, x_11); x_4602 = lean_alloc_ctor(1, 2, 0); @@ -18615,7 +19001,7 @@ lean_dec(x_4621); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_4624 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10; +x_4624 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10; x_4625 = l_Lean_Elab_Term_throwError___rarg(x_11, x_4624, x_5, x_6); lean_dec(x_11); x_4626 = !lean_is_exclusive(x_4625); @@ -18657,28 +19043,28 @@ goto _start; } } } -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___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* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_1); return x_7; } } -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_3, x_4, x_5, x_6); return x_7; } } -lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_1); return x_7; } @@ -18689,7 +19075,7 @@ _start: lean_object* x_5; lean_object* x_6; lean_object* x_7; x_5 = lean_unsigned_to_nat(0u); x_6 = l_Array_empty___closed__1; -x_7 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main(x_1, x_2, x_5, x_6, x_3, x_4); +x_7 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main(x_1, x_2, x_5, x_6, x_3, x_4); return x_7; } } @@ -18702,7 +19088,7 @@ lean_dec(x_1); return x_5; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1() { _start: { lean_object* x_1; @@ -18710,27 +19096,27 @@ x_1 = lean_mk_string("autoParam is not allowed at 'fun/λ' binders"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1; +x_1 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2; +x_1 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4() { _start: { lean_object* x_1; @@ -18738,27 +19124,27 @@ x_1 = lean_mk_string("optParam is not allowed at 'fun/λ' binders"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4; +x_1 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6() { +lean_object* _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5; +x_1 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(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; @@ -18788,7 +19174,7 @@ else { lean_object* x_12; lean_object* x_13; lean_free_object(x_5); -x_12 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3; +x_12 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3; x_13 = l_Lean_Elab_Term_throwError___rarg(x_1, x_12, x_3, x_8); return x_13; } @@ -18798,7 +19184,7 @@ else lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_free_object(x_5); lean_dec(x_7); -x_14 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6; +x_14 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6; x_15 = l_Lean_Elab_Term_throwError___rarg(x_1, x_14, x_3, x_8); x_16 = !lean_is_exclusive(x_15); if (x_16 == 0) @@ -18847,7 +19233,7 @@ return x_25; else { lean_object* x_26; lean_object* x_27; -x_26 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3; +x_26 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3; x_27 = l_Lean_Elab_Term_throwError___rarg(x_1, x_26, x_3, x_21); return x_27; } @@ -18856,7 +19242,7 @@ 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_dec(x_20); -x_28 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6; +x_28 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6; x_29 = l_Lean_Elab_Term_throwError___rarg(x_1, x_28, x_3, x_21); x_30 = lean_ctor_get(x_29, 0); lean_inc(x_30); @@ -18882,16 +19268,16 @@ return x_33; } } } -lean_object* l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_1, x_2, x_3, x_4); lean_dec(x_1); return x_5; } } -lean_object* l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(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; @@ -18968,7 +19354,7 @@ lean_object* x_28; lean_object* x_29; x_28 = lean_ctor_get(x_27, 1); lean_inc(x_28); lean_dec(x_27); -x_29 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_1, x_3, x_5, x_28); +x_29 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_1, x_3, x_5, x_28); if (lean_obj_tag(x_29) == 0) { uint8_t x_30; @@ -19177,7 +19563,7 @@ lean_object* x_64; lean_object* x_65; x_64 = lean_ctor_get(x_63, 1); lean_inc(x_64); lean_dec(x_63); -x_65 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_1, x_3, x_5, x_64); +x_65 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_1, x_3, x_5, x_64); if (lean_obj_tag(x_65) == 0) { lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; @@ -19339,17 +19725,17 @@ return x_84; } } } -lean_object* l___private_Init_Lean_Elab_Binders_12__propagateExpectedType___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Elab_Binders_13__propagateExpectedType___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_2); lean_dec(x_1); return x_7; } } -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___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; @@ -19576,7 +19962,7 @@ block_207: lean_object* x_27; lean_inc(x_4); lean_inc(x_25); -x_27 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_17, x_25, x_4, x_26); +x_27 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_17, x_25, x_4, x_26); if (lean_obj_tag(x_27) == 0) { lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; @@ -19734,7 +20120,7 @@ lean_inc(x_25); x_71 = lean_local_ctx_mk_local_decl(x_35, x_30, x_70, x_25, x_14); lean_inc(x_4); lean_inc(x_25); -x_72 = l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(x_69, x_32, x_25, x_24, x_4, x_31); +x_72 = l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(x_69, x_32, x_25, x_24, x_4, x_31); lean_dec(x_69); if (lean_obj_tag(x_72) == 0) { @@ -20153,7 +20539,7 @@ lean_inc(x_25); x_169 = lean_local_ctx_mk_local_decl(x_131, x_30, x_168, x_25, x_14); lean_inc(x_4); lean_inc(x_25); -x_170 = l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(x_167, x_32, x_25, x_166, x_4, x_31); +x_170 = l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(x_167, x_32, x_25, x_166, x_4, x_31); lean_dec(x_167); if (lean_obj_tag(x_170) == 0) { @@ -20497,7 +20883,7 @@ block_326: lean_object* x_242; lean_inc(x_4); lean_inc(x_240); -x_242 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_17, x_240, x_4, x_241); +x_242 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_17, x_240, x_4, x_241); 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; uint8_t x_252; lean_object* x_253; lean_object* x_254; @@ -20684,7 +21070,7 @@ lean_inc(x_240); x_288 = lean_local_ctx_mk_local_decl(x_249, x_245, x_287, x_240, x_14); lean_inc(x_4); lean_inc(x_240); -x_289 = l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(x_286, x_247, x_240, x_285, x_4, x_246); +x_289 = l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(x_286, x_247, x_240, x_285, x_4, x_246); lean_dec(x_286); if (lean_obj_tag(x_289) == 0) { @@ -21079,7 +21465,7 @@ block_448: lean_object* x_364; lean_inc(x_359); lean_inc(x_362); -x_364 = l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam(x_17, x_362, x_359, x_363); +x_364 = l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam(x_17, x_362, x_359, x_363); if (lean_obj_tag(x_364) == 0) { 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; uint8_t x_374; lean_object* x_375; lean_object* x_376; @@ -21268,7 +21654,7 @@ lean_inc(x_362); x_410 = lean_local_ctx_mk_local_decl(x_371, x_367, x_409, x_362, x_14); lean_inc(x_359); lean_inc(x_362); -x_411 = l___private_Init_Lean_Elab_Binders_12__propagateExpectedType(x_408, x_369, x_362, x_407, x_359, x_368); +x_411 = l___private_Init_Lean_Elab_Binders_13__propagateExpectedType(x_408, x_369, x_362, x_407, x_359, x_368); lean_dec(x_408); if (lean_obj_tag(x_411) == 0) { @@ -21471,28 +21857,28 @@ return x_447; } } } -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main(x_1, x_2, x_3, x_4, x_5); lean_dec(x_1); return x_6; } } -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main(x_1, x_2, x_3, x_4, x_5); return x_6; } } -lean_object* l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews(x_1, x_2, x_3, x_4, x_5); lean_dec(x_1); return x_6; } @@ -21519,7 +21905,7 @@ 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___private_Init_Lean_Elab_Binders_5__matchBinder(x_9, x_4, x_5); +x_10 = l___private_Init_Lean_Elab_Binders_6__matchBinder(x_9, x_4, x_5); lean_dec(x_9); if (lean_obj_tag(x_10) == 0) { @@ -21531,7 +21917,7 @@ lean_inc(x_12); lean_dec(x_10); x_13 = lean_unsigned_to_nat(0u); lean_inc(x_4); -x_14 = l___private_Init_Lean_Elab_Binders_13__elabFunBinderViews___main(x_11, x_13, x_3, x_4, x_12); +x_14 = l___private_Init_Lean_Elab_Binders_14__elabFunBinderViews___main(x_11, x_13, x_3, x_4, x_12); lean_dec(x_11); if (lean_obj_tag(x_14) == 0) { @@ -21868,90 +22254,97 @@ return x_69; } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; x_81 = lean_ctor_get(x_72, 0); x_82 = lean_ctor_get(x_72, 1); +x_83 = lean_ctor_get(x_72, 3); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); lean_dec(x_72); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_60); -lean_ctor_set(x_71, 2, x_83); +x_84 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_84, 0, x_81); +lean_ctor_set(x_84, 1, x_82); +lean_ctor_set(x_84, 2, x_60); +lean_ctor_set(x_84, 3, x_83); +lean_ctor_set(x_71, 2, x_84); return x_69; } } 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; -x_84 = lean_ctor_get(x_71, 0); -x_85 = lean_ctor_get(x_71, 1); -x_86 = lean_ctor_get(x_71, 3); -x_87 = lean_ctor_get(x_71, 4); -x_88 = lean_ctor_get(x_71, 5); +lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_85 = lean_ctor_get(x_71, 0); +x_86 = lean_ctor_get(x_71, 1); +x_87 = lean_ctor_get(x_71, 3); +x_88 = lean_ctor_get(x_71, 4); +x_89 = lean_ctor_get(x_71, 5); +lean_inc(x_89); lean_inc(x_88); lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); lean_dec(x_71); -x_89 = lean_ctor_get(x_72, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_72, 1); +x_90 = lean_ctor_get(x_72, 0); lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); if (lean_is_exclusive(x_72)) { lean_ctor_release(x_72, 0); lean_ctor_release(x_72, 1); lean_ctor_release(x_72, 2); - x_91 = x_72; + lean_ctor_release(x_72, 3); + x_93 = x_72; } else { lean_dec_ref(x_72); - x_91 = lean_box(0); + x_93 = lean_box(0); } -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_93)) { + x_94 = lean_alloc_ctor(0, 4, 0); } else { - x_92 = x_91; + x_94 = x_93; } -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_60); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_70, 0, 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_60); +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_70, 0, x_95); return x_69; } } else { -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_94 = lean_ctor_get(x_70, 1); -x_95 = lean_ctor_get(x_70, 2); -x_96 = lean_ctor_get(x_70, 3); -x_97 = lean_ctor_get(x_70, 4); -x_98 = lean_ctor_get(x_70, 5); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_96 = lean_ctor_get(x_70, 1); +x_97 = lean_ctor_get(x_70, 2); +x_98 = lean_ctor_get(x_70, 3); +x_99 = lean_ctor_get(x_70, 4); +x_100 = lean_ctor_get(x_70, 5); +lean_inc(x_100); +lean_inc(x_99); lean_inc(x_98); lean_inc(x_97); lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); lean_dec(x_70); -x_99 = lean_ctor_get(x_71, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_71, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_71, 3); +x_101 = lean_ctor_get(x_71, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_71, 4); +x_102 = lean_ctor_get(x_71, 1); lean_inc(x_102); -x_103 = lean_ctor_get(x_71, 5); +x_103 = lean_ctor_get(x_71, 3); lean_inc(x_103); +x_104 = lean_ctor_get(x_71, 4); +lean_inc(x_104); +x_105 = lean_ctor_get(x_71, 5); +lean_inc(x_105); if (lean_is_exclusive(x_71)) { lean_ctor_release(x_71, 0); lean_ctor_release(x_71, 1); @@ -21959,70 +22352,74 @@ if (lean_is_exclusive(x_71)) { lean_ctor_release(x_71, 3); lean_ctor_release(x_71, 4); lean_ctor_release(x_71, 5); - x_104 = x_71; + x_106 = x_71; } else { lean_dec_ref(x_71); - x_104 = lean_box(0); + x_106 = lean_box(0); } -x_105 = lean_ctor_get(x_72, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_72, 1); -lean_inc(x_106); +x_107 = lean_ctor_get(x_72, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_72, 1); +lean_inc(x_108); +x_109 = lean_ctor_get(x_72, 3); +lean_inc(x_109); if (lean_is_exclusive(x_72)) { lean_ctor_release(x_72, 0); lean_ctor_release(x_72, 1); lean_ctor_release(x_72, 2); - x_107 = x_72; + lean_ctor_release(x_72, 3); + x_110 = x_72; } else { lean_dec_ref(x_72); - x_107 = lean_box(0); + x_110 = lean_box(0); } -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_110)) { + x_111 = lean_alloc_ctor(0, 4, 0); } else { - x_108 = x_107; + x_111 = x_110; } -lean_ctor_set(x_108, 0, x_105); -lean_ctor_set(x_108, 1, x_106); -lean_ctor_set(x_108, 2, x_60); -if (lean_is_scalar(x_104)) { - x_109 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_111, 0, x_107); +lean_ctor_set(x_111, 1, x_108); +lean_ctor_set(x_111, 2, x_60); +lean_ctor_set(x_111, 3, x_109); +if (lean_is_scalar(x_106)) { + x_112 = lean_alloc_ctor(0, 6, 0); } else { - x_109 = x_104; + x_112 = x_106; } -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); -x_110 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_110, 0, x_109); -lean_ctor_set(x_110, 1, x_94); -lean_ctor_set(x_110, 2, x_95); -lean_ctor_set(x_110, 3, x_96); -lean_ctor_set(x_110, 4, x_97); -lean_ctor_set(x_110, 5, x_98); -lean_ctor_set(x_69, 1, x_110); +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, 6, 0); +lean_ctor_set(x_113, 0, x_112); +lean_ctor_set(x_113, 1, x_96); +lean_ctor_set(x_113, 2, x_97); +lean_ctor_set(x_113, 3, x_98); +lean_ctor_set(x_113, 4, x_99); +lean_ctor_set(x_113, 5, x_100); +lean_ctor_set(x_69, 1, x_113); return x_69; } } 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; -x_111 = lean_ctor_get(x_69, 0); -lean_inc(x_111); -lean_dec(x_69); -x_112 = lean_ctor_get(x_70, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_70, 2); -lean_inc(x_113); -x_114 = lean_ctor_get(x_70, 3); +lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +x_114 = lean_ctor_get(x_69, 0); lean_inc(x_114); -x_115 = lean_ctor_get(x_70, 4); +lean_dec(x_69); +x_115 = lean_ctor_get(x_70, 1); lean_inc(x_115); -x_116 = lean_ctor_get(x_70, 5); +x_116 = lean_ctor_get(x_70, 2); lean_inc(x_116); +x_117 = lean_ctor_get(x_70, 3); +lean_inc(x_117); +x_118 = lean_ctor_get(x_70, 4); +lean_inc(x_118); +x_119 = lean_ctor_get(x_70, 5); +lean_inc(x_119); if (lean_is_exclusive(x_70)) { lean_ctor_release(x_70, 0); lean_ctor_release(x_70, 1); @@ -22030,21 +22427,21 @@ if (lean_is_exclusive(x_70)) { lean_ctor_release(x_70, 3); lean_ctor_release(x_70, 4); lean_ctor_release(x_70, 5); - x_117 = x_70; + x_120 = x_70; } else { lean_dec_ref(x_70); - x_117 = lean_box(0); + x_120 = lean_box(0); } -x_118 = lean_ctor_get(x_71, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_71, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_71, 3); -lean_inc(x_120); -x_121 = lean_ctor_get(x_71, 4); +x_121 = lean_ctor_get(x_71, 0); lean_inc(x_121); -x_122 = lean_ctor_get(x_71, 5); +x_122 = lean_ctor_get(x_71, 1); lean_inc(x_122); +x_123 = lean_ctor_get(x_71, 3); +lean_inc(x_123); +x_124 = lean_ctor_get(x_71, 4); +lean_inc(x_124); +x_125 = lean_ctor_get(x_71, 5); +lean_inc(x_125); if (lean_is_exclusive(x_71)) { lean_ctor_release(x_71, 0); lean_ctor_release(x_71, 1); @@ -22052,919 +22449,954 @@ if (lean_is_exclusive(x_71)) { lean_ctor_release(x_71, 3); lean_ctor_release(x_71, 4); lean_ctor_release(x_71, 5); - x_123 = x_71; + x_126 = x_71; } else { lean_dec_ref(x_71); - x_123 = lean_box(0); + x_126 = lean_box(0); } -x_124 = lean_ctor_get(x_72, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_72, 1); -lean_inc(x_125); +x_127 = lean_ctor_get(x_72, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_72, 1); +lean_inc(x_128); +x_129 = lean_ctor_get(x_72, 3); +lean_inc(x_129); if (lean_is_exclusive(x_72)) { lean_ctor_release(x_72, 0); lean_ctor_release(x_72, 1); lean_ctor_release(x_72, 2); - x_126 = x_72; + lean_ctor_release(x_72, 3); + x_130 = x_72; } else { lean_dec_ref(x_72); - x_126 = lean_box(0); + 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_60); +lean_ctor_set(x_131, 3, x_129); if (lean_is_scalar(x_126)) { - x_127 = lean_alloc_ctor(0, 3, 0); + x_132 = lean_alloc_ctor(0, 6, 0); } else { - x_127 = x_126; + x_132 = x_126; } -lean_ctor_set(x_127, 0, x_124); -lean_ctor_set(x_127, 1, x_125); -lean_ctor_set(x_127, 2, x_60); -if (lean_is_scalar(x_123)) { - x_128 = lean_alloc_ctor(0, 6, 0); +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_120)) { + x_133 = lean_alloc_ctor(0, 6, 0); } else { - x_128 = x_123; + x_133 = x_120; } -lean_ctor_set(x_128, 0, x_118); -lean_ctor_set(x_128, 1, x_119); -lean_ctor_set(x_128, 2, x_127); -lean_ctor_set(x_128, 3, x_120); -lean_ctor_set(x_128, 4, x_121); -lean_ctor_set(x_128, 5, x_122); -if (lean_is_scalar(x_117)) { - x_129 = lean_alloc_ctor(0, 6, 0); -} else { - x_129 = x_117; -} -lean_ctor_set(x_129, 0, x_128); -lean_ctor_set(x_129, 1, x_112); -lean_ctor_set(x_129, 2, x_113); -lean_ctor_set(x_129, 3, x_114); -lean_ctor_set(x_129, 4, x_115); -lean_ctor_set(x_129, 5, x_116); -x_130 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_130, 0, x_111); -lean_ctor_set(x_130, 1, x_129); -return x_130; +lean_ctor_set(x_133, 0, x_132); +lean_ctor_set(x_133, 1, x_115); +lean_ctor_set(x_133, 2, x_116); +lean_ctor_set(x_133, 3, x_117); +lean_ctor_set(x_133, 4, x_118); +lean_ctor_set(x_133, 5, x_119); +x_134 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_134, 0, x_114); +lean_ctor_set(x_134, 1, x_133); +return x_134; } } else { -lean_object* x_131; lean_object* x_132; lean_object* x_133; uint8_t x_134; -x_131 = lean_ctor_get(x_69, 1); -lean_inc(x_131); -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_69); -if (x_134 == 0) -{ -lean_object* x_135; uint8_t x_136; +lean_object* x_135; lean_object* x_136; lean_object* x_137; uint8_t x_138; x_135 = lean_ctor_get(x_69, 1); -lean_dec(x_135); -x_136 = !lean_is_exclusive(x_131); -if (x_136 == 0) -{ -lean_object* x_137; uint8_t x_138; -x_137 = lean_ctor_get(x_131, 0); -lean_dec(x_137); -x_138 = !lean_is_exclusive(x_132); +lean_inc(x_135); +x_136 = lean_ctor_get(x_135, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_136, 2); +lean_inc(x_137); +x_138 = !lean_is_exclusive(x_69); if (x_138 == 0) { lean_object* x_139; uint8_t x_140; -x_139 = lean_ctor_get(x_132, 2); +x_139 = lean_ctor_get(x_69, 1); lean_dec(x_139); -x_140 = !lean_is_exclusive(x_133); +x_140 = !lean_is_exclusive(x_135); if (x_140 == 0) { -lean_object* x_141; -x_141 = lean_ctor_get(x_133, 2); +lean_object* x_141; uint8_t x_142; +x_141 = lean_ctor_get(x_135, 0); lean_dec(x_141); -lean_ctor_set(x_133, 2, x_60); +x_142 = !lean_is_exclusive(x_136); +if (x_142 == 0) +{ +lean_object* x_143; uint8_t x_144; +x_143 = lean_ctor_get(x_136, 2); +lean_dec(x_143); +x_144 = !lean_is_exclusive(x_137); +if (x_144 == 0) +{ +lean_object* x_145; +x_145 = lean_ctor_get(x_137, 2); +lean_dec(x_145); +lean_ctor_set(x_137, 2, x_60); return x_69; } else { -lean_object* x_142; lean_object* x_143; lean_object* x_144; -x_142 = lean_ctor_get(x_133, 0); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -lean_inc(x_142); -lean_dec(x_133); -x_144 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_144, 0, x_142); -lean_ctor_set(x_144, 1, x_143); -lean_ctor_set(x_144, 2, x_60); -lean_ctor_set(x_132, 2, x_144); -return x_69; -} -} -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; -x_145 = lean_ctor_get(x_132, 0); -x_146 = lean_ctor_get(x_132, 1); -x_147 = lean_ctor_get(x_132, 3); -x_148 = lean_ctor_get(x_132, 4); -x_149 = lean_ctor_get(x_132, 5); -lean_inc(x_149); +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_146 = lean_ctor_get(x_137, 0); +x_147 = lean_ctor_get(x_137, 1); +x_148 = lean_ctor_get(x_137, 3); lean_inc(x_148); lean_inc(x_147); lean_inc(x_146); -lean_inc(x_145); -lean_dec(x_132); -x_150 = lean_ctor_get(x_133, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_133, 1); +lean_dec(x_137); +x_149 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_149, 0, x_146); +lean_ctor_set(x_149, 1, x_147); +lean_ctor_set(x_149, 2, x_60); +lean_ctor_set(x_149, 3, x_148); +lean_ctor_set(x_136, 2, x_149); +return x_69; +} +} +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; +x_150 = lean_ctor_get(x_136, 0); +x_151 = lean_ctor_get(x_136, 1); +x_152 = lean_ctor_get(x_136, 3); +x_153 = lean_ctor_get(x_136, 4); +x_154 = lean_ctor_get(x_136, 5); +lean_inc(x_154); +lean_inc(x_153); +lean_inc(x_152); lean_inc(x_151); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_152 = x_133; -} else { - lean_dec_ref(x_133); - x_152 = lean_box(0); -} -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 3, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_150); -lean_ctor_set(x_153, 1, x_151); -lean_ctor_set(x_153, 2, x_60); -x_154 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_154, 0, x_145); -lean_ctor_set(x_154, 1, x_146); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_147); -lean_ctor_set(x_154, 4, x_148); -lean_ctor_set(x_154, 5, x_149); -lean_ctor_set(x_131, 0, x_154); -return x_69; -} -} -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; lean_object* x_171; -x_155 = lean_ctor_get(x_131, 1); -x_156 = lean_ctor_get(x_131, 2); -x_157 = lean_ctor_get(x_131, 3); -x_158 = lean_ctor_get(x_131, 4); -x_159 = lean_ctor_get(x_131, 5); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); +lean_inc(x_150); +lean_dec(x_136); +x_155 = lean_ctor_get(x_137, 0); lean_inc(x_155); -lean_dec(x_131); -x_160 = lean_ctor_get(x_132, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_132, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_132, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_132, 4); -lean_inc(x_163); -x_164 = lean_ctor_get(x_132, 5); -lean_inc(x_164); -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_165 = x_132; +x_156 = lean_ctor_get(x_137, 1); +lean_inc(x_156); +x_157 = lean_ctor_get(x_137, 3); +lean_inc(x_157); +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_158 = x_137; } else { - lean_dec_ref(x_132); - x_165 = lean_box(0); + lean_dec_ref(x_137); + x_158 = lean_box(0); } -x_166 = lean_ctor_get(x_133, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_133, 1); -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); - x_168 = x_133; +if (lean_is_scalar(x_158)) { + x_159 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_133); - x_168 = lean_box(0); + x_159 = x_158; } -if (lean_is_scalar(x_168)) { - x_169 = lean_alloc_ctor(0, 3, 0); -} else { - x_169 = x_168; -} -lean_ctor_set(x_169, 0, x_166); -lean_ctor_set(x_169, 1, x_167); -lean_ctor_set(x_169, 2, x_60); -if (lean_is_scalar(x_165)) { - x_170 = lean_alloc_ctor(0, 6, 0); -} else { - x_170 = x_165; -} -lean_ctor_set(x_170, 0, x_160); -lean_ctor_set(x_170, 1, x_161); -lean_ctor_set(x_170, 2, x_169); -lean_ctor_set(x_170, 3, x_162); -lean_ctor_set(x_170, 4, x_163); -lean_ctor_set(x_170, 5, x_164); -x_171 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_171, 0, x_170); -lean_ctor_set(x_171, 1, x_155); -lean_ctor_set(x_171, 2, x_156); -lean_ctor_set(x_171, 3, x_157); -lean_ctor_set(x_171, 4, x_158); -lean_ctor_set(x_171, 5, x_159); -lean_ctor_set(x_69, 1, x_171); +lean_ctor_set(x_159, 0, x_155); +lean_ctor_set(x_159, 1, x_156); +lean_ctor_set(x_159, 2, x_60); +lean_ctor_set(x_159, 3, x_157); +x_160 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_160, 0, x_150); +lean_ctor_set(x_160, 1, x_151); +lean_ctor_set(x_160, 2, x_159); +lean_ctor_set(x_160, 3, x_152); +lean_ctor_set(x_160, 4, x_153); +lean_ctor_set(x_160, 5, x_154); +lean_ctor_set(x_135, 0, x_160); return x_69; } } else { -lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; -x_172 = lean_ctor_get(x_69, 0); +lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_161 = lean_ctor_get(x_135, 1); +x_162 = lean_ctor_get(x_135, 2); +x_163 = lean_ctor_get(x_135, 3); +x_164 = lean_ctor_get(x_135, 4); +x_165 = lean_ctor_get(x_135, 5); +lean_inc(x_165); +lean_inc(x_164); +lean_inc(x_163); +lean_inc(x_162); +lean_inc(x_161); +lean_dec(x_135); +x_166 = lean_ctor_get(x_136, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_136, 1); +lean_inc(x_167); +x_168 = lean_ctor_get(x_136, 3); +lean_inc(x_168); +x_169 = lean_ctor_get(x_136, 4); +lean_inc(x_169); +x_170 = lean_ctor_get(x_136, 5); +lean_inc(x_170); +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_171 = x_136; +} else { + lean_dec_ref(x_136); + x_171 = lean_box(0); +} +x_172 = lean_ctor_get(x_137, 0); lean_inc(x_172); -lean_dec(x_69); -x_173 = lean_ctor_get(x_131, 1); +x_173 = lean_ctor_get(x_137, 1); lean_inc(x_173); -x_174 = lean_ctor_get(x_131, 2); +x_174 = lean_ctor_get(x_137, 3); lean_inc(x_174); -x_175 = lean_ctor_get(x_131, 3); -lean_inc(x_175); -x_176 = lean_ctor_get(x_131, 4); -lean_inc(x_176); -x_177 = lean_ctor_get(x_131, 5); -lean_inc(x_177); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - lean_ctor_release(x_131, 4); - lean_ctor_release(x_131, 5); - x_178 = x_131; +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_175 = x_137; } else { - lean_dec_ref(x_131); - x_178 = lean_box(0); + lean_dec_ref(x_137); + x_175 = lean_box(0); } -x_179 = lean_ctor_get(x_132, 0); +if (lean_is_scalar(x_175)) { + x_176 = lean_alloc_ctor(0, 4, 0); +} else { + x_176 = x_175; +} +lean_ctor_set(x_176, 0, x_172); +lean_ctor_set(x_176, 1, x_173); +lean_ctor_set(x_176, 2, x_60); +lean_ctor_set(x_176, 3, x_174); +if (lean_is_scalar(x_171)) { + x_177 = lean_alloc_ctor(0, 6, 0); +} else { + x_177 = x_171; +} +lean_ctor_set(x_177, 0, x_166); +lean_ctor_set(x_177, 1, x_167); +lean_ctor_set(x_177, 2, x_176); +lean_ctor_set(x_177, 3, x_168); +lean_ctor_set(x_177, 4, x_169); +lean_ctor_set(x_177, 5, x_170); +x_178 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_178, 0, x_177); +lean_ctor_set(x_178, 1, x_161); +lean_ctor_set(x_178, 2, x_162); +lean_ctor_set(x_178, 3, x_163); +lean_ctor_set(x_178, 4, x_164); +lean_ctor_set(x_178, 5, x_165); +lean_ctor_set(x_69, 1, x_178); +return x_69; +} +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; +x_179 = lean_ctor_get(x_69, 0); lean_inc(x_179); -x_180 = lean_ctor_get(x_132, 1); +lean_dec(x_69); +x_180 = lean_ctor_get(x_135, 1); lean_inc(x_180); -x_181 = lean_ctor_get(x_132, 3); +x_181 = lean_ctor_get(x_135, 2); lean_inc(x_181); -x_182 = lean_ctor_get(x_132, 4); +x_182 = lean_ctor_get(x_135, 3); lean_inc(x_182); -x_183 = lean_ctor_get(x_132, 5); +x_183 = lean_ctor_get(x_135, 4); lean_inc(x_183); -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_184 = x_132; +x_184 = lean_ctor_get(x_135, 5); +lean_inc(x_184); +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_185 = x_135; } else { - lean_dec_ref(x_132); - x_184 = lean_box(0); + lean_dec_ref(x_135); + x_185 = lean_box(0); } -x_185 = lean_ctor_get(x_133, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_133, 1); +x_186 = lean_ctor_get(x_136, 0); lean_inc(x_186); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_187 = x_133; +x_187 = lean_ctor_get(x_136, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_136, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_136, 4); +lean_inc(x_189); +x_190 = lean_ctor_get(x_136, 5); +lean_inc(x_190); +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_191 = x_136; } else { - lean_dec_ref(x_133); - x_187 = lean_box(0); + lean_dec_ref(x_136); + x_191 = lean_box(0); } -if (lean_is_scalar(x_187)) { - x_188 = lean_alloc_ctor(0, 3, 0); -} else { - x_188 = x_187; -} -lean_ctor_set(x_188, 0, x_185); -lean_ctor_set(x_188, 1, x_186); -lean_ctor_set(x_188, 2, x_60); -if (lean_is_scalar(x_184)) { - x_189 = lean_alloc_ctor(0, 6, 0); -} else { - x_189 = x_184; -} -lean_ctor_set(x_189, 0, x_179); -lean_ctor_set(x_189, 1, x_180); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_181); -lean_ctor_set(x_189, 4, x_182); -lean_ctor_set(x_189, 5, x_183); -if (lean_is_scalar(x_178)) { - x_190 = lean_alloc_ctor(0, 6, 0); -} else { - x_190 = x_178; -} -lean_ctor_set(x_190, 0, x_189); -lean_ctor_set(x_190, 1, x_173); -lean_ctor_set(x_190, 2, x_174); -lean_ctor_set(x_190, 3, x_175); -lean_ctor_set(x_190, 4, x_176); -lean_ctor_set(x_190, 5, x_177); -x_191 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_191, 0, x_172); -lean_ctor_set(x_191, 1, x_190); -return x_191; -} -} -} -else -{ -lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; -x_192 = lean_ctor_get(x_62, 0); -x_193 = lean_ctor_get(x_62, 3); -x_194 = lean_ctor_get(x_62, 4); -lean_inc(x_194); -lean_inc(x_193); +x_192 = lean_ctor_get(x_137, 0); lean_inc(x_192); -lean_dec(x_62); -x_195 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_195, 0, x_192); -lean_ctor_set(x_195, 1, x_22); -lean_ctor_set(x_195, 2, x_23); -lean_ctor_set(x_195, 3, x_193); -lean_ctor_set(x_195, 4, x_194); -lean_ctor_set(x_5, 0, x_195); -x_196 = lean_apply_4(x_4, x_21, x_24, x_5, x_63); -if (lean_obj_tag(x_196) == 0) -{ -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; lean_object* x_219; lean_object* x_220; -x_197 = lean_ctor_get(x_196, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_197, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_198, 2); -lean_inc(x_199); -x_200 = lean_ctor_get(x_196, 0); -lean_inc(x_200); -if (lean_is_exclusive(x_196)) { - lean_ctor_release(x_196, 0); - lean_ctor_release(x_196, 1); - x_201 = x_196; +x_193 = lean_ctor_get(x_137, 1); +lean_inc(x_193); +x_194 = lean_ctor_get(x_137, 3); +lean_inc(x_194); +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_195 = x_137; } else { - lean_dec_ref(x_196); - x_201 = lean_box(0); + lean_dec_ref(x_137); + x_195 = lean_box(0); } -x_202 = lean_ctor_get(x_197, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_197, 2); -lean_inc(x_203); -x_204 = lean_ctor_get(x_197, 3); -lean_inc(x_204); -x_205 = lean_ctor_get(x_197, 4); -lean_inc(x_205); -x_206 = lean_ctor_get(x_197, 5); -lean_inc(x_206); -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_207 = x_197; +if (lean_is_scalar(x_195)) { + x_196 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_197); - x_207 = lean_box(0); + x_196 = x_195; } -x_208 = lean_ctor_get(x_198, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_198, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_198, 3); -lean_inc(x_210); -x_211 = lean_ctor_get(x_198, 4); -lean_inc(x_211); -x_212 = lean_ctor_get(x_198, 5); -lean_inc(x_212); -if (lean_is_exclusive(x_198)) { - lean_ctor_release(x_198, 0); - lean_ctor_release(x_198, 1); - lean_ctor_release(x_198, 2); - lean_ctor_release(x_198, 3); - lean_ctor_release(x_198, 4); - lean_ctor_release(x_198, 5); - x_213 = x_198; +lean_ctor_set(x_196, 0, x_192); +lean_ctor_set(x_196, 1, x_193); +lean_ctor_set(x_196, 2, x_60); +lean_ctor_set(x_196, 3, x_194); +if (lean_is_scalar(x_191)) { + x_197 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_198); - x_213 = lean_box(0); + x_197 = x_191; } -x_214 = lean_ctor_get(x_199, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_199, 1); -lean_inc(x_215); -if (lean_is_exclusive(x_199)) { - lean_ctor_release(x_199, 0); - lean_ctor_release(x_199, 1); - lean_ctor_release(x_199, 2); - x_216 = x_199; +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, 6, 0); } else { - lean_dec_ref(x_199); - x_216 = lean_box(0); + x_198 = x_185; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 3, 0); -} else { - x_217 = x_216; +lean_ctor_set(x_198, 0, x_197); +lean_ctor_set(x_198, 1, x_180); +lean_ctor_set(x_198, 2, x_181); +lean_ctor_set(x_198, 3, x_182); +lean_ctor_set(x_198, 4, x_183); +lean_ctor_set(x_198, 5, x_184); +x_199 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_199, 0, x_179); +lean_ctor_set(x_199, 1, x_198); +return x_199; } -lean_ctor_set(x_217, 0, x_214); -lean_ctor_set(x_217, 1, x_215); -lean_ctor_set(x_217, 2, x_60); -if (lean_is_scalar(x_213)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_213; } -lean_ctor_set(x_218, 0, x_208); -lean_ctor_set(x_218, 1, x_209); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_210); -lean_ctor_set(x_218, 4, x_211); -lean_ctor_set(x_218, 5, x_212); -if (lean_is_scalar(x_207)) { - x_219 = lean_alloc_ctor(0, 6, 0); -} else { - x_219 = x_207; -} -lean_ctor_set(x_219, 0, x_218); -lean_ctor_set(x_219, 1, x_202); -lean_ctor_set(x_219, 2, x_203); -lean_ctor_set(x_219, 3, x_204); -lean_ctor_set(x_219, 4, x_205); -lean_ctor_set(x_219, 5, x_206); -if (lean_is_scalar(x_201)) { - x_220 = lean_alloc_ctor(0, 2, 0); -} else { - x_220 = x_201; -} -lean_ctor_set(x_220, 0, x_200); -lean_ctor_set(x_220, 1, x_219); -return x_220; } else { -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; lean_object* x_244; -x_221 = lean_ctor_get(x_196, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_221, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_222, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_196, 0); -lean_inc(x_224); -if (lean_is_exclusive(x_196)) { - lean_ctor_release(x_196, 0); - lean_ctor_release(x_196, 1); - x_225 = x_196; +lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_200 = lean_ctor_get(x_62, 0); +x_201 = lean_ctor_get(x_62, 3); +x_202 = lean_ctor_get(x_62, 4); +lean_inc(x_202); +lean_inc(x_201); +lean_inc(x_200); +lean_dec(x_62); +x_203 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_203, 0, x_200); +lean_ctor_set(x_203, 1, x_22); +lean_ctor_set(x_203, 2, x_23); +lean_ctor_set(x_203, 3, x_201); +lean_ctor_set(x_203, 4, x_202); +lean_ctor_set(x_5, 0, x_203); +x_204 = lean_apply_4(x_4, x_21, x_24, x_5, x_63); +if (lean_obj_tag(x_204) == 0) +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; 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_205 = lean_ctor_get(x_204, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_205, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_206, 2); +lean_inc(x_207); +x_208 = lean_ctor_get(x_204, 0); +lean_inc(x_208); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + x_209 = x_204; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_204); + x_209 = lean_box(0); +} +x_210 = lean_ctor_get(x_205, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_205, 2); +lean_inc(x_211); +x_212 = lean_ctor_get(x_205, 3); +lean_inc(x_212); +x_213 = lean_ctor_get(x_205, 4); +lean_inc(x_213); +x_214 = lean_ctor_get(x_205, 5); +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); + lean_ctor_release(x_205, 4); + lean_ctor_release(x_205, 5); + x_215 = x_205; +} else { + lean_dec_ref(x_205); + x_215 = lean_box(0); +} +x_216 = lean_ctor_get(x_206, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_206, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_206, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_206, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_206, 5); +lean_inc(x_220); +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); + lean_ctor_release(x_206, 4); + lean_ctor_release(x_206, 5); + x_221 = x_206; +} else { + lean_dec_ref(x_206); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_207, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_207, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_207, 3); +lean_inc(x_224); +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); + x_225 = x_207; +} else { + lean_dec_ref(x_207); x_225 = lean_box(0); } -x_226 = lean_ctor_get(x_221, 1); -lean_inc(x_226); -x_227 = lean_ctor_get(x_221, 2); -lean_inc(x_227); -x_228 = lean_ctor_get(x_221, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_221, 4); -lean_inc(x_229); -x_230 = lean_ctor_get(x_221, 5); +if (lean_is_scalar(x_225)) { + x_226 = lean_alloc_ctor(0, 4, 0); +} else { + x_226 = x_225; +} +lean_ctor_set(x_226, 0, x_222); +lean_ctor_set(x_226, 1, x_223); +lean_ctor_set(x_226, 2, x_60); +lean_ctor_set(x_226, 3, x_224); +if (lean_is_scalar(x_221)) { + x_227 = lean_alloc_ctor(0, 6, 0); +} else { + x_227 = x_221; +} +lean_ctor_set(x_227, 0, x_216); +lean_ctor_set(x_227, 1, x_217); +lean_ctor_set(x_227, 2, x_226); +lean_ctor_set(x_227, 3, x_218); +lean_ctor_set(x_227, 4, x_219); +lean_ctor_set(x_227, 5, x_220); +if (lean_is_scalar(x_215)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_215; +} +lean_ctor_set(x_228, 0, x_227); +lean_ctor_set(x_228, 1, x_210); +lean_ctor_set(x_228, 2, x_211); +lean_ctor_set(x_228, 3, x_212); +lean_ctor_set(x_228, 4, x_213); +lean_ctor_set(x_228, 5, x_214); +if (lean_is_scalar(x_209)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_209; +} +lean_ctor_set(x_229, 0, x_208); +lean_ctor_set(x_229, 1, x_228); +return x_229; +} +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; 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_230 = lean_ctor_get(x_204, 1); lean_inc(x_230); -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); - lean_ctor_release(x_221, 4); - lean_ctor_release(x_221, 5); - x_231 = x_221; -} else { - lean_dec_ref(x_221); - x_231 = lean_box(0); -} -x_232 = lean_ctor_get(x_222, 0); +x_231 = lean_ctor_get(x_230, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_231, 2); lean_inc(x_232); -x_233 = lean_ctor_get(x_222, 1); +x_233 = lean_ctor_get(x_204, 0); lean_inc(x_233); -x_234 = lean_ctor_get(x_222, 3); -lean_inc(x_234); -x_235 = lean_ctor_get(x_222, 4); -lean_inc(x_235); -x_236 = lean_ctor_get(x_222, 5); -lean_inc(x_236); -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_237 = x_222; +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + x_234 = x_204; } else { - lean_dec_ref(x_222); - x_237 = lean_box(0); + lean_dec_ref(x_204); + x_234 = lean_box(0); } -x_238 = lean_ctor_get(x_223, 0); +x_235 = lean_ctor_get(x_230, 1); +lean_inc(x_235); +x_236 = lean_ctor_get(x_230, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_230, 3); +lean_inc(x_237); +x_238 = lean_ctor_get(x_230, 4); lean_inc(x_238); -x_239 = lean_ctor_get(x_223, 1); +x_239 = lean_ctor_get(x_230, 5); lean_inc(x_239); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - lean_ctor_release(x_223, 2); - x_240 = x_223; +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_240 = x_230; } else { - lean_dec_ref(x_223); + lean_dec_ref(x_230); x_240 = lean_box(0); } +x_241 = lean_ctor_get(x_231, 0); +lean_inc(x_241); +x_242 = lean_ctor_get(x_231, 1); +lean_inc(x_242); +x_243 = lean_ctor_get(x_231, 3); +lean_inc(x_243); +x_244 = lean_ctor_get(x_231, 4); +lean_inc(x_244); +x_245 = lean_ctor_get(x_231, 5); +lean_inc(x_245); +if (lean_is_exclusive(x_231)) { + lean_ctor_release(x_231, 0); + lean_ctor_release(x_231, 1); + lean_ctor_release(x_231, 2); + lean_ctor_release(x_231, 3); + lean_ctor_release(x_231, 4); + lean_ctor_release(x_231, 5); + x_246 = x_231; +} else { + lean_dec_ref(x_231); + x_246 = lean_box(0); +} +x_247 = lean_ctor_get(x_232, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_232, 1); +lean_inc(x_248); +x_249 = lean_ctor_get(x_232, 3); +lean_inc(x_249); +if (lean_is_exclusive(x_232)) { + lean_ctor_release(x_232, 0); + lean_ctor_release(x_232, 1); + lean_ctor_release(x_232, 2); + lean_ctor_release(x_232, 3); + x_250 = x_232; +} else { + lean_dec_ref(x_232); + 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_60); +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_241 = lean_alloc_ctor(0, 3, 0); + x_253 = lean_alloc_ctor(0, 6, 0); } else { - x_241 = x_240; + x_253 = x_240; } -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_60); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_253, 0, x_252); +lean_ctor_set(x_253, 1, x_235); +lean_ctor_set(x_253, 2, x_236); +lean_ctor_set(x_253, 3, x_237); +lean_ctor_set(x_253, 4, x_238); +lean_ctor_set(x_253, 5, x_239); +if (lean_is_scalar(x_234)) { + x_254 = lean_alloc_ctor(1, 2, 0); } else { - x_242 = x_237; + x_254 = x_234; } -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 6, 0); -} else { - x_243 = x_231; -} -lean_ctor_set(x_243, 0, x_242); -lean_ctor_set(x_243, 1, x_226); -lean_ctor_set(x_243, 2, x_227); -lean_ctor_set(x_243, 3, x_228); -lean_ctor_set(x_243, 4, x_229); -lean_ctor_set(x_243, 5, x_230); -if (lean_is_scalar(x_225)) { - x_244 = lean_alloc_ctor(1, 2, 0); -} else { - x_244 = x_225; -} -lean_ctor_set(x_244, 0, x_224); -lean_ctor_set(x_244, 1, x_243); -return x_244; +lean_ctor_set(x_254, 0, x_233); +lean_ctor_set(x_254, 1, x_253); +return x_254; } } } 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; uint8_t x_254; uint8_t x_255; uint8_t 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_245 = lean_ctor_get(x_5, 1); -x_246 = lean_ctor_get(x_5, 2); -x_247 = lean_ctor_get(x_5, 3); -x_248 = lean_ctor_get(x_5, 4); -x_249 = lean_ctor_get(x_5, 5); -x_250 = lean_ctor_get(x_5, 6); -x_251 = lean_ctor_get(x_5, 7); -x_252 = lean_ctor_get(x_5, 8); -x_253 = lean_ctor_get(x_5, 9); -x_254 = lean_ctor_get_uint8(x_5, sizeof(void*)*10); -x_255 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 1); -x_256 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 2); -lean_inc(x_253); -lean_inc(x_252); -lean_inc(x_251); -lean_inc(x_250); -lean_inc(x_249); -lean_inc(x_248); -lean_inc(x_247); -lean_inc(x_246); -lean_inc(x_245); -lean_dec(x_5); -x_257 = lean_ctor_get(x_62, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_62, 3); -lean_inc(x_258); -x_259 = lean_ctor_get(x_62, 4); +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; uint8_t x_264; uint8_t x_265; uint8_t 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_255 = lean_ctor_get(x_5, 1); +x_256 = lean_ctor_get(x_5, 2); +x_257 = lean_ctor_get(x_5, 3); +x_258 = lean_ctor_get(x_5, 4); +x_259 = lean_ctor_get(x_5, 5); +x_260 = lean_ctor_get(x_5, 6); +x_261 = lean_ctor_get(x_5, 7); +x_262 = lean_ctor_get(x_5, 8); +x_263 = lean_ctor_get(x_5, 9); +x_264 = lean_ctor_get_uint8(x_5, sizeof(void*)*10); +x_265 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 1); +x_266 = lean_ctor_get_uint8(x_5, sizeof(void*)*10 + 2); +lean_inc(x_263); +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_dec(x_5); +x_267 = lean_ctor_get(x_62, 0); +lean_inc(x_267); +x_268 = lean_ctor_get(x_62, 3); +lean_inc(x_268); +x_269 = lean_ctor_get(x_62, 4); +lean_inc(x_269); if (lean_is_exclusive(x_62)) { lean_ctor_release(x_62, 0); lean_ctor_release(x_62, 1); lean_ctor_release(x_62, 2); lean_ctor_release(x_62, 3); lean_ctor_release(x_62, 4); - x_260 = x_62; + x_270 = x_62; } else { lean_dec_ref(x_62); - x_260 = lean_box(0); + x_270 = lean_box(0); } -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 5, 0); } else { - x_261 = x_260; + x_271 = x_270; } -lean_ctor_set(x_261, 0, x_257); -lean_ctor_set(x_261, 1, x_22); -lean_ctor_set(x_261, 2, x_23); -lean_ctor_set(x_261, 3, x_258); -lean_ctor_set(x_261, 4, x_259); -x_262 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_262, 0, x_261); -lean_ctor_set(x_262, 1, x_245); -lean_ctor_set(x_262, 2, x_246); -lean_ctor_set(x_262, 3, x_247); -lean_ctor_set(x_262, 4, x_248); -lean_ctor_set(x_262, 5, x_249); -lean_ctor_set(x_262, 6, x_250); -lean_ctor_set(x_262, 7, x_251); -lean_ctor_set(x_262, 8, x_252); -lean_ctor_set(x_262, 9, x_253); -lean_ctor_set_uint8(x_262, sizeof(void*)*10, x_254); -lean_ctor_set_uint8(x_262, sizeof(void*)*10 + 1, x_255); -lean_ctor_set_uint8(x_262, sizeof(void*)*10 + 2, x_256); -x_263 = lean_apply_4(x_4, x_21, x_24, x_262, x_63); -if (lean_obj_tag(x_263) == 0) +lean_ctor_set(x_271, 0, x_267); +lean_ctor_set(x_271, 1, x_22); +lean_ctor_set(x_271, 2, x_23); +lean_ctor_set(x_271, 3, x_268); +lean_ctor_set(x_271, 4, x_269); +x_272 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_272, 0, x_271); +lean_ctor_set(x_272, 1, x_255); +lean_ctor_set(x_272, 2, x_256); +lean_ctor_set(x_272, 3, x_257); +lean_ctor_set(x_272, 4, x_258); +lean_ctor_set(x_272, 5, x_259); +lean_ctor_set(x_272, 6, x_260); +lean_ctor_set(x_272, 7, x_261); +lean_ctor_set(x_272, 8, x_262); +lean_ctor_set(x_272, 9, x_263); +lean_ctor_set_uint8(x_272, sizeof(void*)*10, x_264); +lean_ctor_set_uint8(x_272, sizeof(void*)*10 + 1, x_265); +lean_ctor_set_uint8(x_272, sizeof(void*)*10 + 2, x_266); +x_273 = lean_apply_4(x_4, x_21, x_24, x_272, x_63); +if (lean_obj_tag(x_273) == 0) { -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; -x_264 = lean_ctor_get(x_263, 1); -lean_inc(x_264); -x_265 = lean_ctor_get(x_264, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_265, 2); -lean_inc(x_266); -x_267 = lean_ctor_get(x_263, 0); -lean_inc(x_267); -if (lean_is_exclusive(x_263)) { - lean_ctor_release(x_263, 0); - lean_ctor_release(x_263, 1); - x_268 = x_263; -} else { - lean_dec_ref(x_263); - x_268 = lean_box(0); -} -x_269 = lean_ctor_get(x_264, 1); -lean_inc(x_269); -x_270 = lean_ctor_get(x_264, 2); -lean_inc(x_270); -x_271 = lean_ctor_get(x_264, 3); -lean_inc(x_271); -x_272 = lean_ctor_get(x_264, 4); -lean_inc(x_272); -x_273 = lean_ctor_get(x_264, 5); -lean_inc(x_273); -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_274 = x_264; -} else { - lean_dec_ref(x_264); - x_274 = lean_box(0); -} -x_275 = lean_ctor_get(x_265, 0); +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; +x_274 = lean_ctor_get(x_273, 1); +lean_inc(x_274); +x_275 = lean_ctor_get(x_274, 0); lean_inc(x_275); -x_276 = lean_ctor_get(x_265, 1); +x_276 = lean_ctor_get(x_275, 2); lean_inc(x_276); -x_277 = lean_ctor_get(x_265, 3); +x_277 = lean_ctor_get(x_273, 0); lean_inc(x_277); -x_278 = lean_ctor_get(x_265, 4); -lean_inc(x_278); -x_279 = lean_ctor_get(x_265, 5); +if (lean_is_exclusive(x_273)) { + lean_ctor_release(x_273, 0); + lean_ctor_release(x_273, 1); + x_278 = x_273; +} else { + lean_dec_ref(x_273); + x_278 = lean_box(0); +} +x_279 = lean_ctor_get(x_274, 1); lean_inc(x_279); -if (lean_is_exclusive(x_265)) { - lean_ctor_release(x_265, 0); - lean_ctor_release(x_265, 1); - lean_ctor_release(x_265, 2); - lean_ctor_release(x_265, 3); - lean_ctor_release(x_265, 4); - lean_ctor_release(x_265, 5); - x_280 = x_265; -} else { - lean_dec_ref(x_265); - x_280 = lean_box(0); -} -x_281 = lean_ctor_get(x_266, 0); +x_280 = lean_ctor_get(x_274, 2); +lean_inc(x_280); +x_281 = lean_ctor_get(x_274, 3); lean_inc(x_281); -x_282 = lean_ctor_get(x_266, 1); +x_282 = lean_ctor_get(x_274, 4); lean_inc(x_282); -if (lean_is_exclusive(x_266)) { - lean_ctor_release(x_266, 0); - lean_ctor_release(x_266, 1); - lean_ctor_release(x_266, 2); - x_283 = x_266; +x_283 = lean_ctor_get(x_274, 5); +lean_inc(x_283); +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_284 = x_274; } else { - lean_dec_ref(x_266); - x_283 = lean_box(0); + lean_dec_ref(x_274); + x_284 = lean_box(0); } -if (lean_is_scalar(x_283)) { - x_284 = lean_alloc_ctor(0, 3, 0); -} else { - x_284 = x_283; -} -lean_ctor_set(x_284, 0, x_281); -lean_ctor_set(x_284, 1, x_282); -lean_ctor_set(x_284, 2, x_60); -if (lean_is_scalar(x_280)) { - x_285 = lean_alloc_ctor(0, 6, 0); -} else { - x_285 = x_280; -} -lean_ctor_set(x_285, 0, x_275); -lean_ctor_set(x_285, 1, x_276); -lean_ctor_set(x_285, 2, x_284); -lean_ctor_set(x_285, 3, x_277); -lean_ctor_set(x_285, 4, x_278); -lean_ctor_set(x_285, 5, x_279); -if (lean_is_scalar(x_274)) { - x_286 = lean_alloc_ctor(0, 6, 0); -} else { - x_286 = x_274; -} -lean_ctor_set(x_286, 0, x_285); -lean_ctor_set(x_286, 1, x_269); -lean_ctor_set(x_286, 2, x_270); -lean_ctor_set(x_286, 3, x_271); -lean_ctor_set(x_286, 4, x_272); -lean_ctor_set(x_286, 5, x_273); -if (lean_is_scalar(x_268)) { - x_287 = lean_alloc_ctor(0, 2, 0); -} else { - x_287 = x_268; -} -lean_ctor_set(x_287, 0, x_267); -lean_ctor_set(x_287, 1, x_286); -return x_287; -} -else -{ -lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; 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; -x_288 = lean_ctor_get(x_263, 1); +x_285 = lean_ctor_get(x_275, 0); +lean_inc(x_285); +x_286 = lean_ctor_get(x_275, 1); +lean_inc(x_286); +x_287 = lean_ctor_get(x_275, 3); +lean_inc(x_287); +x_288 = lean_ctor_get(x_275, 4); lean_inc(x_288); -x_289 = lean_ctor_get(x_288, 0); +x_289 = lean_ctor_get(x_275, 5); lean_inc(x_289); -x_290 = lean_ctor_get(x_289, 2); -lean_inc(x_290); -x_291 = lean_ctor_get(x_263, 0); +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); + lean_ctor_release(x_275, 4); + lean_ctor_release(x_275, 5); + x_290 = x_275; +} else { + lean_dec_ref(x_275); + x_290 = lean_box(0); +} +x_291 = lean_ctor_get(x_276, 0); lean_inc(x_291); -if (lean_is_exclusive(x_263)) { - lean_ctor_release(x_263, 0); - lean_ctor_release(x_263, 1); - x_292 = x_263; -} else { - lean_dec_ref(x_263); - x_292 = lean_box(0); -} -x_293 = lean_ctor_get(x_288, 1); +x_292 = lean_ctor_get(x_276, 1); +lean_inc(x_292); +x_293 = lean_ctor_get(x_276, 3); lean_inc(x_293); -x_294 = lean_ctor_get(x_288, 2); -lean_inc(x_294); -x_295 = lean_ctor_get(x_288, 3); -lean_inc(x_295); -x_296 = lean_ctor_get(x_288, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_288, 5); -lean_inc(x_297); -if (lean_is_exclusive(x_288)) { - lean_ctor_release(x_288, 0); - lean_ctor_release(x_288, 1); - lean_ctor_release(x_288, 2); - lean_ctor_release(x_288, 3); - lean_ctor_release(x_288, 4); - lean_ctor_release(x_288, 5); - x_298 = x_288; +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_294 = x_276; } else { - lean_dec_ref(x_288); - x_298 = lean_box(0); + lean_dec_ref(x_276); + x_294 = lean_box(0); } -x_299 = lean_ctor_get(x_289, 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_60); +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); +if (lean_is_scalar(x_278)) { + x_298 = lean_alloc_ctor(0, 2, 0); +} else { + x_298 = x_278; +} +lean_ctor_set(x_298, 0, x_277); +lean_ctor_set(x_298, 1, x_297); +return x_298; +} +else +{ +lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; 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; lean_object* x_323; +x_299 = lean_ctor_get(x_273, 1); lean_inc(x_299); -x_300 = lean_ctor_get(x_289, 1); +x_300 = lean_ctor_get(x_299, 0); lean_inc(x_300); -x_301 = lean_ctor_get(x_289, 3); +x_301 = lean_ctor_get(x_300, 2); lean_inc(x_301); -x_302 = lean_ctor_get(x_289, 4); +x_302 = lean_ctor_get(x_273, 0); lean_inc(x_302); -x_303 = lean_ctor_get(x_289, 5); -lean_inc(x_303); -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_304 = x_289; +if (lean_is_exclusive(x_273)) { + lean_ctor_release(x_273, 0); + lean_ctor_release(x_273, 1); + x_303 = x_273; } else { - lean_dec_ref(x_289); - x_304 = lean_box(0); + lean_dec_ref(x_273); + x_303 = lean_box(0); } -x_305 = lean_ctor_get(x_290, 0); +x_304 = lean_ctor_get(x_299, 1); +lean_inc(x_304); +x_305 = lean_ctor_get(x_299, 2); lean_inc(x_305); -x_306 = lean_ctor_get(x_290, 1); +x_306 = lean_ctor_get(x_299, 3); lean_inc(x_306); -if (lean_is_exclusive(x_290)) { - lean_ctor_release(x_290, 0); - lean_ctor_release(x_290, 1); - lean_ctor_release(x_290, 2); - x_307 = x_290; +x_307 = lean_ctor_get(x_299, 4); +lean_inc(x_307); +x_308 = lean_ctor_get(x_299, 5); +lean_inc(x_308); +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_309 = x_299; } else { - lean_dec_ref(x_290); - x_307 = lean_box(0); + lean_dec_ref(x_299); + x_309 = lean_box(0); } -if (lean_is_scalar(x_307)) { - x_308 = lean_alloc_ctor(0, 3, 0); +x_310 = lean_ctor_get(x_300, 0); +lean_inc(x_310); +x_311 = lean_ctor_get(x_300, 1); +lean_inc(x_311); +x_312 = lean_ctor_get(x_300, 3); +lean_inc(x_312); +x_313 = lean_ctor_get(x_300, 4); +lean_inc(x_313); +x_314 = lean_ctor_get(x_300, 5); +lean_inc(x_314); +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); + lean_ctor_release(x_300, 4); + lean_ctor_release(x_300, 5); + x_315 = x_300; } else { - x_308 = x_307; + lean_dec_ref(x_300); + x_315 = lean_box(0); } -lean_ctor_set(x_308, 0, x_305); -lean_ctor_set(x_308, 1, x_306); -lean_ctor_set(x_308, 2, x_60); -if (lean_is_scalar(x_304)) { - x_309 = lean_alloc_ctor(0, 6, 0); +x_316 = lean_ctor_get(x_301, 0); +lean_inc(x_316); +x_317 = lean_ctor_get(x_301, 1); +lean_inc(x_317); +x_318 = lean_ctor_get(x_301, 3); +lean_inc(x_318); +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); + x_319 = x_301; } else { - x_309 = x_304; + lean_dec_ref(x_301); + x_319 = lean_box(0); } -lean_ctor_set(x_309, 0, x_299); -lean_ctor_set(x_309, 1, x_300); -lean_ctor_set(x_309, 2, x_308); -lean_ctor_set(x_309, 3, x_301); -lean_ctor_set(x_309, 4, x_302); -lean_ctor_set(x_309, 5, x_303); -if (lean_is_scalar(x_298)) { - x_310 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_319)) { + x_320 = lean_alloc_ctor(0, 4, 0); } else { - x_310 = x_298; + x_320 = x_319; } -lean_ctor_set(x_310, 0, x_309); -lean_ctor_set(x_310, 1, x_293); -lean_ctor_set(x_310, 2, x_294); -lean_ctor_set(x_310, 3, x_295); -lean_ctor_set(x_310, 4, x_296); -lean_ctor_set(x_310, 5, x_297); -if (lean_is_scalar(x_292)) { - x_311 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_320, 0, x_316); +lean_ctor_set(x_320, 1, x_317); +lean_ctor_set(x_320, 2, x_60); +lean_ctor_set(x_320, 3, x_318); +if (lean_is_scalar(x_315)) { + x_321 = lean_alloc_ctor(0, 6, 0); } else { - x_311 = x_292; + x_321 = x_315; } -lean_ctor_set(x_311, 0, x_291); -lean_ctor_set(x_311, 1, x_310); -return x_311; +lean_ctor_set(x_321, 0, x_310); +lean_ctor_set(x_321, 1, x_311); +lean_ctor_set(x_321, 2, x_320); +lean_ctor_set(x_321, 3, x_312); +lean_ctor_set(x_321, 4, x_313); +lean_ctor_set(x_321, 5, x_314); +if (lean_is_scalar(x_309)) { + x_322 = lean_alloc_ctor(0, 6, 0); +} else { + x_322 = x_309; +} +lean_ctor_set(x_322, 0, x_321); +lean_ctor_set(x_322, 1, x_304); +lean_ctor_set(x_322, 2, x_305); +lean_ctor_set(x_322, 3, x_306); +lean_ctor_set(x_322, 4, x_307); +lean_ctor_set(x_322, 5, x_308); +if (lean_is_scalar(x_303)) { + x_323 = lean_alloc_ctor(1, 2, 0); +} else { + x_323 = x_303; +} +lean_ctor_set(x_323, 0, x_302); +lean_ctor_set(x_323, 1, x_322); +return x_323; } } } } else { -uint8_t x_312; +uint8_t x_324; lean_dec(x_12); lean_dec(x_5); lean_dec(x_4); -x_312 = !lean_is_exclusive(x_17); -if (x_312 == 0) +x_324 = !lean_is_exclusive(x_17); +if (x_324 == 0) { return x_17; } else { -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_17, 0); -x_314 = lean_ctor_get(x_17, 1); -lean_inc(x_314); -lean_inc(x_313); +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_17, 0); +x_326 = lean_ctor_get(x_17, 1); +lean_inc(x_326); +lean_inc(x_325); lean_dec(x_17); -x_315 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -return x_315; +x_327 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_327, 0, x_325); +lean_ctor_set(x_327, 1, x_326); +return x_327; } } } else { -lean_object* x_316; lean_object* x_317; -x_316 = l_Array_empty___closed__1; -x_317 = lean_apply_4(x_4, x_316, x_2, x_5, x_6); -return x_317; +lean_object* x_328; lean_object* x_329; +x_328 = l_Array_empty___closed__1; +x_329 = lean_apply_4(x_4, x_328, x_2, x_5, x_6); +return x_329; } } } @@ -24028,10 +24460,10 @@ x_65 = lean_array_push(x_42, x_64); x_66 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_66, 0, x_51); lean_ctor_set(x_66, 1, x_65); -x_67 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_67 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_68 = lean_array_push(x_67, x_66); x_69 = lean_array_push(x_68, x_44); -x_70 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_70 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_71 = lean_array_push(x_69, x_70); x_72 = lean_array_push(x_71, x_44); x_73 = lean_array_push(x_42, x_12); @@ -24212,10 +24644,10 @@ x_160 = lean_array_push(x_144, x_159); x_161 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_161, 0, x_121); lean_ctor_set(x_161, 1, x_160); -x_162 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_162 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_163 = lean_array_push(x_162, x_161); x_164 = lean_array_push(x_163, x_146); -x_165 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_165 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_166 = lean_array_push(x_164, x_165); x_167 = lean_array_push(x_166, x_146); x_168 = lean_array_push(x_144, x_12); @@ -24769,10 +25201,10 @@ x_65 = lean_array_push(x_42, x_64); x_66 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_66, 0, x_51); lean_ctor_set(x_66, 1, x_65); -x_67 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_67 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_68 = lean_array_push(x_67, x_66); x_69 = lean_array_push(x_68, x_44); -x_70 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_70 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_71 = lean_array_push(x_69, x_70); x_72 = lean_array_push(x_71, x_44); x_73 = lean_array_push(x_42, x_12); @@ -24953,10 +25385,10 @@ x_160 = lean_array_push(x_144, x_159); x_161 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_161, 0, x_121); lean_ctor_set(x_161, 1, x_160); -x_162 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_162 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_163 = lean_array_push(x_162, x_161); x_164 = lean_array_push(x_163, x_146); -x_165 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_165 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_166 = lean_array_push(x_164, x_165); x_167 = lean_array_push(x_166, x_146); x_168 = lean_array_push(x_144, x_12); @@ -25216,7 +25648,7 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } -lean_object* l___private_Init_Lean_Elab_Binders_14__regTraceClasses(lean_object* x_1) { +lean_object* l___private_Init_Lean_Elab_Binders_15__regTraceClasses(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; @@ -25323,6 +25755,12 @@ l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__7 = _init_l lean_mark_persistent(l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__7); l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__8 = _init_l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__8(); lean_mark_persistent(l___private_Init_Lean_Elab_Binders_4__expandBinderModifier___closed__8); +l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__1 = _init_l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__1(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__1); +l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__2 = _init_l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__2(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__2); +l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3 = _init_l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3(); +lean_mark_persistent(l_Array_umapMAux___main___at___private_Init_Lean_Elab_Binders_5__getBinderIds___spec__1___closed__3); l___regBuiltin_Lean_Elab_Term_elabForall___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabForall___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabForall___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabForall(lean_io_mk_world()); @@ -25350,38 +25788,38 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabDepArrow___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabDepArrow(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__1); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__3); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__6); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__8); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__9); -l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10 = _init_l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__10); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__1); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__2); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__3); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__4); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__5); -l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6 = _init_l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__checkNoOptAutoParam___closed__6); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__1); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__3); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__6); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__8); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__9); +l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10 = _init_l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__10); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__1); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__2); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__3); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__4); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__5); +l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6 = _init_l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Elab_Binders_12__checkNoOptAutoParam___closed__6); l___regBuiltin_Lean_Elab_Term_elabFun___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabFun___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabFun___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabFun(lean_io_mk_world()); @@ -25411,7 +25849,7 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabLetBangDecl___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabLetBangDecl(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -res = l___private_Init_Lean_Elab_Binders_14__regTraceClasses(lean_io_mk_world()); +res = l___private_Init_Lean_Elab_Binders_15__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/Init/Lean/Elab/BuiltinNotation.c b/stage0/stdlib/Init/Lean/Elab/BuiltinNotation.c index 8747649a25..cb56333211 100644 --- a/stage0/stdlib/Init/Lean/Elab/BuiltinNotation.c +++ b/stage0/stdlib/Init/Lean/Elab/BuiltinNotation.c @@ -15,6 +15,7 @@ extern "C" { #endif lean_object* l_Lean_Elab_Term_elabModN___closed__2; lean_object* l_Lean_Elab_Term_elabBAnd___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_mkAppM(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__5; lean_object* l_Lean_Elab_Term_elabseqLeft___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabNe___closed__1; @@ -25,7 +26,9 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabParserMacro(lean_object*); lean_object* l_Lean_Elab_Term_elabAdd___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabseqLeft___closed__1; lean_object* l_Lean_Elab_Term_elabBind___boxed(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_prod_x3f___closed__2; lean_object* l_Lean_mkAppStx(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6; lean_object* l_Lean_extractMacroScopes(lean_object*); lean_object* l_Lean_Elab_Term_elabAdd___closed__1; extern lean_object* l_Lean_Parser_Term_andthen___elambda__1___closed__2; @@ -36,11 +39,8 @@ lean_object* l_Lean_Elab_Term_expandIf___closed__3; extern lean_object* l_Lean_Parser_Term_andthen___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_elabBAnd___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__13; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__14; extern lean_object* l_Lean_Expr_eq_x3f___closed__2; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__15; lean_object* l___regBuiltin_Lean_Elab_Term_elabBAnd___closed__1; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__18; lean_object* l_Lean_Elab_Term_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__23; extern lean_object* l_Lean_Parser_Term_sub___elambda__1___closed__2; @@ -52,12 +52,14 @@ lean_object* l_Lean_Elab_Term_elabModN___closed__3; lean_object* l___regBuiltin_Lean_Elab_Term_elabNativeRefl___closed__1; lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__2; lean_object* l_Lean_Elab_Term_elabBOr___boxed(lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Term_8__exceptionToSorry___closed__1; lean_object* l_Lean_Elab_Term_elabInfix(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__5; lean_object* l_Lean_Elab_Term_expandSubtype___closed__9; lean_object* l___regBuiltin_Lean_Elab_Term_elabMapConstRev(lean_object*); lean_object* l_Lean_Elab_Term_inferType(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__30; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4; extern lean_object* l_Lean_Parser_Term_eq___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabBAnd(lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__28; @@ -66,6 +68,7 @@ lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__18; lean_object* l_Lean_Elab_Term_expandHave___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_7__getHeadInfo___elambda__3___closed__1; lean_object* l_Lean_Elab_Term_getDeclName_x3f(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__14; lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__1; lean_object* l_Lean_Elab_Term_elabBOr___closed__1; @@ -73,6 +76,7 @@ lean_object* l_Lean_Elab_Term_elabMul___closed__1; extern lean_object* l_Lean_Parser_Term_seqLeft___elambda__1___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabEquiv(lean_object*); lean_object* l_Lean_Elab_Term_elabseqLeft___closed__3; +lean_object* l_Lean_Elab_Term_elabNativeDecide___closed__2; extern lean_object* l_Lean_Parser_Term_where___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__11; lean_object* l___regBuiltin_Lean_Elab_Term_elabBNe(lean_object*); @@ -86,11 +90,13 @@ extern lean_object* l_Lean_Parser_Term_anonymousCtor___elambda__1___closed__2; extern lean_object* l_Array_empty___closed__1; lean_object* l_Lean_Elab_Term_elabPow___closed__3; lean_object* lean_environment_find(lean_object*, lean_object*); +extern lean_object* l_Lean_Parser_Term_decide___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabseqRight___closed__1; extern lean_object* l___private_Init_Lean_Elab_Quotation_13__toPreterm___main___lambda__2___closed__4; lean_object* l_Lean_Elab_Term_elabMod___closed__1; lean_object* l_Lean_Elab_Term_elabTermAndSynthesize(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandDollar(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Parser_Term_decide___elambda__1___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_ElabFComp___closed__1; extern lean_object* l_Lean_Parser_Term_fromTerm___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabGT(lean_object*); @@ -101,13 +107,14 @@ lean_object* l_Lean_Elab_Term_elabEquiv___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__17; lean_object* l_Lean_Elab_Term_elabNativeRefl(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabEquiv___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__13; +extern lean_object* l_Lean_Parser_Term_nativeDecide___elambda__1___closed__2; lean_object* l_Lean_mkIdentFrom(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__4; extern lean_object* l_Lean_Parser_Term_pow___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_expandSubtype(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_parser_x21___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_compileDecl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6; lean_object* l_Lean_Elab_Term_elabMul___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__8; lean_object* l_Lean_Elab_Term_expandIf___closed__7; @@ -121,12 +128,14 @@ lean_object* lean_array_get_size(lean_object*); extern lean_object* l___private_Init_Lean_Elab_Quotation_8__explodeHeadPat___lambda__1___closed__3; lean_object* l_Lean_Elab_Term_elabModN(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabAndThen___closed__1; +lean_object* l_Lean_Elab_Term_elabDecide___closed__3; extern lean_object* l_Lean_Parser_Term_gt___elambda__1___closed__2; -extern lean_object* l_Lean_listToExpr___rarg___closed__8; lean_object* l_Lean_Elab_Term_elabEquiv(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +extern lean_object* l_Lean_Expr_listLitAux___main___closed__5; lean_object* l___regBuiltin_Lean_Elab_Term_elabAppend___closed__1; lean_object* l_Lean_Elab_Term_elabTParserMacro___lambda__1___closed__6; +extern lean_object* l_Lean_Expr_getAppArgs___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__6; lean_object* l_Lean_Elab_Term_mkAuxName(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabAnd(lean_object*, lean_object*, lean_object*); @@ -137,6 +146,7 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabAppend(lean_object*); lean_object* l_Lean_Elab_Term_elabDiv___closed__3; lean_object* l___regBuiltin_Lean_Elab_Term_elabHEq___closed__1; lean_object* l_Lean_Elab_Term_elabBNe(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabLT___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_string_utf8_byte_size(lean_object*); @@ -144,13 +154,12 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabMul(lean_object*); extern lean_object* l_Lean_mkAppStx___closed__4; lean_object* l_Lean_Elab_Term_elabEquiv___closed__4; extern lean_object* l_Lean_Parser_Term_andM___elambda__1___closed__2; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3; lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_ElabFComp(lean_object*); -extern lean_object* l_Lean_Parser_Term_cons___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_elabLT___closed__1; lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabEquiv___closed__2; -extern lean_object* l_Lean_mkTermIdFromIdent___closed__1; lean_object* l_Lean_Elab_Term_getMainModule___rarg(lean_object*); lean_object* l_Lean_Elab_Term_elabMod___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__6; @@ -167,6 +176,7 @@ lean_object* l___regBuiltin_Lean_Elab_Term_expandDollar___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabGT___closed__1; extern lean_object* l_Lean_mkAppStx___closed__8; lean_object* l_Lean_Elab_Term_expandSubtype___closed__1; +lean_object* l_Lean_Elab_Term_mkExpectedTypeHint(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabMap(lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_expandShow___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabBNe___closed__1; @@ -179,9 +189,12 @@ lean_object* l_Lean_Elab_Term_expandDollarProj(lean_object*, lean_object*, lean_ lean_object* l_Lean_Elab_Term_whnf(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_or___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabCons___closed__1; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabAndThen(lean_object*); lean_object* l_Lean_Elab_Term_elabseq___closed__1; lean_object* l_Lean_Elab_Term_addDecl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5; 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_Term_elabParserMacro___lambda__1___closed__19; @@ -189,11 +202,12 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabTParserMacro(lean_object*); extern lean_object* l_Lean_Parser_Term_proj___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Term_add___elambda__1___closed__1; extern lean_object* l_Lean_Parser_Term_add___elambda__1___closed__2; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__17; lean_object* l_Lean_Elab_Term_expandShow___closed__2; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_List_beq___main___at_Lean_Elab_Term_elabParserMacro___spec__1___boxed(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_dollarProj___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_expandHave(lean_object*); +lean_object* l_Lean_Elab_Term_elabDecide___closed__2; lean_object* l_Lean_Elab_Term_elabOr___closed__2; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__9; lean_object* l___private_Init_Lean_Elab_Term_2__fromMetaException(lean_object*, lean_object*, lean_object*); @@ -206,6 +220,7 @@ lean_object* l_Lean_Elab_Term_expandSubtype___closed__6; lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__8; lean_object* l___regBuiltin_Lean_Elab_Term_elabBOr___closed__1; +lean_object* l___regBuiltin_Lean_Elab_Term_elabCons___closed__2; lean_object* l_Lean_Elab_Term_elabAnonymousCtor(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabHEq(lean_object*); lean_object* l_Lean_Elab_Term_elabTParserMacro___lambda__1(lean_object*, lean_object*, lean_object*); @@ -220,6 +235,7 @@ extern lean_object* l___private_Init_Lean_Elab_Quotation_13__toPreterm___main___ lean_object* l___regBuiltin_Lean_Elab_Term_elabOrElse___closed__1; extern lean_object* l_Lean_Parser_Term_band___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_expandHave___closed__1; +lean_object* l_Lean_Elab_Term_elabNativeDecide(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabBind___closed__1; lean_object* l_Lean_Elab_Term_elabAppend(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__1; @@ -227,13 +243,13 @@ extern lean_object* l_Lean_Parser_Term_or___elambda__1___closed__1; lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandShow___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(lean_object*); +lean_object* l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1; extern lean_object* l_Lean_Parser_Term_ne___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabMapConst(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_mul___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabSub(lean_object*); extern lean_object* l_Lean_Parser_Term_div___elambda__1___closed__1; extern lean_object* l_Lean_Parser_Term_tparser_x21___elambda__1___closed__2; -extern lean_object* l_Lean_listToExpr___rarg___closed__5; lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__9; extern lean_object* l_Lean_Parser_Tactic_seq___elambda__1___closed__3; extern lean_object* l_Lean_Parser_Term_ge___elambda__1___closed__2; @@ -264,6 +280,8 @@ lean_object* l_Lean_Elab_Term_elabEquiv___closed__3; lean_object* l_Lean_Elab_Term_elabTParserMacro___closed__1; lean_object* l_Lean_Elab_Term_expandIf___closed__6; extern lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__29; +lean_object* l_Lean_Elab_Term_elabDecide___closed__1; +lean_object* l___regBuiltin_Lean_Elab_Term_elabDecide(lean_object*); lean_object* l_Lean_Elab_Term_ElabFComp(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabLE___closed__1; lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__8; @@ -273,8 +291,10 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabAnonymousCtor(lean_object*); extern lean_object* l_Lean_Parser_Term_mod___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_elabMapRev___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabEq___closed__1; +extern lean_object* l_Lean_boolToExpr___closed__1; lean_object* l_Lean_Elab_Term_elabTParserMacro___lambda__1___closed__7; extern lean_object* l_Lean_Elab_Term_expandCDot_x3f___closed__3; +lean_object* l___regBuiltin_Lean_Elab_Term_elabNativeDecide(lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__27; lean_object* l___regBuiltin_Lean_Elab_Term_elabMapConst___closed__1; lean_object* l_Lean_Elab_Term_elabSub(lean_object*, lean_object*, lean_object*); @@ -284,6 +304,7 @@ lean_object* l_Lean_Elab_Term_elabMod___closed__3; lean_object* l_Lean_Elab_Term_elabLE___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabAnd___closed__1; lean_object* l_Lean_Elab_Term_elabseqRight___closed__1; +extern lean_object* l_Lean_mkDecIsTrue___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*); lean_object* l___regBuiltin_Lean_Elab_Term_elabBOr(lean_object*); @@ -327,8 +348,8 @@ lean_object* l___regBuiltin_Lean_Elab_Term_expandWhere(lean_object*); extern lean_object* l_Lean_Parser_Term_append___elambda__1___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_expandSubtype(lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabModN(lean_object*); -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__11; extern lean_object* l_Lean_Parser_Term_mapConstRev___elambda__1___closed__1; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isConstOf(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_beq___elambda__1___closed__2; extern lean_object* l_Lean_Parser_Term_bor___elambda__1___closed__2; @@ -349,6 +370,7 @@ lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__26; lean_object* l_Lean_Elab_Term_elabAnd___closed__2; extern lean_object* l_Lean_Parser_Term_mapConstRev___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabMapConstRev___closed__1; +lean_object* l_Lean_Elab_Term_elabDecide___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBOr(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_seq___elambda__1___closed__1; extern lean_object* l_Lean_Parser_Term_haveAssign___elambda__1___closed__2; @@ -358,14 +380,15 @@ lean_object* l_Lean_Elab_Term_elabOrElse___boxed(lean_object*, lean_object*, lea lean_object* l_Lean_addMacroScope(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabOrM___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__11; -extern lean_object* l_Lean_prodToExpr___rarg___lambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabAdd___closed__1; lean_object* l_Lean_Elab_Term_expandSubtype___closed__7; lean_object* l_Lean_Elab_Term_elabPow___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1(lean_object*, lean_object*, lean_object*); +lean_object* l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabNativeRefl(lean_object*); extern lean_object* l_Lean_nullKind___closed__2; extern lean_object* l_Lean_Parser_Term_heq___elambda__1___closed__2; +extern lean_object* l_Lean_boolToExpr___lambda__1___closed__6; extern lean_object* l_Lean_Elab_Term_termElabAttribute; lean_object* l_Lean_Elab_Term_elabBEq___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabAppend___closed__2; @@ -387,7 +410,7 @@ extern lean_object* l_Lean_Parser_Term_str___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__20; lean_object* l_Lean_Elab_Term_elabTParserMacro(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabAnd___closed__1; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__12; +extern lean_object* l_Lean_Expr_listLitAux___main___closed__6; extern lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__7; lean_object* l___regBuiltin_Lean_Elab_Term_elabseq___closed__1; lean_object* l_Lean_Elab_Term_elabAnonymousCtor___closed__12; @@ -401,10 +424,12 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabPow___closed__1; lean_object* l_Lean_Elab_Term_expandSubtype___closed__2; extern lean_object* l_Lean_Parser_Term_if___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__16; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3; lean_object* l_Lean_Elab_Term_elabLE___closed__3; lean_object* l_Lean_Elab_Term_elabLT(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabDiv(lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5; uint8_t l_Lean_Expr_hasMVar(lean_object*); extern lean_object* l_Lean_Parser_Term_let___elambda__1___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabAndM(lean_object*); @@ -431,6 +456,7 @@ lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__10; lean_object* l_Lean_Elab_Term_expandSubtype___closed__5; lean_object* l_Lean_Elab_Term_adaptExpander(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabProd___closed__1; +lean_object* l_Lean_Elab_Term_elabDecide(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkStxStrLit(lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabBind(lean_object*); lean_object* l_Lean_Elab_Term_elabInfix___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -464,7 +490,6 @@ lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__3; lean_object* l_Lean_Elab_Term_elabGT___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_mapConst___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__15; -lean_object* l_Lean_Elab_Term_elabNativeRefl___closed__16; lean_object* l_Lean_Elab_Term_elabHEq___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabOrM(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandShow___closed__4; @@ -476,8 +501,11 @@ lean_object* l_Lean_Elab_Term_expandSubtype___closed__12; lean_object* l___regBuiltin_Lean_Elab_Term_elabAnd(lean_object*); lean_object* l_Lean_Elab_Term_elabseqLeft(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabMapConst___closed__1; +extern lean_object* l_Lean_mkHole___closed__2; +lean_object* l_Lean_Elab_Term_elabNativeDecide___closed__1; lean_object* l_Lean_Elab_Term_elabseqRight(lean_object*, lean_object*, lean_object*); uint8_t l_List_beq___main___at_Lean_Elab_Term_elabParserMacro___spec__1(lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_elabNativeDecide___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_expandIf(lean_object*); lean_object* l_Lean_Elab_Term_elabseqRight___boxed(lean_object*, lean_object*, lean_object*); @@ -498,6 +526,7 @@ lean_object* l___private_Init_Lean_Elab_Term_3__fromMetaState(lean_object*, lean extern lean_object* l_Lean_Parser_Term_bne___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabProd(lean_object*); extern lean_object* l_Lean_Parser_Term_typeSpec___elambda__1___closed__2; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4; extern lean_object* l_Lean_Parser_Term_nativeRefl___elambda__1___closed__2; lean_object* l_Lean_mkCTermIdFrom(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabCons(lean_object*, lean_object*, lean_object*); @@ -512,6 +541,7 @@ extern lean_object* l_Lean_Parser_Term_orelse___elambda__1___closed__2; lean_object* l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBEq___closed__2; lean_object* l_Lean_Elab_Term_elabBNe___closed__1; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabBEq___closed__1; lean_object* l___regBuiltin_Lean_Elab_Term_elabMod___closed__1; lean_object* l_Lean_Elab_Term_elabBNe___boxed(lean_object*, lean_object*, lean_object*); @@ -520,10 +550,10 @@ lean_object* l_Lean_Elab_Term_elabTParserMacro___lambda__1___closed__1; lean_object* l_Lean_Meta_mkEq(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabSub___closed__1; lean_object* l_Lean_Elab_Term_elabMap(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_mkAppB(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabMapRev(lean_object*); extern lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__2; lean_object* l_Lean_indentExpr(lean_object*); +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabseqRight___closed__3; uint8_t l_Lean_Expr_hasFVar(lean_object*); lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__29; @@ -542,6 +572,7 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabseqRight(lean_object*); lean_object* l_Lean_Elab_Term_elabNe___closed__2; extern lean_object* l_Lean_Parser_Term_and___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_elabParserMacro___lambda__1___closed__7; +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1; lean_object* l_Lean_Elab_Term_elabNe(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_orelse___elambda__1___closed__1; lean_object* l_Lean_Elab_Term_ElabFComp___closed__2; @@ -4598,6 +4629,273 @@ lean_dec(x_1); return x_6; } } +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid macro application, term contains free variables"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid macro application, term contains metavariables"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l_Lean_Elab_Term_elabTermAndSynthesize(x_1, x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +uint8_t x_6; +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = lean_ctor_get(x_5, 0); +x_8 = lean_ctor_get(x_5, 1); +x_9 = l_Lean_Expr_hasMVar(x_7); +if (x_9 == 0) +{ +uint8_t x_10; +x_10 = l_Lean_Expr_hasFVar(x_7); +if (x_10 == 0) +{ +lean_dec(x_3); +lean_dec(x_1); +return x_5; +} +else +{ +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_free_object(x_5); +x_11 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_11, 0, x_7); +x_12 = l_Lean_indentExpr(x_11); +x_13 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3; +x_14 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_12); +x_15 = l_Lean_Elab_Term_throwError___rarg(x_1, x_14, x_3, x_8); +lean_dec(x_1); +x_16 = !lean_is_exclusive(x_15); +if (x_16 == 0) +{ +return x_15; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_15, 0); +x_18 = lean_ctor_get(x_15, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_15); +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; lean_object* x_23; lean_object* x_24; uint8_t x_25; +lean_free_object(x_5); +x_20 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_20, 0, x_7); +x_21 = l_Lean_indentExpr(x_20); +x_22 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6; +x_23 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_21); +x_24 = l_Lean_Elab_Term_throwError___rarg(x_1, x_23, x_3, x_8); +lean_dec(x_1); +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +return x_24; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_24, 0); +x_27 = lean_ctor_get(x_24, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_24); +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; uint8_t x_31; +x_29 = lean_ctor_get(x_5, 0); +x_30 = lean_ctor_get(x_5, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_5); +x_31 = l_Lean_Expr_hasMVar(x_29); +if (x_31 == 0) +{ +uint8_t x_32; +x_32 = l_Lean_Expr_hasFVar(x_29); +if (x_32 == 0) +{ +lean_object* x_33; +lean_dec(x_3); +lean_dec(x_1); +x_33 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_33, 0, x_29); +lean_ctor_set(x_33, 1, x_30); +return x_33; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_34 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_34, 0, x_29); +x_35 = l_Lean_indentExpr(x_34); +x_36 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3; +x_37 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_35); +x_38 = l_Lean_Elab_Term_throwError___rarg(x_1, x_37, x_3, x_30); +lean_dec(x_1); +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); +} +if (lean_is_scalar(x_41)) { + x_42 = lean_alloc_ctor(1, 2, 0); +} else { + x_42 = x_41; +} +lean_ctor_set(x_42, 0, x_39); +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_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_43 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_43, 0, x_29); +x_44 = l_Lean_indentExpr(x_43); +x_45 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6; +x_46 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_46, 1, x_44); +x_47 = l_Lean_Elab_Term_throwError___rarg(x_1, x_46, x_3, x_30); +lean_dec(x_1); +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +if (lean_is_exclusive(x_47)) { + lean_ctor_release(x_47, 0); + lean_ctor_release(x_47, 1); + x_50 = x_47; +} else { + lean_dec_ref(x_47); + 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_3); +lean_dec(x_1); +x_52 = !lean_is_exclusive(x_5); +if (x_52 == 0) +{ +return x_5; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_5, 0); +x_54 = lean_ctor_get(x_5, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_5); +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* _init_l_Lean_Elab_Term_elabNativeRefl___closed__1() { _start: { @@ -4629,20 +4927,18 @@ return x_2; lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__4() { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = lean_box(0); -x_2 = l_Lean_mkTermIdFromIdent___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; +lean_object* x_1; +x_1 = lean_mk_string("ofReduceNat"); +return x_1; } } lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Elab_Term_elabNativeRefl___closed__4; -x_2 = l_Lean_listToExpr___rarg___closed__5; -x_3 = l_Lean_mkConst(x_1, x_2); +x_1 = l_Lean_mkAppStx___closed__2; +x_2 = l_Lean_Elab_Term_elabNativeRefl___closed__4; +x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } @@ -4650,7 +4946,7 @@ lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__6() { _start: { lean_object* x_1; -x_1 = lean_mk_string("ofReduceNat"); +x_1 = lean_mk_string("ofReduceBool"); return x_1; } } @@ -4668,99 +4964,25 @@ lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__8() { _start: { lean_object* x_1; -x_1 = lean_mk_string("ofReduceBool"); +x_1 = lean_mk_string("invalid `nativeRefl!` macro application, term must have type `Nat` or `Bool`"); return x_1; } } lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__9() { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_mkAppStx___closed__2; -x_2 = l_Lean_Elab_Term_elabNativeRefl___closed__8; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Term_elabNativeRefl___closed__8; +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_Term_elabNativeRefl___closed__10() { _start: { -lean_object* x_1; -x_1 = lean_mk_string("invalid `nativeRefl!` macro application, term must have type `Nat` or `Bool`"); -return x_1; -} -} -lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__11() { -_start: -{ lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___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_Lean_Elab_Term_elabNativeRefl___closed__12() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___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_Lean_Elab_Term_elabNativeRefl___closed__13() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("invalid `nativeRefl!` macro application, term contains free variables"); -return x_1; -} -} -lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__14() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___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_Lean_Elab_Term_elabNativeRefl___closed__15() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___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_Lean_Elab_Term_elabNativeRefl___closed__16() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("invalid `nativeRefl!` macro application, term contains metavariables"); -return x_1; -} -} -lean_object* _init_l_Lean_Elab_Term_elabNativeRefl___closed__17() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___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_Lean_Elab_Term_elabNativeRefl___closed__18() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Elab_Term_elabNativeRefl___closed__17; +x_1 = l_Lean_Elab_Term_elabNativeRefl___closed__9; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; @@ -4774,838 +4996,769 @@ x_5 = lean_unsigned_to_nat(1u); x_6 = l_Lean_Syntax_getArg(x_1, x_5); x_7 = lean_box(0); lean_inc(x_3); -x_8 = l_Lean_Elab_Term_elabTermAndSynthesize(x_6, x_7, x_3, x_4); +x_8 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm(x_6, 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; uint8_t x_281; +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_281 = l_Lean_Expr_hasMVar(x_9); -if (x_281 == 0) -{ -uint8_t x_282; -x_282 = l_Lean_Expr_hasFVar(x_9); -if (x_282 == 0) -{ -x_11 = x_10; -goto block_280; -} -else -{ -lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; uint8_t x_288; -x_283 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_283, 0, x_9); -x_284 = l_Lean_indentExpr(x_283); -x_285 = l_Lean_Elab_Term_elabNativeRefl___closed__15; -x_286 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_286, 0, x_285); -lean_ctor_set(x_286, 1, x_284); -x_287 = l_Lean_Elab_Term_throwError___rarg(x_1, x_286, x_3, x_10); -x_288 = !lean_is_exclusive(x_287); -if (x_288 == 0) -{ -return x_287; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_289 = lean_ctor_get(x_287, 0); -x_290 = lean_ctor_get(x_287, 1); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_287); -x_291 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_291, 0, x_289); -lean_ctor_set(x_291, 1, x_290); -return x_291; -} -} -} -else -{ -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; uint8_t x_297; -x_292 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_292, 0, x_9); -x_293 = l_Lean_indentExpr(x_292); -x_294 = l_Lean_Elab_Term_elabNativeRefl___closed__18; -x_295 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_295, 0, x_294); -lean_ctor_set(x_295, 1, x_293); -x_296 = l_Lean_Elab_Term_throwError___rarg(x_1, x_295, x_3, x_10); -x_297 = !lean_is_exclusive(x_296); -if (x_297 == 0) -{ -return x_296; -} -else -{ -lean_object* x_298; lean_object* x_299; lean_object* x_300; -x_298 = lean_ctor_get(x_296, 0); -x_299 = lean_ctor_get(x_296, 1); -lean_inc(x_299); -lean_inc(x_298); -lean_dec(x_296); -x_300 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_300, 0, x_298); -lean_ctor_set(x_300, 1, x_299); -return x_300; -} -} -block_280: -{ -lean_object* x_12; lean_inc(x_3); lean_inc(x_9); -x_12 = l_Lean_Elab_Term_inferType(x_1, x_9, x_3, x_11); -if (lean_obj_tag(x_12) == 0) +x_11 = l_Lean_Elab_Term_inferType(x_1, x_9, x_3, x_10); +if (lean_obj_tag(x_11) == 0) { -lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_13 = lean_ctor_get(x_12, 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); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); +lean_dec(x_11); lean_inc(x_3); -x_15 = l_Lean_Elab_Term_whnf(x_1, x_13, x_3, x_14); -if (lean_obj_tag(x_15) == 0) +x_14 = l_Lean_Elab_Term_whnf(x_1, x_12, x_3, x_13); +if (lean_obj_tag(x_14) == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x_20; -x_16 = lean_ctor_get(x_15, 0); +lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t 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); -x_17 = lean_ctor_get(x_15, 1); -lean_inc(x_17); -lean_dec(x_15); -x_18 = l_Lean_boolToExpr___lambda__1___closed__2; -x_19 = l_Lean_Expr_isConstOf(x_16, x_18); -if (x_19 == 0) +lean_dec(x_14); +x_17 = l_Lean_boolToExpr___lambda__1___closed__2; +x_18 = l_Lean_Expr_isConstOf(x_15, x_17); +if (x_18 == 0) { -lean_object* x_261; uint8_t x_262; -x_261 = l_Lean_Literal_type___closed__2; -x_262 = l_Lean_Expr_isConstOf(x_16, x_261); -if (x_262 == 0) +lean_object* x_243; uint8_t x_244; +x_243 = l_Lean_Literal_type___closed__2; +x_244 = l_Lean_Expr_isConstOf(x_15, x_243); +if (x_244 == 0) { -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; +lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; uint8_t x_250; lean_dec(x_9); -x_263 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_263, 0, x_16); -x_264 = l_Lean_indentExpr(x_263); -x_265 = l_Lean_Elab_Term_elabNativeRefl___closed__12; -x_266 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_266, 0, x_265); -lean_ctor_set(x_266, 1, x_264); -x_267 = l_Lean_Elab_Term_throwError___rarg(x_1, x_266, x_3, x_17); -x_268 = !lean_is_exclusive(x_267); -if (x_268 == 0) +x_245 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_245, 0, x_15); +x_246 = l_Lean_indentExpr(x_245); +x_247 = l_Lean_Elab_Term_elabNativeRefl___closed__10; +x_248 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_248, 0, x_247); +lean_ctor_set(x_248, 1, x_246); +x_249 = l_Lean_Elab_Term_throwError___rarg(x_1, x_248, x_3, x_16); +x_250 = !lean_is_exclusive(x_249); +if (x_250 == 0) { -return x_267; +return x_249; } else { -lean_object* x_269; lean_object* x_270; lean_object* x_271; -x_269 = lean_ctor_get(x_267, 0); -x_270 = lean_ctor_get(x_267, 1); -lean_inc(x_270); -lean_inc(x_269); -lean_dec(x_267); -x_271 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_271, 0, x_269); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_object* x_251; lean_object* x_252; lean_object* x_253; +x_251 = lean_ctor_get(x_249, 0); +x_252 = lean_ctor_get(x_249, 1); +lean_inc(x_252); +lean_inc(x_251); +lean_dec(x_249); +x_253 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_253, 0, x_251); +lean_ctor_set(x_253, 1, x_252); +return x_253; } } else { -x_20 = x_17; -goto block_260; +x_19 = x_16; +goto block_242; } } else { -x_20 = x_17; -goto block_260; +x_19 = x_16; +goto block_242; } -block_260: +block_242: { -lean_object* x_21; +lean_object* x_20; lean_inc(x_3); lean_inc(x_9); -x_21 = l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl(x_1, x_16, x_9, x_3, x_20); -if (lean_obj_tag(x_21) == 0) +x_20 = l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl(x_1, x_15, x_9, x_3, 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, 0); +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_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = lean_box(0); -x_25 = l_Lean_mkConst(x_22, x_24); -x_26 = lean_ctor_get(x_23, 0); -lean_inc(x_26); -x_27 = !lean_is_exclusive(x_26); -if (x_27 == 0) -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; -x_28 = lean_ctor_get(x_26, 4); -x_29 = lean_ctor_get(x_3, 0); -lean_inc(x_29); -x_30 = l_Lean_TraceState_Inhabited___closed__1; -lean_ctor_set(x_26, 4, x_30); -if (x_19 == 0) -{ -uint8_t x_171; -x_171 = 0; -x_31 = x_171; -goto block_170; -} -else -{ -uint8_t x_172; -x_172 = 1; -x_31 = x_172; -goto block_170; -} -block_170: -{ -lean_object* x_32; -if (x_31 == 0) -{ -lean_object* x_168; -x_168 = l_Lean_Meta_reduceNative_x3f___closed__4; -x_32 = x_168; -goto block_167; -} -else -{ -lean_object* x_169; -x_169 = l_Lean_Meta_reduceNative_x3f___closed__2; -x_32 = x_169; -goto block_167; -} -block_167: -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = l_Lean_mkConst(x_32, x_24); +lean_dec(x_20); +x_23 = lean_box(0); +x_24 = l_Lean_mkConst(x_21, x_23); +x_25 = lean_ctor_get(x_22, 0); lean_inc(x_25); -x_34 = l_Lean_mkApp(x_33, x_25); -x_35 = l_Lean_Meta_reduceNative_x3f(x_34, x_29, x_26); -if (x_31 == 0) +x_26 = !lean_is_exclusive(x_25); +if (x_26 == 0) { -lean_object* x_165; -x_165 = l_Lean_Elab_Term_elabNativeRefl___closed__7; -x_36 = x_165; -goto block_164; +lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; +x_27 = lean_ctor_get(x_25, 4); +x_28 = lean_ctor_get(x_3, 0); +lean_inc(x_28); +x_29 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_25, 4, x_29); +if (x_18 == 0) +{ +uint8_t x_156; +x_156 = 0; +x_30 = x_156; +goto block_155; } else { -lean_object* x_166; -x_166 = l_Lean_Elab_Term_elabNativeRefl___closed__9; -x_36 = x_166; -goto block_164; +uint8_t x_157; +x_157 = 1; +x_30 = x_157; +goto block_155; } -block_164: +block_155: { -if (lean_obj_tag(x_35) == 0) +lean_object* x_31; +if (x_30 == 0) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_35, 0); +lean_object* x_153; +x_153 = l_Lean_Meta_reduceNative_x3f___closed__4; +x_31 = x_153; +goto block_152; +} +else +{ +lean_object* x_154; +x_154 = l_Lean_Meta_reduceNative_x3f___closed__2; +x_31 = x_154; +goto block_152; +} +block_152: +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_32 = l_Lean_mkConst(x_31, x_23); +lean_inc(x_24); +x_33 = l_Lean_mkApp(x_32, x_24); +x_34 = l_Lean_Meta_reduceNative_x3f(x_33, x_28, x_25); +if (x_30 == 0) +{ +lean_object* x_150; +x_150 = l_Lean_Elab_Term_elabNativeRefl___closed__5; +x_35 = x_150; +goto block_149; +} +else +{ +lean_object* x_151; +x_151 = l_Lean_Elab_Term_elabNativeRefl___closed__7; +x_35 = x_151; +goto block_149; +} +block_149: +{ +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_34, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_34, 1); lean_inc(x_37); -x_38 = lean_ctor_get(x_35, 1); -lean_inc(x_38); +lean_dec(x_34); +lean_inc(x_3); +x_38 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_22, x_37, x_27); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_dec(x_35); -lean_inc(x_3); -x_39 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_23, x_38, x_28); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -lean_dec(x_36); -lean_dec(x_29); -lean_dec(x_25); -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_Lean_Elab_Term_elabNativeRefl___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_Elab_Term_throwError___rarg(x_1, x_43, x_3, x_39); -return x_44; +lean_dec(x_28); +lean_dec(x_24); +x_39 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_39, 0, x_9); +x_40 = l_Lean_indentExpr(x_39); +x_41 = l_Lean_Elab_Term_elabNativeRefl___closed__3; +x_42 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_42, 0, x_41); +lean_ctor_set(x_42, 1, x_40); +x_43 = l_Lean_Elab_Term_throwError___rarg(x_1, x_42, x_3, x_38); +return x_43; } else { -lean_object* x_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_39, 0); +lean_object* x_44; lean_object* x_45; uint8_t x_46; +x_44 = lean_ctor_get(x_38, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_36, 0); lean_inc(x_45); -x_46 = lean_ctor_get(x_37, 0); -lean_inc(x_46); -lean_dec(x_37); -x_47 = !lean_is_exclusive(x_45); -if (x_47 == 0) +lean_dec(x_36); +x_46 = !lean_is_exclusive(x_44); +if (x_46 == 0) { -lean_object* x_48; lean_object* x_49; -x_48 = lean_ctor_get(x_45, 4); -lean_ctor_set(x_45, 4, x_30); -lean_inc(x_29); -lean_inc(x_46); -x_49 = l_Lean_Meta_mkEqRefl(x_46, x_29, x_45); -if (lean_obj_tag(x_49) == 0) +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_44, 4); +lean_ctor_set(x_44, 4, x_29); +lean_inc(x_28); +lean_inc(x_45); +x_48 = l_Lean_Meta_mkEqRefl(x_45, x_28, x_44); +if (lean_obj_tag(x_48) == 0) { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_50 = lean_ctor_get(x_49, 0); +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_48, 1); lean_inc(x_50); -x_51 = lean_ctor_get(x_49, 1); -lean_inc(x_51); -lean_dec(x_49); +lean_dec(x_48); lean_inc(x_3); -x_52 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_39, x_51, x_48); -x_53 = l_Lean_mkConst(x_36, x_24); -lean_inc(x_46); -x_54 = l_Lean_mkApp3(x_53, x_25, x_46, x_50); -x_55 = lean_ctor_get(x_52, 0); -lean_inc(x_55); -x_56 = !lean_is_exclusive(x_55); -if (x_56 == 0) +x_51 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_38, x_50, x_47); +x_52 = l_Lean_mkConst(x_35, x_23); +lean_inc(x_45); +x_53 = l_Lean_mkApp3(x_52, x_24, x_45, x_49); +x_54 = lean_ctor_get(x_51, 0); +lean_inc(x_54); +x_55 = !lean_is_exclusive(x_54); +if (x_55 == 0) { -lean_object* x_57; lean_object* x_58; -x_57 = lean_ctor_get(x_55, 4); -lean_ctor_set(x_55, 4, x_30); -x_58 = l_Lean_Meta_mkEq(x_9, x_46, x_29, x_55); -if (lean_obj_tag(x_58) == 0) +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_54, 4); +lean_ctor_set(x_54, 4, x_29); +x_57 = l_Lean_Meta_mkEq(x_9, x_45, x_28, x_54); +if (lean_obj_tag(x_57) == 0) { -uint8_t x_59; -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; -x_60 = lean_ctor_get(x_58, 0); -x_61 = lean_ctor_get(x_58, 1); -x_62 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_61, x_57); -x_63 = l_Lean_Elab_Term_elabNativeRefl___closed__5; -x_64 = l_Lean_mkAppB(x_63, x_60, x_54); -lean_ctor_set(x_58, 1, x_62); -lean_ctor_set(x_58, 0, x_64); -return x_58; -} -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; -x_65 = lean_ctor_get(x_58, 0); -x_66 = lean_ctor_get(x_58, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_58); -x_67 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_66, x_57); -x_68 = l_Lean_Elab_Term_elabNativeRefl___closed__5; -x_69 = l_Lean_mkAppB(x_68, x_65, x_54); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_67); -return x_70; -} -} -else -{ -uint8_t x_71; -lean_dec(x_54); -x_71 = !lean_is_exclusive(x_58); -if (x_71 == 0) -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_72 = lean_ctor_get(x_58, 0); -x_73 = lean_ctor_get(x_58, 1); +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); lean_inc(x_3); -x_74 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_72); -x_75 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_73, x_57); -lean_ctor_set(x_58, 1, x_75); -lean_ctor_set(x_58, 0, x_74); -return x_58; +x_60 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_51, x_59, x_56); +x_61 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_53, x_58, x_3, x_60); +return x_61; } else { -lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_76 = lean_ctor_get(x_58, 0); -x_77 = lean_ctor_get(x_58, 1); +uint8_t x_62; +lean_dec(x_53); +x_62 = !lean_is_exclusive(x_57); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_63 = lean_ctor_get(x_57, 0); +x_64 = lean_ctor_get(x_57, 1); +lean_inc(x_3); +x_65 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_63); +x_66 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_51, x_64, x_56); +lean_ctor_set(x_57, 1, x_66); +lean_ctor_set(x_57, 0, x_65); +return x_57; +} +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_57, 0); +x_68 = lean_ctor_get(x_57, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_57); +lean_inc(x_3); +x_69 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_67); +x_70 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_51, x_68, x_56); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_72 = lean_ctor_get(x_54, 0); +x_73 = lean_ctor_get(x_54, 1); +x_74 = lean_ctor_get(x_54, 2); +x_75 = lean_ctor_get(x_54, 3); +x_76 = lean_ctor_get(x_54, 4); +x_77 = lean_ctor_get(x_54, 5); lean_inc(x_77); lean_inc(x_76); -lean_dec(x_58); -lean_inc(x_3); -x_78 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_76); -x_79 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_77, x_57); -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_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_81 = lean_ctor_get(x_55, 0); -x_82 = lean_ctor_get(x_55, 1); -x_83 = lean_ctor_get(x_55, 2); -x_84 = lean_ctor_get(x_55, 3); -x_85 = lean_ctor_get(x_55, 4); -x_86 = lean_ctor_get(x_55, 5); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_55); -x_87 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_87, 0, x_81); -lean_ctor_set(x_87, 1, x_82); -lean_ctor_set(x_87, 2, x_83); -lean_ctor_set(x_87, 3, x_84); -lean_ctor_set(x_87, 4, x_30); -lean_ctor_set(x_87, 5, x_86); -x_88 = l_Lean_Meta_mkEq(x_9, x_46, x_29, 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; lean_object* x_94; lean_object* x_95; -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_88, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_91 = x_88; -} else { - lean_dec_ref(x_88); - x_91 = lean_box(0); -} -x_92 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_90, x_85); -x_93 = l_Lean_Elab_Term_elabNativeRefl___closed__5; -x_94 = l_Lean_mkAppB(x_93, x_89, x_54); -if (lean_is_scalar(x_91)) { - x_95 = lean_alloc_ctor(0, 2, 0); -} else { - x_95 = x_91; -} -lean_ctor_set(x_95, 0, x_94); -lean_ctor_set(x_95, 1, x_92); -return x_95; -} -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_inc(x_75); +lean_inc(x_74); +lean_inc(x_73); +lean_inc(x_72); lean_dec(x_54); -x_96 = lean_ctor_get(x_88, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_88, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_98 = x_88; +x_78 = lean_alloc_ctor(0, 6, 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_29); +lean_ctor_set(x_78, 5, x_77); +x_79 = l_Lean_Meta_mkEq(x_9, x_45, x_28, x_78); +if (lean_obj_tag(x_79) == 0) +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_80 = lean_ctor_get(x_79, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_79, 1); +lean_inc(x_81); +lean_dec(x_79); +lean_inc(x_3); +x_82 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_51, x_81, x_76); +x_83 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_53, x_80, x_3, x_82); +return x_83; +} +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_dec(x_53); +x_84 = lean_ctor_get(x_79, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_79, 1); +lean_inc(x_85); +if (lean_is_exclusive(x_79)) { + lean_ctor_release(x_79, 0); + lean_ctor_release(x_79, 1); + x_86 = x_79; } else { - lean_dec_ref(x_88); - x_98 = lean_box(0); + lean_dec_ref(x_79); + x_86 = lean_box(0); } lean_inc(x_3); -x_99 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_96); -x_100 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_52, x_97, x_85); -if (lean_is_scalar(x_98)) { - x_101 = lean_alloc_ctor(1, 2, 0); +x_87 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_84); +x_88 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_51, x_85, x_76); +if (lean_is_scalar(x_86)) { + x_89 = lean_alloc_ctor(1, 2, 0); } else { - x_101 = x_98; + x_89 = x_86; } -lean_ctor_set(x_101, 0, x_99); -lean_ctor_set(x_101, 1, x_100); -return x_101; +lean_ctor_set(x_89, 0, x_87); +lean_ctor_set(x_89, 1, x_88); +return x_89; } } } else { -uint8_t x_102; -lean_dec(x_46); -lean_dec(x_36); -lean_dec(x_29); -lean_dec(x_25); -lean_dec(x_9); -x_102 = !lean_is_exclusive(x_49); -if (x_102 == 0) -{ -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_103 = lean_ctor_get(x_49, 0); -x_104 = lean_ctor_get(x_49, 1); -lean_inc(x_3); -x_105 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_103); -x_106 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_39, x_104, x_48); -lean_ctor_set(x_49, 1, x_106); -lean_ctor_set(x_49, 0, x_105); -return x_49; -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_107 = lean_ctor_get(x_49, 0); -x_108 = lean_ctor_get(x_49, 1); -lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_49); -lean_inc(x_3); -x_109 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_107); -x_110 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_39, x_108, x_48); -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_45, 0); -x_113 = lean_ctor_get(x_45, 1); -x_114 = lean_ctor_get(x_45, 2); -x_115 = lean_ctor_get(x_45, 3); -x_116 = lean_ctor_get(x_45, 4); -x_117 = lean_ctor_get(x_45, 5); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); +uint8_t x_90; lean_dec(x_45); -x_118 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_118, 0, x_112); -lean_ctor_set(x_118, 1, x_113); -lean_ctor_set(x_118, 2, x_114); -lean_ctor_set(x_118, 3, x_115); -lean_ctor_set(x_118, 4, x_30); -lean_ctor_set(x_118, 5, x_117); -lean_inc(x_29); -lean_inc(x_46); -x_119 = l_Lean_Meta_mkEqRefl(x_46, x_29, x_118); -if (lean_obj_tag(x_119) == 0) +lean_dec(x_35); +lean_dec(x_28); +lean_dec(x_24); +lean_dec(x_9); +x_90 = !lean_is_exclusive(x_48); +if (x_90 == 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; lean_object* x_132; lean_object* x_133; lean_object* x_134; -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); +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_48, 0); +x_92 = lean_ctor_get(x_48, 1); lean_inc(x_3); -x_122 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_39, x_121, x_116); -x_123 = l_Lean_mkConst(x_36, x_24); -lean_inc(x_46); -x_124 = l_Lean_mkApp3(x_123, x_25, x_46, x_120); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_125, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_125, 1); +x_93 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_91); +x_94 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_38, x_92, x_47); +lean_ctor_set(x_48, 1, x_94); +lean_ctor_set(x_48, 0, x_93); +return x_48; +} +else +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_95 = lean_ctor_get(x_48, 0); +x_96 = lean_ctor_get(x_48, 1); +lean_inc(x_96); +lean_inc(x_95); +lean_dec(x_48); +lean_inc(x_3); +x_97 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_95); +x_98 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_38, x_96, x_47); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_97); +lean_ctor_set(x_99, 1, x_98); +return x_99; +} +} +} +else +{ +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_100 = lean_ctor_get(x_44, 0); +x_101 = lean_ctor_get(x_44, 1); +x_102 = lean_ctor_get(x_44, 2); +x_103 = lean_ctor_get(x_44, 3); +x_104 = lean_ctor_get(x_44, 4); +x_105 = lean_ctor_get(x_44, 5); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_inc(x_100); +lean_dec(x_44); +x_106 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_106, 0, x_100); +lean_ctor_set(x_106, 1, x_101); +lean_ctor_set(x_106, 2, x_102); +lean_ctor_set(x_106, 3, x_103); +lean_ctor_set(x_106, 4, x_29); +lean_ctor_set(x_106, 5, x_105); +lean_inc(x_28); +lean_inc(x_45); +x_107 = l_Lean_Meta_mkEqRefl(x_45, x_28, x_106); +if (lean_obj_tag(x_107) == 0) +{ +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_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___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_38, x_109, x_104); +x_111 = l_Lean_mkConst(x_35, x_23); +lean_inc(x_45); +x_112 = l_Lean_mkApp3(x_111, x_24, x_45, x_108); +x_113 = lean_ctor_get(x_110, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_113, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_113, 1); +lean_inc(x_115); +x_116 = lean_ctor_get(x_113, 2); +lean_inc(x_116); +x_117 = lean_ctor_get(x_113, 3); +lean_inc(x_117); +x_118 = lean_ctor_get(x_113, 4); +lean_inc(x_118); +x_119 = lean_ctor_get(x_113, 5); +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); + lean_ctor_release(x_113, 5); + x_120 = x_113; +} else { + lean_dec_ref(x_113); + x_120 = lean_box(0); +} +if (lean_is_scalar(x_120)) { + x_121 = lean_alloc_ctor(0, 6, 0); +} else { + x_121 = x_120; +} +lean_ctor_set(x_121, 0, x_114); +lean_ctor_set(x_121, 1, x_115); +lean_ctor_set(x_121, 2, x_116); +lean_ctor_set(x_121, 3, x_117); +lean_ctor_set(x_121, 4, x_29); +lean_ctor_set(x_121, 5, x_119); +x_122 = l_Lean_Meta_mkEq(x_9, x_45, x_28, x_121); +if (lean_obj_tag(x_122) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_123 = lean_ctor_get(x_122, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_122, 1); +lean_inc(x_124); +lean_dec(x_122); +lean_inc(x_3); +x_125 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_110, x_124, x_118); +x_126 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_112, x_123, x_3, x_125); +return x_126; +} +else +{ +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_dec(x_112); +x_127 = lean_ctor_get(x_122, 0); lean_inc(x_127); -x_128 = lean_ctor_get(x_125, 2); +x_128 = lean_ctor_get(x_122, 1); lean_inc(x_128); -x_129 = lean_ctor_get(x_125, 3); -lean_inc(x_129); -x_130 = lean_ctor_get(x_125, 4); -lean_inc(x_130); -x_131 = lean_ctor_get(x_125, 5); -lean_inc(x_131); -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_132 = x_125; +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + x_129 = x_122; } else { - lean_dec_ref(x_125); - x_132 = lean_box(0); -} -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 6, 0); -} else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_126); -lean_ctor_set(x_133, 1, x_127); -lean_ctor_set(x_133, 2, x_128); -lean_ctor_set(x_133, 3, x_129); -lean_ctor_set(x_133, 4, x_30); -lean_ctor_set(x_133, 5, x_131); -x_134 = l_Lean_Meta_mkEq(x_9, x_46, x_29, x_133); -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; -x_135 = lean_ctor_get(x_134, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_134, 1); -lean_inc(x_136); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_137 = x_134; -} else { - lean_dec_ref(x_134); - x_137 = lean_box(0); -} -x_138 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_122, x_136, x_130); -x_139 = l_Lean_Elab_Term_elabNativeRefl___closed__5; -x_140 = l_Lean_mkAppB(x_139, x_135, x_124); -if (lean_is_scalar(x_137)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_137; -} -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_138); -return x_141; -} -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_dec(x_124); -x_142 = lean_ctor_get(x_134, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_134, 1); -lean_inc(x_143); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_144 = x_134; -} else { - lean_dec_ref(x_134); - x_144 = lean_box(0); + lean_dec_ref(x_122); + x_129 = lean_box(0); } lean_inc(x_3); -x_145 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_142); -x_146 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_122, x_143, x_130); -if (lean_is_scalar(x_144)) { - x_147 = lean_alloc_ctor(1, 2, 0); +x_130 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_127); +x_131 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_110, x_128, x_118); +if (lean_is_scalar(x_129)) { + x_132 = lean_alloc_ctor(1, 2, 0); } else { - x_147 = x_144; + x_132 = x_129; } -lean_ctor_set(x_147, 0, x_145); -lean_ctor_set(x_147, 1, x_146); -return x_147; +lean_ctor_set(x_132, 0, x_130); +lean_ctor_set(x_132, 1, x_131); +return x_132; } } 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_dec(x_46); -lean_dec(x_36); -lean_dec(x_29); -lean_dec(x_25); +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_dec(x_45); +lean_dec(x_35); +lean_dec(x_28); +lean_dec(x_24); lean_dec(x_9); -x_148 = lean_ctor_get(x_119, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_119, 1); -lean_inc(x_149); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_150 = x_119; +x_133 = lean_ctor_get(x_107, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_107, 1); +lean_inc(x_134); +if (lean_is_exclusive(x_107)) { + lean_ctor_release(x_107, 0); + lean_ctor_release(x_107, 1); + x_135 = x_107; } else { - lean_dec_ref(x_119); - x_150 = lean_box(0); + lean_dec_ref(x_107); + x_135 = lean_box(0); } lean_inc(x_3); -x_151 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_148); -x_152 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_39, x_149, x_116); -if (lean_is_scalar(x_150)) { - x_153 = lean_alloc_ctor(1, 2, 0); +x_136 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_133); +x_137 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_38, x_134, x_104); +if (lean_is_scalar(x_135)) { + x_138 = lean_alloc_ctor(1, 2, 0); } else { - x_153 = x_150; + x_138 = x_135; } -lean_ctor_set(x_153, 0, x_151); -lean_ctor_set(x_153, 1, x_152); -return x_153; +lean_ctor_set(x_138, 0, x_136); +lean_ctor_set(x_138, 1, x_137); +return x_138; } } } } else { -uint8_t x_154; -lean_dec(x_36); -lean_dec(x_29); -lean_dec(x_25); +uint8_t x_139; +lean_dec(x_35); +lean_dec(x_28); +lean_dec(x_24); lean_dec(x_9); -x_154 = !lean_is_exclusive(x_35); -if (x_154 == 0) +x_139 = !lean_is_exclusive(x_34); +if (x_139 == 0) { -lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_155 = lean_ctor_get(x_35, 0); -x_156 = lean_ctor_get(x_35, 1); +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; +x_140 = lean_ctor_get(x_34, 0); +x_141 = lean_ctor_get(x_34, 1); lean_inc(x_3); -x_157 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_155); -x_158 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_23, x_156, x_28); -lean_ctor_set(x_35, 1, x_158); -lean_ctor_set(x_35, 0, x_157); -return x_35; +x_142 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_140); +x_143 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_22, x_141, x_27); +lean_ctor_set(x_34, 1, x_143); +lean_ctor_set(x_34, 0, x_142); +return x_34; } 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_35, 0); -x_160 = lean_ctor_get(x_35, 1); +lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_144 = lean_ctor_get(x_34, 0); +x_145 = lean_ctor_get(x_34, 1); +lean_inc(x_145); +lean_inc(x_144); +lean_dec(x_34); +lean_inc(x_3); +x_146 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_144); +x_147 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_22, x_145, x_27); +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; +} +} +} +} +} +} +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; uint8_t x_167; +x_158 = lean_ctor_get(x_25, 0); +x_159 = lean_ctor_get(x_25, 1); +x_160 = lean_ctor_get(x_25, 2); +x_161 = lean_ctor_get(x_25, 3); +x_162 = lean_ctor_get(x_25, 4); +x_163 = lean_ctor_get(x_25, 5); +lean_inc(x_163); +lean_inc(x_162); +lean_inc(x_161); lean_inc(x_160); lean_inc(x_159); -lean_dec(x_35); -lean_inc(x_3); -x_161 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_159); -x_162 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_23, x_160, x_28); -x_163 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_163, 0, x_161); -lean_ctor_set(x_163, 1, x_162); -return x_163; -} -} -} -} -} -} -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; uint8_t x_182; -x_173 = lean_ctor_get(x_26, 0); -x_174 = lean_ctor_get(x_26, 1); -x_175 = lean_ctor_get(x_26, 2); -x_176 = lean_ctor_get(x_26, 3); -x_177 = lean_ctor_get(x_26, 4); -x_178 = lean_ctor_get(x_26, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_174); -lean_inc(x_173); -lean_dec(x_26); -x_179 = lean_ctor_get(x_3, 0); -lean_inc(x_179); -x_180 = l_Lean_TraceState_Inhabited___closed__1; -x_181 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_181, 0, x_173); -lean_ctor_set(x_181, 1, x_174); -lean_ctor_set(x_181, 2, x_175); -lean_ctor_set(x_181, 3, x_176); -lean_ctor_set(x_181, 4, x_180); -lean_ctor_set(x_181, 5, x_178); -if (x_19 == 0) -{ -uint8_t x_254; -x_254 = 0; -x_182 = x_254; -goto block_253; -} -else -{ -uint8_t x_255; -x_255 = 1; -x_182 = x_255; -goto block_253; -} -block_253: -{ -lean_object* x_183; -if (x_182 == 0) -{ -lean_object* x_251; -x_251 = l_Lean_Meta_reduceNative_x3f___closed__4; -x_183 = x_251; -goto block_250; -} -else -{ -lean_object* x_252; -x_252 = l_Lean_Meta_reduceNative_x3f___closed__2; -x_183 = x_252; -goto block_250; -} -block_250: -{ -lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -x_184 = l_Lean_mkConst(x_183, x_24); -lean_inc(x_25); -x_185 = l_Lean_mkApp(x_184, x_25); -x_186 = l_Lean_Meta_reduceNative_x3f(x_185, x_179, x_181); -if (x_182 == 0) -{ -lean_object* x_248; -x_248 = l_Lean_Elab_Term_elabNativeRefl___closed__7; -x_187 = x_248; -goto block_247; -} -else -{ -lean_object* x_249; -x_249 = l_Lean_Elab_Term_elabNativeRefl___closed__9; -x_187 = x_249; -goto block_247; -} -block_247: -{ -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_188; lean_object* x_189; lean_object* x_190; -x_188 = lean_ctor_get(x_186, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_186, 1); -lean_inc(x_189); -lean_dec(x_186); -lean_inc(x_3); -x_190 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_23, x_189, x_177); -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; -lean_dec(x_187); -lean_dec(x_179); +lean_inc(x_158); lean_dec(x_25); -x_191 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_191, 0, x_9); -x_192 = l_Lean_indentExpr(x_191); -x_193 = l_Lean_Elab_Term_elabNativeRefl___closed__3; -x_194 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_194, 0, x_193); -lean_ctor_set(x_194, 1, x_192); -x_195 = l_Lean_Elab_Term_throwError___rarg(x_1, x_194, x_3, x_190); -return x_195; +x_164 = lean_ctor_get(x_3, 0); +lean_inc(x_164); +x_165 = l_Lean_TraceState_Inhabited___closed__1; +x_166 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_160); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_165); +lean_ctor_set(x_166, 5, x_163); +if (x_18 == 0) +{ +uint8_t x_236; +x_236 = 0; +x_167 = x_236; +goto block_235; } 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; -x_196 = lean_ctor_get(x_190, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_188, 0); -lean_inc(x_197); -lean_dec(x_188); -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); -x_203 = lean_ctor_get(x_196, 5); -lean_inc(x_203); -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_204 = x_196; +uint8_t x_237; +x_237 = 1; +x_167 = x_237; +goto block_235; +} +block_235: +{ +lean_object* x_168; +if (x_167 == 0) +{ +lean_object* x_233; +x_233 = l_Lean_Meta_reduceNative_x3f___closed__4; +x_168 = x_233; +goto block_232; +} +else +{ +lean_object* x_234; +x_234 = l_Lean_Meta_reduceNative_x3f___closed__2; +x_168 = x_234; +goto block_232; +} +block_232: +{ +lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_169 = l_Lean_mkConst(x_168, x_23); +lean_inc(x_24); +x_170 = l_Lean_mkApp(x_169, x_24); +x_171 = l_Lean_Meta_reduceNative_x3f(x_170, x_164, x_166); +if (x_167 == 0) +{ +lean_object* x_230; +x_230 = l_Lean_Elab_Term_elabNativeRefl___closed__5; +x_172 = x_230; +goto block_229; +} +else +{ +lean_object* x_231; +x_231 = l_Lean_Elab_Term_elabNativeRefl___closed__7; +x_172 = x_231; +goto block_229; +} +block_229: +{ +if (lean_obj_tag(x_171) == 0) +{ +lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_173 = lean_ctor_get(x_171, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_171, 1); +lean_inc(x_174); +lean_dec(x_171); +lean_inc(x_3); +x_175 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_22, x_174, x_162); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; +lean_dec(x_172); +lean_dec(x_164); +lean_dec(x_24); +x_176 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_176, 0, x_9); +x_177 = l_Lean_indentExpr(x_176); +x_178 = l_Lean_Elab_Term_elabNativeRefl___closed__3; +x_179 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_179, 0, x_178); +lean_ctor_set(x_179, 1, x_177); +x_180 = l_Lean_Elab_Term_throwError___rarg(x_1, x_179, x_3, x_175); +return x_180; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_181 = lean_ctor_get(x_175, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_173, 0); +lean_inc(x_182); +lean_dec(x_173); +x_183 = lean_ctor_get(x_181, 0); +lean_inc(x_183); +x_184 = lean_ctor_get(x_181, 1); +lean_inc(x_184); +x_185 = lean_ctor_get(x_181, 2); +lean_inc(x_185); +x_186 = lean_ctor_get(x_181, 3); +lean_inc(x_186); +x_187 = lean_ctor_get(x_181, 4); +lean_inc(x_187); +x_188 = lean_ctor_get(x_181, 5); +lean_inc(x_188); +if (lean_is_exclusive(x_181)) { + lean_ctor_release(x_181, 0); + lean_ctor_release(x_181, 1); + lean_ctor_release(x_181, 2); + lean_ctor_release(x_181, 3); + lean_ctor_release(x_181, 4); + lean_ctor_release(x_181, 5); + x_189 = x_181; } else { - lean_dec_ref(x_196); + lean_dec_ref(x_181); + x_189 = lean_box(0); +} +if (lean_is_scalar(x_189)) { + x_190 = lean_alloc_ctor(0, 6, 0); +} else { + x_190 = x_189; +} +lean_ctor_set(x_190, 0, x_183); +lean_ctor_set(x_190, 1, x_184); +lean_ctor_set(x_190, 2, x_185); +lean_ctor_set(x_190, 3, x_186); +lean_ctor_set(x_190, 4, x_165); +lean_ctor_set(x_190, 5, x_188); +lean_inc(x_164); +lean_inc(x_182); +x_191 = l_Lean_Meta_mkEqRefl(x_182, x_164, x_190); +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +x_193 = lean_ctor_get(x_191, 1); +lean_inc(x_193); +lean_dec(x_191); +lean_inc(x_3); +x_194 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_175, x_193, x_187); +x_195 = l_Lean_mkConst(x_172, x_23); +lean_inc(x_182); +x_196 = l_Lean_mkApp3(x_195, x_24, x_182, x_192); +x_197 = lean_ctor_get(x_194, 0); +lean_inc(x_197); +x_198 = lean_ctor_get(x_197, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_197, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_197, 2); +lean_inc(x_200); +x_201 = lean_ctor_get(x_197, 3); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 5); +lean_inc(x_203); +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_204 = x_197; +} else { + lean_dec_ref(x_197); x_204 = lean_box(0); } if (lean_is_scalar(x_204)) { @@ -5617,182 +5770,115 @@ lean_ctor_set(x_205, 0, x_198); lean_ctor_set(x_205, 1, x_199); lean_ctor_set(x_205, 2, x_200); lean_ctor_set(x_205, 3, x_201); -lean_ctor_set(x_205, 4, x_180); +lean_ctor_set(x_205, 4, x_165); lean_ctor_set(x_205, 5, x_203); -lean_inc(x_179); -lean_inc(x_197); -x_206 = l_Lean_Meta_mkEqRefl(x_197, x_179, x_205); +x_206 = l_Lean_Meta_mkEq(x_9, x_182, x_164, x_205); if (lean_obj_tag(x_206) == 0) { -lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; +lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; 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); lean_inc(x_3); -x_209 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_190, x_208, x_202); -x_210 = l_Lean_mkConst(x_187, x_24); -lean_inc(x_197); -x_211 = l_Lean_mkApp3(x_210, x_25, x_197, x_207); -x_212 = lean_ctor_get(x_209, 0); +x_209 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_194, x_208, x_202); +x_210 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_196, x_207, x_3, 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_dec(x_196); +x_211 = lean_ctor_get(x_206, 0); +lean_inc(x_211); +x_212 = lean_ctor_get(x_206, 1); lean_inc(x_212); -x_213 = lean_ctor_get(x_212, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_212, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_212, 2); -lean_inc(x_215); -x_216 = lean_ctor_get(x_212, 3); -lean_inc(x_216); -x_217 = lean_ctor_get(x_212, 4); -lean_inc(x_217); -x_218 = lean_ctor_get(x_212, 5); -lean_inc(x_218); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - lean_ctor_release(x_212, 2); - lean_ctor_release(x_212, 3); - lean_ctor_release(x_212, 4); - lean_ctor_release(x_212, 5); - x_219 = x_212; -} else { - lean_dec_ref(x_212); - x_219 = lean_box(0); -} -if (lean_is_scalar(x_219)) { - x_220 = lean_alloc_ctor(0, 6, 0); -} else { - x_220 = x_219; -} -lean_ctor_set(x_220, 0, x_213); -lean_ctor_set(x_220, 1, x_214); -lean_ctor_set(x_220, 2, x_215); -lean_ctor_set(x_220, 3, x_216); -lean_ctor_set(x_220, 4, x_180); -lean_ctor_set(x_220, 5, x_218); -x_221 = l_Lean_Meta_mkEq(x_9, x_197, x_179, x_220); -if (lean_obj_tag(x_221) == 0) -{ -lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_222 = lean_ctor_get(x_221, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_221, 1); -lean_inc(x_223); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_224 = x_221; -} else { - lean_dec_ref(x_221); - x_224 = lean_box(0); -} -x_225 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_209, x_223, x_217); -x_226 = l_Lean_Elab_Term_elabNativeRefl___closed__5; -x_227 = l_Lean_mkAppB(x_226, x_222, x_211); -if (lean_is_scalar(x_224)) { - x_228 = lean_alloc_ctor(0, 2, 0); -} else { - x_228 = x_224; -} -lean_ctor_set(x_228, 0, x_227); -lean_ctor_set(x_228, 1, x_225); -return x_228; -} -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_dec(x_211); -x_229 = lean_ctor_get(x_221, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_221, 1); -lean_inc(x_230); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_231 = x_221; -} else { - lean_dec_ref(x_221); - x_231 = lean_box(0); -} -lean_inc(x_3); -x_232 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_229); -x_233 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_209, x_230, x_217); -if (lean_is_scalar(x_231)) { - x_234 = lean_alloc_ctor(1, 2, 0); -} else { - x_234 = x_231; -} -lean_ctor_set(x_234, 0, x_232); -lean_ctor_set(x_234, 1, x_233); -return x_234; -} -} -else -{ -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_197); -lean_dec(x_187); -lean_dec(x_179); -lean_dec(x_25); -lean_dec(x_9); -x_235 = lean_ctor_get(x_206, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_206, 1); -lean_inc(x_236); if (lean_is_exclusive(x_206)) { lean_ctor_release(x_206, 0); lean_ctor_release(x_206, 1); - x_237 = x_206; + x_213 = x_206; } else { lean_dec_ref(x_206); - x_237 = lean_box(0); + x_213 = lean_box(0); } lean_inc(x_3); -x_238 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_235); -x_239 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_190, x_236, x_202); -if (lean_is_scalar(x_237)) { - x_240 = lean_alloc_ctor(1, 2, 0); +x_214 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_211); +x_215 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_194, x_212, x_202); +if (lean_is_scalar(x_213)) { + x_216 = lean_alloc_ctor(1, 2, 0); } else { - x_240 = x_237; -} -lean_ctor_set(x_240, 0, x_238); -lean_ctor_set(x_240, 1, x_239); -return x_240; + x_216 = x_213; } +lean_ctor_set(x_216, 0, x_214); +lean_ctor_set(x_216, 1, x_215); +return x_216; } } 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_dec(x_187); -lean_dec(x_179); -lean_dec(x_25); +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_dec(x_182); +lean_dec(x_172); +lean_dec(x_164); +lean_dec(x_24); lean_dec(x_9); -x_241 = lean_ctor_get(x_186, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_186, 1); -lean_inc(x_242); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_243 = x_186; +x_217 = lean_ctor_get(x_191, 0); +lean_inc(x_217); +x_218 = lean_ctor_get(x_191, 1); +lean_inc(x_218); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_219 = x_191; } else { - lean_dec_ref(x_186); - x_243 = lean_box(0); + lean_dec_ref(x_191); + x_219 = lean_box(0); } lean_inc(x_3); -x_244 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_241); -x_245 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_23, x_242, x_177); -if (lean_is_scalar(x_243)) { - x_246 = lean_alloc_ctor(1, 2, 0); +x_220 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_217); +x_221 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_175, x_218, x_187); +if (lean_is_scalar(x_219)) { + x_222 = lean_alloc_ctor(1, 2, 0); } else { - x_246 = x_243; + x_222 = x_219; } -lean_ctor_set(x_246, 0, x_244); -lean_ctor_set(x_246, 1, x_245); -return x_246; +lean_ctor_set(x_222, 0, x_220); +lean_ctor_set(x_222, 1, x_221); +return x_222; +} +} +} +else +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; +lean_dec(x_172); +lean_dec(x_164); +lean_dec(x_24); +lean_dec(x_9); +x_223 = lean_ctor_get(x_171, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_171, 1); +lean_inc(x_224); +if (lean_is_exclusive(x_171)) { + lean_ctor_release(x_171, 0); + lean_ctor_release(x_171, 1); + x_225 = x_171; +} else { + lean_dec_ref(x_171); + x_225 = lean_box(0); +} +lean_inc(x_3); +x_226 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_223); +x_227 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_22, x_224, x_162); +if (lean_is_scalar(x_225)) { + x_228 = lean_alloc_ctor(1, 2, 0); +} else { + x_228 = x_225; +} +lean_ctor_set(x_228, 0, x_226); +lean_ctor_set(x_228, 1, x_227); +return x_228; } } } @@ -5801,102 +5887,101 @@ return x_246; } else { -uint8_t x_256; +uint8_t x_238; lean_dec(x_9); lean_dec(x_3); -x_256 = !lean_is_exclusive(x_21); -if (x_256 == 0) +x_238 = !lean_is_exclusive(x_20); +if (x_238 == 0) { -return x_21; +return x_20; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_257 = lean_ctor_get(x_21, 0); -x_258 = lean_ctor_get(x_21, 1); -lean_inc(x_258); -lean_inc(x_257); -lean_dec(x_21); -x_259 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_259, 0, x_257); -lean_ctor_set(x_259, 1, x_258); -return x_259; +lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_20, 0); +x_240 = lean_ctor_get(x_20, 1); +lean_inc(x_240); +lean_inc(x_239); +lean_dec(x_20); +x_241 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_241, 0, x_239); +lean_ctor_set(x_241, 1, x_240); +return x_241; } } } } else { -uint8_t x_272; +uint8_t x_254; lean_dec(x_9); lean_dec(x_3); -x_272 = !lean_is_exclusive(x_15); -if (x_272 == 0) +x_254 = !lean_is_exclusive(x_14); +if (x_254 == 0) { -return x_15; +return x_14; } else { -lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_273 = lean_ctor_get(x_15, 0); -x_274 = lean_ctor_get(x_15, 1); -lean_inc(x_274); -lean_inc(x_273); -lean_dec(x_15); -x_275 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_275, 0, x_273); -lean_ctor_set(x_275, 1, x_274); -return x_275; +lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_255 = lean_ctor_get(x_14, 0); +x_256 = lean_ctor_get(x_14, 1); +lean_inc(x_256); +lean_inc(x_255); +lean_dec(x_14); +x_257 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_257, 0, x_255); +lean_ctor_set(x_257, 1, x_256); +return x_257; } } } else { -uint8_t x_276; +uint8_t x_258; lean_dec(x_9); lean_dec(x_3); -x_276 = !lean_is_exclusive(x_12); -if (x_276 == 0) +x_258 = !lean_is_exclusive(x_11); +if (x_258 == 0) { -return x_12; +return x_11; } else { -lean_object* x_277; lean_object* x_278; lean_object* x_279; -x_277 = lean_ctor_get(x_12, 0); -x_278 = lean_ctor_get(x_12, 1); -lean_inc(x_278); -lean_inc(x_277); -lean_dec(x_12); -x_279 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_279, 0, x_277); -lean_ctor_set(x_279, 1, x_278); -return x_279; -} +lean_object* x_259; lean_object* x_260; lean_object* x_261; +x_259 = lean_ctor_get(x_11, 0); +x_260 = lean_ctor_get(x_11, 1); +lean_inc(x_260); +lean_inc(x_259); +lean_dec(x_11); +x_261 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_261, 0, x_259); +lean_ctor_set(x_261, 1, x_260); +return x_261; } } } else { -uint8_t x_301; +uint8_t x_262; lean_dec(x_3); -x_301 = !lean_is_exclusive(x_8); -if (x_301 == 0) +x_262 = !lean_is_exclusive(x_8); +if (x_262 == 0) { return x_8; } else { -lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_302 = lean_ctor_get(x_8, 0); -x_303 = lean_ctor_get(x_8, 1); -lean_inc(x_303); -lean_inc(x_302); +lean_object* x_263; lean_object* x_264; lean_object* x_265; +x_263 = lean_ctor_get(x_8, 0); +x_264 = lean_ctor_get(x_8, 1); +lean_inc(x_264); +lean_inc(x_263); lean_dec(x_8); -x_304 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_304, 0, x_302); -lean_ctor_set(x_304, 1, x_303); -return x_304; +x_265 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_265, 0, x_263); +lean_ctor_set(x_265, 1, x_264); +return x_265; } } } @@ -5930,6 +6015,941 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Expr_getAppArgs___closed__1; +x_2 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__2() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("invalid macro, expected type is not available"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___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___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("expected type must not contain free or meta variables"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide(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_mkHole___closed__2; +lean_inc(x_2); +x_7 = l_Lean_Syntax_isOfKind(x_2, x_6); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_3); +x_8 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1; +x_9 = l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm(x_2, x_8, x_4, x_5); +return x_9; +} +else +{ +lean_object* x_10; +lean_dec(x_2); +x_10 = l_Lean_Elab_Term_tryPostponeIfNoneOrMVar(x_3, x_4, x_5); +if (lean_obj_tag(x_10) == 0) +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +x_12 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4; +x_13 = l_Lean_Elab_Term_throwError___rarg(x_1, x_12, x_4, x_11); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +x_14 = lean_ctor_get(x_10, 1); +lean_inc(x_14); +lean_dec(x_10); +x_15 = lean_ctor_get(x_3, 0); +lean_inc(x_15); +lean_dec(x_3); +lean_inc(x_4); +x_16 = l_Lean_Elab_Term_instantiateMVars(x_1, x_15, x_4, x_14); +x_17 = !lean_is_exclusive(x_16); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; uint8_t x_20; +x_18 = lean_ctor_get(x_16, 0); +x_19 = lean_ctor_get(x_16, 1); +x_20 = l_Lean_Expr_hasFVar(x_18); +if (x_20 == 0) +{ +uint8_t x_21; +x_21 = l_Lean_Expr_hasMVar(x_18); +if (x_21 == 0) +{ +lean_dec(x_4); +return x_16; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; +lean_free_object(x_16); +x_22 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_22, 0, x_18); +x_23 = l_Lean_indentExpr(x_22); +x_24 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7; +x_25 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_25, 0, x_24); +lean_ctor_set(x_25, 1, x_23); +x_26 = l_Lean_Elab_Term_throwError___rarg(x_1, x_25, x_4, x_19); +x_27 = !lean_is_exclusive(x_26); +if (x_27 == 0) +{ +return x_26; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_26, 0); +x_29 = lean_ctor_get(x_26, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_26); +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; lean_object* x_35; uint8_t x_36; +lean_free_object(x_16); +x_31 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_31, 0, x_18); +x_32 = l_Lean_indentExpr(x_31); +x_33 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7; +x_34 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_34, 0, x_33); +lean_ctor_set(x_34, 1, x_32); +x_35 = l_Lean_Elab_Term_throwError___rarg(x_1, x_34, x_4, x_19); +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; +x_40 = lean_ctor_get(x_16, 0); +x_41 = lean_ctor_get(x_16, 1); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_16); +x_42 = l_Lean_Expr_hasFVar(x_40); +if (x_42 == 0) +{ +uint8_t x_43; +x_43 = l_Lean_Expr_hasMVar(x_40); +if (x_43 == 0) +{ +lean_object* x_44; +lean_dec(x_4); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_40); +lean_ctor_set(x_44, 1, x_41); +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; +x_45 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_45, 0, x_40); +x_46 = l_Lean_indentExpr(x_45); +x_47 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7; +x_48 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_46); +x_49 = l_Lean_Elab_Term_throwError___rarg(x_1, x_48, x_4, x_41); +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); +} +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; lean_object* x_61; lean_object* x_62; +x_54 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_54, 0, x_40); +x_55 = l_Lean_indentExpr(x_54); +x_56 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7; +x_57 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_55); +x_58 = l_Lean_Elab_Term_throwError___rarg(x_1, x_57, x_4, x_41); +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); +} +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 +{ +uint8_t x_63; +lean_dec(x_4); +lean_dec(x_3); +x_63 = !lean_is_exclusive(x_10); +if (x_63 == 0) +{ +return x_10; +} +else +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_64 = lean_ctor_get(x_10, 0); +x_65 = lean_ctor_get(x_10, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_10); +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; +} +} +} +} +} +lean_object* l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} +lean_object* _init_l_Lean_Elab_Term_elabNativeDecide___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_mkDecIsTrue___closed__2; +x_2 = l_Lean_Parser_Term_decide___elambda__1___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Elab_Term_elabNativeDecide___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Elab_Term_elabNativeRefl___closed__7; +x_3 = l_Lean_mkConst(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Elab_Term_elabNativeDecide(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_unsigned_to_nat(1u); +x_6 = l_Lean_Syntax_getArg(x_1, x_5); +lean_inc(x_3); +x_7 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide(x_1, x_6, x_2, x_3, x_4); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +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_mkOptionalNode___closed__2; +lean_inc(x_8); +x_11 = lean_array_push(x_10, x_8); +x_12 = l_Lean_Elab_Term_elabNativeDecide___closed__1; +lean_inc(x_3); +x_13 = l_Lean_Elab_Term_mkAppM(x_1, x_12, x_11, x_3, x_9); +lean_dec(x_11); +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_box(0); +x_17 = l_Lean_boolToExpr___closed__1; +lean_inc(x_3); +x_18 = l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl(x_1, x_17, x_14, x_3, x_15); +if (lean_obj_tag(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_18, 1); +lean_inc(x_19); +x_20 = lean_ctor_get(x_19, 0); +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_20); +if (x_22 == 0) +{ +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_20, 4); +x_24 = lean_ctor_get(x_3, 0); +lean_inc(x_24); +x_25 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_20, 4, x_25); +x_26 = l___private_Init_Lean_Elab_Term_8__exceptionToSorry___closed__1; +x_27 = l_Lean_Meta_mkEqRefl(x_26, x_24, x_20); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +lean_dec(x_27); +lean_inc(x_3); +x_30 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_19, x_29, x_23); +x_31 = l_Lean_mkConst(x_21, x_16); +x_32 = l_Lean_Elab_Term_elabNativeDecide___closed__2; +x_33 = l_Lean_mkApp3(x_32, x_31, x_26, x_28); +x_34 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_33, x_8, x_3, x_30); +return x_34; +} +else +{ +uint8_t x_35; +lean_dec(x_21); +lean_dec(x_8); +x_35 = !lean_is_exclusive(x_27); +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_27, 0); +x_37 = lean_ctor_get(x_27, 1); +lean_inc(x_3); +x_38 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_36); +x_39 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_19, x_37, x_23); +lean_ctor_set(x_27, 1, x_39); +lean_ctor_set(x_27, 0, x_38); +return x_27; +} +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_27, 0); +x_41 = lean_ctor_get(x_27, 1); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_27); +lean_inc(x_3); +x_42 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_40); +x_43 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_19, x_41, x_23); +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; lean_object* x_55; +x_45 = lean_ctor_get(x_20, 0); +x_46 = lean_ctor_get(x_20, 1); +x_47 = lean_ctor_get(x_20, 2); +x_48 = lean_ctor_get(x_20, 3); +x_49 = lean_ctor_get(x_20, 4); +x_50 = lean_ctor_get(x_20, 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_20); +x_51 = lean_ctor_get(x_3, 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); +x_54 = l___private_Init_Lean_Elab_Term_8__exceptionToSorry___closed__1; +x_55 = l_Lean_Meta_mkEqRefl(x_54, x_51, 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; lean_object* x_61; lean_object* x_62; +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +lean_inc(x_3); +x_58 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_19, x_57, x_49); +x_59 = l_Lean_mkConst(x_21, x_16); +x_60 = l_Lean_Elab_Term_elabNativeDecide___closed__2; +x_61 = l_Lean_mkApp3(x_60, x_59, x_54, x_56); +x_62 = l_Lean_Elab_Term_mkExpectedTypeHint(x_1, x_61, x_8, x_3, x_58); +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_dec(x_21); +lean_dec(x_8); +x_63 = lean_ctor_get(x_55, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_55, 1); +lean_inc(x_64); +if (lean_is_exclusive(x_55)) { + lean_ctor_release(x_55, 0); + lean_ctor_release(x_55, 1); + x_65 = x_55; +} else { + lean_dec_ref(x_55); + x_65 = lean_box(0); +} +lean_inc(x_3); +x_66 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_63); +x_67 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_19, x_64, x_49); +if (lean_is_scalar(x_65)) { + x_68 = lean_alloc_ctor(1, 2, 0); +} else { + x_68 = x_65; +} +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; +} +} +} +else +{ +uint8_t x_69; +lean_dec(x_8); +lean_dec(x_3); +x_69 = !lean_is_exclusive(x_18); +if (x_69 == 0) +{ +return x_18; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_18, 0); +x_71 = lean_ctor_get(x_18, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_18); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_8); +lean_dec(x_3); +x_73 = !lean_is_exclusive(x_13); +if (x_73 == 0) +{ +return x_13; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_13, 0); +x_75 = lean_ctor_get(x_13, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_13); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_3); +x_77 = !lean_is_exclusive(x_7); +if (x_77 == 0) +{ +return x_7; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_7, 0); +x_79 = lean_ctor_get(x_7, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_7); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +lean_object* l_Lean_Elab_Term_elabNativeDecide___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_elabNativeDecide(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* _init_l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Elab_Term_elabNativeDecide___boxed), 4, 0); +return x_1; +} +} +lean_object* l___regBuiltin_Lean_Elab_Term_elabNativeDecide(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_2 = l_Lean_Elab_Term_termElabAttribute; +x_3 = l_Lean_Parser_Term_nativeDecide___elambda__1___closed__2; +x_4 = l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1; +x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); +return x_5; +} +} +lean_object* _init_l_Lean_Elab_Term_elabDecide___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("ofDecideEqTrue"); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_elabDecide___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Elab_Term_elabDecide___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Elab_Term_elabDecide___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Elab_Term_elabDecide___closed__2; +x_3 = l_Lean_mkConst(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Elab_Term_elabDecide(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_unsigned_to_nat(1u); +x_6 = l_Lean_Syntax_getArg(x_1, x_5); +lean_inc(x_3); +x_7 = l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide(x_1, x_6, x_2, x_3, x_4); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +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_mkOptionalNode___closed__2; +lean_inc(x_8); +x_11 = lean_array_push(x_10, x_8); +x_12 = l_Lean_Elab_Term_elabNativeDecide___closed__1; +lean_inc(x_3); +x_13 = l_Lean_Elab_Term_mkAppM(x_1, x_12, x_11, x_3, x_9); +lean_dec(x_11); +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; uint8_t x_21; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +lean_inc(x_3); +x_16 = l_Lean_Elab_Term_instantiateMVars(x_1, x_14, x_3, 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_Expr_appArg_x21(x_17); +lean_dec(x_17); +x_20 = lean_ctor_get(x_18, 0); +lean_inc(x_20); +x_21 = !lean_is_exclusive(x_20); +if (x_21 == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_22 = lean_ctor_get(x_20, 4); +x_23 = lean_ctor_get(x_3, 0); +lean_inc(x_23); +x_24 = l_Lean_TraceState_Inhabited___closed__1; +lean_ctor_set(x_20, 4, x_24); +x_25 = l_Lean_boolToExpr___lambda__1___closed__6; +x_26 = l_Lean_Meta_mkEqRefl(x_25, x_23, x_20); +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; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_28 = lean_ctor_get(x_26, 0); +x_29 = lean_ctor_get(x_26, 1); +x_30 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_29, x_22); +x_31 = l_Lean_Elab_Term_elabDecide___closed__3; +x_32 = l_Lean_mkApp3(x_31, x_8, x_19, x_28); +lean_ctor_set(x_26, 1, x_30); +lean_ctor_set(x_26, 0, x_32); +return x_26; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_33 = lean_ctor_get(x_26, 0); +x_34 = lean_ctor_get(x_26, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_26); +x_35 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_34, x_22); +x_36 = l_Lean_Elab_Term_elabDecide___closed__3; +x_37 = l_Lean_mkApp3(x_36, x_8, x_19, x_33); +x_38 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_38, 0, x_37); +lean_ctor_set(x_38, 1, x_35); +return x_38; +} +} +else +{ +uint8_t x_39; +lean_dec(x_19); +lean_dec(x_8); +x_39 = !lean_is_exclusive(x_26); +if (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_26, 0); +x_41 = lean_ctor_get(x_26, 1); +lean_inc(x_3); +x_42 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_40); +x_43 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_41, x_22); +lean_ctor_set(x_26, 1, x_43); +lean_ctor_set(x_26, 0, x_42); +return x_26; +} +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_26, 0); +x_45 = lean_ctor_get(x_26, 1); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_26); +lean_inc(x_3); +x_46 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_44); +x_47 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_45, x_22); +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_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_49 = lean_ctor_get(x_20, 0); +x_50 = lean_ctor_get(x_20, 1); +x_51 = lean_ctor_get(x_20, 2); +x_52 = lean_ctor_get(x_20, 3); +x_53 = lean_ctor_get(x_20, 4); +x_54 = lean_ctor_get(x_20, 5); +lean_inc(x_54); +lean_inc(x_53); +lean_inc(x_52); +lean_inc(x_51); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_20); +x_55 = lean_ctor_get(x_3, 0); +lean_inc(x_55); +x_56 = l_Lean_TraceState_Inhabited___closed__1; +x_57 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_57, 0, x_49); +lean_ctor_set(x_57, 1, x_50); +lean_ctor_set(x_57, 2, x_51); +lean_ctor_set(x_57, 3, x_52); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_57, 5, x_54); +x_58 = l_Lean_boolToExpr___lambda__1___closed__6; +x_59 = l_Lean_Meta_mkEqRefl(x_58, x_55, x_57); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +x_61 = lean_ctor_get(x_59, 1); +lean_inc(x_61); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + x_62 = x_59; +} else { + lean_dec_ref(x_59); + x_62 = lean_box(0); +} +x_63 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_61, x_53); +x_64 = l_Lean_Elab_Term_elabDecide___closed__3; +x_65 = l_Lean_mkApp3(x_64, x_8, x_19, x_60); +if (lean_is_scalar(x_62)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_62; +} +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +lean_dec(x_19); +lean_dec(x_8); +x_67 = lean_ctor_get(x_59, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_59, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + x_69 = x_59; +} else { + lean_dec_ref(x_59); + x_69 = lean_box(0); +} +lean_inc(x_3); +x_70 = l___private_Init_Lean_Elab_Term_2__fromMetaException(x_3, x_1, x_67); +x_71 = l___private_Init_Lean_Elab_Term_3__fromMetaState(x_1, x_3, x_18, x_68, x_53); +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 +{ +uint8_t x_73; +lean_dec(x_8); +lean_dec(x_3); +x_73 = !lean_is_exclusive(x_13); +if (x_73 == 0) +{ +return x_13; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_13, 0); +x_75 = lean_ctor_get(x_13, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_13); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_3); +x_77 = !lean_is_exclusive(x_7); +if (x_77 == 0) +{ +return x_7; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_7, 0); +x_79 = lean_ctor_get(x_7, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_7); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +lean_object* l_Lean_Elab_Term_elabDecide___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_elabDecide(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* _init_l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Elab_Term_elabDecide___boxed), 4, 0); +return x_1; +} +} +lean_object* l___regBuiltin_Lean_Elab_Term_elabDecide(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_2 = l_Lean_Elab_Term_termElabAttribute; +x_3 = l_Lean_Parser_Term_decide___elambda__1___closed__2; +x_4 = l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1; +x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); +return x_5; +} +} lean_object* l_Lean_Elab_Term_elabInfix(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -5984,7 +7004,7 @@ lean_object* l_Lean_Elab_Term_elabProd(lean_object* x_1, lean_object* x_2, lean_ _start: { lean_object* x_4; lean_object* x_5; -x_4 = l_Lean_prodToExpr___rarg___lambda__1___closed__2; +x_4 = l_Lean_Expr_prod_x3f___closed__2; x_5 = l_Lean_Elab_Term_elabInfixOp(x_4, x_1, x_2, x_3); return x_5; } @@ -7432,7 +8452,7 @@ lean_object* l_Lean_Elab_Term_elabCons(lean_object* x_1, lean_object* x_2, lean_ _start: { lean_object* x_4; lean_object* x_5; -x_4 = l_Lean_listToExpr___rarg___closed__8; +x_4 = l_Lean_Expr_listLitAux___main___closed__6; x_5 = l_Lean_Elab_Term_elabInfixOp(x_4, x_1, x_2, x_3); return x_5; } @@ -7450,6 +8470,16 @@ return x_4; lean_object* _init_l___regBuiltin_Lean_Elab_Term_elabCons___closed__1() { _start: { +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_mkAppStx___closed__6; +x_2 = l_Lean_Expr_listLitAux___main___closed__5; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l___regBuiltin_Lean_Elab_Term_elabCons___closed__2() { +_start: +{ lean_object* x_1; x_1 = lean_alloc_closure((void*)(l_Lean_Elab_Term_elabCons___boxed), 3, 0); return x_1; @@ -7460,8 +8490,8 @@ _start: { lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_2 = l_Lean_Elab_macroAttribute; -x_3 = l_Lean_Parser_Term_cons___elambda__1___closed__1; -x_4 = l___regBuiltin_Lean_Elab_Term_elabCons___closed__1; +x_3 = l___regBuiltin_Lean_Elab_Term_elabCons___closed__1; +x_4 = l___regBuiltin_Lean_Elab_Term_elabCons___closed__2; x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } @@ -8355,6 +9385,18 @@ l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__1 = lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__1); l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__2 = _init_l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__2(); lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_1__mkNativeReflAuxDecl___closed__2); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__1); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__2); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__3); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__4); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__5); +l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6 = _init_l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_2__elabClosedTerm___closed__6); l_Lean_Elab_Term_elabNativeRefl___closed__1 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__1); l_Lean_Elab_Term_elabNativeRefl___closed__2 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__2(); @@ -8375,27 +9417,45 @@ l_Lean_Elab_Term_elabNativeRefl___closed__9 = _init_l_Lean_Elab_Term_elabNativeR lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__9); l_Lean_Elab_Term_elabNativeRefl___closed__10 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__10(); lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__10); -l_Lean_Elab_Term_elabNativeRefl___closed__11 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__11(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__11); -l_Lean_Elab_Term_elabNativeRefl___closed__12 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__12(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__12); -l_Lean_Elab_Term_elabNativeRefl___closed__13 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__13(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__13); -l_Lean_Elab_Term_elabNativeRefl___closed__14 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__14(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__14); -l_Lean_Elab_Term_elabNativeRefl___closed__15 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__15(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__15); -l_Lean_Elab_Term_elabNativeRefl___closed__16 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__16(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__16); -l_Lean_Elab_Term_elabNativeRefl___closed__17 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__17(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__17); -l_Lean_Elab_Term_elabNativeRefl___closed__18 = _init_l_Lean_Elab_Term_elabNativeRefl___closed__18(); -lean_mark_persistent(l_Lean_Elab_Term_elabNativeRefl___closed__18); l___regBuiltin_Lean_Elab_Term_elabNativeRefl___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabNativeRefl___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabNativeRefl___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabNativeRefl(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__1); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__2 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__2); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__3); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__4); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__5); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__6); +l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7 = _init_l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7(); +lean_mark_persistent(l___private_Init_Lean_Elab_BuiltinNotation_3__getPropToDecide___closed__7); +l_Lean_Elab_Term_elabNativeDecide___closed__1 = _init_l_Lean_Elab_Term_elabNativeDecide___closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_elabNativeDecide___closed__1); +l_Lean_Elab_Term_elabNativeDecide___closed__2 = _init_l_Lean_Elab_Term_elabNativeDecide___closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_elabNativeDecide___closed__2); +l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1(); +lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabNativeDecide___closed__1); +res = l___regBuiltin_Lean_Elab_Term_elabNativeDecide(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +l_Lean_Elab_Term_elabDecide___closed__1 = _init_l_Lean_Elab_Term_elabDecide___closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_elabDecide___closed__1); +l_Lean_Elab_Term_elabDecide___closed__2 = _init_l_Lean_Elab_Term_elabDecide___closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_elabDecide___closed__2); +l_Lean_Elab_Term_elabDecide___closed__3 = _init_l_Lean_Elab_Term_elabDecide___closed__3(); +lean_mark_persistent(l_Lean_Elab_Term_elabDecide___closed__3); +l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1(); +lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabDecide___closed__1); +res = l___regBuiltin_Lean_Elab_Term_elabDecide(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); l___regBuiltin_Lean_Elab_Term_elabProd___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabProd___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabProd___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabProd(lean_io_mk_world()); @@ -8631,6 +9691,8 @@ if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l___regBuiltin_Lean_Elab_Term_elabCons___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabCons___closed__1(); lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabCons___closed__1); +l___regBuiltin_Lean_Elab_Term_elabCons___closed__2 = _init_l___regBuiltin_Lean_Elab_Term_elabCons___closed__2(); +lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabCons___closed__2); res = l___regBuiltin_Lean_Elab_Term_elabCons(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); diff --git a/stage0/stdlib/Init/Lean/Elab/DoNotation.c b/stage0/stdlib/Init/Lean/Elab/DoNotation.c index 8976b31311..79a9924846 100644 --- a/stage0/stdlib/Init/Lean/Elab/DoNotation.c +++ b/stage0/stdlib/Init/Lean/Elab/DoNotation.c @@ -43,6 +43,7 @@ lean_object* l_Lean_Elab_Term_ProcessedDoElem_inhabited___closed__1; lean_object* l___private_Init_Lean_Elab_DoNotation_9__extractTypeFormerAppArg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_liftMethod___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); uint8_t l___private_Init_Lean_Elab_DoNotation_4__hasLiftMethod(lean_object*); @@ -51,6 +52,7 @@ extern lean_object* l___private_Init_Lean_Elab_Term_5__expandCDot___main___close lean_object* l_Lean_Elab_Term_synthesizeInst(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_3__getDoElems___boxed(lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_11__processDoElemsAux___main___closed__6; +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_do___elambda__1___closed__2; lean_object* l___private_Init_Lean_Elab_DoNotation_5__expandLiftMethodAux___main___closed__3; @@ -75,12 +77,12 @@ lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwUnsupportedSyntax___rarg(lean_object*); lean_object* l_Lean_Elab_Term_elabTerm(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; lean_object* l___private_Init_Lean_Elab_DoNotation_12__processDoElems(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__6; extern lean_object* l_Lean_Parser_Term_doId___elambda__1___closed__2; lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); lean_object* l_Array_back___at___private_Init_Lean_Elab_DoNotation_10__mkBind___spec__1___boxed(lean_object*); -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; extern lean_object* l___private_Init_Lean_Elab_Quotation_7__getHeadInfo___elambda__3___closed__2; extern lean_object* l___private_Init_Lean_Elab_Quotation_11__letBindRhss___main___closed__11; extern lean_object* l_Lean_Elab_Term_expandCDot_x3f___closed__3; @@ -119,7 +121,6 @@ lean_object* l___private_Init_Lean_Elab_DoNotation_10__mkBind(lean_object*, lean extern lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__7; lean_object* lean_environment_main_module(lean_object*); uint8_t l_Lean_Expr_isMVar(lean_object*); -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; extern lean_object* l_Lean_Elab_Term_elabLetDecl___closed__2; extern lean_object* l_Lean_Parser_Term_match___elambda__1___closed__2; lean_object* l_Lean_mkApp(lean_object*, lean_object*); @@ -128,8 +129,8 @@ lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_11__processDoElemsAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_getKind(lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_13__regTraceClasses(lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; lean_object* lean_panic_fn(lean_object*, lean_object*); -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; lean_object* l___regBuiltin_Lean_Elab_Term_elabDo(lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_2__extractBind(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabType(lean_object*, lean_object*, lean_object*); @@ -147,7 +148,6 @@ extern lean_object* l_Lean_Expr_Inhabited; lean_object* lean_array_pop(lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_7__expandDoElemsAux___main(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabDo(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; lean_object* l___private_Init_Lean_Elab_DoNotation_11__processDoElemsAux___main___closed__1; lean_object* l___private_Init_Lean_Elab_DoNotation_11__processDoElemsAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_DoNotation_11__processDoElemsAux___main___closed__2; @@ -2456,12 +2456,12 @@ x_164 = lean_array_push(x_130, x_163); x_165 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_165, 0, x_132); lean_ctor_set(x_165, 1, x_164); -x_166 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_166 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_167 = lean_array_push(x_166, x_165); x_168 = lean_array_push(x_167, x_152); -x_169 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_169 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_170 = lean_array_push(x_168, x_169); -x_171 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_171 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_172 = lean_array_push(x_170, x_171); x_173 = lean_array_push(x_130, x_117); x_174 = lean_alloc_ctor(1, 2, 0); @@ -2476,7 +2476,7 @@ x_180 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_180, 0, x_179); lean_ctor_set(x_180, 1, x_178); x_181 = lean_array_push(x_130, x_180); -x_182 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_182 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_183 = lean_array_push(x_181, x_182); x_184 = l___private_Init_Lean_Elab_DoNotation_7__expandDoElemsAux___main___closed__5; x_185 = lean_array_push(x_184, x_145); @@ -2544,12 +2544,12 @@ x_217 = lean_array_push(x_130, x_216); x_218 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_218, 0, x_132); lean_ctor_set(x_218, 1, x_217); -x_219 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_219 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_220 = lean_array_push(x_219, x_218); x_221 = lean_array_push(x_220, x_205); -x_222 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_222 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_223 = lean_array_push(x_221, x_222); -x_224 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_224 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_225 = lean_array_push(x_223, x_224); x_226 = lean_array_push(x_130, x_117); x_227 = lean_alloc_ctor(1, 2, 0); @@ -2642,12 +2642,12 @@ x_274 = l_Lean_nullKind___closed__2; x_275 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_275, 0, x_274); lean_ctor_set(x_275, 1, x_273); -x_276 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_276 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_277 = lean_array_push(x_276, x_275); x_278 = lean_array_push(x_277, x_261); -x_279 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_279 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_280 = lean_array_push(x_278, x_279); -x_281 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_281 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_282 = lean_array_push(x_280, x_281); x_283 = lean_array_push(x_259, x_117); x_284 = lean_alloc_ctor(1, 2, 0); @@ -2662,7 +2662,7 @@ x_290 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_290, 0, x_289); lean_ctor_set(x_290, 1, x_288); x_291 = lean_array_push(x_259, x_290); -x_292 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_292 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_293 = lean_array_push(x_291, x_292); x_294 = l___private_Init_Lean_Elab_DoNotation_7__expandDoElemsAux___main___closed__5; x_295 = lean_array_push(x_294, x_252); @@ -2735,12 +2735,12 @@ x_332 = l_Lean_nullKind___closed__2; x_333 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_333, 0, x_332); lean_ctor_set(x_333, 1, x_331); -x_334 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_334 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_335 = lean_array_push(x_334, x_333); x_336 = lean_array_push(x_335, x_319); -x_337 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_337 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_338 = lean_array_push(x_336, x_337); -x_339 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_339 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_340 = lean_array_push(x_338, x_339); x_341 = lean_array_push(x_317, x_117); x_342 = lean_alloc_ctor(1, 2, 0); @@ -3149,12 +3149,12 @@ x_545 = lean_array_push(x_511, x_544); x_546 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_546, 0, x_513); lean_ctor_set(x_546, 1, x_545); -x_547 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_547 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_548 = lean_array_push(x_547, x_546); x_549 = lean_array_push(x_548, x_533); -x_550 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_550 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_551 = lean_array_push(x_549, x_550); -x_552 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_552 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_553 = lean_array_push(x_551, x_552); x_554 = lean_array_push(x_511, x_498); x_555 = lean_alloc_ctor(1, 2, 0); @@ -3169,7 +3169,7 @@ x_561 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_561, 0, x_560); lean_ctor_set(x_561, 1, x_559); x_562 = lean_array_push(x_511, x_561); -x_563 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_563 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_564 = lean_array_push(x_562, x_563); x_565 = l___private_Init_Lean_Elab_DoNotation_7__expandDoElemsAux___main___closed__5; x_566 = lean_array_push(x_565, x_526); @@ -3237,12 +3237,12 @@ x_598 = lean_array_push(x_511, x_597); x_599 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_599, 0, x_513); lean_ctor_set(x_599, 1, x_598); -x_600 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_600 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_601 = lean_array_push(x_600, x_599); x_602 = lean_array_push(x_601, x_586); -x_603 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_603 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_604 = lean_array_push(x_602, x_603); -x_605 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_605 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_606 = lean_array_push(x_604, x_605); x_607 = lean_array_push(x_511, x_498); x_608 = lean_alloc_ctor(1, 2, 0); @@ -3335,12 +3335,12 @@ x_655 = l_Lean_nullKind___closed__2; x_656 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_656, 0, x_655); lean_ctor_set(x_656, 1, x_654); -x_657 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_657 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_658 = lean_array_push(x_657, x_656); x_659 = lean_array_push(x_658, x_642); -x_660 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_660 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_661 = lean_array_push(x_659, x_660); -x_662 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_662 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_663 = lean_array_push(x_661, x_662); x_664 = lean_array_push(x_640, x_498); x_665 = lean_alloc_ctor(1, 2, 0); @@ -3355,7 +3355,7 @@ x_671 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_671, 0, x_670); lean_ctor_set(x_671, 1, x_669); x_672 = lean_array_push(x_640, x_671); -x_673 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_673 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_674 = lean_array_push(x_672, x_673); x_675 = l___private_Init_Lean_Elab_DoNotation_7__expandDoElemsAux___main___closed__5; x_676 = lean_array_push(x_675, x_633); @@ -3428,12 +3428,12 @@ x_713 = l_Lean_nullKind___closed__2; x_714 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_714, 0, x_713); lean_ctor_set(x_714, 1, x_712); -x_715 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__2; +x_715 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__2; x_716 = lean_array_push(x_715, x_714); x_717 = lean_array_push(x_716, x_700); -x_718 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_718 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_719 = lean_array_push(x_717, x_718); -x_720 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_720 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_721 = lean_array_push(x_719, x_720); x_722 = lean_array_push(x_698, x_498); x_723 = lean_alloc_ctor(1, 2, 0); diff --git a/stage0/stdlib/Init/Lean/Elab/Quotation.c b/stage0/stdlib/Init/Lean/Elab/Quotation.c index c9d54417f3..dfc13d34de 100644 --- a/stage0/stdlib/Init/Lean/Elab/Quotation.c +++ b/stage0/stdlib/Init/Lean/Elab/Quotation.c @@ -131,7 +131,6 @@ lean_object* l_Lean_Elab_Term_Quotation_HeadInfo_Inhabited___closed__2; lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__23; extern lean_object* l_Lean_Parser_Term_num___elambda__1___closed__1; lean_object* l_List_range(lean_object*); -extern lean_object* l_Lean_listToExpr___rarg___closed__8; lean_object* l___private_Init_Lean_Elab_Quotation_8__explodeHeadPat___lambda__1___closed__2; lean_object* lean_string_utf8_extract(lean_object*, lean_object*, lean_object*); lean_object* l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(lean_object*); @@ -175,7 +174,6 @@ extern lean_object* l_Nat_HasOfNat___closed__1; lean_object* l___private_Init_Lean_Elab_Quotation_13__toPreterm___main___closed__5; lean_object* l_Lean_Elab_Term_Quotation_match__syntax_expand(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_Quotation_oldExpandMatchSyntax___closed__1; -extern lean_object* l_Lean_listToExpr___rarg___closed__4; lean_object* l___private_Init_Lean_Elab_Quotation_11__letBindRhss___main___closed__8; lean_object* l___private_Init_Lean_Elab_Quotation_1__quoteName___main(lean_object*); extern lean_object* l_Lean_mkAppStx___closed__8; @@ -237,6 +235,7 @@ lean_object* l___private_Init_Lean_Elab_Quotation_1__quoteName(lean_object*); lean_object* l___private_Init_Lean_Elab_Quotation_12__exprPlaceholder___closed__1; extern lean_object* l_Lean_choiceKind___closed__1; lean_object* l_Array_umapMAux___main___at_Lean_Elab_Term_Quotation_match__syntax_expand___spec__1___closed__3; +extern lean_object* l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4; lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__25; lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__17; lean_object* l_List_mapM___main___at___private_Init_Lean_Elab_Quotation_9__compileStxMatch___main___spec__8___closed__8; @@ -354,6 +353,7 @@ lean_object* l_Lean_Parser_getTokenTable(lean_object*); lean_object* l_Lean_List_hasQuote(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*); +extern lean_object* l_Lean_Expr_listLitAux___main___closed__4; lean_object* l___private_Init_Lean_Elab_Quotation_7__getHeadInfo___lambda__2___closed__3; lean_object* l___private_Init_Lean_Elab_Quotation_11__letBindRhss___main___closed__7; uint8_t l_Lean_Elab_Term_Quotation_isAntiquot(lean_object*); @@ -395,7 +395,6 @@ lean_object* l___private_Init_Lean_Elab_Quotation_14__oldRunTermElabM___rarg___c lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__43; lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__32; lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__10; -extern lean_object* l_Lean_prodToExpr___rarg___lambda__1___closed__4; extern lean_object* l_Lean_Parser_Term_str___elambda__1___closed__2; extern lean_object* l_Lean_Syntax_inhabited; lean_object* l___private_Init_Lean_Elab_Quotation_2__quoteList___main(lean_object*); @@ -404,6 +403,7 @@ extern lean_object* l_Lean_mkAppStx___closed__5; lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__44; extern lean_object* l_Lean_Parser_Level_paren___elambda__1___closed__3; lean_object* l_Lean_Parser_Error_toString(lean_object*); +extern lean_object* l_Lean_Expr_listLitAux___main___closed__6; lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__8; lean_object* l___private_Init_Lean_Elab_Quotation_9__compileStxMatch___main___closed__28; lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__7; @@ -508,6 +508,7 @@ extern lean_object* l_Lean_mkHole___closed__2; lean_object* l___private_Init_Lean_Elab_Quotation_10__getPatternVarsAux___main___boxed(lean_object*); extern lean_object* l_Lean_Parser_Term_stxQuot___elambda__1___closed__3; lean_object* l___private_Init_Lean_Elab_Quotation_8__explodeHeadPat___lambda__1(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_arrayLit_x3f___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_Quotation_elabStxQuot(lean_object*); lean_object* l___private_Init_Lean_Elab_Quotation_5__quoteSyntax___main___closed__7; lean_object* l_List_foldl___main___at___private_Init_Lean_Elab_Quotation_13__toPreterm___main___spec__5(lean_object*, lean_object*, lean_object*); @@ -520,7 +521,6 @@ lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Elab_Quotation_4__ lean_object* l___private_Init_Lean_Elab_Quotation_9__compileStxMatch___main___closed__3; lean_object* l_Lean_mkStxLit(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_Quotation_stxQuot_expand___closed__24; -extern lean_object* l_Lean_arrayToExpr___rarg___lambda__1___closed__2; lean_object* l___private_Init_Lean_Elab_Quotation_14__oldRunTermElabM___rarg(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Quotation_11__letBindRhss___main___closed__13; lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); @@ -813,7 +813,7 @@ x_7 = lean_apply_1(x_2, x_5); x_8 = l_Lean_mkAppStx___closed__9; x_9 = lean_array_push(x_8, x_6); x_10 = lean_array_push(x_9, x_7); -x_11 = l_Lean_prodToExpr___rarg___lambda__1___closed__4; +x_11 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4; x_12 = l_Lean_mkCAppStx(x_11, x_10); return x_12; } @@ -831,7 +831,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l_Lean_listToExpr___rarg___closed__4; +x_2 = l_Lean_Expr_listLitAux___main___closed__4; x_3 = l_Lean_mkCTermIdFrom(x_1, x_2); return x_3; } @@ -860,7 +860,7 @@ x_7 = l___private_Init_Lean_Elab_Quotation_2__quoteList___main___rarg(x_1, x_5); x_8 = l_Lean_mkAppStx___closed__9; x_9 = lean_array_push(x_8, x_6); x_10 = lean_array_push(x_9, x_7); -x_11 = l_Lean_listToExpr___rarg___closed__8; +x_11 = l_Lean_Expr_listLitAux___main___closed__6; x_12 = l_Lean_mkCAppStx(x_11, x_10); return x_12; } @@ -915,7 +915,7 @@ x_3 = l_Array_toList___rarg(x_2); x_4 = l___private_Init_Lean_Elab_Quotation_2__quoteList___main___rarg(x_1, x_3); x_5 = l_Lean_mkOptionalNode___closed__2; x_6 = lean_array_push(x_5, x_4); -x_7 = l_Lean_arrayToExpr___rarg___lambda__1___closed__2; +x_7 = l_Lean_Expr_arrayLit_x3f___closed__2; x_8 = l_Lean_mkCAppStx(x_7, x_6); return x_8; } @@ -1974,7 +1974,7 @@ x_11 = l___private_Init_Lean_Elab_Quotation_2__quoteList___main___at___private_I x_12 = l_Lean_mkAppStx___closed__9; x_13 = lean_array_push(x_12, x_10); x_14 = lean_array_push(x_13, x_11); -x_15 = l_Lean_listToExpr___rarg___closed__8; +x_15 = l_Lean_Expr_listLitAux___main___closed__6; x_16 = l_Lean_mkCAppStx(x_15, x_14); return x_16; } @@ -2008,11 +2008,11 @@ x_9 = l___private_Init_Lean_Elab_Quotation_2__quoteList___main___at___private_In x_10 = l_Lean_mkAppStx___closed__9; x_11 = lean_array_push(x_10, x_8); x_12 = lean_array_push(x_11, x_9); -x_13 = l_Lean_prodToExpr___rarg___lambda__1___closed__4; +x_13 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4; x_14 = l_Lean_mkCAppStx(x_13, x_12); x_15 = lean_array_push(x_10, x_14); x_16 = lean_array_push(x_15, x_5); -x_17 = l_Lean_listToExpr___rarg___closed__8; +x_17 = l_Lean_Expr_listLitAux___main___closed__6; x_18 = l_Lean_mkCAppStx(x_17, x_16); return x_18; } diff --git a/stage0/stdlib/Init/Lean/Elab/StructInst.c b/stage0/stdlib/Init/Lean/Elab/StructInst.c index 19e87c4bfe..f904afc499 100644 --- a/stage0/stdlib/Init/Lean/Elab/StructInst.c +++ b/stage0/stdlib/Init/Lean/Elab/StructInst.c @@ -40,6 +40,7 @@ lean_object* lean_mk_empty_array_with_capacity(lean_object*); uint8_t l_AssocList_contains___main___at___private_Init_Lean_Elab_StructInst_12__mkFieldMap___spec__4(lean_object*, lean_object*); lean_object* l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_12__mkFieldMap___spec__10___closed__6; lean_object* l_List_head_x21___at___private_Init_Lean_Elab_StructInst_19__expandStruct___main___spec__5___boxed(lean_object*); +extern lean_object* l_Lean_Meta_mkExpectedTypeHint___closed__1; lean_object* l_Lean_Elab_Term_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_HashMap_toList___rarg(lean_object*); lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_getHierarchyDepth___main___boxed(lean_object*); @@ -162,7 +163,6 @@ lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefault___ lean_object* l_AssocList_contains___main___at___private_Init_Lean_Elab_StructInst_12__mkFieldMap___spec__4___boxed(lean_object*, lean_object*); lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_mkTermIdFromIdent___closed__1; lean_object* l_List_foldl___main___at_Lean_Elab_Term_StructInst_DefaultFields_getHierarchyDepth___main___spec__1___boxed(lean_object*, lean_object*); lean_object* l_List_mapM___main___at___private_Init_Lean_Elab_StructInst_10__expandParentFields___spec__2___closed__6; lean_object* l_Lean_Elab_Term_getMainModule___rarg(lean_object*); @@ -494,7 +494,6 @@ lean_object* l___private_Init_Lean_Elab_StructInst_19__expandStruct___main(lean_ lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefault(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_reduce___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1; lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_step(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_umapMAux___main___at_Lean_Elab_Term_StructInst_ExpandNonAtomicExplicitSource_main___spec__1___closed__2; lean_object* l___private_Init_Lean_Elab_StructInst_25__elabStructInstAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -21625,16 +21624,6 @@ lean_dec(x_1); return x_3; } } -lean_object* _init_l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = lean_box(0); -x_2 = l_Lean_mkTermIdFromIdent___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; -} -} lean_object* l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -21830,7 +21819,7 @@ block_14: { lean_object* x_6; lean_object* x_7; uint8_t x_8; lean_dec(x_5); -x_6 = l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1; +x_6 = l_Lean_Meta_mkExpectedTypeHint___closed__1; x_7 = lean_unsigned_to_nat(2u); x_8 = l_Lean_Expr_isAppOfArity___main(x_2, x_6, x_7); if (x_8 == 0) @@ -26090,8 +26079,6 @@ l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_24__elabStruct___m lean_mark_persistent(l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_24__elabStruct___main___spec__1___closed__2); l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_24__elabStruct___main___spec__1___closed__3 = _init_l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_24__elabStruct___main___spec__1___closed__3(); lean_mark_persistent(l_List_foldlM___main___at___private_Init_Lean_Elab_StructInst_24__elabStruct___main___spec__1___closed__3); -l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1 = _init_l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1(); -lean_mark_persistent(l_Lean_Elab_Term_StructInst_DefaultFields_mkDefaultValueAux_x3f___main___closed__1); l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefaultAux___main___closed__1 = _init_l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefaultAux___main___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefaultAux___main___closed__1); l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefaultAux___main___closed__2 = _init_l_Lean_Elab_Term_StructInst_DefaultFields_tryToSynthesizeDefaultAux___main___closed__2(); diff --git a/stage0/stdlib/Init/Lean/Elab/Syntax.c b/stage0/stdlib/Init/Lean/Elab/Syntax.c index 5e84101b23..83c6725b0c 100644 --- a/stage0/stdlib/Init/Lean/Elab/Syntax.c +++ b/stage0/stdlib/Init/Lean/Elab/Syntax.c @@ -133,6 +133,7 @@ lean_object* l_Lean_Elab_Command_elabMacroRulesAux___closed__25; lean_object* lean_string_utf8_byte_size(lean_object*); lean_object* l_Lean_mkAtom(lean_object*); lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__20; +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__10; lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__32; lean_object* l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(lean_object*, lean_object*, lean_object*, lean_object*); @@ -225,6 +226,7 @@ extern lean_object* l_Lean_Parser_Command_def___elambda__1___closed__2; lean_object* l_Lean_Macro_addMacroScope(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Command_declValSimple___elambda__1___closed__2; lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; lean_object* l_Lean_Elab_Command_elabSyntax___closed__25; extern lean_object* l_Lean_numLitKind___closed__1; extern lean_object* l_Lean_Parser_Command_def___elambda__1___closed__1; @@ -377,7 +379,6 @@ lean_object* l_Lean_Syntax_setArg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__18; lean_object* l_Lean_Elab_Command_elabNoKindMacroRulesAux___closed__3; lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__3; -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; extern lean_object* l_Lean_Parser_Syntax_sepBy1___elambda__1___closed__1; uint8_t l_Lean_Parser_isParserCategory(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Syntax_5__withoutLeftRec___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -394,6 +395,7 @@ lean_object* l_Lean_Elab_Command_elabMacroRulesAux___closed__7; lean_object* l_Lean_Syntax_getArgs(lean_object*); lean_object* l_Lean_Elab_Term_checkLeftRec___closed__3; lean_object* l_Lean_Syntax_getKind(lean_object*); +extern lean_object* l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; extern lean_object* l_Lean_Parser_Term_match__syntax___elambda__1___closed__2; lean_object* l_Lean_Elab_Command_elabMacroRulesAux___closed__24; lean_object* l_Array_findMAux___main___at_Lean_Elab_Command_elabMacroRulesAux___spec__1(lean_object*, lean_object*, lean_object*); @@ -406,7 +408,6 @@ lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__111; lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__97; lean_object* l_Array_umapMAux___main___at_Lean_Elab_Command_expandMacro___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Syntax_5__withoutLeftRec(lean_object*); -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__64; lean_object* l___private_Init_Lean_Elab_Syntax_1__expandOptPrecedence___boxed(lean_object*); lean_object* l_Lean_Elab_Command_elabSyntax___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -463,7 +464,6 @@ lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__119; extern lean_object* l_Lean_Parser_Command_macro___elambda__1___closed__1; lean_object* l___private_Init_Lean_Elab_Syntax_4__withNotFirst___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_toParserDescrAux___main___closed__29; -extern lean_object* l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; lean_object* l___private_Init_Lean_Elab_Syntax_7__antiquote___main___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBinders___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_stxQuot___elambda__1___closed__3; @@ -10419,13 +10419,13 @@ x_90 = l_Lean_Elab_Term_expandCDot_x3f___closed__3; x_91 = lean_array_push(x_89, x_90); x_92 = l_Lean_Elab_Command_elabMacroRulesAux___closed__17; x_93 = lean_array_push(x_92, x_85); -x_94 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_94 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_95 = lean_array_push(x_93, x_94); x_96 = lean_array_push(x_95, x_42); x_97 = lean_unsigned_to_nat(0u); x_98 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_7, x_7, x_97, x_21); lean_dec(x_7); -x_99 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_99 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_100 = lean_array_push(x_98, x_99); x_101 = l_Lean_Elab_Command_elabMacroRulesAux___closed__23; lean_inc(x_10); @@ -10644,13 +10644,13 @@ x_222 = l_Lean_Elab_Term_expandCDot_x3f___closed__3; x_223 = lean_array_push(x_221, x_222); x_224 = l_Lean_Elab_Command_elabMacroRulesAux___closed__17; x_225 = lean_array_push(x_224, x_217); -x_226 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__4; +x_226 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__4; x_227 = lean_array_push(x_225, x_226); x_228 = lean_array_push(x_227, x_174); x_229 = lean_unsigned_to_nat(0u); x_230 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_7, x_7, x_229, x_153); lean_dec(x_7); -x_231 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__5; +x_231 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__5; x_232 = lean_array_push(x_230, x_231); x_233 = l_Lean_Elab_Command_elabMacroRulesAux___closed__23; lean_inc(x_10); @@ -13085,7 +13085,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_Elab_Command_elabNoKindMacroRulesAux___closed__3; -x_2 = l___private_Init_Lean_Elab_Binders_10__expandFunBindersAux___main___closed__7; +x_2 = l___private_Init_Lean_Elab_Binders_11__expandFunBindersAux___main___closed__7; x_3 = lean_array_push(x_1, x_2); return x_3; } diff --git a/stage0/stdlib/Init/Lean/Elab/Tactic/Basic.c b/stage0/stdlib/Init/Lean/Elab/Tactic/Basic.c index e4244f6a0d..ee79abfcb6 100644 --- a/stage0/stdlib/Init/Lean/Elab/Tactic/Basic.c +++ b/stage0/stdlib/Init/Lean/Elab/Tactic/Basic.c @@ -7178,90 +7178,97 @@ return x_12; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; +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_29 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_29, 0, x_27); -lean_ctor_set(x_29, 1, x_28); -lean_ctor_set(x_29, 2, x_7); -lean_ctor_set(x_15, 2, x_29); +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_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_30 = lean_ctor_get(x_15, 0); -x_31 = lean_ctor_get(x_15, 1); -x_32 = lean_ctor_get(x_15, 3); -x_33 = lean_ctor_get(x_15, 4); -x_34 = lean_ctor_get(x_15, 5); +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +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_inc(x_30); lean_dec(x_15); -x_35 = lean_ctor_get(x_16, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_16, 1); +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); - x_37 = x_16; + lean_ctor_release(x_16, 3); + x_39 = x_16; } else { lean_dec_ref(x_16); - x_37 = lean_box(0); + x_39 = lean_box(0); } -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_39)) { + x_40 = lean_alloc_ctor(0, 4, 0); } else { - x_38 = x_37; + x_40 = x_39; } -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -lean_ctor_set(x_38, 2, x_7); -x_39 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_39, 0, x_30); -lean_ctor_set(x_39, 1, x_31); -lean_ctor_set(x_39, 2, x_38); -lean_ctor_set(x_39, 3, x_32); -lean_ctor_set(x_39, 4, x_33); -lean_ctor_set(x_39, 5, x_34); -lean_ctor_set(x_14, 0, 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_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_40 = lean_ctor_get(x_14, 1); -x_41 = lean_ctor_get(x_14, 2); -x_42 = lean_ctor_get(x_14, 3); -x_43 = lean_ctor_get(x_14, 4); -x_44 = lean_ctor_get(x_14, 5); +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_inc(x_41); -lean_inc(x_40); lean_dec(x_14); -x_45 = lean_ctor_get(x_15, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_15, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_15, 3); +x_47 = lean_ctor_get(x_15, 0); lean_inc(x_47); -x_48 = lean_ctor_get(x_15, 4); +x_48 = lean_ctor_get(x_15, 1); lean_inc(x_48); -x_49 = lean_ctor_get(x_15, 5); +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); @@ -7269,70 +7276,74 @@ if (lean_is_exclusive(x_15)) { lean_ctor_release(x_15, 3); lean_ctor_release(x_15, 4); lean_ctor_release(x_15, 5); - x_50 = x_15; + x_52 = x_15; } else { lean_dec_ref(x_15); - x_50 = lean_box(0); + x_52 = lean_box(0); } -x_51 = lean_ctor_get(x_16, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_16, 1); -lean_inc(x_52); +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); - x_53 = x_16; + lean_ctor_release(x_16, 3); + x_56 = x_16; } else { lean_dec_ref(x_16); - x_53 = lean_box(0); + x_56 = lean_box(0); } -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_54 = x_53; + x_57 = x_56; } -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_7); -if (lean_is_scalar(x_50)) { - x_55 = lean_alloc_ctor(0, 6, 0); +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_55 = x_50; + x_58 = x_52; } -lean_ctor_set(x_55, 0, x_45); -lean_ctor_set(x_55, 1, x_46); -lean_ctor_set(x_55, 2, x_54); -lean_ctor_set(x_55, 3, x_47); -lean_ctor_set(x_55, 4, x_48); -lean_ctor_set(x_55, 5, x_49); -x_56 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_56, 0, x_55); -lean_ctor_set(x_56, 1, x_40); -lean_ctor_set(x_56, 2, x_41); -lean_ctor_set(x_56, 3, x_42); -lean_ctor_set(x_56, 4, x_43); -lean_ctor_set(x_56, 5, x_44); -lean_ctor_set(x_13, 0, x_56); +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_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_57 = lean_ctor_get(x_13, 1); -lean_inc(x_57); -lean_dec(x_13); -x_58 = lean_ctor_get(x_14, 1); -lean_inc(x_58); -x_59 = lean_ctor_get(x_14, 2); -lean_inc(x_59); -x_60 = lean_ctor_get(x_14, 3); +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); -x_61 = lean_ctor_get(x_14, 4); +lean_dec(x_13); +x_61 = lean_ctor_get(x_14, 1); lean_inc(x_61); -x_62 = lean_ctor_get(x_14, 5); +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); @@ -7340,21 +7351,21 @@ if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 3); lean_ctor_release(x_14, 4); lean_ctor_release(x_14, 5); - x_63 = x_14; + x_66 = x_14; } else { lean_dec_ref(x_14); - x_63 = lean_box(0); + x_66 = lean_box(0); } -x_64 = lean_ctor_get(x_15, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_15, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_15, 3); -lean_inc(x_66); -x_67 = lean_ctor_get(x_15, 4); +x_67 = lean_ctor_get(x_15, 0); lean_inc(x_67); -x_68 = lean_ctor_get(x_15, 5); +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); @@ -7362,87 +7373,91 @@ if (lean_is_exclusive(x_15)) { lean_ctor_release(x_15, 3); lean_ctor_release(x_15, 4); lean_ctor_release(x_15, 5); - x_69 = x_15; + x_72 = x_15; } else { lean_dec_ref(x_15); - x_69 = lean_box(0); + x_72 = lean_box(0); } -x_70 = lean_ctor_get(x_16, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_16, 1); -lean_inc(x_71); +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); - x_72 = x_16; + lean_ctor_release(x_16, 3); + x_76 = x_16; } else { lean_dec_ref(x_16); - x_72 = lean_box(0); + 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_73 = lean_alloc_ctor(0, 3, 0); + x_78 = lean_alloc_ctor(0, 6, 0); } else { - x_73 = x_72; + x_78 = x_72; } -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -lean_ctor_set(x_73, 2, x_7); -if (lean_is_scalar(x_69)) { - x_74 = lean_alloc_ctor(0, 6, 0); +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_74 = x_69; + x_79 = x_66; } -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); -if (lean_is_scalar(x_63)) { - x_75 = lean_alloc_ctor(0, 6, 0); -} else { - x_75 = x_63; -} -lean_ctor_set(x_75, 0, x_74); -lean_ctor_set(x_75, 1, x_58); -lean_ctor_set(x_75, 2, x_59); -lean_ctor_set(x_75, 3, x_60); -lean_ctor_set(x_75, 4, x_61); -lean_ctor_set(x_75, 5, x_62); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_57); -lean_ctor_set(x_12, 1, x_76); +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_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_77 = lean_ctor_get(x_12, 0); -lean_inc(x_77); +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_78 = lean_ctor_get(x_13, 1); -lean_inc(x_78); +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_79 = x_13; + x_83 = x_13; } else { lean_dec_ref(x_13); - x_79 = lean_box(0); + x_83 = lean_box(0); } -x_80 = lean_ctor_get(x_14, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_14, 2); -lean_inc(x_81); -x_82 = lean_ctor_get(x_14, 3); -lean_inc(x_82); -x_83 = lean_ctor_get(x_14, 4); -lean_inc(x_83); -x_84 = lean_ctor_get(x_14, 5); +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); @@ -7450,21 +7465,21 @@ if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 3); lean_ctor_release(x_14, 4); lean_ctor_release(x_14, 5); - x_85 = x_14; + x_89 = x_14; } else { lean_dec_ref(x_14); - x_85 = lean_box(0); + x_89 = 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_15, 3); -lean_inc(x_88); -x_89 = lean_ctor_get(x_15, 4); -lean_inc(x_89); -x_90 = lean_ctor_get(x_15, 5); +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); @@ -7472,471 +7487,490 @@ if (lean_is_exclusive(x_15)) { lean_ctor_release(x_15, 3); lean_ctor_release(x_15, 4); lean_ctor_release(x_15, 5); - x_91 = x_15; + x_95 = x_15; } else { lean_dec_ref(x_15); - x_91 = lean_box(0); + x_95 = lean_box(0); } -x_92 = lean_ctor_get(x_16, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_16, 1); -lean_inc(x_93); +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); - x_94 = x_16; + lean_ctor_release(x_16, 3); + x_99 = x_16; } else { lean_dec_ref(x_16); - x_94 = lean_box(0); + x_99 = lean_box(0); } -if (lean_is_scalar(x_94)) { - x_95 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_99)) { + x_100 = lean_alloc_ctor(0, 4, 0); } else { - x_95 = x_94; + x_100 = x_99; } -lean_ctor_set(x_95, 0, x_92); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_95, 2, x_7); -if (lean_is_scalar(x_91)) { - x_96 = lean_alloc_ctor(0, 6, 0); +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_96 = x_91; + x_101 = x_95; } -lean_ctor_set(x_96, 0, x_86); -lean_ctor_set(x_96, 1, x_87); -lean_ctor_set(x_96, 2, x_95); -lean_ctor_set(x_96, 3, x_88); -lean_ctor_set(x_96, 4, x_89); -lean_ctor_set(x_96, 5, x_90); -if (lean_is_scalar(x_85)) { - x_97 = lean_alloc_ctor(0, 6, 0); +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_97 = x_85; + x_102 = x_89; } -lean_ctor_set(x_97, 0, x_96); -lean_ctor_set(x_97, 1, x_80); -lean_ctor_set(x_97, 2, x_81); -lean_ctor_set(x_97, 3, x_82); -lean_ctor_set(x_97, 4, x_83); -lean_ctor_set(x_97, 5, x_84); -if (lean_is_scalar(x_79)) { - x_98 = lean_alloc_ctor(0, 2, 0); +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_98 = x_79; + x_103 = x_83; } -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set(x_98, 1, x_78); -x_99 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_99, 0, x_77); -lean_ctor_set(x_99, 1, x_98); -return x_99; +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_100; -x_100 = !lean_is_exclusive(x_12); -if (x_100 == 0) +uint8_t x_105; +x_105 = !lean_is_exclusive(x_12); +if (x_105 == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; uint8_t x_106; -x_101 = lean_ctor_get(x_12, 1); -x_102 = l_Lean_Elab_Tactic_restore(x_101, x_11); +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_103 = lean_ctor_get(x_102, 0); -lean_inc(x_103); -lean_dec(x_102); -x_104 = lean_ctor_get(x_103, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_104, 2); -lean_inc(x_105); -x_106 = !lean_is_exclusive(x_103); -if (x_106 == 0) -{ -lean_object* x_107; uint8_t x_108; -x_107 = lean_ctor_get(x_103, 0); +x_108 = lean_ctor_get(x_107, 0); +lean_inc(x_108); lean_dec(x_107); -x_108 = !lean_is_exclusive(x_104); -if (x_108 == 0) +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_109; uint8_t x_110; -x_109 = lean_ctor_get(x_104, 2); -lean_dec(x_109); -x_110 = !lean_is_exclusive(x_105); -if (x_110 == 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_111; uint8_t x_112; -x_111 = lean_ctor_get(x_105, 2); -lean_dec(x_111); -lean_ctor_set(x_105, 2, x_7); -x_112 = !lean_is_exclusive(x_10); -if (x_112 == 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_113; -x_113 = lean_ctor_get(x_10, 0); -lean_dec(x_113); -lean_ctor_set(x_10, 0, x_103); +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_114; lean_object* x_115; -x_114 = lean_ctor_get(x_10, 1); -lean_inc(x_114); -lean_dec(x_10); -x_115 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_115, 0, x_103); -lean_ctor_set(x_115, 1, x_114); -lean_ctor_set(x_12, 1, x_115); -return x_12; -} -} -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; -x_116 = lean_ctor_get(x_105, 0); -x_117 = lean_ctor_get(x_105, 1); -lean_inc(x_117); -lean_inc(x_116); -lean_dec(x_105); -x_118 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_118, 0, x_116); -lean_ctor_set(x_118, 1, x_117); -lean_ctor_set(x_118, 2, x_7); -lean_ctor_set(x_104, 2, x_118); +lean_object* x_119; lean_object* x_120; x_119 = lean_ctor_get(x_10, 1); lean_inc(x_119); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_120 = x_10; -} else { - lean_dec_ref(x_10); - x_120 = lean_box(0); -} -if (lean_is_scalar(x_120)) { - x_121 = lean_alloc_ctor(0, 2, 0); -} else { - x_121 = x_120; -} -lean_ctor_set(x_121, 0, x_103); -lean_ctor_set(x_121, 1, x_119); -lean_ctor_set(x_12, 1, x_121); +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_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_122 = lean_ctor_get(x_104, 0); -x_123 = lean_ctor_get(x_104, 1); -x_124 = lean_ctor_get(x_104, 3); -x_125 = lean_ctor_get(x_104, 4); -x_126 = lean_ctor_get(x_104, 5); -lean_inc(x_126); -lean_inc(x_125); -lean_inc(x_124); +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_dec(x_104); -x_127 = lean_ctor_get(x_105, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_105, 1); -lean_inc(x_128); -if (lean_is_exclusive(x_105)) { - lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - lean_ctor_release(x_105, 2); - x_129 = x_105; +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_105); - x_129 = lean_box(0); + lean_dec_ref(x_10); + x_126 = lean_box(0); } -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_126)) { + x_127 = lean_alloc_ctor(0, 2, 0); } else { - x_130 = x_129; + x_127 = x_126; } -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set(x_130, 1, x_128); -lean_ctor_set(x_130, 2, x_7); -x_131 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_131, 0, x_122); -lean_ctor_set(x_131, 1, x_123); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_124); -lean_ctor_set(x_131, 4, x_125); -lean_ctor_set(x_131, 5, x_126); -lean_ctor_set(x_103, 0, x_131); -x_132 = lean_ctor_get(x_10, 1); +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); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_133 = x_10; -} else { - lean_dec_ref(x_10); - 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_103); -lean_ctor_set(x_134, 1, x_132); -lean_ctor_set(x_12, 1, x_134); -return x_12; -} -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; -x_135 = lean_ctor_get(x_103, 1); -x_136 = lean_ctor_get(x_103, 2); -x_137 = lean_ctor_get(x_103, 3); -x_138 = lean_ctor_get(x_103, 4); -x_139 = lean_ctor_get(x_103, 5); -lean_inc(x_139); -lean_inc(x_138); -lean_inc(x_137); -lean_inc(x_136); +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); -lean_dec(x_103); -x_140 = lean_ctor_get(x_104, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_104, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_104, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_104, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_104, 5); -lean_inc(x_144); -if (lean_is_exclusive(x_104)) { - lean_ctor_release(x_104, 0); - lean_ctor_release(x_104, 1); - lean_ctor_release(x_104, 2); - lean_ctor_release(x_104, 3); - lean_ctor_release(x_104, 4); - lean_ctor_release(x_104, 5); - x_145 = x_104; +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_104); - x_145 = lean_box(0); + lean_dec_ref(x_110); + x_136 = lean_box(0); } -x_146 = lean_ctor_get(x_105, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_105, 1); -lean_inc(x_147); -if (lean_is_exclusive(x_105)) { - lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - lean_ctor_release(x_105, 2); - x_148 = x_105; +if (lean_is_scalar(x_136)) { + x_137 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_105); - x_148 = lean_box(0); + x_137 = x_136; } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 3, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_146); -lean_ctor_set(x_149, 1, x_147); -lean_ctor_set(x_149, 2, x_7); -if (lean_is_scalar(x_145)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_145; -} -lean_ctor_set(x_150, 0, x_140); -lean_ctor_set(x_150, 1, x_141); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_142); -lean_ctor_set(x_150, 4, x_143); -lean_ctor_set(x_150, 5, x_144); -x_151 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_135); -lean_ctor_set(x_151, 2, x_136); -lean_ctor_set(x_151, 3, x_137); -lean_ctor_set(x_151, 4, x_138); -lean_ctor_set(x_151, 5, x_139); -x_152 = lean_ctor_get(x_10, 1); -lean_inc(x_152); +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_153 = x_10; + x_140 = x_10; } else { lean_dec_ref(x_10); - x_153 = lean_box(0); + x_140 = lean_box(0); } -if (lean_is_scalar(x_153)) { - x_154 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_140)) { + x_141 = lean_alloc_ctor(0, 2, 0); } else { - x_154 = x_153; + x_141 = x_140; } -lean_ctor_set(x_154, 0, x_151); -lean_ctor_set(x_154, 1, x_152); -lean_ctor_set(x_12, 1, x_154); +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_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; 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_155 = lean_ctor_get(x_12, 0); -x_156 = lean_ctor_get(x_12, 1); -lean_inc(x_156); +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_inc(x_155); -lean_dec(x_12); -x_157 = l_Lean_Elab_Tactic_restore(x_156, x_11); -lean_dec(x_11); -x_158 = lean_ctor_get(x_157, 0); -lean_inc(x_158); -lean_dec(x_157); -x_159 = lean_ctor_get(x_158, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_159, 2); +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); +} +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); -x_161 = lean_ctor_get(x_158, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_158, 2); -lean_inc(x_162); -x_163 = lean_ctor_get(x_158, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_158, 4); -lean_inc(x_164); -x_165 = lean_ctor_get(x_158, 5); -lean_inc(x_165); -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); - lean_ctor_release(x_158, 4); - lean_ctor_release(x_158, 5); - x_166 = x_158; -} else { - lean_dec_ref(x_158); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_159, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_159, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_159, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_159, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_159, 5); -lean_inc(x_171); -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); - lean_ctor_release(x_159, 5); - x_172 = x_159; -} else { - lean_dec_ref(x_159); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_160, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_160, 1); -lean_inc(x_174); -if (lean_is_exclusive(x_160)) { - lean_ctor_release(x_160, 0); - lean_ctor_release(x_160, 1); - lean_ctor_release(x_160, 2); - x_175 = x_160; -} else { - lean_dec_ref(x_160); - x_175 = lean_box(0); -} -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_7); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 6, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_177); -lean_ctor_set(x_178, 1, x_161); -lean_ctor_set(x_178, 2, x_162); -lean_ctor_set(x_178, 3, x_163); -lean_ctor_set(x_178, 4, x_164); -lean_ctor_set(x_178, 5, x_165); -x_179 = lean_ctor_get(x_10, 1); -lean_inc(x_179); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); - x_180 = x_10; + 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_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); } -if (lean_is_scalar(x_180)) { - x_181 = lean_alloc_ctor(0, 2, 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 { - x_181 = x_180; + lean_dec_ref(x_168); + x_184 = lean_box(0); } -lean_ctor_set(x_181, 0, x_178); -lean_ctor_set(x_181, 1, x_179); -x_182 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_182, 0, x_155); -lean_ctor_set(x_182, 1, x_181); -return x_182; +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_183; +uint8_t x_192; lean_dec(x_7); lean_dec(x_2); lean_dec(x_1); -x_183 = !lean_is_exclusive(x_9); -if (x_183 == 0) +x_192 = !lean_is_exclusive(x_9); +if (x_192 == 0) { return x_9; } else { -lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_184 = lean_ctor_get(x_9, 0); -x_185 = lean_ctor_get(x_9, 1); -lean_inc(x_185); -lean_inc(x_184); +lean_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_dec(x_9); -x_186 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_186, 0, x_184); -lean_ctor_set(x_186, 1, x_185); -return x_186; +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; } } } @@ -8032,90 +8066,97 @@ return x_14; } else { -lean_object* x_29; lean_object* x_30; lean_object* x_31; +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_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -lean_ctor_set(x_31, 2, x_9); -lean_ctor_set(x_17, 2, x_31); +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_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_32 = lean_ctor_get(x_17, 0); -x_33 = lean_ctor_get(x_17, 1); -x_34 = lean_ctor_get(x_17, 3); -x_35 = lean_ctor_get(x_17, 4); -x_36 = lean_ctor_get(x_17, 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; +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_inc(x_32); lean_dec(x_17); -x_37 = lean_ctor_get(x_18, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_18, 1); +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); - x_39 = x_18; + lean_ctor_release(x_18, 3); + x_41 = x_18; } else { lean_dec_ref(x_18); - x_39 = lean_box(0); + x_41 = lean_box(0); } -if (lean_is_scalar(x_39)) { - x_40 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_41)) { + x_42 = lean_alloc_ctor(0, 4, 0); } else { - x_40 = x_39; + x_42 = x_41; } -lean_ctor_set(x_40, 0, x_37); -lean_ctor_set(x_40, 1, x_38); -lean_ctor_set(x_40, 2, x_9); -x_41 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_41, 0, x_32); -lean_ctor_set(x_41, 1, x_33); -lean_ctor_set(x_41, 2, x_40); -lean_ctor_set(x_41, 3, x_34); -lean_ctor_set(x_41, 4, x_35); -lean_ctor_set(x_41, 5, x_36); -lean_ctor_set(x_16, 0, 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_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_42 = lean_ctor_get(x_16, 1); -x_43 = lean_ctor_get(x_16, 2); -x_44 = lean_ctor_get(x_16, 3); -x_45 = lean_ctor_get(x_16, 4); -x_46 = lean_ctor_get(x_16, 5); +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_43); -lean_inc(x_42); lean_dec(x_16); -x_47 = lean_ctor_get(x_17, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_17, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_17, 3); +x_49 = lean_ctor_get(x_17, 0); lean_inc(x_49); -x_50 = lean_ctor_get(x_17, 4); +x_50 = lean_ctor_get(x_17, 1); lean_inc(x_50); -x_51 = lean_ctor_get(x_17, 5); +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); @@ -8123,70 +8164,74 @@ if (lean_is_exclusive(x_17)) { lean_ctor_release(x_17, 3); lean_ctor_release(x_17, 4); lean_ctor_release(x_17, 5); - x_52 = x_17; + x_54 = x_17; } else { lean_dec_ref(x_17); - x_52 = lean_box(0); + x_54 = lean_box(0); } -x_53 = lean_ctor_get(x_18, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_18, 1); -lean_inc(x_54); +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); - x_55 = x_18; + lean_ctor_release(x_18, 3); + x_58 = x_18; } else { lean_dec_ref(x_18); - x_55 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_55)) { - x_56 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 4, 0); } else { - x_56 = x_55; + x_59 = x_58; } -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_9); -if (lean_is_scalar(x_52)) { - x_57 = lean_alloc_ctor(0, 6, 0); +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_57 = x_52; + x_60 = x_54; } -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); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_42); -lean_ctor_set(x_58, 2, x_43); -lean_ctor_set(x_58, 3, x_44); -lean_ctor_set(x_58, 4, x_45); -lean_ctor_set(x_58, 5, x_46); -lean_ctor_set(x_15, 0, x_58); +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_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; -x_59 = lean_ctor_get(x_15, 1); -lean_inc(x_59); -lean_dec(x_15); -x_60 = lean_ctor_get(x_16, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_16, 2); -lean_inc(x_61); -x_62 = lean_ctor_get(x_16, 3); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_62 = lean_ctor_get(x_15, 1); lean_inc(x_62); -x_63 = lean_ctor_get(x_16, 4); +lean_dec(x_15); +x_63 = lean_ctor_get(x_16, 1); lean_inc(x_63); -x_64 = lean_ctor_get(x_16, 5); +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); @@ -8194,21 +8239,21 @@ if (lean_is_exclusive(x_16)) { lean_ctor_release(x_16, 3); lean_ctor_release(x_16, 4); lean_ctor_release(x_16, 5); - x_65 = x_16; + x_68 = x_16; } else { lean_dec_ref(x_16); - x_65 = lean_box(0); + x_68 = lean_box(0); } -x_66 = lean_ctor_get(x_17, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_17, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_17, 3); -lean_inc(x_68); -x_69 = lean_ctor_get(x_17, 4); +x_69 = lean_ctor_get(x_17, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_17, 5); +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); @@ -8216,87 +8261,91 @@ if (lean_is_exclusive(x_17)) { lean_ctor_release(x_17, 3); lean_ctor_release(x_17, 4); lean_ctor_release(x_17, 5); - x_71 = x_17; + x_74 = x_17; } else { lean_dec_ref(x_17); - x_71 = lean_box(0); + x_74 = lean_box(0); } -x_72 = lean_ctor_get(x_18, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_18, 1); -lean_inc(x_73); +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); - x_74 = x_18; + lean_ctor_release(x_18, 3); + x_78 = x_18; } else { lean_dec_ref(x_18); - x_74 = lean_box(0); + 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_75 = lean_alloc_ctor(0, 3, 0); + x_80 = lean_alloc_ctor(0, 6, 0); } else { - x_75 = x_74; + x_80 = x_74; } -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_9); -if (lean_is_scalar(x_71)) { - x_76 = lean_alloc_ctor(0, 6, 0); +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_76 = x_71; + x_81 = x_68; } -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_67); -lean_ctor_set(x_76, 2, x_75); -lean_ctor_set(x_76, 3, x_68); -lean_ctor_set(x_76, 4, x_69); -lean_ctor_set(x_76, 5, x_70); -if (lean_is_scalar(x_65)) { - x_77 = lean_alloc_ctor(0, 6, 0); -} else { - x_77 = x_65; -} -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_60); -lean_ctor_set(x_77, 2, x_61); -lean_ctor_set(x_77, 3, x_62); -lean_ctor_set(x_77, 4, x_63); -lean_ctor_set(x_77, 5, x_64); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_59); -lean_ctor_set(x_14, 1, x_78); +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_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_79 = lean_ctor_get(x_14, 0); -lean_inc(x_79); +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_80 = lean_ctor_get(x_15, 1); -lean_inc(x_80); +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_81 = x_15; + x_85 = x_15; } else { lean_dec_ref(x_15); - x_81 = lean_box(0); + x_85 = lean_box(0); } -x_82 = lean_ctor_get(x_16, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_16, 2); -lean_inc(x_83); -x_84 = lean_ctor_get(x_16, 3); -lean_inc(x_84); -x_85 = lean_ctor_get(x_16, 4); -lean_inc(x_85); -x_86 = lean_ctor_get(x_16, 5); +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); @@ -8304,21 +8353,21 @@ if (lean_is_exclusive(x_16)) { lean_ctor_release(x_16, 3); lean_ctor_release(x_16, 4); lean_ctor_release(x_16, 5); - x_87 = x_16; + x_91 = x_16; } else { lean_dec_ref(x_16); - x_87 = lean_box(0); + x_91 = lean_box(0); } -x_88 = lean_ctor_get(x_17, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_17, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_17, 3); -lean_inc(x_90); -x_91 = lean_ctor_get(x_17, 4); -lean_inc(x_91); -x_92 = lean_ctor_get(x_17, 5); +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); @@ -8326,471 +8375,490 @@ if (lean_is_exclusive(x_17)) { lean_ctor_release(x_17, 3); lean_ctor_release(x_17, 4); lean_ctor_release(x_17, 5); - x_93 = x_17; + x_97 = x_17; } else { lean_dec_ref(x_17); - x_93 = lean_box(0); + x_97 = lean_box(0); } -x_94 = lean_ctor_get(x_18, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_18, 1); -lean_inc(x_95); +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); - x_96 = x_18; + lean_ctor_release(x_18, 3); + x_101 = x_18; } else { lean_dec_ref(x_18); - x_96 = lean_box(0); + x_101 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_101)) { + x_102 = lean_alloc_ctor(0, 4, 0); } else { - x_97 = x_96; + x_102 = x_101; } -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_9); -if (lean_is_scalar(x_93)) { - x_98 = lean_alloc_ctor(0, 6, 0); +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_98 = x_93; + x_103 = x_97; } -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); -if (lean_is_scalar(x_87)) { - x_99 = lean_alloc_ctor(0, 6, 0); +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_99 = x_87; + x_104 = x_91; } -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); -if (lean_is_scalar(x_81)) { - x_100 = lean_alloc_ctor(0, 2, 0); +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_100 = x_81; + x_105 = x_85; } -lean_ctor_set(x_100, 0, x_99); -lean_ctor_set(x_100, 1, x_80); -x_101 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_101, 0, x_79); -lean_ctor_set(x_101, 1, x_100); -return x_101; +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_102; -x_102 = !lean_is_exclusive(x_14); -if (x_102 == 0) +uint8_t x_107; +x_107 = !lean_is_exclusive(x_14); +if (x_107 == 0) { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; uint8_t x_108; -x_103 = lean_ctor_get(x_14, 1); -x_104 = l_Lean_Elab_Tactic_restore(x_103, x_13); +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_105 = lean_ctor_get(x_104, 0); -lean_inc(x_105); -lean_dec(x_104); -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_is_exclusive(x_105); -if (x_108 == 0) -{ -lean_object* x_109; uint8_t x_110; -x_109 = lean_ctor_get(x_105, 0); +x_110 = lean_ctor_get(x_109, 0); +lean_inc(x_110); lean_dec(x_109); -x_110 = !lean_is_exclusive(x_106); -if (x_110 == 0) +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_111; uint8_t x_112; -x_111 = lean_ctor_get(x_106, 2); -lean_dec(x_111); -x_112 = !lean_is_exclusive(x_107); -if (x_112 == 0) +lean_object* x_114; uint8_t x_115; +x_114 = lean_ctor_get(x_110, 0); +lean_dec(x_114); +x_115 = !lean_is_exclusive(x_111); +if (x_115 == 0) { -lean_object* x_113; uint8_t x_114; -x_113 = lean_ctor_get(x_107, 2); -lean_dec(x_113); -lean_ctor_set(x_107, 2, x_9); -x_114 = !lean_is_exclusive(x_12); -if (x_114 == 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_115; -x_115 = lean_ctor_get(x_12, 0); -lean_dec(x_115); -lean_ctor_set(x_12, 0, x_105); +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_116; lean_object* x_117; -x_116 = lean_ctor_get(x_12, 1); -lean_inc(x_116); -lean_dec(x_12); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_105); -lean_ctor_set(x_117, 1, x_116); -lean_ctor_set(x_14, 1, x_117); -return x_14; -} -} -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; -x_118 = lean_ctor_get(x_107, 0); -x_119 = lean_ctor_get(x_107, 1); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_107); -x_120 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_120, 0, x_118); -lean_ctor_set(x_120, 1, x_119); -lean_ctor_set(x_120, 2, x_9); -lean_ctor_set(x_106, 2, x_120); +lean_object* x_121; lean_object* x_122; x_121 = lean_ctor_get(x_12, 1); lean_inc(x_121); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_122 = x_12; -} else { - lean_dec_ref(x_12); - x_122 = lean_box(0); -} -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(0, 2, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_105); -lean_ctor_set(x_123, 1, x_121); -lean_ctor_set(x_14, 1, x_123); +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_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_124 = lean_ctor_get(x_106, 0); -x_125 = lean_ctor_get(x_106, 1); -x_126 = lean_ctor_get(x_106, 3); -x_127 = lean_ctor_get(x_106, 4); -x_128 = lean_ctor_get(x_106, 5); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_126); +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_dec(x_106); -x_129 = lean_ctor_get(x_107, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_107, 1); -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); - x_131 = x_107; +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_107); - x_131 = lean_box(0); + lean_dec_ref(x_12); + x_128 = lean_box(0); } -if (lean_is_scalar(x_131)) { - x_132 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_128)) { + x_129 = lean_alloc_ctor(0, 2, 0); } else { - x_132 = x_131; + x_129 = x_128; } -lean_ctor_set(x_132, 0, x_129); -lean_ctor_set(x_132, 1, x_130); -lean_ctor_set(x_132, 2, x_9); -x_133 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_133, 0, x_124); -lean_ctor_set(x_133, 1, x_125); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_126); -lean_ctor_set(x_133, 4, x_127); -lean_ctor_set(x_133, 5, x_128); -lean_ctor_set(x_105, 0, x_133); -x_134 = lean_ctor_get(x_12, 1); +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); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - x_135 = x_12; -} else { - lean_dec_ref(x_12); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 2, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_105); -lean_ctor_set(x_136, 1, x_134); -lean_ctor_set(x_14, 1, x_136); -return x_14; -} -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; -x_137 = lean_ctor_get(x_105, 1); -x_138 = lean_ctor_get(x_105, 2); -x_139 = lean_ctor_get(x_105, 3); -x_140 = lean_ctor_get(x_105, 4); -x_141 = lean_ctor_get(x_105, 5); -lean_inc(x_141); -lean_inc(x_140); -lean_inc(x_139); -lean_inc(x_138); +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); -lean_dec(x_105); -x_142 = lean_ctor_get(x_106, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_106, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_106, 3); -lean_inc(x_144); -x_145 = lean_ctor_get(x_106, 4); -lean_inc(x_145); -x_146 = lean_ctor_get(x_106, 5); -lean_inc(x_146); -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_147 = x_106; +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_106); - x_147 = lean_box(0); + lean_dec_ref(x_112); + x_138 = lean_box(0); } -x_148 = lean_ctor_get(x_107, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_107, 1); -lean_inc(x_149); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - x_150 = x_107; +if (lean_is_scalar(x_138)) { + x_139 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_107); - x_150 = lean_box(0); + x_139 = x_138; } -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 3, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -lean_ctor_set(x_151, 2, x_9); -if (lean_is_scalar(x_147)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_147; -} -lean_ctor_set(x_152, 0, x_142); -lean_ctor_set(x_152, 1, x_143); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_144); -lean_ctor_set(x_152, 4, x_145); -lean_ctor_set(x_152, 5, x_146); -x_153 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_153, 0, x_152); -lean_ctor_set(x_153, 1, x_137); -lean_ctor_set(x_153, 2, x_138); -lean_ctor_set(x_153, 3, x_139); -lean_ctor_set(x_153, 4, x_140); -lean_ctor_set(x_153, 5, x_141); -x_154 = lean_ctor_get(x_12, 1); -lean_inc(x_154); +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_155 = x_12; + x_142 = x_12; } else { lean_dec_ref(x_12); - x_155 = lean_box(0); + x_142 = lean_box(0); } -if (lean_is_scalar(x_155)) { - x_156 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_142)) { + x_143 = lean_alloc_ctor(0, 2, 0); } else { - x_156 = x_155; + x_143 = x_142; } -lean_ctor_set(x_156, 0, x_153); -lean_ctor_set(x_156, 1, x_154); -lean_ctor_set(x_14, 1, x_156); +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_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; 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_157 = lean_ctor_get(x_14, 0); -x_158 = lean_ctor_get(x_14, 1); -lean_inc(x_158); +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_inc(x_157); -lean_dec(x_14); -x_159 = l_Lean_Elab_Tactic_restore(x_158, x_13); -lean_dec(x_13); -x_160 = lean_ctor_get(x_159, 0); -lean_inc(x_160); -lean_dec(x_159); -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_161, 2); +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); +} +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); -x_163 = lean_ctor_get(x_160, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_160, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_160, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_160, 5); -lean_inc(x_167); -if (lean_is_exclusive(x_160)) { - lean_ctor_release(x_160, 0); - lean_ctor_release(x_160, 1); - lean_ctor_release(x_160, 2); - lean_ctor_release(x_160, 3); - lean_ctor_release(x_160, 4); - lean_ctor_release(x_160, 5); - x_168 = x_160; -} else { - lean_dec_ref(x_160); - x_168 = lean_box(0); -} -x_169 = lean_ctor_get(x_161, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_161, 1); -lean_inc(x_170); -x_171 = lean_ctor_get(x_161, 3); -lean_inc(x_171); -x_172 = lean_ctor_get(x_161, 4); -lean_inc(x_172); -x_173 = lean_ctor_get(x_161, 5); -lean_inc(x_173); -if (lean_is_exclusive(x_161)) { - lean_ctor_release(x_161, 0); - lean_ctor_release(x_161, 1); - lean_ctor_release(x_161, 2); - lean_ctor_release(x_161, 3); - lean_ctor_release(x_161, 4); - lean_ctor_release(x_161, 5); - x_174 = x_161; -} else { - lean_dec_ref(x_161); - x_174 = lean_box(0); -} -x_175 = lean_ctor_get(x_162, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_162, 1); -lean_inc(x_176); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - lean_ctor_release(x_162, 2); - x_177 = x_162; -} else { - lean_dec_ref(x_162); - x_177 = lean_box(0); -} -if (lean_is_scalar(x_177)) { - x_178 = lean_alloc_ctor(0, 3, 0); -} else { - x_178 = x_177; -} -lean_ctor_set(x_178, 0, x_175); -lean_ctor_set(x_178, 1, x_176); -lean_ctor_set(x_178, 2, x_9); -if (lean_is_scalar(x_174)) { - x_179 = lean_alloc_ctor(0, 6, 0); -} else { - x_179 = x_174; -} -lean_ctor_set(x_179, 0, x_169); -lean_ctor_set(x_179, 1, x_170); -lean_ctor_set(x_179, 2, x_178); -lean_ctor_set(x_179, 3, x_171); -lean_ctor_set(x_179, 4, x_172); -lean_ctor_set(x_179, 5, x_173); -if (lean_is_scalar(x_168)) { - x_180 = lean_alloc_ctor(0, 6, 0); -} else { - x_180 = x_168; -} -lean_ctor_set(x_180, 0, x_179); -lean_ctor_set(x_180, 1, x_163); -lean_ctor_set(x_180, 2, x_164); -lean_ctor_set(x_180, 3, x_165); -lean_ctor_set(x_180, 4, x_166); -lean_ctor_set(x_180, 5, x_167); -x_181 = lean_ctor_get(x_12, 1); -lean_inc(x_181); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); - x_182 = x_12; + 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_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); } -if (lean_is_scalar(x_182)) { - x_183 = lean_alloc_ctor(0, 2, 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 { - x_183 = x_182; + lean_dec_ref(x_170); + x_186 = lean_box(0); } -lean_ctor_set(x_183, 0, x_180); -lean_ctor_set(x_183, 1, x_181); -x_184 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_184, 0, x_157); -lean_ctor_set(x_184, 1, x_183); -return x_184; +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_185; +uint8_t x_194; lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_185 = !lean_is_exclusive(x_11); -if (x_185 == 0) +x_194 = !lean_is_exclusive(x_11); +if (x_194 == 0) { return x_11; } else { -lean_object* x_186; lean_object* x_187; lean_object* x_188; -x_186 = lean_ctor_get(x_11, 0); -x_187 = lean_ctor_get(x_11, 1); -lean_inc(x_187); -lean_inc(x_186); +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_dec(x_11); -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; +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; } } } @@ -9002,90 +9070,97 @@ return x_35; } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; +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_52 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -lean_ctor_set(x_52, 2, x_30); -lean_ctor_set(x_38, 2, x_52); +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; } } 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_38, 0); -x_54 = lean_ctor_get(x_38, 1); -x_55 = lean_ctor_get(x_38, 3); -x_56 = lean_ctor_get(x_38, 4); -x_57 = lean_ctor_get(x_38, 5); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +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_inc(x_56); lean_inc(x_55); lean_inc(x_54); -lean_inc(x_53); lean_dec(x_38); -x_58 = lean_ctor_get(x_39, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_39, 1); +x_59 = lean_ctor_get(x_39, 0); 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); - x_60 = x_39; + lean_ctor_release(x_39, 3); + x_62 = x_39; } else { lean_dec_ref(x_39); - x_60 = lean_box(0); + x_62 = lean_box(0); } -if (lean_is_scalar(x_60)) { - x_61 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 4, 0); } else { - x_61 = x_60; + x_63 = x_62; } -lean_ctor_set(x_61, 0, x_58); -lean_ctor_set(x_61, 1, x_59); -lean_ctor_set(x_61, 2, x_30); -x_62 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_62, 0, x_53); -lean_ctor_set(x_62, 1, x_54); -lean_ctor_set(x_62, 2, x_61); -lean_ctor_set(x_62, 3, x_55); -lean_ctor_set(x_62, 4, x_56); -lean_ctor_set(x_62, 5, x_57); -lean_ctor_set(x_37, 0, 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_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; } } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; 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_63 = lean_ctor_get(x_37, 1); -x_64 = lean_ctor_get(x_37, 2); -x_65 = lean_ctor_get(x_37, 3); -x_66 = lean_ctor_get(x_37, 4); -x_67 = lean_ctor_get(x_37, 5); +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_inc(x_68); lean_inc(x_67); lean_inc(x_66); lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); lean_dec(x_37); -x_68 = lean_ctor_get(x_38, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_38, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_38, 3); +x_70 = lean_ctor_get(x_38, 0); lean_inc(x_70); -x_71 = lean_ctor_get(x_38, 4); +x_71 = lean_ctor_get(x_38, 1); lean_inc(x_71); -x_72 = lean_ctor_get(x_38, 5); +x_72 = lean_ctor_get(x_38, 3); lean_inc(x_72); +x_73 = lean_ctor_get(x_38, 4); +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); @@ -9093,70 +9168,74 @@ if (lean_is_exclusive(x_38)) { lean_ctor_release(x_38, 3); lean_ctor_release(x_38, 4); lean_ctor_release(x_38, 5); - x_73 = x_38; + x_75 = x_38; } else { lean_dec_ref(x_38); - x_73 = lean_box(0); + x_75 = lean_box(0); } -x_74 = lean_ctor_get(x_39, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_39, 1); -lean_inc(x_75); +x_76 = lean_ctor_get(x_39, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_39, 1); +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); - x_76 = x_39; + lean_ctor_release(x_39, 3); + x_79 = x_39; } else { lean_dec_ref(x_39); - x_76 = lean_box(0); + x_79 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 4, 0); } else { - x_77 = x_76; + x_80 = x_79; } -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_75); -lean_ctor_set(x_77, 2, x_30); -if (lean_is_scalar(x_73)) { - x_78 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_78 = x_73; + x_81 = x_75; } -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); -x_79 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_63); -lean_ctor_set(x_79, 2, x_64); -lean_ctor_set(x_79, 3, x_65); -lean_ctor_set(x_79, 4, x_66); -lean_ctor_set(x_79, 5, x_67); -lean_ctor_set(x_36, 0, x_79); +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; } } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; 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_80 = lean_ctor_get(x_36, 1); -lean_inc(x_80); -lean_dec(x_36); -x_81 = lean_ctor_get(x_37, 1); -lean_inc(x_81); -x_82 = lean_ctor_get(x_37, 2); -lean_inc(x_82); -x_83 = lean_ctor_get(x_37, 3); +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_inc(x_83); -x_84 = lean_ctor_get(x_37, 4); +lean_dec(x_36); +x_84 = lean_ctor_get(x_37, 1); lean_inc(x_84); -x_85 = lean_ctor_get(x_37, 5); +x_85 = lean_ctor_get(x_37, 2); lean_inc(x_85); +x_86 = lean_ctor_get(x_37, 3); +lean_inc(x_86); +x_87 = lean_ctor_get(x_37, 4); +lean_inc(x_87); +x_88 = lean_ctor_get(x_37, 5); +lean_inc(x_88); if (lean_is_exclusive(x_37)) { lean_ctor_release(x_37, 0); lean_ctor_release(x_37, 1); @@ -9164,21 +9243,21 @@ if (lean_is_exclusive(x_37)) { lean_ctor_release(x_37, 3); lean_ctor_release(x_37, 4); lean_ctor_release(x_37, 5); - x_86 = x_37; + x_89 = x_37; } else { lean_dec_ref(x_37); - x_86 = lean_box(0); + x_89 = lean_box(0); } -x_87 = lean_ctor_get(x_38, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_38, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_38, 3); -lean_inc(x_89); -x_90 = lean_ctor_get(x_38, 4); +x_90 = lean_ctor_get(x_38, 0); lean_inc(x_90); -x_91 = lean_ctor_get(x_38, 5); +x_91 = lean_ctor_get(x_38, 1); lean_inc(x_91); +x_92 = lean_ctor_get(x_38, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_38, 4); +lean_inc(x_93); +x_94 = lean_ctor_get(x_38, 5); +lean_inc(x_94); if (lean_is_exclusive(x_38)) { lean_ctor_release(x_38, 0); lean_ctor_release(x_38, 1); @@ -9186,87 +9265,91 @@ if (lean_is_exclusive(x_38)) { lean_ctor_release(x_38, 3); lean_ctor_release(x_38, 4); lean_ctor_release(x_38, 5); - x_92 = x_38; + x_95 = x_38; } else { lean_dec_ref(x_38); - x_92 = lean_box(0); + x_95 = lean_box(0); } -x_93 = lean_ctor_get(x_39, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_39, 1); -lean_inc(x_94); +x_96 = lean_ctor_get(x_39, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_39, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_39, 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); - x_95 = x_39; + lean_ctor_release(x_39, 3); + x_99 = x_39; } else { lean_dec_ref(x_39); - x_95 = lean_box(0); + 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_30); +lean_ctor_set(x_100, 3, x_98); if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 3, 0); + x_101 = lean_alloc_ctor(0, 6, 0); } else { - x_96 = x_95; + x_101 = x_95; } -lean_ctor_set(x_96, 0, x_93); -lean_ctor_set(x_96, 1, x_94); -lean_ctor_set(x_96, 2, x_30); -if (lean_is_scalar(x_92)) { - x_97 = lean_alloc_ctor(0, 6, 0); +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_97 = x_92; + x_102 = x_89; } -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); -if (lean_is_scalar(x_86)) { - x_98 = lean_alloc_ctor(0, 6, 0); -} else { - x_98 = x_86; -} -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set(x_98, 1, x_81); -lean_ctor_set(x_98, 2, x_82); -lean_ctor_set(x_98, 3, x_83); -lean_ctor_set(x_98, 4, x_84); -lean_ctor_set(x_98, 5, x_85); -x_99 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_99, 0, x_98); -lean_ctor_set(x_99, 1, x_80); -lean_ctor_set(x_35, 1, x_99); +lean_ctor_set(x_102, 0, x_101); +lean_ctor_set(x_102, 1, x_84); +lean_ctor_set(x_102, 2, x_85); +lean_ctor_set(x_102, 3, x_86); +lean_ctor_set(x_102, 4, x_87); +lean_ctor_set(x_102, 5, x_88); +x_103 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_103, 0, x_102); +lean_ctor_set(x_103, 1, x_83); +lean_ctor_set(x_35, 1, x_103); return x_35; } } else { -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_100 = lean_ctor_get(x_35, 0); -lean_inc(x_100); +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_101 = lean_ctor_get(x_36, 1); -lean_inc(x_101); +x_105 = lean_ctor_get(x_36, 1); +lean_inc(x_105); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); - x_102 = x_36; + x_106 = x_36; } else { lean_dec_ref(x_36); - x_102 = lean_box(0); + x_106 = lean_box(0); } -x_103 = lean_ctor_get(x_37, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_37, 2); -lean_inc(x_104); -x_105 = lean_ctor_get(x_37, 3); -lean_inc(x_105); -x_106 = lean_ctor_get(x_37, 4); -lean_inc(x_106); -x_107 = lean_ctor_get(x_37, 5); +x_107 = lean_ctor_get(x_37, 1); lean_inc(x_107); +x_108 = lean_ctor_get(x_37, 2); +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); @@ -9274,21 +9357,21 @@ if (lean_is_exclusive(x_37)) { lean_ctor_release(x_37, 3); lean_ctor_release(x_37, 4); lean_ctor_release(x_37, 5); - x_108 = x_37; + x_112 = x_37; } else { lean_dec_ref(x_37); - x_108 = lean_box(0); + x_112 = lean_box(0); } -x_109 = lean_ctor_get(x_38, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_38, 1); -lean_inc(x_110); -x_111 = lean_ctor_get(x_38, 3); -lean_inc(x_111); -x_112 = lean_ctor_get(x_38, 4); -lean_inc(x_112); -x_113 = lean_ctor_get(x_38, 5); +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); @@ -9296,471 +9379,490 @@ if (lean_is_exclusive(x_38)) { lean_ctor_release(x_38, 3); lean_ctor_release(x_38, 4); lean_ctor_release(x_38, 5); - x_114 = x_38; + x_118 = x_38; } else { lean_dec_ref(x_38); - x_114 = lean_box(0); + x_118 = lean_box(0); } -x_115 = lean_ctor_get(x_39, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_39, 1); -lean_inc(x_116); +x_119 = lean_ctor_get(x_39, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_39, 1); +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); - x_117 = x_39; + lean_ctor_release(x_39, 3); + x_122 = x_39; } else { lean_dec_ref(x_39); - x_117 = lean_box(0); + x_122 = lean_box(0); } -if (lean_is_scalar(x_117)) { - x_118 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_122)) { + x_123 = lean_alloc_ctor(0, 4, 0); } else { - x_118 = x_117; + x_123 = x_122; } -lean_ctor_set(x_118, 0, x_115); -lean_ctor_set(x_118, 1, x_116); -lean_ctor_set(x_118, 2, x_30); -if (lean_is_scalar(x_114)) { - x_119 = lean_alloc_ctor(0, 6, 0); +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_119 = x_114; + x_124 = x_118; } -lean_ctor_set(x_119, 0, x_109); -lean_ctor_set(x_119, 1, x_110); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_111); -lean_ctor_set(x_119, 4, x_112); -lean_ctor_set(x_119, 5, x_113); -if (lean_is_scalar(x_108)) { - x_120 = lean_alloc_ctor(0, 6, 0); +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_120 = x_108; + x_125 = x_112; } -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); -if (lean_is_scalar(x_102)) { - x_121 = lean_alloc_ctor(0, 2, 0); +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_121 = x_102; + x_126 = x_106; } -lean_ctor_set(x_121, 0, x_120); -lean_ctor_set(x_121, 1, x_101); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_100); -lean_ctor_set(x_122, 1, x_121); -return x_122; +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; } } else { -uint8_t x_123; -x_123 = !lean_is_exclusive(x_35); -if (x_123 == 0) +uint8_t x_128; +x_128 = !lean_is_exclusive(x_35); +if (x_128 == 0) { -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; uint8_t x_129; -x_124 = lean_ctor_get(x_35, 1); -x_125 = l_Lean_Elab_Tactic_restore(x_124, x_34); +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_126 = lean_ctor_get(x_125, 0); -lean_inc(x_126); -lean_dec(x_125); -x_127 = lean_ctor_get(x_126, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = !lean_is_exclusive(x_126); -if (x_129 == 0) -{ -lean_object* x_130; uint8_t x_131; -x_130 = lean_ctor_get(x_126, 0); +x_131 = lean_ctor_get(x_130, 0); +lean_inc(x_131); lean_dec(x_130); -x_131 = !lean_is_exclusive(x_127); -if (x_131 == 0) +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_132; uint8_t x_133; -x_132 = lean_ctor_get(x_127, 2); -lean_dec(x_132); -x_133 = !lean_is_exclusive(x_128); -if (x_133 == 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_134; uint8_t x_135; -x_134 = lean_ctor_get(x_128, 2); -lean_dec(x_134); -lean_ctor_set(x_128, 2, x_30); -x_135 = !lean_is_exclusive(x_33); -if (x_135 == 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_136; -x_136 = lean_ctor_get(x_33, 0); -lean_dec(x_136); -lean_ctor_set(x_33, 0, x_126); +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; } else { -lean_object* x_137; lean_object* x_138; -x_137 = lean_ctor_get(x_33, 1); -lean_inc(x_137); -lean_dec(x_33); -x_138 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_138, 0, x_126); -lean_ctor_set(x_138, 1, x_137); -lean_ctor_set(x_35, 1, x_138); -return x_35; -} -} -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; -x_139 = lean_ctor_get(x_128, 0); -x_140 = lean_ctor_get(x_128, 1); -lean_inc(x_140); -lean_inc(x_139); -lean_dec(x_128); -x_141 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_141, 0, x_139); -lean_ctor_set(x_141, 1, x_140); -lean_ctor_set(x_141, 2, x_30); -lean_ctor_set(x_127, 2, x_141); +lean_object* x_142; lean_object* x_143; x_142 = lean_ctor_get(x_33, 1); lean_inc(x_142); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_143 = x_33; -} else { - lean_dec_ref(x_33); - x_143 = lean_box(0); -} -if (lean_is_scalar(x_143)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_143; -} -lean_ctor_set(x_144, 0, x_126); -lean_ctor_set(x_144, 1, x_142); -lean_ctor_set(x_35, 1, x_144); +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_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_145 = lean_ctor_get(x_127, 0); -x_146 = lean_ctor_get(x_127, 1); -x_147 = lean_ctor_get(x_127, 3); -x_148 = lean_ctor_get(x_127, 4); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); +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); -lean_dec(x_127); -x_150 = lean_ctor_get(x_128, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_128, 1); -lean_inc(x_151); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - x_152 = x_128; +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; } else { - lean_dec_ref(x_128); - x_152 = lean_box(0); + lean_dec_ref(x_33); + x_149 = lean_box(0); } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_149)) { + x_150 = lean_alloc_ctor(0, 2, 0); } else { - x_153 = x_152; + x_150 = x_149; } -lean_ctor_set(x_153, 0, x_150); -lean_ctor_set(x_153, 1, x_151); -lean_ctor_set(x_153, 2, x_30); -x_154 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_154, 0, x_145); -lean_ctor_set(x_154, 1, x_146); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_147); -lean_ctor_set(x_154, 4, x_148); -lean_ctor_set(x_154, 5, x_149); -lean_ctor_set(x_126, 0, x_154); -x_155 = lean_ctor_get(x_33, 1); +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; +} +} +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); -if (lean_is_exclusive(x_33)) { - lean_ctor_release(x_33, 0); - lean_ctor_release(x_33, 1); - x_156 = x_33; -} else { - lean_dec_ref(x_33); - x_156 = lean_box(0); -} -if (lean_is_scalar(x_156)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_156; -} -lean_ctor_set(x_157, 0, x_126); -lean_ctor_set(x_157, 1, x_155); -lean_ctor_set(x_35, 1, x_157); -return x_35; -} -} -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; lean_object* x_176; lean_object* x_177; -x_158 = lean_ctor_get(x_126, 1); -x_159 = lean_ctor_get(x_126, 2); -x_160 = lean_ctor_get(x_126, 3); -x_161 = lean_ctor_get(x_126, 4); -x_162 = lean_ctor_get(x_126, 5); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_inc(x_159); +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_inc(x_156); +x_157 = lean_ctor_get(x_133, 1); +lean_inc(x_157); +x_158 = lean_ctor_get(x_133, 3); lean_inc(x_158); -lean_dec(x_126); -x_163 = lean_ctor_get(x_127, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_127, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_127, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_127, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_127, 5); -lean_inc(x_167); -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_168 = x_127; +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; } else { - lean_dec_ref(x_127); - x_168 = lean_box(0); + lean_dec_ref(x_133); + x_159 = lean_box(0); } -x_169 = lean_ctor_get(x_128, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_128, 1); -lean_inc(x_170); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - x_171 = x_128; +if (lean_is_scalar(x_159)) { + x_160 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_128); - x_171 = lean_box(0); + x_160 = x_159; } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 3, 0); -} else { - x_172 = x_171; -} -lean_ctor_set(x_172, 0, x_169); -lean_ctor_set(x_172, 1, x_170); -lean_ctor_set(x_172, 2, x_30); -if (lean_is_scalar(x_168)) { - x_173 = lean_alloc_ctor(0, 6, 0); -} else { - x_173 = x_168; -} -lean_ctor_set(x_173, 0, x_163); -lean_ctor_set(x_173, 1, x_164); -lean_ctor_set(x_173, 2, x_172); -lean_ctor_set(x_173, 3, x_165); -lean_ctor_set(x_173, 4, x_166); -lean_ctor_set(x_173, 5, x_167); -x_174 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_174, 0, x_173); -lean_ctor_set(x_174, 1, x_158); -lean_ctor_set(x_174, 2, x_159); -lean_ctor_set(x_174, 3, x_160); -lean_ctor_set(x_174, 4, x_161); -lean_ctor_set(x_174, 5, x_162); -x_175 = lean_ctor_get(x_33, 1); -lean_inc(x_175); +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); +lean_inc(x_162); if (lean_is_exclusive(x_33)) { lean_ctor_release(x_33, 0); lean_ctor_release(x_33, 1); - x_176 = x_33; + x_163 = x_33; } else { lean_dec_ref(x_33); - x_176 = lean_box(0); + x_163 = lean_box(0); } -if (lean_is_scalar(x_176)) { - x_177 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_163)) { + x_164 = lean_alloc_ctor(0, 2, 0); } else { - x_177 = x_176; + x_164 = x_163; } -lean_ctor_set(x_177, 0, x_174); -lean_ctor_set(x_177, 1, x_175); -lean_ctor_set(x_35, 1, x_177); +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_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; 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_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -lean_inc(x_179); +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); +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; +} else { + lean_dec_ref(x_132); + x_175 = 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); -lean_dec(x_35); -x_180 = l_Lean_Elab_Tactic_restore(x_179, x_34); -lean_dec(x_34); -x_181 = lean_ctor_get(x_180, 0); -lean_inc(x_181); -lean_dec(x_180); -x_182 = lean_ctor_get(x_181, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_182, 2); +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; +} else { + lean_dec_ref(x_133); + 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_30); +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); +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); -x_184 = lean_ctor_get(x_181, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_181, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_181, 3); -lean_inc(x_186); -x_187 = lean_ctor_get(x_181, 4); -lean_inc(x_187); -x_188 = lean_ctor_get(x_181, 5); -lean_inc(x_188); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - lean_ctor_release(x_181, 2); - lean_ctor_release(x_181, 3); - lean_ctor_release(x_181, 4); - lean_ctor_release(x_181, 5); - x_189 = x_181; -} else { - lean_dec_ref(x_181); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_182, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_182, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_182, 3); -lean_inc(x_192); -x_193 = lean_ctor_get(x_182, 4); -lean_inc(x_193); -x_194 = lean_ctor_get(x_182, 5); -lean_inc(x_194); -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_195 = x_182; -} else { - lean_dec_ref(x_182); - x_195 = lean_box(0); -} -x_196 = lean_ctor_get(x_183, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_183, 1); -lean_inc(x_197); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - lean_ctor_release(x_183, 2); - x_198 = x_183; -} else { - lean_dec_ref(x_183); - x_198 = lean_box(0); -} -if (lean_is_scalar(x_198)) { - x_199 = lean_alloc_ctor(0, 3, 0); -} else { - x_199 = x_198; -} -lean_ctor_set(x_199, 0, x_196); -lean_ctor_set(x_199, 1, x_197); -lean_ctor_set(x_199, 2, x_30); -if (lean_is_scalar(x_195)) { - x_200 = lean_alloc_ctor(0, 6, 0); -} else { - x_200 = x_195; -} -lean_ctor_set(x_200, 0, x_190); -lean_ctor_set(x_200, 1, x_191); -lean_ctor_set(x_200, 2, x_199); -lean_ctor_set(x_200, 3, x_192); -lean_ctor_set(x_200, 4, x_193); -lean_ctor_set(x_200, 5, x_194); -if (lean_is_scalar(x_189)) { - x_201 = lean_alloc_ctor(0, 6, 0); -} else { - x_201 = x_189; -} -lean_ctor_set(x_201, 0, x_200); -lean_ctor_set(x_201, 1, x_184); -lean_ctor_set(x_201, 2, x_185); -lean_ctor_set(x_201, 3, x_186); -lean_ctor_set(x_201, 4, x_187); -lean_ctor_set(x_201, 5, x_188); -x_202 = lean_ctor_get(x_33, 1); -lean_inc(x_202); if (lean_is_exclusive(x_33)) { lean_ctor_release(x_33, 0); lean_ctor_release(x_33, 1); - x_203 = x_33; + x_184 = x_33; } else { lean_dec_ref(x_33); + x_184 = lean_box(0); +} +if (lean_is_scalar(x_184)) { + x_185 = lean_alloc_ctor(0, 2, 0); +} else { + x_185 = x_184; +} +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_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); } -if (lean_is_scalar(x_203)) { - x_204 = lean_alloc_ctor(0, 2, 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 { - x_204 = x_203; + lean_dec_ref(x_191); + x_207 = lean_box(0); } -lean_ctor_set(x_204, 0, x_201); -lean_ctor_set(x_204, 1, x_202); -x_205 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_205, 0, x_178); -lean_ctor_set(x_205, 1, x_204); -return x_205; +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_206; +uint8_t x_215; lean_dec(x_30); lean_dec(x_22); lean_dec(x_2); -x_206 = !lean_is_exclusive(x_32); -if (x_206 == 0) +x_215 = !lean_is_exclusive(x_32); +if (x_215 == 0) { return x_32; } else { -lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_207 = lean_ctor_get(x_32, 0); -x_208 = lean_ctor_get(x_32, 1); -lean_inc(x_208); -lean_inc(x_207); +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_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; +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; } } } @@ -9768,388 +9870,396 @@ 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; uint8_t x_218; lean_object* x_219; lean_object* x_220; -x_210 = lean_ctor_get(x_7, 0); -x_211 = lean_ctor_get(x_7, 2); -x_212 = lean_ctor_get(x_7, 3); -x_213 = lean_ctor_get(x_7, 4); -lean_inc(x_213); -lean_inc(x_212); -lean_inc(x_211); -lean_inc(x_210); -lean_dec(x_7); -x_214 = lean_ctor_get(x_8, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_8, 4); -lean_inc(x_215); -x_216 = lean_array_get_size(x_211); -x_217 = lean_array_get_size(x_215); -x_218 = lean_nat_dec_eq(x_216, x_217); -lean_dec(x_217); -lean_dec(x_216); -lean_inc(x_215); -x_219 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_219, 0, x_210); -lean_ctor_set(x_219, 1, x_214); -lean_ctor_set(x_219, 2, x_215); -lean_ctor_set(x_219, 3, x_212); -lean_ctor_set(x_219, 4, x_213); -lean_ctor_set(x_6, 0, x_219); -x_220 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_220, 0, x_6); -lean_ctor_set(x_220, 1, x_10); -lean_ctor_set(x_220, 2, x_11); -if (x_218 == 0) -{ -lean_object* x_221; -lean_dec(x_215); -lean_dec(x_211); -lean_dec(x_8); -lean_dec(x_3); -x_221 = lean_apply_2(x_2, x_220, x_9); -return x_221; -} -else -{ -lean_object* x_222; uint8_t x_223; -x_222 = lean_unsigned_to_nat(0u); -x_223 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_211, x_215, x_222); -lean_dec(x_215); -lean_dec(x_211); -lean_dec(x_8); -lean_dec(x_3); -if (x_223 == 0) -{ -lean_object* x_224; -x_224 = lean_apply_2(x_2, x_220, x_9); -return x_224; -} -else -{ -lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_225 = lean_ctor_get(x_9, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_225, 0); -lean_inc(x_226); -lean_dec(x_225); -x_227 = lean_ctor_get(x_226, 2); -lean_inc(x_227); -lean_dec(x_226); -x_228 = lean_ctor_get(x_227, 2); -lean_inc(x_228); -lean_dec(x_227); -x_229 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +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); -x_230 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_229, x_220, x_9); -if (lean_obj_tag(x_230) == 0) +lean_inc(x_219); +lean_dec(x_7); +x_223 = lean_ctor_get(x_8, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_8, 4); +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_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_230, 1); -lean_inc(x_231); -lean_dec(x_230); -x_232 = l_Lean_Elab_Tactic_save(x_231); -lean_inc(x_231); -x_233 = lean_apply_2(x_2, x_220, x_231); -if (lean_obj_tag(x_233) == 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; +} +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_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_dec(x_232); -lean_dec(x_231); -x_234 = lean_ctor_get(x_233, 1); +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); -x_236 = lean_ctor_get(x_235, 0); +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); -x_238 = lean_ctor_get(x_233, 0); -lean_inc(x_238); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_239 = x_233; -} else { - lean_dec_ref(x_233); - x_239 = lean_box(0); -} -x_240 = lean_ctor_get(x_234, 1); +lean_dec(x_236); +x_238 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +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) +{ +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 1); lean_inc(x_240); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_241 = x_234; -} else { - lean_dec_ref(x_234); - x_241 = lean_box(0); -} -x_242 = lean_ctor_get(x_235, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_235, 2); +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_inc(x_243); -x_244 = lean_ctor_get(x_235, 3); +x_244 = lean_ctor_get(x_243, 0); lean_inc(x_244); -x_245 = lean_ctor_get(x_235, 4); +x_245 = lean_ctor_get(x_244, 0); lean_inc(x_245); -x_246 = lean_ctor_get(x_235, 5); +x_246 = lean_ctor_get(x_245, 2); 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); - lean_ctor_release(x_235, 4); - lean_ctor_release(x_235, 5); - x_247 = x_235; +x_247 = lean_ctor_get(x_242, 0); +lean_inc(x_247); +if (lean_is_exclusive(x_242)) { + lean_ctor_release(x_242, 0); + lean_ctor_release(x_242, 1); + x_248 = x_242; } else { - lean_dec_ref(x_235); - x_247 = lean_box(0); + lean_dec_ref(x_242); + x_248 = lean_box(0); } -x_248 = lean_ctor_get(x_236, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_236, 1); +x_249 = lean_ctor_get(x_243, 1); lean_inc(x_249); -x_250 = lean_ctor_get(x_236, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_236, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_236, 5); -lean_inc(x_252); -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_253 = x_236; +if (lean_is_exclusive(x_243)) { + lean_ctor_release(x_243, 0); + lean_ctor_release(x_243, 1); + x_250 = x_243; } else { - lean_dec_ref(x_236); - x_253 = lean_box(0); + lean_dec_ref(x_243); + x_250 = lean_box(0); } -x_254 = lean_ctor_get(x_237, 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_237, 1); +x_255 = lean_ctor_get(x_244, 5); lean_inc(x_255); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - lean_ctor_release(x_237, 2); - x_256 = x_237; +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_237); + 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); +} 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_257 = lean_alloc_ctor(0, 3, 0); + x_269 = lean_alloc_ctor(0, 6, 0); } else { - x_257 = x_256; + x_269 = x_256; } -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_228); -if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_258 = x_253; + x_270 = x_250; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_259 = x_247; + x_271 = x_248; } -lean_ctor_set(x_259, 0, x_258); -lean_ctor_set(x_259, 1, x_242); -lean_ctor_set(x_259, 2, x_243); -lean_ctor_set(x_259, 3, x_244); -lean_ctor_set(x_259, 4, x_245); -lean_ctor_set(x_259, 5, x_246); -if (lean_is_scalar(x_241)) { - x_260 = lean_alloc_ctor(0, 2, 0); -} else { - x_260 = x_241; -} -lean_ctor_set(x_260, 0, x_259); -lean_ctor_set(x_260, 1, x_240); -if (lean_is_scalar(x_239)) { - x_261 = lean_alloc_ctor(0, 2, 0); -} else { - x_261 = x_239; -} -lean_ctor_set(x_261, 0, x_238); -lean_ctor_set(x_261, 1, x_260); -return x_261; +lean_ctor_set(x_271, 0, x_247); +lean_ctor_set(x_271, 1, x_270); +return x_271; } else { -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_262 = lean_ctor_get(x_233, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_233, 1); -lean_inc(x_263); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - x_264 = x_233; -} else { - lean_dec_ref(x_233); - x_264 = lean_box(0); -} -x_265 = l_Lean_Elab_Tactic_restore(x_263, x_232); -lean_dec(x_232); -x_266 = lean_ctor_get(x_265, 0); -lean_inc(x_266); -lean_dec(x_265); -x_267 = lean_ctor_get(x_266, 0); -lean_inc(x_267); -x_268 = lean_ctor_get(x_267, 2); -lean_inc(x_268); -x_269 = lean_ctor_get(x_266, 1); -lean_inc(x_269); -x_270 = lean_ctor_get(x_266, 2); -lean_inc(x_270); -x_271 = lean_ctor_get(x_266, 3); -lean_inc(x_271); -x_272 = lean_ctor_get(x_266, 4); +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_266, 5); +x_273 = lean_ctor_get(x_242, 1); lean_inc(x_273); -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); - lean_ctor_release(x_266, 5); - x_274 = x_266; +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_266); + lean_dec_ref(x_242); x_274 = lean_box(0); } -x_275 = lean_ctor_get(x_267, 0); -lean_inc(x_275); -x_276 = lean_ctor_get(x_267, 1); +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); -x_277 = lean_ctor_get(x_267, 3); +lean_dec(x_275); +x_277 = lean_ctor_get(x_276, 0); lean_inc(x_277); -x_278 = lean_ctor_get(x_267, 4); +x_278 = lean_ctor_get(x_277, 2); lean_inc(x_278); -x_279 = lean_ctor_get(x_267, 5); +x_279 = lean_ctor_get(x_276, 1); lean_inc(x_279); -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_280 = x_267; -} else { - lean_dec_ref(x_267); - x_280 = lean_box(0); -} -x_281 = lean_ctor_get(x_268, 0); +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_268, 1); +x_282 = lean_ctor_get(x_276, 4); lean_inc(x_282); -if (lean_is_exclusive(x_268)) { - lean_ctor_release(x_268, 0); - lean_ctor_release(x_268, 1); - lean_ctor_release(x_268, 2); - x_283 = x_268; +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_268); - x_283 = lean_box(0); + lean_dec_ref(x_276); + x_284 = lean_box(0); } -if (lean_is_scalar(x_283)) { - x_284 = lean_alloc_ctor(0, 3, 0); -} else { - x_284 = x_283; -} -lean_ctor_set(x_284, 0, x_281); -lean_ctor_set(x_284, 1, x_282); -lean_ctor_set(x_284, 2, x_228); -if (lean_is_scalar(x_280)) { - x_285 = lean_alloc_ctor(0, 6, 0); -} else { - x_285 = x_280; -} -lean_ctor_set(x_285, 0, x_275); -lean_ctor_set(x_285, 1, x_276); -lean_ctor_set(x_285, 2, x_284); -lean_ctor_set(x_285, 3, x_277); -lean_ctor_set(x_285, 4, x_278); -lean_ctor_set(x_285, 5, x_279); -if (lean_is_scalar(x_274)) { - x_286 = lean_alloc_ctor(0, 6, 0); -} else { - x_286 = x_274; -} -lean_ctor_set(x_286, 0, x_285); -lean_ctor_set(x_286, 1, x_269); -lean_ctor_set(x_286, 2, x_270); -lean_ctor_set(x_286, 3, x_271); -lean_ctor_set(x_286, 4, x_272); -lean_ctor_set(x_286, 5, x_273); -x_287 = lean_ctor_get(x_231, 1); +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); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_288 = x_231; +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_231); - x_288 = lean_box(0); + lean_dec_ref(x_277); + x_290 = lean_box(0); } -if (lean_is_scalar(x_288)) { - x_289 = lean_alloc_ctor(0, 2, 0); -} else { - x_289 = x_288; -} -lean_ctor_set(x_289, 0, x_286); -lean_ctor_set(x_289, 1, x_287); -if (lean_is_scalar(x_264)) { - x_290 = lean_alloc_ctor(1, 2, 0); -} else { - x_290 = x_264; -} -lean_ctor_set(x_290, 0, x_262); -lean_ctor_set(x_290, 1, x_289); -return x_290; -} -} -else -{ -lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -lean_dec(x_228); -lean_dec(x_220); -lean_dec(x_2); -x_291 = lean_ctor_get(x_230, 0); +x_291 = lean_ctor_get(x_278, 0); lean_inc(x_291); -x_292 = lean_ctor_get(x_230, 1); +x_292 = lean_ctor_get(x_278, 1); lean_inc(x_292); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_293 = x_230; +x_293 = lean_ctor_get(x_278, 3); +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_230); - x_293 = lean_box(0); + lean_dec_ref(x_278); + x_294 = lean_box(0); } -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_294)) { + x_295 = lean_alloc_ctor(0, 4, 0); } else { - x_294 = x_293; + x_295 = x_294; } -lean_ctor_set(x_294, 0, x_291); -lean_ctor_set(x_294, 1, x_292); -return 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; } } } @@ -10157,437 +10267,445 @@ return x_294; } else { -lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; uint8_t x_304; uint8_t x_305; uint8_t x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; uint8_t x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; -x_295 = lean_ctor_get(x_6, 1); -x_296 = lean_ctor_get(x_6, 2); -x_297 = lean_ctor_get(x_6, 3); -x_298 = lean_ctor_get(x_6, 4); -x_299 = lean_ctor_get(x_6, 5); -x_300 = lean_ctor_get(x_6, 6); -x_301 = lean_ctor_get(x_6, 7); -x_302 = lean_ctor_get(x_6, 8); -x_303 = lean_ctor_get(x_6, 9); -x_304 = lean_ctor_get_uint8(x_6, sizeof(void*)*10); -x_305 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 1); -x_306 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 2); -lean_inc(x_303); -lean_inc(x_302); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); -lean_dec(x_6); -x_307 = lean_ctor_get(x_7, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_7, 2); -lean_inc(x_308); -x_309 = lean_ctor_get(x_7, 3); -lean_inc(x_309); -x_310 = lean_ctor_get(x_7, 4); +lean_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_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); 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_311 = x_7; + x_322 = x_7; } else { lean_dec_ref(x_7); - x_311 = lean_box(0); + x_322 = lean_box(0); } -x_312 = lean_ctor_get(x_8, 1); -lean_inc(x_312); -x_313 = lean_ctor_get(x_8, 4); -lean_inc(x_313); -x_314 = lean_array_get_size(x_308); -x_315 = lean_array_get_size(x_313); -x_316 = lean_nat_dec_eq(x_314, x_315); -lean_dec(x_315); -lean_dec(x_314); -lean_inc(x_313); -if (lean_is_scalar(x_311)) { - x_317 = lean_alloc_ctor(0, 5, 0); -} else { - x_317 = x_311; -} -lean_ctor_set(x_317, 0, x_307); -lean_ctor_set(x_317, 1, x_312); -lean_ctor_set(x_317, 2, x_313); -lean_ctor_set(x_317, 3, x_309); -lean_ctor_set(x_317, 4, x_310); -x_318 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_318, 0, x_317); -lean_ctor_set(x_318, 1, x_295); -lean_ctor_set(x_318, 2, x_296); -lean_ctor_set(x_318, 3, x_297); -lean_ctor_set(x_318, 4, x_298); -lean_ctor_set(x_318, 5, x_299); -lean_ctor_set(x_318, 6, x_300); -lean_ctor_set(x_318, 7, x_301); -lean_ctor_set(x_318, 8, x_302); -lean_ctor_set(x_318, 9, x_303); -lean_ctor_set_uint8(x_318, sizeof(void*)*10, x_304); -lean_ctor_set_uint8(x_318, sizeof(void*)*10 + 1, x_305); -lean_ctor_set_uint8(x_318, sizeof(void*)*10 + 2, x_306); -x_319 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_319, 0, x_318); -lean_ctor_set(x_319, 1, x_10); -lean_ctor_set(x_319, 2, x_11); -if (x_316 == 0) -{ -lean_object* x_320; -lean_dec(x_313); -lean_dec(x_308); -lean_dec(x_8); -lean_dec(x_3); -x_320 = lean_apply_2(x_2, x_319, x_9); -return x_320; -} -else -{ -lean_object* x_321; uint8_t x_322; -x_321 = lean_unsigned_to_nat(0u); -x_322 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_308, x_313, x_321); -lean_dec(x_313); -lean_dec(x_308); -lean_dec(x_8); -lean_dec(x_3); -if (x_322 == 0) -{ -lean_object* x_323; -x_323 = lean_apply_2(x_2, x_319, x_9); -return x_323; -} -else -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_324 = lean_ctor_get(x_9, 0); +x_323 = lean_ctor_get(x_8, 1); +lean_inc(x_323); +x_324 = lean_ctor_get(x_8, 4); lean_inc(x_324); -x_325 = lean_ctor_get(x_324, 0); -lean_inc(x_325); -lean_dec(x_324); -x_326 = lean_ctor_get(x_325, 2); -lean_inc(x_326); -lean_dec(x_325); -x_327 = lean_ctor_get(x_326, 2); -lean_inc(x_327); +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); -x_328 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; -lean_inc(x_319); -x_329 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_328, x_319, x_9); -if (lean_obj_tag(x_329) == 0) +lean_dec(x_325); +lean_inc(x_324); +if (lean_is_scalar(x_322)) { + x_328 = lean_alloc_ctor(0, 5, 0); +} else { + x_328 = x_322; +} +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_330; lean_object* x_331; lean_object* x_332; -x_330 = lean_ctor_get(x_329, 1); -lean_inc(x_330); -lean_dec(x_329); -x_331 = l_Lean_Elab_Tactic_save(x_330); -lean_inc(x_330); -x_332 = lean_apply_2(x_2, x_319, 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; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; -lean_dec(x_331); -lean_dec(x_330); -x_333 = lean_ctor_get(x_332, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_333, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_334, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = lean_ctor_get(x_332, 0); -lean_inc(x_337); -if (lean_is_exclusive(x_332)) { - lean_ctor_release(x_332, 0); - lean_ctor_release(x_332, 1); - x_338 = x_332; -} else { - lean_dec_ref(x_332); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_333, 1); -lean_inc(x_339); -if (lean_is_exclusive(x_333)) { - lean_ctor_release(x_333, 0); - lean_ctor_release(x_333, 1); - x_340 = x_333; -} else { - lean_dec_ref(x_333); - x_340 = lean_box(0); -} -x_341 = lean_ctor_get(x_334, 1); -lean_inc(x_341); -x_342 = lean_ctor_get(x_334, 2); -lean_inc(x_342); -x_343 = lean_ctor_get(x_334, 3); -lean_inc(x_343); -x_344 = lean_ctor_get(x_334, 4); -lean_inc(x_344); -x_345 = lean_ctor_get(x_334, 5); -lean_inc(x_345); -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_346 = x_334; -} else { - lean_dec_ref(x_334); - x_346 = lean_box(0); -} -x_347 = lean_ctor_get(x_335, 0); -lean_inc(x_347); -x_348 = lean_ctor_get(x_335, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_335, 3); -lean_inc(x_349); -x_350 = lean_ctor_get(x_335, 4); -lean_inc(x_350); -x_351 = lean_ctor_get(x_335, 5); -lean_inc(x_351); -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_352 = x_335; -} else { - lean_dec_ref(x_335); - x_352 = lean_box(0); -} -x_353 = lean_ctor_get(x_336, 0); -lean_inc(x_353); -x_354 = lean_ctor_get(x_336, 1); -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); - 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, 3, 0); -} else { - x_356 = x_355; -} -lean_ctor_set(x_356, 0, x_353); -lean_ctor_set(x_356, 1, x_354); -lean_ctor_set(x_356, 2, x_327); -if (lean_is_scalar(x_352)) { - x_357 = lean_alloc_ctor(0, 6, 0); -} else { - x_357 = x_352; -} -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); -if (lean_is_scalar(x_346)) { - x_358 = lean_alloc_ctor(0, 6, 0); -} else { - x_358 = x_346; -} -lean_ctor_set(x_358, 0, x_357); -lean_ctor_set(x_358, 1, x_341); -lean_ctor_set(x_358, 2, x_342); -lean_ctor_set(x_358, 3, x_343); -lean_ctor_set(x_358, 4, x_344); -lean_ctor_set(x_358, 5, x_345); -if (lean_is_scalar(x_340)) { - x_359 = lean_alloc_ctor(0, 2, 0); -} else { - x_359 = x_340; -} -lean_ctor_set(x_359, 0, x_358); -lean_ctor_set(x_359, 1, x_339); -if (lean_is_scalar(x_338)) { - x_360 = lean_alloc_ctor(0, 2, 0); -} else { - x_360 = x_338; -} -lean_ctor_set(x_360, 0, x_337); -lean_ctor_set(x_360, 1, x_359); -return x_360; +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_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_361 = lean_ctor_get(x_332, 0); -lean_inc(x_361); -x_362 = lean_ctor_get(x_332, 1); -lean_inc(x_362); -if (lean_is_exclusive(x_332)) { - lean_ctor_release(x_332, 0); - lean_ctor_release(x_332, 1); - x_363 = x_332; +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; +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) +{ +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_inc(x_347); +x_348 = lean_ctor_get(x_343, 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_332); + lean_dec_ref(x_343); + x_349 = lean_box(0); +} +x_350 = lean_ctor_get(x_344, 1); +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; +} else { + lean_dec_ref(x_344); + x_351 = lean_box(0); +} +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); +} +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 = l_Lean_Elab_Tactic_restore(x_362, x_331); -lean_dec(x_331); -x_365 = lean_ctor_get(x_364, 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); -lean_dec(x_364); -x_366 = lean_ctor_get(x_365, 0); +x_366 = lean_ctor_get(x_347, 3); lean_inc(x_366); -x_367 = lean_ctor_get(x_366, 2); -lean_inc(x_367); -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); -x_372 = lean_ctor_get(x_365, 5); -lean_inc(x_372); -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); - lean_ctor_release(x_365, 5); - x_373 = x_365; +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; } else { - lean_dec_ref(x_365); - x_373 = lean_box(0); + lean_dec_ref(x_347); + x_367 = lean_box(0); } -x_374 = lean_ctor_get(x_366, 0); -lean_inc(x_374); -x_375 = lean_ctor_get(x_366, 1); -lean_inc(x_375); -x_376 = lean_ctor_get(x_366, 3); -lean_inc(x_376); -x_377 = lean_ctor_get(x_366, 4); -lean_inc(x_377); -x_378 = lean_ctor_get(x_366, 5); -lean_inc(x_378); -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_379 = x_366; +if (lean_is_scalar(x_367)) { + x_368 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_366); - x_379 = lean_box(0); + x_368 = x_367; } -x_380 = lean_ctor_get(x_367, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_367, 1); -lean_inc(x_381); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - lean_ctor_release(x_367, 2); - x_382 = x_367; -} else { - lean_dec_ref(x_367); - x_382 = lean_box(0); -} -if (lean_is_scalar(x_382)) { - x_383 = lean_alloc_ctor(0, 3, 0); -} else { - x_383 = x_382; -} -lean_ctor_set(x_383, 0, x_380); -lean_ctor_set(x_383, 1, x_381); -lean_ctor_set(x_383, 2, x_327); -if (lean_is_scalar(x_379)) { - x_384 = lean_alloc_ctor(0, 6, 0); -} else { - x_384 = x_379; -} -lean_ctor_set(x_384, 0, x_374); -lean_ctor_set(x_384, 1, x_375); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_376); -lean_ctor_set(x_384, 4, x_377); -lean_ctor_set(x_384, 5, x_378); -if (lean_is_scalar(x_373)) { - x_385 = lean_alloc_ctor(0, 6, 0); -} else { - x_385 = x_373; -} -lean_ctor_set(x_385, 0, x_384); -lean_ctor_set(x_385, 1, x_368); -lean_ctor_set(x_385, 2, x_369); -lean_ctor_set(x_385, 3, x_370); -lean_ctor_set(x_385, 4, x_371); -lean_ctor_set(x_385, 5, x_372); -x_386 = lean_ctor_get(x_330, 1); -lean_inc(x_386); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - x_387 = x_330; -} else { - lean_dec_ref(x_330); - x_387 = lean_box(0); -} -if (lean_is_scalar(x_387)) { - x_388 = lean_alloc_ctor(0, 2, 0); -} else { - x_388 = x_387; -} -lean_ctor_set(x_388, 0, x_385); -lean_ctor_set(x_388, 1, x_386); +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_389 = lean_alloc_ctor(1, 2, 0); + x_369 = lean_alloc_ctor(0, 6, 0); } else { - x_389 = x_363; + x_369 = x_363; } -lean_ctor_set(x_389, 0, x_361); -lean_ctor_set(x_389, 1, x_388); -return x_389; +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)) { + x_370 = lean_alloc_ctor(0, 6, 0); +} else { + x_370 = x_357; +} +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); +} else { + x_371 = x_351; +} +lean_ctor_set(x_371, 0, x_370); +lean_ctor_set(x_371, 1, x_350); +if (lean_is_scalar(x_349)) { + x_372 = lean_alloc_ctor(0, 2, 0); +} else { + x_372 = x_349; +} +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; +} else { + lean_dec_ref(x_343); + x_375 = lean_box(0); +} +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); +} +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_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; -lean_dec(x_327); -lean_dec(x_319); +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_390 = lean_ctor_get(x_329, 0); -lean_inc(x_390); -x_391 = lean_ctor_get(x_329, 1); -lean_inc(x_391); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - x_392 = x_329; +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_329); - x_392 = lean_box(0); + lean_dec_ref(x_340); + x_405 = lean_box(0); } -if (lean_is_scalar(x_392)) { - x_393 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_405)) { + x_406 = lean_alloc_ctor(1, 2, 0); } else { - x_393 = x_392; + x_406 = x_405; } -lean_ctor_set(x_393, 0, x_390); -lean_ctor_set(x_393, 1, x_391); -return x_393; +lean_ctor_set(x_406, 0, x_403); +lean_ctor_set(x_406, 1, x_404); +return x_406; } } } diff --git a/stage0/stdlib/Init/Lean/Elab/Term.c b/stage0/stdlib/Init/Lean/Elab/Term.c index 2650243308..b8b88a9602 100644 --- a/stage0/stdlib/Init/Lean/Elab/Term.c +++ b/stage0/stdlib/Init/Lean/Elab/Term.c @@ -19,11 +19,13 @@ 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*); lean_object* l___private_Init_Lean_Elab_Term_1__mkMessageAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6; lean_object* l_Lean_Elab_Term_getEnv___rarg(lean_object*); extern lean_object* l_Lean_Name_toString___closed__1; lean_object* l_Lean_Elab_Term_mkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabImplicitLambdaAux___closed__2; lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__1; +extern lean_object* l_Lean_Expr_prod_x3f___closed__2; lean_object* l_Lean_mkAppStx(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_monadQuotation; lean_object* l___regBuiltin_Lean_Elab_Term_elabArrayLit___closed__1; @@ -74,6 +76,7 @@ extern lean_object* l_Lean_Expr_hasSorry___main___closed__1; lean_object* l_Lean_Elab_Term_mkTermElabAttribute___closed__3; lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__2; extern lean_object* l_IO_Prim_fopenFlags___closed__12; +lean_object* l_Lean_Elab_Term_throwErrorIfErrors___closed__1; lean_object* l_Lean_Elab_Term_resettingSynthInstanceCacheWhen(lean_object*); lean_object* l_Lean_Elab_Term_monadLog___closed__3; lean_object* l_Lean_Format_pretty(lean_object*, lean_object*); @@ -123,6 +126,7 @@ lean_object* lean_dbg_trace(lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabNum___closed__1; lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Elab_Term_3__fromMetaState___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getEnv___boxed(lean_object*); +lean_object* l_Lean_Elab_Term_throwErrorIfErrors___closed__2; extern lean_object* l_Lean_charLitKind___closed__2; lean_object* l_List_append___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_Exception_mkAppTypeMismatchMessage(lean_object*, lean_object*, lean_object*); @@ -157,13 +161,13 @@ lean_object* l_Lean_Elab_Term_inferType___boxed(lean_object*, lean_object*, lean lean_object* l_Lean_Elab_Term_monadLog___closed__7; lean_object* l___regBuiltin_Lean_Elab_Term_elabProp(lean_object*); lean_object* lean_string_append(lean_object*, lean_object*); +lean_object* l_PersistentArray_forM___at___private_Init_Lean_Parser_Module_4__testModuleParserAux___main___spec__6(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_Exception_toStr___closed__1; extern lean_object* l_Lean_Parser_Term_num___elambda__1___closed__1; lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_elabListLit___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_ensureType(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabBadCDot___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_tacticBlock___elambda__1___closed__2; -extern lean_object* l_Lean_listToExpr___rarg___closed__8; lean_object* l_Lean_Expr_getAppFn___main(lean_object*); lean_object* l_PersistentArray_push___rarg(lean_object*, lean_object*); lean_object* l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(lean_object*); @@ -214,7 +218,6 @@ lean_object* l_Lean_Elab_Term_Exception_hasToString(lean_object*); lean_object* l_Lean_Elab_Term_elabParen___closed__5; lean_object* l_Lean_Elab_Term_mkTermElabAttribute___closed__5; extern lean_object* l_Lean_LocalContext_Inhabited___closed__1; -extern lean_object* l_Lean_listToExpr___rarg___closed__4; lean_object* l_Lean_Elab_Term_resolveName___closed__5; lean_object* l_Lean_Elab_Term_mkFreshExprMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_LVal_hasToString(lean_object*); @@ -224,6 +227,8 @@ lean_object* l_Lean_Elab_Term_mkFreshAnonymousName___rarg___closed__2; lean_object* l_Lean_Elab_Term_trace___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__8; lean_object* l_Lean_Elab_Term_elabBadCDot___closed__1; +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__6; +lean_object* l_Lean_Elab_Term_mkExpectedTypeHint(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_TermElabResult_inhabited___closed__1; lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Meta_ppGoal(lean_object*, lean_object*, lean_object*); @@ -256,6 +261,7 @@ lean_object* l_Lean_Elab_Term_liftMetaM(lean_object*); extern lean_object* l_Lean_PersistentEnvExtension_inhabited___rarg___closed__1; lean_object* l_List_foldlM___main___at___private_Init_Lean_Elab_Term_20__mkConsts___spec__1(lean_object*, lean_object*, 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*); lean_object* l___regBuiltin_Lean_Elab_Term_elabHole(lean_object*); lean_object* l_Lean_Elab_Term_withTransparency(lean_object*); @@ -291,6 +297,7 @@ lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__5; lean_object* l_Lean_Elab_Term_elabRawCharLit(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkFreshAnonymousName___rarg(lean_object*); +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__2; extern lean_object* l_Lean_Expr_Inhabited___closed__1; uint8_t lean_nat_dec_eq(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Term_18__resolveLocalName(lean_object*, lean_object*, lean_object*); @@ -306,6 +313,7 @@ lean_object* l_Lean_Elab_Term_withoutMacroStackAtErr(lean_object*); lean_object* l_Lean_Elab_Term_withMacroExpansion(lean_object*); lean_object* l_Lean_Elab_Term_getTraceState___rarg(lean_object*); lean_object* l_Lean_Elab_Term_State_inhabited___closed__1; +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__4; extern lean_object* l_Lean_EnvExtension_Inhabited___rarg___closed__1; lean_object* l_Lean_Elab_Term_dbgTrace(lean_object*); lean_object* l_Lean_Elab_Term_elabArrayLit___closed__11; @@ -395,6 +403,7 @@ lean_object* l_Nat_repr(lean_object*); lean_object* l_Lean_Elab_Term_State_inhabited___closed__2; extern lean_object* l_Char_HasRepr___closed__1; lean_object* l_Lean_Elab_Term_elabImplicitLambda(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_throwErrorIfErrors___closed__3; lean_object* l_Lean_Elab_getMacros(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandCDot_x3f___closed__3; lean_object* l_Lean_Elab_Term_logTrace(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -444,6 +453,7 @@ lean_object* l_Lean_Elab_Term_throwUnsupportedSyntax___boxed(lean_object*, lean_ lean_object* l_Lean_Elab_Term_mkTermElabAttribute(lean_object*); extern lean_object* l_Lean_numLitKind___closed__2; extern lean_object* l_Lean_Meta_Exception_toTraceMessageData___closed__4; +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___lambda__1(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabTacticBlock___closed__2; extern lean_object* l_Lean_Parser_Term_fun___elambda__1___closed__1; lean_object* l___private_Init_Lean_Elab_Term_7__isMonad_x3f___closed__1; @@ -469,6 +479,7 @@ extern lean_object* l_Lean_charToExpr___lambda__1___closed__2; lean_object* l_Lean_Elab_Term_resolveName___closed__8; 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, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_termElabAttribute___closed__5; lean_object* l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1; @@ -487,6 +498,7 @@ lean_object* l_ReaderT_bind___at_Lean_Elab_Term_monadLog___spec__2___rarg(lean_o lean_object* l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_TermElabResult_inhabited; lean_object* l_Lean_Elab_Term_withMVarContext___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_listLitAux___main___closed__4; lean_object* l_Lean_mkFVar(lean_object*); lean_object* l_Lean_Elab_Term_elabArrayLit___closed__4; lean_object* l___private_Init_Lean_Elab_Term_15__mkPairsAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -517,17 +529,20 @@ lean_object* l___private_Init_Lean_Elab_Term_10__elabTermUsing___main___closed__ 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*); lean_object* l_Lean_Elab_Term_termElabAttribute; +lean_object* l_IO_println___at_Lean_Meta_MetaHasEval___spec__1(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_expandCDot_x3f___closed__1; lean_object* l_Lean_Elab_Term_elabArrayLit___closed__10; lean_object* l_Lean_Elab_Term_Lean_Elab_MonadMacroAdapter___closed__2; lean_object* l_Lean_Elab_Term_monadLog___closed__2; extern lean_object* l_Lean_Meta_Exception_toStr___closed__7; +lean_object* l_Lean_Elab_Term_logDbgTrace___closed__1; lean_object* l_Array_foldlStepMAux___main___at_Lean_Elab_Term_elabParen___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getDeclName_x3f___boxed(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isDefEq(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Term_13__tryCoeSort___closed__5; lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___closed__10; lean_object* l_Lean_Elab_Term_Lean_Elab_MonadMacroAdapter___closed__5; +lean_object* l_Lean_Elab_Term_logDbgTrace___boxed(lean_object*, lean_object*, lean_object*); 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); @@ -541,7 +556,6 @@ uint8_t l___private_Init_Lean_Elab_Term_4__hasCDot___main(lean_object*); lean_object* l_Lean_Elab_Term_withoutPostponing___rarg(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_prop___elambda__1___closed__2; extern lean_object* l_Lean_Meta_Exception_mkAppTypeMismatchMessage___closed__8; -extern lean_object* l_Lean_prodToExpr___rarg___lambda__1___closed__4; lean_object* l_Lean_Elab_Term_savingMCtx(lean_object*); lean_object* l_Lean_Elab_Term_Exception_inhabited; lean_object* l_Lean_Elab_Term_elabHole(lean_object*, lean_object*, lean_object*, lean_object*); @@ -553,12 +567,15 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabRawStrLit(lean_object*); lean_object* l_Lean_Elab_Term_liftMetaM___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_trySynthInstance(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkAppStx___closed__5; +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*, lean_object*); lean_object* l___private_Init_Lean_Elab_Term_6__isTypeApp_x3f___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Elab_Term_3__fromMetaState___spec__5(lean_object*, 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_Lean_Elab_Term_setMCtx(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabStr(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__1; lean_object* l_Lean_Elab_Term_getLCtx(lean_object*, lean_object*); lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Elab_Term_3__fromMetaState___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_traceAtCmdPos(lean_object*, lean_object*, lean_object*, lean_object*); @@ -574,6 +591,7 @@ lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, le lean_object* l_Lean_Elab_Term_mkConst___closed__5; lean_object* l_Lean_mkApp(lean_object*, lean_object*); lean_object* l_HashMapImp_find_x3f___at_Lean_Elab_Term_elabTermAux___main___spec__5(lean_object*, lean_object*); +lean_object* l_Lean_getMaxRecDepth(lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabChar(lean_object*); lean_object* l_Lean_Elab_Term_throwError___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabHole___closed__1; @@ -636,6 +654,7 @@ lean_object* l_Lean_Elab_Term_tryPostponeIfMVar(lean_object*, lean_object*, lean lean_object* l_Lean_Elab_Term_elabImplicitLambda___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_evalNat___main___closed__7; lean_object* l_Lean_Syntax_getPos(lean_object*); +lean_object* l_Lean_Elab_Term_mkExpectedTypeHint___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabListLit(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withIncRecDepth___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Term_12__isExplicitApp___boxed(lean_object*); @@ -660,8 +679,11 @@ lean_object* l_Lean_Elab_Term_getOpenDecls(lean_object*, lean_object*); lean_object* l_Lean_Meta_isExprDefEq(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkTermIdFrom(lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabRawCharLit___closed__1; +extern lean_object* l_Lean_FileMap_Inhabited___closed__1; lean_object* l_Lean_Elab_Term_elabArrayLit___closed__3; extern lean_object* l_Lean_mkOptionalNode___closed__1; +extern lean_object* l_Lean_prodToExpr___rarg___lambda__1___closed__3; +lean_object* l_Lean_Elab_Term_logDbgTrace(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_isNameLit_x3f(lean_object*); lean_object* l_Lean_Elab_Term_getMainModule___boxed(lean_object*); lean_object* l_Lean_Elab_Term_decLevel___closed__4; @@ -698,6 +720,7 @@ lean_object* l_Lean_Elab_Term_resettingSynthInstanceCache___rarg(lean_object*, l extern lean_object* l_Lean_mkHole___closed__2; lean_object* l_Lean_Elab_Term_withLocalDecl(lean_object*); lean_object* l_Lean_Elab_Term_resolveName___closed__2; +extern lean_object* l_Lean_Expr_arrayLit_x3f___closed__2; lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Elab_Term_elabListLit___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); 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*); @@ -709,14 +732,15 @@ lean_object* l___private_Init_Lean_Elab_Term_13__tryCoeSort(lean_object*, lean_o lean_object* l_Lean_Elab_Term_mkFreshLevelMVar___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabByTactic___closed__1; lean_object* l_Lean_Elab_Term_ppGoal(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkExpectedTypeHint(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_setTraceState(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_tryPostpone(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_mkPairs(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_throwErrorIfErrors(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_monadLog___lambda__3(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Elab_Term_3__fromMetaState___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_monadQuotation___closed__3; lean_object* l_Lean_Elab_Term_setEnv(lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_arrayToExpr___rarg___lambda__1___closed__2; lean_object* l_Lean_Meta_mkFreshLevelMVar___rarg(lean_object*); lean_object* l_Lean_Syntax_getArg(lean_object*, lean_object*); extern lean_object* l_Lean_MetavarContext_Inhabited___closed__1; @@ -734,6 +758,7 @@ extern lean_object* l_Lean_MessageData_coeOfOptExpr___closed__1; extern lean_object* l_Lean_Parser_Term_listLit___elambda__1___closed__2; lean_object* l___regBuiltin_Lean_Elab_Term_elabTacticBlock___closed__1; uint8_t l_Lean_LocalInstance_beq(lean_object*, lean_object*); +uint8_t l_PersistentArray_anyM___at_Lean_MessageLog_hasErrors___spec__1(lean_object*); lean_object* l___private_Init_Lean_Elab_Term_5__expandCDot___main___closed__4; lean_object* lean_compile_decl(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; @@ -758,6 +783,7 @@ lean_object* l_Lean_Elab_Term_getMCtx___boxed(lean_object*); lean_object* l_Lean_Elab_Term_applyResult(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Name_toStringWithSep___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_isTypeFormer(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__3; lean_object* l_Lean_Elab_Term_mkTacticMVar(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabRawStrLit___closed__1; lean_object* lean_usize_to_nat(size_t); @@ -771,6 +797,7 @@ lean_object* l_Lean_mkAppB(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Elab_Term_18__resolveLocalName___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_char___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_isLocalTermId_x3f(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___closed__5; lean_object* l_Lean_indentExpr(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*); @@ -783,6 +810,7 @@ lean_object* l_Lean_Elab_Term_resolveName___closed__1; lean_object* l_Lean_Elab_Term_mkAuxName___closed__1; lean_object* l_Lean_Elab_Term_resettingSynthInstanceCache(lean_object*); lean_object* l___private_Init_Lean_Elab_Term_13__tryCoeSort___closed__7; +lean_object* l_Lean_Elab_Term_MetaHasEval(lean_object*); 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*); @@ -819,6 +847,7 @@ lean_object* l___private_Init_Lean_Elab_Term_15__mkPairsAux___boxed(lean_object* lean_object* l_Lean_Meta_isType(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_liftMetaM___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabArrayLit___closed__7; +extern lean_object* l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3; lean_object* l_Lean_Elab_Term_mkTermElabAttribute___closed__1; lean_object* l_Lean_Elab_Term_mkFreshInstanceName___rarg___closed__2; lean_object* l_Lean_mkApp3(lean_object*, lean_object*, lean_object*, lean_object*); @@ -3695,6 +3724,143 @@ lean_dec(x_2); return x_6; } } +lean_object* _init_l_Lean_Elab_Term_logDbgTrace___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l___private_Init_Lean_Elab_Util_4__regTraceClasses___closed__1; +x_2 = l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Elab_Term_logDbgTrace(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; uint8_t x_5; +x_4 = l_Lean_Elab_Term_getOptions(x_2, x_3); +x_5 = !lean_is_exclusive(x_4); +if (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_4, 0); +x_7 = lean_ctor_get(x_4, 1); +x_8 = l_Lean_Elab_Term_logDbgTrace___closed__1; +x_9 = l_Lean_checkTraceOption(x_6, x_8); +lean_dec(x_6); +if (x_9 == 0) +{ +lean_object* x_10; +lean_dec(x_1); +x_10 = lean_box(0); +lean_ctor_set(x_4, 0, x_10); +return x_4; +} +else +{ +lean_object* x_11; lean_object* x_12; +lean_free_object(x_4); +x_11 = lean_box(0); +x_12 = l_Lean_Elab_Term_logTrace(x_8, x_11, x_1, x_2, x_7); +return x_12; +} +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_13 = lean_ctor_get(x_4, 0); +x_14 = lean_ctor_get(x_4, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_4); +x_15 = l_Lean_Elab_Term_logDbgTrace___closed__1; +x_16 = l_Lean_checkTraceOption(x_13, x_15); +lean_dec(x_13); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; +lean_dec(x_1); +x_17 = lean_box(0); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_14); +return x_18; +} +else +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_box(0); +x_20 = l_Lean_Elab_Term_logTrace(x_15, x_19, x_1, x_2, x_14); +return x_20; +} +} +} +} +lean_object* l_Lean_Elab_Term_logDbgTrace___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Elab_Term_logDbgTrace(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} +lean_object* _init_l_Lean_Elab_Term_throwErrorIfErrors___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("Error(s)"); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_throwErrorIfErrors___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Term_throwErrorIfErrors___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_Term_throwErrorIfErrors___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Term_throwErrorIfErrors___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_Term_throwErrorIfErrors(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = lean_ctor_get(x_2, 2); +lean_inc(x_3); +x_4 = l_PersistentArray_anyM___at_Lean_MessageLog_hasErrors___spec__1(x_3); +lean_dec(x_3); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; +lean_dec(x_1); +x_5 = lean_box(0); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_2); +return x_6; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_box(0); +x_8 = l_Lean_Elab_Term_throwErrorIfErrors___closed__3; +x_9 = l_Lean_Elab_Term_throwError___rarg(x_7, x_8, x_1, x_2); +return x_9; +} +} +} lean_object* l_Lean_Elab_Term_traceAtCmdPos(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -8185,6 +8351,174 @@ lean_dec(x_1); return x_6; } } +lean_object* l_Lean_Elab_Term_mkExpectedTypeHint(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_mkExpectedTypeHint(x_2, x_3, x_9, x_6); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_11, 1); +x_14 = l___private_Init_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_Init_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_Init_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_20); +x_23 = l___private_Init_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_Init_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_24); +x_27 = l___private_Init_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_mkExpectedTypeHint(x_2, x_3, x_35, x_37); +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_Init_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_Init_Lean_Elab_Term_2__fromMetaException(x_4, x_1, x_44); +x_48 = l___private_Init_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_mkExpectedTypeHint___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_mkExpectedTypeHint(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_1); +return x_6; +} +} lean_object* l_Lean_Elab_Term_decLevel_x3f(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -20340,100 +20674,107 @@ return x_12; } else { -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; x_13 = lean_ctor_get(x_3, 0); x_14 = lean_ctor_get(x_3, 1); +x_15 = lean_ctor_get(x_3, 3); +lean_inc(x_15); lean_inc(x_14); lean_inc(x_13); lean_dec(x_3); -x_15 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_16 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_16, 0, x_13); -lean_ctor_set(x_16, 1, x_14); -lean_ctor_set(x_16, 2, x_15); -lean_ctor_set(x_2, 2, x_16); -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_1); -return x_18; +x_16 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_17 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_17, 0, x_13); +lean_ctor_set(x_17, 1, x_14); +lean_ctor_set(x_17, 2, x_16); +lean_ctor_set(x_17, 3, x_15); +lean_ctor_set(x_2, 2, x_17); +x_18 = lean_box(0); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_18); +lean_ctor_set(x_19, 1, x_1); +return x_19; } } 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; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_19 = lean_ctor_get(x_2, 0); -x_20 = lean_ctor_get(x_2, 1); -x_21 = lean_ctor_get(x_2, 3); -x_22 = lean_ctor_get(x_2, 4); -x_23 = lean_ctor_get(x_2, 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; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_20 = lean_ctor_get(x_2, 0); +x_21 = lean_ctor_get(x_2, 1); +x_22 = lean_ctor_get(x_2, 3); +x_23 = lean_ctor_get(x_2, 4); +x_24 = lean_ctor_get(x_2, 5); +lean_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_2); -x_24 = lean_ctor_get(x_3, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_3, 1); +x_25 = lean_ctor_get(x_3, 0); lean_inc(x_25); +x_26 = lean_ctor_get(x_3, 1); +lean_inc(x_26); +x_27 = lean_ctor_get(x_3, 3); +lean_inc(x_27); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); - x_26 = x_3; + lean_ctor_release(x_3, 3); + x_28 = x_3; } else { lean_dec_ref(x_3); - x_26 = lean_box(0); + x_28 = lean_box(0); } -x_27 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_26)) { - x_28 = lean_alloc_ctor(0, 3, 0); +x_29 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_28)) { + x_30 = lean_alloc_ctor(0, 4, 0); } else { - x_28 = x_26; + x_30 = x_28; } -lean_ctor_set(x_28, 0, x_24); -lean_ctor_set(x_28, 1, x_25); -lean_ctor_set(x_28, 2, x_27); -x_29 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_29, 0, x_19); -lean_ctor_set(x_29, 1, x_20); -lean_ctor_set(x_29, 2, x_28); -lean_ctor_set(x_29, 3, x_21); -lean_ctor_set(x_29, 4, x_22); -lean_ctor_set(x_29, 5, x_23); -lean_ctor_set(x_1, 0, x_29); -x_30 = lean_box(0); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_30); -lean_ctor_set(x_31, 1, x_1); -return x_31; +lean_ctor_set(x_30, 0, x_25); +lean_ctor_set(x_30, 1, x_26); +lean_ctor_set(x_30, 2, x_29); +lean_ctor_set(x_30, 3, x_27); +x_31 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_31, 0, x_20); +lean_ctor_set(x_31, 1, x_21); +lean_ctor_set(x_31, 2, x_30); +lean_ctor_set(x_31, 3, x_22); +lean_ctor_set(x_31, 4, x_23); +lean_ctor_set(x_31, 5, x_24); +lean_ctor_set(x_1, 0, x_31); +x_32 = lean_box(0); +x_33 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_33, 0, x_32); +lean_ctor_set(x_33, 1, x_1); +return x_33; } } 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; 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_32 = lean_ctor_get(x_1, 1); -x_33 = lean_ctor_get(x_1, 2); -x_34 = lean_ctor_get(x_1, 3); -x_35 = lean_ctor_get(x_1, 4); -x_36 = lean_ctor_get(x_1, 5); +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_34 = lean_ctor_get(x_1, 1); +x_35 = lean_ctor_get(x_1, 2); +x_36 = lean_ctor_get(x_1, 3); +x_37 = lean_ctor_get(x_1, 4); +x_38 = lean_ctor_get(x_1, 5); +lean_inc(x_38); +lean_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); -lean_inc(x_33); -lean_inc(x_32); lean_dec(x_1); -x_37 = lean_ctor_get(x_2, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_2, 1); -lean_inc(x_38); -x_39 = lean_ctor_get(x_2, 3); +x_39 = lean_ctor_get(x_2, 0); lean_inc(x_39); -x_40 = lean_ctor_get(x_2, 4); +x_40 = lean_ctor_get(x_2, 1); lean_inc(x_40); -x_41 = lean_ctor_get(x_2, 5); +x_41 = lean_ctor_get(x_2, 3); lean_inc(x_41); +x_42 = lean_ctor_get(x_2, 4); +lean_inc(x_42); +x_43 = lean_ctor_get(x_2, 5); +lean_inc(x_43); if (lean_is_exclusive(x_2)) { lean_ctor_release(x_2, 0); lean_ctor_release(x_2, 1); @@ -20441,56 +20782,60 @@ if (lean_is_exclusive(x_2)) { lean_ctor_release(x_2, 3); lean_ctor_release(x_2, 4); lean_ctor_release(x_2, 5); - x_42 = x_2; + x_44 = x_2; } else { lean_dec_ref(x_2); - x_42 = lean_box(0); + x_44 = lean_box(0); } -x_43 = lean_ctor_get(x_3, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_3, 1); -lean_inc(x_44); +x_45 = lean_ctor_get(x_3, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_3, 1); +lean_inc(x_46); +x_47 = lean_ctor_get(x_3, 3); +lean_inc(x_47); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); - x_45 = x_3; + lean_ctor_release(x_3, 3); + x_48 = x_3; } else { lean_dec_ref(x_3); - x_45 = lean_box(0); + x_48 = lean_box(0); } -x_46 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_45)) { - x_47 = lean_alloc_ctor(0, 3, 0); +x_49 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_48)) { + x_50 = lean_alloc_ctor(0, 4, 0); } else { - x_47 = x_45; + x_50 = x_48; } -lean_ctor_set(x_47, 0, x_43); -lean_ctor_set(x_47, 1, x_44); -lean_ctor_set(x_47, 2, x_46); -if (lean_is_scalar(x_42)) { - x_48 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_46); +lean_ctor_set(x_50, 2, x_49); +lean_ctor_set(x_50, 3, x_47); +if (lean_is_scalar(x_44)) { + x_51 = lean_alloc_ctor(0, 6, 0); } else { - x_48 = x_42; + x_51 = x_44; } -lean_ctor_set(x_48, 0, x_37); -lean_ctor_set(x_48, 1, x_38); -lean_ctor_set(x_48, 2, x_47); -lean_ctor_set(x_48, 3, x_39); -lean_ctor_set(x_48, 4, x_40); -lean_ctor_set(x_48, 5, x_41); -x_49 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_32); -lean_ctor_set(x_49, 2, x_33); -lean_ctor_set(x_49, 3, x_34); -lean_ctor_set(x_49, 4, x_35); -lean_ctor_set(x_49, 5, x_36); -x_50 = lean_box(0); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_49); -return x_51; +lean_ctor_set(x_51, 0, x_39); +lean_ctor_set(x_51, 1, x_40); +lean_ctor_set(x_51, 2, x_50); +lean_ctor_set(x_51, 3, x_41); +lean_ctor_set(x_51, 4, x_42); +lean_ctor_set(x_51, 5, x_43); +x_52 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_34); +lean_ctor_set(x_52, 2, x_35); +lean_ctor_set(x_52, 3, x_36); +lean_ctor_set(x_52, 4, x_37); +lean_ctor_set(x_52, 5, x_38); +x_53 = lean_box(0); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_52); +return x_54; } } } @@ -20566,90 +20911,97 @@ return x_9; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; +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_inc(x_21); lean_dec(x_12); -x_23 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_23, 0, x_21); -lean_ctor_set(x_23, 1, x_22); -lean_ctor_set(x_23, 2, x_6); -lean_ctor_set(x_11, 2, x_23); +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; } } 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; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -x_26 = lean_ctor_get(x_11, 3); -x_27 = lean_ctor_get(x_11, 4); -x_28 = lean_ctor_get(x_11, 5); +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_25 = lean_ctor_get(x_11, 0); +x_26 = lean_ctor_get(x_11, 1); +x_27 = lean_ctor_get(x_11, 3); +x_28 = lean_ctor_get(x_11, 4); +x_29 = lean_ctor_get(x_11, 5); +lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); lean_dec(x_11); -x_29 = lean_ctor_get(x_12, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_12, 1); +x_30 = lean_ctor_get(x_12, 0); lean_inc(x_30); +x_31 = lean_ctor_get(x_12, 1); +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); - x_31 = x_12; + lean_ctor_release(x_12, 3); + x_33 = x_12; } else { lean_dec_ref(x_12); - x_31 = lean_box(0); + x_33 = lean_box(0); } -if (lean_is_scalar(x_31)) { - x_32 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_33)) { + x_34 = lean_alloc_ctor(0, 4, 0); } else { - x_32 = x_31; + x_34 = x_33; } -lean_ctor_set(x_32, 0, x_29); -lean_ctor_set(x_32, 1, x_30); -lean_ctor_set(x_32, 2, x_6); -x_33 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_33, 0, x_24); -lean_ctor_set(x_33, 1, x_25); -lean_ctor_set(x_33, 2, x_32); -lean_ctor_set(x_33, 3, x_26); -lean_ctor_set(x_33, 4, x_27); -lean_ctor_set(x_33, 5, x_28); -lean_ctor_set(x_10, 0, x_33); +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; } } else { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_34 = lean_ctor_get(x_10, 1); -x_35 = lean_ctor_get(x_10, 2); -x_36 = lean_ctor_get(x_10, 3); -x_37 = lean_ctor_get(x_10, 4); -x_38 = 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; +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_inc(x_40); +lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); lean_dec(x_10); -x_39 = lean_ctor_get(x_11, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_11, 1); -lean_inc(x_40); -x_41 = lean_ctor_get(x_11, 3); +x_41 = lean_ctor_get(x_11, 0); lean_inc(x_41); -x_42 = lean_ctor_get(x_11, 4); +x_42 = lean_ctor_get(x_11, 1); lean_inc(x_42); -x_43 = lean_ctor_get(x_11, 5); +x_43 = lean_ctor_get(x_11, 3); lean_inc(x_43); +x_44 = lean_ctor_get(x_11, 4); +lean_inc(x_44); +x_45 = lean_ctor_get(x_11, 5); +lean_inc(x_45); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); @@ -20657,70 +21009,74 @@ 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_44 = x_11; + x_46 = x_11; } else { lean_dec_ref(x_11); - x_44 = lean_box(0); + x_46 = lean_box(0); } -x_45 = lean_ctor_get(x_12, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_12, 1); -lean_inc(x_46); +x_47 = lean_ctor_get(x_12, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_12, 1); +lean_inc(x_48); +x_49 = lean_ctor_get(x_12, 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); - x_47 = x_12; + lean_ctor_release(x_12, 3); + x_50 = x_12; } else { lean_dec_ref(x_12); - x_47 = lean_box(0); + x_50 = lean_box(0); } -if (lean_is_scalar(x_47)) { - x_48 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(0, 4, 0); } else { - x_48 = x_47; + x_51 = x_50; } -lean_ctor_set(x_48, 0, x_45); -lean_ctor_set(x_48, 1, x_46); -lean_ctor_set(x_48, 2, x_6); -if (lean_is_scalar(x_44)) { - x_49 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_51, 0, x_47); +lean_ctor_set(x_51, 1, x_48); +lean_ctor_set(x_51, 2, x_6); +lean_ctor_set(x_51, 3, x_49); +if (lean_is_scalar(x_46)) { + x_52 = lean_alloc_ctor(0, 6, 0); } else { - x_49 = x_44; + x_52 = x_46; } -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); -x_50 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_50, 0, x_49); -lean_ctor_set(x_50, 1, x_34); -lean_ctor_set(x_50, 2, x_35); -lean_ctor_set(x_50, 3, x_36); -lean_ctor_set(x_50, 4, x_37); -lean_ctor_set(x_50, 5, x_38); -lean_ctor_set(x_9, 1, x_50); +lean_ctor_set(x_52, 0, x_41); +lean_ctor_set(x_52, 1, x_42); +lean_ctor_set(x_52, 2, x_51); +lean_ctor_set(x_52, 3, x_43); +lean_ctor_set(x_52, 4, x_44); +lean_ctor_set(x_52, 5, x_45); +x_53 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_36); +lean_ctor_set(x_53, 2, x_37); +lean_ctor_set(x_53, 3, x_38); +lean_ctor_set(x_53, 4, x_39); +lean_ctor_set(x_53, 5, x_40); +lean_ctor_set(x_9, 1, x_53); return x_9; } } 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; lean_object* x_70; -x_51 = lean_ctor_get(x_9, 0); -lean_inc(x_51); -lean_dec(x_9); -x_52 = lean_ctor_get(x_10, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_10, 2); -lean_inc(x_53); -x_54 = lean_ctor_get(x_10, 3); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; 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); -x_55 = lean_ctor_get(x_10, 4); +lean_dec(x_9); +x_55 = lean_ctor_get(x_10, 1); lean_inc(x_55); -x_56 = lean_ctor_get(x_10, 5); +x_56 = lean_ctor_get(x_10, 2); lean_inc(x_56); +x_57 = lean_ctor_get(x_10, 3); +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); @@ -20728,21 +21084,21 @@ if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 3); lean_ctor_release(x_10, 4); lean_ctor_release(x_10, 5); - x_57 = x_10; + x_60 = x_10; } else { lean_dec_ref(x_10); - x_57 = lean_box(0); + x_60 = lean_box(0); } -x_58 = lean_ctor_get(x_11, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_11, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_11, 3); -lean_inc(x_60); -x_61 = lean_ctor_get(x_11, 4); +x_61 = lean_ctor_get(x_11, 0); lean_inc(x_61); -x_62 = lean_ctor_get(x_11, 5); +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); @@ -20750,334 +21106,353 @@ 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_63 = x_11; + x_66 = x_11; } else { lean_dec_ref(x_11); - x_63 = lean_box(0); + x_66 = lean_box(0); } -x_64 = lean_ctor_get(x_12, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_12, 1); -lean_inc(x_65); +x_67 = lean_ctor_get(x_12, 0); +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); - x_66 = x_12; + lean_ctor_release(x_12, 3); + x_70 = x_12; } else { lean_dec_ref(x_12); - x_66 = lean_box(0); + 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_67 = lean_alloc_ctor(0, 3, 0); + x_72 = lean_alloc_ctor(0, 6, 0); } else { - x_67 = x_66; + x_72 = x_66; } -lean_ctor_set(x_67, 0, x_64); -lean_ctor_set(x_67, 1, x_65); -lean_ctor_set(x_67, 2, x_6); -if (lean_is_scalar(x_63)) { - x_68 = lean_alloc_ctor(0, 6, 0); +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_68 = x_63; + x_73 = x_60; } -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_57)) { - x_69 = lean_alloc_ctor(0, 6, 0); -} else { - x_69 = x_57; -} -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_52); -lean_ctor_set(x_69, 2, x_53); -lean_ctor_set(x_69, 3, x_54); -lean_ctor_set(x_69, 4, x_55); -lean_ctor_set(x_69, 5, x_56); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_51); -lean_ctor_set(x_70, 1, x_69); -return x_70; +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; } } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_71 = lean_ctor_get(x_9, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_71, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_72, 2); -lean_inc(x_73); -x_74 = !lean_is_exclusive(x_9); -if (x_74 == 0) -{ -lean_object* x_75; uint8_t x_76; +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_dec(x_75); -x_76 = !lean_is_exclusive(x_71); -if (x_76 == 0) -{ -lean_object* x_77; uint8_t x_78; -x_77 = lean_ctor_get(x_71, 0); -lean_dec(x_77); -x_78 = !lean_is_exclusive(x_72); +lean_inc(x_75); +x_76 = lean_ctor_get(x_75, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +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_72, 2); +x_79 = lean_ctor_get(x_9, 1); lean_dec(x_79); -x_80 = !lean_is_exclusive(x_73); +x_80 = !lean_is_exclusive(x_75); if (x_80 == 0) { -lean_object* x_81; -x_81 = lean_ctor_get(x_73, 2); +lean_object* x_81; uint8_t x_82; +x_81 = lean_ctor_get(x_75, 0); lean_dec(x_81); -lean_ctor_set(x_73, 2, x_6); +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; } else { -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_73, 0); -x_83 = lean_ctor_get(x_73, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_73); -x_84 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -lean_ctor_set(x_84, 2, x_6); -lean_ctor_set(x_72, 2, x_84); -return x_9; -} -} -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; -x_85 = lean_ctor_get(x_72, 0); -x_86 = lean_ctor_get(x_72, 1); -x_87 = lean_ctor_get(x_72, 3); -x_88 = lean_ctor_get(x_72, 4); -x_89 = lean_ctor_get(x_72, 5); -lean_inc(x_89); +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_inc(x_86); -lean_inc(x_85); -lean_dec(x_72); -x_90 = lean_ctor_get(x_73, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_73, 1); +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - x_92 = x_73; -} else { - lean_dec_ref(x_73); - x_92 = lean_box(0); -} -if (lean_is_scalar(x_92)) { - x_93 = lean_alloc_ctor(0, 3, 0); -} else { - x_93 = x_92; -} -lean_ctor_set(x_93, 0, x_90); -lean_ctor_set(x_93, 1, x_91); -lean_ctor_set(x_93, 2, x_6); -x_94 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_94, 0, x_85); -lean_ctor_set(x_94, 1, x_86); -lean_ctor_set(x_94, 2, x_93); -lean_ctor_set(x_94, 3, x_87); -lean_ctor_set(x_94, 4, x_88); -lean_ctor_set(x_94, 5, x_89); -lean_ctor_set(x_71, 0, x_94); -return x_9; -} -} -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; -x_95 = lean_ctor_get(x_71, 1); -x_96 = lean_ctor_get(x_71, 2); -x_97 = lean_ctor_get(x_71, 3); -x_98 = lean_ctor_get(x_71, 4); -x_99 = lean_ctor_get(x_71, 5); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); +lean_inc(x_90); +lean_dec(x_76); +x_95 = lean_ctor_get(x_77, 0); lean_inc(x_95); -lean_dec(x_71); -x_100 = lean_ctor_get(x_72, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_72, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_72, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_72, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_72, 5); -lean_inc(x_104); -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_105 = x_72; +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; } else { - lean_dec_ref(x_72); - x_105 = lean_box(0); + lean_dec_ref(x_77); + x_98 = lean_box(0); } -x_106 = lean_ctor_get(x_73, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_73, 1); -lean_inc(x_107); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - x_108 = x_73; +if (lean_is_scalar(x_98)) { + x_99 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_73); - x_108 = lean_box(0); + x_99 = x_98; } -if (lean_is_scalar(x_108)) { - x_109 = lean_alloc_ctor(0, 3, 0); -} else { - x_109 = x_108; -} -lean_ctor_set(x_109, 0, x_106); -lean_ctor_set(x_109, 1, x_107); -lean_ctor_set(x_109, 2, x_6); -if (lean_is_scalar(x_105)) { - x_110 = lean_alloc_ctor(0, 6, 0); -} else { - x_110 = x_105; -} -lean_ctor_set(x_110, 0, x_100); -lean_ctor_set(x_110, 1, x_101); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_102); -lean_ctor_set(x_110, 4, x_103); -lean_ctor_set(x_110, 5, x_104); -x_111 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_111, 0, x_110); -lean_ctor_set(x_111, 1, x_95); -lean_ctor_set(x_111, 2, x_96); -lean_ctor_set(x_111, 3, x_97); -lean_ctor_set(x_111, 4, x_98); -lean_ctor_set(x_111, 5, x_99); -lean_ctor_set(x_9, 1, x_111); +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_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_112 = lean_ctor_get(x_9, 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_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; +} else { + lean_dec_ref(x_76); + x_111 = lean_box(0); +} +x_112 = lean_ctor_get(x_77, 0); lean_inc(x_112); -lean_dec(x_9); -x_113 = lean_ctor_get(x_71, 1); +x_113 = lean_ctor_get(x_77, 1); lean_inc(x_113); -x_114 = lean_ctor_get(x_71, 2); +x_114 = lean_ctor_get(x_77, 3); lean_inc(x_114); -x_115 = lean_ctor_get(x_71, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_71, 4); -lean_inc(x_116); -x_117 = lean_ctor_get(x_71, 5); -lean_inc(x_117); -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_118 = x_71; +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_71); - x_118 = lean_box(0); + lean_dec_ref(x_77); + x_115 = lean_box(0); } -x_119 = lean_ctor_get(x_72, 0); +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 4, 0); +} else { + x_116 = x_115; +} +lean_ctor_set(x_116, 0, x_112); +lean_ctor_set(x_116, 1, x_113); +lean_ctor_set(x_116, 2, x_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); -x_120 = lean_ctor_get(x_72, 1); +lean_dec(x_9); +x_120 = lean_ctor_get(x_75, 1); lean_inc(x_120); -x_121 = lean_ctor_get(x_72, 3); +x_121 = lean_ctor_get(x_75, 2); lean_inc(x_121); -x_122 = lean_ctor_get(x_72, 4); +x_122 = lean_ctor_get(x_75, 3); lean_inc(x_122); -x_123 = lean_ctor_get(x_72, 5); +x_123 = lean_ctor_get(x_75, 4); lean_inc(x_123); -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_124 = x_72; +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_72); - x_124 = lean_box(0); + lean_dec_ref(x_75); + x_125 = lean_box(0); } -x_125 = lean_ctor_get(x_73, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_73, 1); +x_126 = lean_ctor_get(x_76, 0); lean_inc(x_126); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - x_127 = x_73; +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_73); - x_127 = lean_box(0); + lean_dec_ref(x_76); + x_131 = lean_box(0); } -if (lean_is_scalar(x_127)) { - x_128 = lean_alloc_ctor(0, 3, 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 { - x_128 = x_127; + lean_dec_ref(x_77); + x_135 = lean_box(0); } -lean_ctor_set(x_128, 0, x_125); -lean_ctor_set(x_128, 1, x_126); -lean_ctor_set(x_128, 2, x_6); -if (lean_is_scalar(x_124)) { - x_129 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_129 = x_124; + x_136 = x_135; } -lean_ctor_set(x_129, 0, x_119); -lean_ctor_set(x_129, 1, x_120); -lean_ctor_set(x_129, 2, x_128); -lean_ctor_set(x_129, 3, x_121); -lean_ctor_set(x_129, 4, x_122); -lean_ctor_set(x_129, 5, x_123); -if (lean_is_scalar(x_118)) { - x_130 = lean_alloc_ctor(0, 6, 0); +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_130 = x_118; + x_137 = x_131; } -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); -x_131 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_131, 0, x_112); -lean_ctor_set(x_131, 1, x_130); -return 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; } } } @@ -21153,90 +21528,97 @@ return x_11; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; +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_inc(x_23); lean_dec(x_14); -x_25 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_25, 0, x_23); -lean_ctor_set(x_25, 1, x_24); -lean_ctor_set(x_25, 2, x_8); -lean_ctor_set(x_13, 2, x_25); +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; } } 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; -x_26 = lean_ctor_get(x_13, 0); -x_27 = lean_ctor_get(x_13, 1); -x_28 = lean_ctor_get(x_13, 3); -x_29 = lean_ctor_get(x_13, 4); -x_30 = lean_ctor_get(x_13, 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; +x_27 = lean_ctor_get(x_13, 0); +x_28 = lean_ctor_get(x_13, 1); +x_29 = lean_ctor_get(x_13, 3); +x_30 = lean_ctor_get(x_13, 4); +x_31 = lean_ctor_get(x_13, 5); +lean_inc(x_31); lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); -lean_inc(x_26); lean_dec(x_13); -x_31 = lean_ctor_get(x_14, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_14, 1); +x_32 = lean_ctor_get(x_14, 0); lean_inc(x_32); +x_33 = lean_ctor_get(x_14, 1); +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); - x_33 = x_14; + lean_ctor_release(x_14, 3); + x_35 = x_14; } else { lean_dec_ref(x_14); - x_33 = lean_box(0); + x_35 = lean_box(0); } -if (lean_is_scalar(x_33)) { - x_34 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_35)) { + x_36 = lean_alloc_ctor(0, 4, 0); } else { - x_34 = x_33; + x_36 = x_35; } -lean_ctor_set(x_34, 0, x_31); -lean_ctor_set(x_34, 1, x_32); -lean_ctor_set(x_34, 2, x_8); -x_35 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_35, 0, x_26); -lean_ctor_set(x_35, 1, x_27); -lean_ctor_set(x_35, 2, x_34); -lean_ctor_set(x_35, 3, x_28); -lean_ctor_set(x_35, 4, x_29); -lean_ctor_set(x_35, 5, x_30); -lean_ctor_set(x_12, 0, x_35); +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; } } 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; -x_36 = lean_ctor_get(x_12, 1); -x_37 = lean_ctor_get(x_12, 2); -x_38 = lean_ctor_get(x_12, 3); -x_39 = lean_ctor_get(x_12, 4); -x_40 = 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; +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_inc(x_42); +lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); lean_dec(x_12); -x_41 = lean_ctor_get(x_13, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_13, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_13, 3); +x_43 = lean_ctor_get(x_13, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_13, 4); +x_44 = lean_ctor_get(x_13, 1); lean_inc(x_44); -x_45 = lean_ctor_get(x_13, 5); +x_45 = lean_ctor_get(x_13, 3); lean_inc(x_45); +x_46 = lean_ctor_get(x_13, 4); +lean_inc(x_46); +x_47 = lean_ctor_get(x_13, 5); +lean_inc(x_47); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); @@ -21244,70 +21626,74 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_46 = x_13; + x_48 = x_13; } else { lean_dec_ref(x_13); - x_46 = lean_box(0); + x_48 = lean_box(0); } -x_47 = lean_ctor_get(x_14, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_14, 1); -lean_inc(x_48); +x_49 = lean_ctor_get(x_14, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_14, 1); +lean_inc(x_50); +x_51 = lean_ctor_get(x_14, 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); - x_49 = x_14; + lean_ctor_release(x_14, 3); + x_52 = x_14; } else { lean_dec_ref(x_14); - x_49 = lean_box(0); + x_52 = lean_box(0); } -if (lean_is_scalar(x_49)) { - x_50 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_52)) { + x_53 = lean_alloc_ctor(0, 4, 0); } else { - x_50 = x_49; + x_53 = x_52; } -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set(x_50, 2, x_8); -if (lean_is_scalar(x_46)) { - x_51 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_8); +lean_ctor_set(x_53, 3, x_51); +if (lean_is_scalar(x_48)) { + x_54 = lean_alloc_ctor(0, 6, 0); } else { - x_51 = x_46; + x_54 = x_48; } -lean_ctor_set(x_51, 0, x_41); -lean_ctor_set(x_51, 1, x_42); -lean_ctor_set(x_51, 2, x_50); -lean_ctor_set(x_51, 3, x_43); -lean_ctor_set(x_51, 4, x_44); -lean_ctor_set(x_51, 5, x_45); -x_52 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_36); -lean_ctor_set(x_52, 2, x_37); -lean_ctor_set(x_52, 3, x_38); -lean_ctor_set(x_52, 4, x_39); -lean_ctor_set(x_52, 5, x_40); -lean_ctor_set(x_11, 1, x_52); +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_44); +lean_ctor_set(x_54, 2, x_53); +lean_ctor_set(x_54, 3, x_45); +lean_ctor_set(x_54, 4, x_46); +lean_ctor_set(x_54, 5, x_47); +x_55 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_55, 0, x_54); +lean_ctor_set(x_55, 1, x_38); +lean_ctor_set(x_55, 2, x_39); +lean_ctor_set(x_55, 3, x_40); +lean_ctor_set(x_55, 4, x_41); +lean_ctor_set(x_55, 5, x_42); +lean_ctor_set(x_11, 1, x_55); return x_11; } } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_53 = lean_ctor_get(x_11, 0); -lean_inc(x_53); -lean_dec(x_11); -x_54 = lean_ctor_get(x_12, 1); -lean_inc(x_54); -x_55 = lean_ctor_get(x_12, 2); -lean_inc(x_55); -x_56 = lean_ctor_get(x_12, 3); +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); -x_57 = lean_ctor_get(x_12, 4); +lean_dec(x_11); +x_57 = lean_ctor_get(x_12, 1); lean_inc(x_57); -x_58 = lean_ctor_get(x_12, 5); +x_58 = lean_ctor_get(x_12, 2); lean_inc(x_58); +x_59 = lean_ctor_get(x_12, 3); +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); @@ -21315,21 +21701,21 @@ if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); lean_ctor_release(x_12, 5); - x_59 = x_12; + x_62 = x_12; } else { lean_dec_ref(x_12); - x_59 = lean_box(0); + x_62 = lean_box(0); } -x_60 = lean_ctor_get(x_13, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_13, 1); -lean_inc(x_61); -x_62 = lean_ctor_get(x_13, 3); -lean_inc(x_62); -x_63 = lean_ctor_get(x_13, 4); +x_63 = lean_ctor_get(x_13, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_13, 5); +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); @@ -21337,334 +21723,353 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_65 = x_13; + x_68 = x_13; } else { lean_dec_ref(x_13); - x_65 = lean_box(0); + x_68 = lean_box(0); } -x_66 = lean_ctor_get(x_14, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_14, 1); -lean_inc(x_67); +x_69 = lean_ctor_get(x_14, 0); +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); - x_68 = x_14; + lean_ctor_release(x_14, 3); + x_72 = x_14; } else { lean_dec_ref(x_14); - x_68 = lean_box(0); + 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_69 = lean_alloc_ctor(0, 3, 0); + x_74 = lean_alloc_ctor(0, 6, 0); } else { - x_69 = x_68; + x_74 = x_68; } -lean_ctor_set(x_69, 0, x_66); -lean_ctor_set(x_69, 1, x_67); -lean_ctor_set(x_69, 2, x_8); -if (lean_is_scalar(x_65)) { - x_70 = lean_alloc_ctor(0, 6, 0); +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_70 = x_65; + x_75 = x_62; } -lean_ctor_set(x_70, 0, x_60); -lean_ctor_set(x_70, 1, x_61); -lean_ctor_set(x_70, 2, x_69); -lean_ctor_set(x_70, 3, x_62); -lean_ctor_set(x_70, 4, x_63); -lean_ctor_set(x_70, 5, x_64); -if (lean_is_scalar(x_59)) { - x_71 = lean_alloc_ctor(0, 6, 0); -} else { - x_71 = x_59; -} -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_54); -lean_ctor_set(x_71, 2, x_55); -lean_ctor_set(x_71, 3, x_56); -lean_ctor_set(x_71, 4, x_57); -lean_ctor_set(x_71, 5, x_58); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_53); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; uint8_t x_76; -x_73 = lean_ctor_get(x_11, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_74, 2); -lean_inc(x_75); -x_76 = !lean_is_exclusive(x_11); -if (x_76 == 0) -{ -lean_object* x_77; uint8_t x_78; +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_dec(x_77); -x_78 = !lean_is_exclusive(x_73); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_73, 0); -lean_dec(x_79); -x_80 = !lean_is_exclusive(x_74); +lean_inc(x_77); +x_78 = lean_ctor_get(x_77, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_78, 2); +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_74, 2); +x_81 = lean_ctor_get(x_11, 1); lean_dec(x_81); -x_82 = !lean_is_exclusive(x_75); +x_82 = !lean_is_exclusive(x_77); if (x_82 == 0) { -lean_object* x_83; -x_83 = lean_ctor_get(x_75, 2); +lean_object* x_83; uint8_t x_84; +x_83 = lean_ctor_get(x_77, 0); lean_dec(x_83); -lean_ctor_set(x_75, 2, x_8); +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; } else { -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_75, 0); -x_85 = lean_ctor_get(x_75, 1); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_75); -x_86 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_86, 0, x_84); -lean_ctor_set(x_86, 1, x_85); -lean_ctor_set(x_86, 2, x_8); -lean_ctor_set(x_74, 2, x_86); -return x_11; -} -} -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; -x_87 = lean_ctor_get(x_74, 0); -x_88 = lean_ctor_get(x_74, 1); -x_89 = lean_ctor_get(x_74, 3); -x_90 = lean_ctor_get(x_74, 4); -x_91 = lean_ctor_get(x_74, 5); -lean_inc(x_91); +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_inc(x_88); -lean_inc(x_87); -lean_dec(x_74); -x_92 = lean_ctor_get(x_75, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_75, 1); +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); -if (lean_is_exclusive(x_75)) { - lean_ctor_release(x_75, 0); - lean_ctor_release(x_75, 1); - lean_ctor_release(x_75, 2); - x_94 = x_75; -} else { - lean_dec_ref(x_75); - x_94 = lean_box(0); -} -if (lean_is_scalar(x_94)) { - x_95 = lean_alloc_ctor(0, 3, 0); -} else { - x_95 = x_94; -} -lean_ctor_set(x_95, 0, x_92); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_95, 2, x_8); -x_96 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_96, 0, x_87); -lean_ctor_set(x_96, 1, x_88); -lean_ctor_set(x_96, 2, x_95); -lean_ctor_set(x_96, 3, x_89); -lean_ctor_set(x_96, 4, x_90); -lean_ctor_set(x_96, 5, x_91); -lean_ctor_set(x_73, 0, x_96); -return x_11; -} -} -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; -x_97 = lean_ctor_get(x_73, 1); -x_98 = lean_ctor_get(x_73, 2); -x_99 = lean_ctor_get(x_73, 3); -x_100 = lean_ctor_get(x_73, 4); -x_101 = lean_ctor_get(x_73, 5); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); +lean_inc(x_92); +lean_dec(x_78); +x_97 = lean_ctor_get(x_79, 0); lean_inc(x_97); -lean_dec(x_73); -x_102 = lean_ctor_get(x_74, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_74, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_74, 3); -lean_inc(x_104); -x_105 = lean_ctor_get(x_74, 4); -lean_inc(x_105); -x_106 = lean_ctor_get(x_74, 5); -lean_inc(x_106); -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); - lean_ctor_release(x_74, 5); - x_107 = x_74; +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; } else { - lean_dec_ref(x_74); - x_107 = lean_box(0); + lean_dec_ref(x_79); + x_100 = lean_box(0); } -x_108 = lean_ctor_get(x_75, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_75, 1); -lean_inc(x_109); -if (lean_is_exclusive(x_75)) { - lean_ctor_release(x_75, 0); - lean_ctor_release(x_75, 1); - lean_ctor_release(x_75, 2); - x_110 = x_75; +if (lean_is_scalar(x_100)) { + x_101 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_75); - x_110 = lean_box(0); + x_101 = x_100; } -if (lean_is_scalar(x_110)) { - x_111 = lean_alloc_ctor(0, 3, 0); -} else { - x_111 = x_110; -} -lean_ctor_set(x_111, 0, x_108); -lean_ctor_set(x_111, 1, x_109); -lean_ctor_set(x_111, 2, x_8); -if (lean_is_scalar(x_107)) { - x_112 = lean_alloc_ctor(0, 6, 0); -} else { - x_112 = x_107; -} -lean_ctor_set(x_112, 0, x_102); -lean_ctor_set(x_112, 1, x_103); -lean_ctor_set(x_112, 2, x_111); -lean_ctor_set(x_112, 3, x_104); -lean_ctor_set(x_112, 4, x_105); -lean_ctor_set(x_112, 5, x_106); -x_113 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_97); -lean_ctor_set(x_113, 2, x_98); -lean_ctor_set(x_113, 3, x_99); -lean_ctor_set(x_113, 4, x_100); -lean_ctor_set(x_113, 5, x_101); -lean_ctor_set(x_11, 1, x_113); +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_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_114 = lean_ctor_get(x_11, 0); +lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; 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; +} else { + lean_dec_ref(x_78); + x_113 = lean_box(0); +} +x_114 = lean_ctor_get(x_79, 0); lean_inc(x_114); -lean_dec(x_11); -x_115 = lean_ctor_get(x_73, 1); +x_115 = lean_ctor_get(x_79, 1); lean_inc(x_115); -x_116 = lean_ctor_get(x_73, 2); +x_116 = lean_ctor_get(x_79, 3); lean_inc(x_116); -x_117 = lean_ctor_get(x_73, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_73, 4); -lean_inc(x_118); -x_119 = lean_ctor_get(x_73, 5); -lean_inc(x_119); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_120 = x_73; +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_73); - x_120 = lean_box(0); + lean_dec_ref(x_79); + x_117 = lean_box(0); } -x_121 = lean_ctor_get(x_74, 0); +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); -x_122 = lean_ctor_get(x_74, 1); +lean_dec(x_11); +x_122 = lean_ctor_get(x_77, 1); lean_inc(x_122); -x_123 = lean_ctor_get(x_74, 3); +x_123 = lean_ctor_get(x_77, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_74, 4); +x_124 = lean_ctor_get(x_77, 3); lean_inc(x_124); -x_125 = lean_ctor_get(x_74, 5); +x_125 = lean_ctor_get(x_77, 4); lean_inc(x_125); -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); - lean_ctor_release(x_74, 5); - x_126 = x_74; +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_74); - x_126 = lean_box(0); + lean_dec_ref(x_77); + x_127 = lean_box(0); } -x_127 = lean_ctor_get(x_75, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_75, 1); +x_128 = lean_ctor_get(x_78, 0); lean_inc(x_128); -if (lean_is_exclusive(x_75)) { - lean_ctor_release(x_75, 0); - lean_ctor_release(x_75, 1); - lean_ctor_release(x_75, 2); - x_129 = x_75; +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_75); - x_129 = lean_box(0); + lean_dec_ref(x_78); + x_133 = lean_box(0); } -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 3, 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 { - x_130 = x_129; + lean_dec_ref(x_79); + x_137 = lean_box(0); } -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set(x_130, 1, x_128); -lean_ctor_set(x_130, 2, x_8); -if (lean_is_scalar(x_126)) { - x_131 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_137)) { + x_138 = lean_alloc_ctor(0, 4, 0); } else { - x_131 = x_126; + x_138 = x_137; } -lean_ctor_set(x_131, 0, x_121); -lean_ctor_set(x_131, 1, x_122); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_123); -lean_ctor_set(x_131, 4, x_124); -lean_ctor_set(x_131, 5, x_125); -if (lean_is_scalar(x_120)) { - x_132 = lean_alloc_ctor(0, 6, 0); +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_132 = x_120; + x_139 = x_133; } -lean_ctor_set(x_132, 0, x_131); -lean_ctor_set(x_132, 1, x_115); -lean_ctor_set(x_132, 2, x_116); -lean_ctor_set(x_132, 3, x_117); -lean_ctor_set(x_132, 4, x_118); -lean_ctor_set(x_132, 5, x_119); -x_133 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_133, 0, x_114); -lean_ctor_set(x_133, 1, x_132); -return 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; } } } @@ -21875,90 +22280,97 @@ return x_39; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; +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_inc(x_52); lean_inc(x_51); lean_dec(x_42); -x_53 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -lean_ctor_set(x_53, 2, x_36); -lean_ctor_set(x_41, 2, x_53); +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; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); +x_61 = lean_ctor_get(x_42, 1); +lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 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); - x_61 = x_42; + lean_ctor_release(x_42, 3); + x_63 = x_42; } else { lean_dec_ref(x_42); - x_61 = lean_box(0); + x_63 = lean_box(0); } -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 4, 0); } else { - x_62 = x_61; + x_64 = x_63; } -lean_ctor_set(x_62, 0, x_59); -lean_ctor_set(x_62, 1, x_60); -lean_ctor_set(x_62, 2, x_36); -x_63 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_63, 0, x_54); -lean_ctor_set(x_63, 1, x_55); -lean_ctor_set(x_63, 2, x_62); -lean_ctor_set(x_63, 3, x_56); -lean_ctor_set(x_63, 4, x_57); -lean_ctor_set(x_63, 5, x_58); -lean_ctor_set(x_40, 0, 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, 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_40, 0, x_65); return x_39; } } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_64 = lean_ctor_get(x_40, 1); -x_65 = lean_ctor_get(x_40, 2); -x_66 = lean_ctor_get(x_40, 3); -x_67 = lean_ctor_get(x_40, 4); -x_68 = lean_ctor_get(x_40, 5); +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +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_inc(x_70); +lean_inc(x_69); lean_inc(x_68); lean_inc(x_67); lean_inc(x_66); -lean_inc(x_65); -lean_inc(x_64); lean_dec(x_40); -x_69 = lean_ctor_get(x_41, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_41, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_41, 3); +x_71 = lean_ctor_get(x_41, 0); lean_inc(x_71); -x_72 = lean_ctor_get(x_41, 4); +x_72 = lean_ctor_get(x_41, 1); lean_inc(x_72); -x_73 = lean_ctor_get(x_41, 5); +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); @@ -21966,70 +22378,74 @@ if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 3); lean_ctor_release(x_41, 4); lean_ctor_release(x_41, 5); - x_74 = x_41; + x_76 = x_41; } else { lean_dec_ref(x_41); - x_74 = lean_box(0); + x_76 = lean_box(0); } -x_75 = lean_ctor_get(x_42, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_42, 1); -lean_inc(x_76); +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); - x_77 = x_42; + lean_ctor_release(x_42, 3); + x_80 = x_42; } else { lean_dec_ref(x_42); - x_77 = lean_box(0); + x_80 = lean_box(0); } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_78 = x_77; + x_81 = x_80; } -lean_ctor_set(x_78, 0, x_75); -lean_ctor_set(x_78, 1, x_76); -lean_ctor_set(x_78, 2, x_36); -if (lean_is_scalar(x_74)) { - x_79 = lean_alloc_ctor(0, 6, 0); +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_79 = x_74; + x_82 = x_76; } -lean_ctor_set(x_79, 0, x_69); -lean_ctor_set(x_79, 1, x_70); -lean_ctor_set(x_79, 2, x_78); -lean_ctor_set(x_79, 3, x_71); -lean_ctor_set(x_79, 4, x_72); -lean_ctor_set(x_79, 5, x_73); -x_80 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_80, 0, x_79); -lean_ctor_set(x_80, 1, x_64); -lean_ctor_set(x_80, 2, x_65); -lean_ctor_set(x_80, 3, x_66); -lean_ctor_set(x_80, 4, x_67); -lean_ctor_set(x_80, 5, x_68); -lean_ctor_set(x_39, 1, x_80); +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_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; -x_81 = lean_ctor_get(x_39, 0); -lean_inc(x_81); -lean_dec(x_39); -x_82 = lean_ctor_get(x_40, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_40, 2); -lean_inc(x_83); -x_84 = lean_ctor_get(x_40, 3); +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); -x_85 = lean_ctor_get(x_40, 4); +lean_dec(x_39); +x_85 = lean_ctor_get(x_40, 1); lean_inc(x_85); -x_86 = lean_ctor_get(x_40, 5); +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); if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 0); lean_ctor_release(x_40, 1); @@ -22037,21 +22453,21 @@ 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_87 = x_40; + x_90 = x_40; } else { lean_dec_ref(x_40); - x_87 = lean_box(0); + x_90 = lean_box(0); } -x_88 = lean_ctor_get(x_41, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_41, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_41, 3); -lean_inc(x_90); -x_91 = lean_ctor_get(x_41, 4); +x_91 = lean_ctor_get(x_41, 0); lean_inc(x_91); -x_92 = lean_ctor_get(x_41, 5); +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); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); @@ -22059,334 +22475,353 @@ if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 3); lean_ctor_release(x_41, 4); lean_ctor_release(x_41, 5); - x_93 = x_41; + x_96 = x_41; } else { lean_dec_ref(x_41); - x_93 = lean_box(0); + x_96 = lean_box(0); } -x_94 = lean_ctor_get(x_42, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_42, 1); -lean_inc(x_95); +x_97 = lean_ctor_get(x_42, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_42, 1); +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); - x_96 = x_42; + lean_ctor_release(x_42, 3); + x_100 = x_42; } else { lean_dec_ref(x_42); - x_96 = lean_box(0); + x_100 = lean_box(0); } +if (lean_is_scalar(x_100)) { + x_101 = lean_alloc_ctor(0, 4, 0); +} else { + x_101 = x_100; +} +lean_ctor_set(x_101, 0, x_97); +lean_ctor_set(x_101, 1, x_98); +lean_ctor_set(x_101, 2, x_36); +lean_ctor_set(x_101, 3, x_99); if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 3, 0); + x_102 = lean_alloc_ctor(0, 6, 0); } else { - x_97 = x_96; + x_102 = x_96; } -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_36); -if (lean_is_scalar(x_93)) { - x_98 = lean_alloc_ctor(0, 6, 0); +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_98 = x_93; + x_103 = x_90; } -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); -if (lean_is_scalar(x_87)) { - x_99 = lean_alloc_ctor(0, 6, 0); -} else { - x_99 = x_87; -} -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_81); -lean_ctor_set(x_100, 1, x_99); -return x_100; +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; } } else { -lean_object* x_101; lean_object* x_102; lean_object* x_103; uint8_t x_104; -x_101 = lean_ctor_get(x_39, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_101, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_102, 2); -lean_inc(x_103); -x_104 = !lean_is_exclusive(x_39); -if (x_104 == 0) -{ -lean_object* x_105; uint8_t x_106; +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_dec(x_105); -x_106 = !lean_is_exclusive(x_101); -if (x_106 == 0) -{ -lean_object* x_107; uint8_t x_108; -x_107 = lean_ctor_get(x_101, 0); -lean_dec(x_107); -x_108 = !lean_is_exclusive(x_102); +lean_inc(x_105); +x_106 = lean_ctor_get(x_105, 0); +lean_inc(x_106); +x_107 = lean_ctor_get(x_106, 2); +lean_inc(x_107); +x_108 = !lean_is_exclusive(x_39); if (x_108 == 0) { lean_object* x_109; uint8_t x_110; -x_109 = lean_ctor_get(x_102, 2); +x_109 = lean_ctor_get(x_39, 1); lean_dec(x_109); -x_110 = !lean_is_exclusive(x_103); +x_110 = !lean_is_exclusive(x_105); if (x_110 == 0) { -lean_object* x_111; -x_111 = lean_ctor_get(x_103, 2); +lean_object* x_111; uint8_t x_112; +x_111 = lean_ctor_get(x_105, 0); lean_dec(x_111); -lean_ctor_set(x_103, 2, x_36); +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; } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_112 = lean_ctor_get(x_103, 0); -x_113 = lean_ctor_get(x_103, 1); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_103); -x_114 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_114, 0, x_112); -lean_ctor_set(x_114, 1, x_113); -lean_ctor_set(x_114, 2, x_36); -lean_ctor_set(x_102, 2, x_114); -return x_39; -} -} -else -{ -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_115 = lean_ctor_get(x_102, 0); -x_116 = lean_ctor_get(x_102, 1); -x_117 = lean_ctor_get(x_102, 3); -x_118 = lean_ctor_get(x_102, 4); -x_119 = lean_ctor_get(x_102, 5); -lean_inc(x_119); +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_inc(x_117); lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_102); -x_120 = lean_ctor_get(x_103, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_103, 1); +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); -if (lean_is_exclusive(x_103)) { - lean_ctor_release(x_103, 0); - lean_ctor_release(x_103, 1); - lean_ctor_release(x_103, 2); - x_122 = x_103; -} else { - lean_dec_ref(x_103); - x_122 = lean_box(0); -} -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(0, 3, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_120); -lean_ctor_set(x_123, 1, x_121); -lean_ctor_set(x_123, 2, x_36); -x_124 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_124, 0, x_115); -lean_ctor_set(x_124, 1, x_116); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_117); -lean_ctor_set(x_124, 4, x_118); -lean_ctor_set(x_124, 5, x_119); -lean_ctor_set(x_101, 0, x_124); -return x_39; -} -} -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; lean_object* x_140; lean_object* x_141; -x_125 = lean_ctor_get(x_101, 1); -x_126 = lean_ctor_get(x_101, 2); -x_127 = lean_ctor_get(x_101, 3); -x_128 = lean_ctor_get(x_101, 4); -x_129 = lean_ctor_get(x_101, 5); -lean_inc(x_129); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_126); +lean_inc(x_120); +lean_dec(x_106); +x_125 = lean_ctor_get(x_107, 0); lean_inc(x_125); -lean_dec(x_101); -x_130 = lean_ctor_get(x_102, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_102, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_102, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_102, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_102, 5); -lean_inc(x_134); -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_135 = x_102; +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_102); - x_135 = lean_box(0); + lean_dec_ref(x_107); + x_128 = lean_box(0); } -x_136 = lean_ctor_get(x_103, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_103, 1); -lean_inc(x_137); -if (lean_is_exclusive(x_103)) { - lean_ctor_release(x_103, 0); - lean_ctor_release(x_103, 1); - lean_ctor_release(x_103, 2); - x_138 = x_103; +if (lean_is_scalar(x_128)) { + x_129 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_103); - x_138 = lean_box(0); + x_129 = x_128; } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_36); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -x_141 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_125); -lean_ctor_set(x_141, 2, x_126); -lean_ctor_set(x_141, 3, x_127); -lean_ctor_set(x_141, 4, x_128); -lean_ctor_set(x_141, 5, x_129); -lean_ctor_set(x_39, 1, x_141); +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_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; -x_142 = lean_ctor_get(x_39, 0); +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; 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); -lean_dec(x_39); -x_143 = lean_ctor_get(x_101, 1); +x_143 = lean_ctor_get(x_107, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_101, 2); +x_144 = lean_ctor_get(x_107, 3); lean_inc(x_144); -x_145 = lean_ctor_get(x_101, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_101, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_101, 5); -lean_inc(x_147); -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_148 = x_101; +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_101); - x_148 = lean_box(0); + lean_dec_ref(x_107); + x_145 = lean_box(0); } -x_149 = lean_ctor_get(x_102, 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); -x_150 = lean_ctor_get(x_102, 1); +lean_dec(x_39); +x_150 = lean_ctor_get(x_105, 1); lean_inc(x_150); -x_151 = lean_ctor_get(x_102, 3); +x_151 = lean_ctor_get(x_105, 2); lean_inc(x_151); -x_152 = lean_ctor_get(x_102, 4); +x_152 = lean_ctor_get(x_105, 3); lean_inc(x_152); -x_153 = lean_ctor_get(x_102, 5); +x_153 = lean_ctor_get(x_105, 4); lean_inc(x_153); -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_154 = x_102; +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; } else { - lean_dec_ref(x_102); - x_154 = lean_box(0); + lean_dec_ref(x_105); + x_155 = lean_box(0); } -x_155 = lean_ctor_get(x_103, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_103, 1); +x_156 = lean_ctor_get(x_106, 0); lean_inc(x_156); -if (lean_is_exclusive(x_103)) { - lean_ctor_release(x_103, 0); - lean_ctor_release(x_103, 1); - lean_ctor_release(x_103, 2); - x_157 = x_103; +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; } else { - lean_dec_ref(x_103); - x_157 = lean_box(0); + lean_dec_ref(x_106); + x_161 = lean_box(0); } -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 3, 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; } else { - x_158 = x_157; + lean_dec_ref(x_107); + x_165 = lean_box(0); } -lean_ctor_set(x_158, 0, x_155); -lean_ctor_set(x_158, 1, x_156); -lean_ctor_set(x_158, 2, x_36); -if (lean_is_scalar(x_154)) { - x_159 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_165)) { + x_166 = lean_alloc_ctor(0, 4, 0); } else { - x_159 = x_154; + x_166 = x_165; } -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); -if (lean_is_scalar(x_148)) { - x_160 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_160 = x_148; + x_167 = x_161; } -lean_ctor_set(x_160, 0, x_159); -lean_ctor_set(x_160, 1, x_143); -lean_ctor_set(x_160, 2, x_144); -lean_ctor_set(x_160, 3, x_145); -lean_ctor_set(x_160, 4, x_146); -lean_ctor_set(x_160, 5, x_147); -x_161 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_161, 0, x_142); -lean_ctor_set(x_161, 1, x_160); -return x_161; +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_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; } } } @@ -22394,319 +22829,327 @@ return x_161; } else { -uint8_t x_162; uint8_t x_163; uint8_t 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; uint8_t x_173; lean_object* x_174; lean_object* x_175; -x_162 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_163 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_164 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -x_165 = lean_ctor_get(x_6, 0); -x_166 = lean_ctor_get(x_6, 2); -x_167 = lean_ctor_get(x_6, 3); -x_168 = lean_ctor_get(x_6, 4); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_inc(x_165); +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); lean_dec(x_6); -x_169 = lean_ctor_get(x_7, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_7, 4); -lean_inc(x_170); -x_171 = lean_array_get_size(x_166); -x_172 = lean_array_get_size(x_170); -x_173 = lean_nat_dec_eq(x_171, x_172); -lean_dec(x_172); -lean_dec(x_171); -lean_inc(x_170); -x_174 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_174, 0, x_165); -lean_ctor_set(x_174, 1, x_169); -lean_ctor_set(x_174, 2, x_170); -lean_ctor_set(x_174, 3, x_167); -lean_ctor_set(x_174, 4, x_168); -x_175 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_175, 0, x_174); -lean_ctor_set(x_175, 1, x_9); -lean_ctor_set(x_175, 2, x_10); -lean_ctor_set(x_175, 3, x_11); -lean_ctor_set(x_175, 4, x_12); -lean_ctor_set(x_175, 5, x_13); -lean_ctor_set(x_175, 6, x_14); -lean_ctor_set(x_175, 7, x_15); -lean_ctor_set(x_175, 8, x_16); -lean_ctor_set(x_175, 9, x_17); -lean_ctor_set_uint8(x_175, sizeof(void*)*10, x_162); -lean_ctor_set_uint8(x_175, sizeof(void*)*10 + 1, x_163); -lean_ctor_set_uint8(x_175, sizeof(void*)*10 + 2, x_164); -if (x_173 == 0) -{ -lean_object* x_176; -lean_dec(x_170); -lean_dec(x_166); -lean_dec(x_7); -lean_dec(x_3); -x_176 = lean_apply_2(x_2, x_175, x_8); -return x_176; -} -else -{ -lean_object* x_177; uint8_t x_178; -x_177 = lean_unsigned_to_nat(0u); -x_178 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_166, x_170, x_177); -lean_dec(x_170); -lean_dec(x_166); -lean_dec(x_7); -lean_dec(x_3); -if (x_178 == 0) -{ -lean_object* x_179; -x_179 = lean_apply_2(x_2, x_175, x_8); -return x_179; -} -else -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; -x_180 = lean_ctor_get(x_8, 0); -lean_inc(x_180); -x_181 = lean_ctor_get(x_180, 2); -lean_inc(x_181); +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); -x_182 = lean_ctor_get(x_181, 2); -lean_inc(x_182); -lean_dec(x_181); -x_183 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_184 = lean_ctor_get(x_183, 1); -lean_inc(x_184); -lean_dec(x_183); -x_185 = lean_apply_2(x_2, x_175, x_184); -if (lean_obj_tag(x_185) == 0) +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) { -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; -x_186 = lean_ctor_get(x_185, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_186, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_187, 2); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 0); -lean_inc(x_189); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - x_190 = x_185; -} else { - lean_dec_ref(x_185); - x_190 = lean_box(0); -} -x_191 = lean_ctor_get(x_186, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_186, 2); -lean_inc(x_192); -x_193 = lean_ctor_get(x_186, 3); -lean_inc(x_193); -x_194 = lean_ctor_get(x_186, 4); -lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 5); -lean_inc(x_195); -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_196 = x_186; -} else { - lean_dec_ref(x_186); - x_196 = lean_box(0); -} -x_197 = lean_ctor_get(x_187, 0); -lean_inc(x_197); -x_198 = lean_ctor_get(x_187, 1); -lean_inc(x_198); -x_199 = lean_ctor_get(x_187, 3); -lean_inc(x_199); -x_200 = lean_ctor_get(x_187, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_187, 5); -lean_inc(x_201); -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_202 = x_187; -} else { - lean_dec_ref(x_187); - x_202 = lean_box(0); -} -x_203 = lean_ctor_get(x_188, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_188, 1); -lean_inc(x_204); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - x_205 = x_188; -} else { - lean_dec_ref(x_188); - x_205 = lean_box(0); -} -if (lean_is_scalar(x_205)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_205; -} -lean_ctor_set(x_206, 0, x_203); -lean_ctor_set(x_206, 1, x_204); -lean_ctor_set(x_206, 2, x_182); -if (lean_is_scalar(x_202)) { - x_207 = lean_alloc_ctor(0, 6, 0); -} else { - x_207 = x_202; -} -lean_ctor_set(x_207, 0, x_197); -lean_ctor_set(x_207, 1, x_198); -lean_ctor_set(x_207, 2, x_206); -lean_ctor_set(x_207, 3, x_199); -lean_ctor_set(x_207, 4, x_200); -lean_ctor_set(x_207, 5, x_201); -if (lean_is_scalar(x_196)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_196; -} -lean_ctor_set(x_208, 0, x_207); -lean_ctor_set(x_208, 1, x_191); -lean_ctor_set(x_208, 2, x_192); -lean_ctor_set(x_208, 3, x_193); -lean_ctor_set(x_208, 4, x_194); -lean_ctor_set(x_208, 5, x_195); -if (lean_is_scalar(x_190)) { - x_209 = lean_alloc_ctor(0, 2, 0); -} else { - x_209 = x_190; -} -lean_ctor_set(x_209, 0, x_189); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_object* x_184; +lean_dec(x_178); +lean_dec(x_174); +lean_dec(x_7); +lean_dec(x_3); +x_184 = lean_apply_2(x_2, x_183, x_8); +return x_184; } 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_185, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_210, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_211, 2); -lean_inc(x_212); -x_213 = lean_ctor_get(x_185, 0); -lean_inc(x_213); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - x_214 = x_185; +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_dec(x_7); +lean_dec(x_3); +if (x_186 == 0) +{ +lean_object* x_187; +x_187 = lean_apply_2(x_2, x_183, x_8); +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_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); +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_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); +lean_inc(x_194); +x_195 = lean_ctor_get(x_194, 0); +lean_inc(x_195); +x_196 = lean_ctor_get(x_195, 2); +lean_inc(x_196); +x_197 = lean_ctor_get(x_193, 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_185); + lean_dec_ref(x_193); + x_198 = lean_box(0); +} +x_199 = lean_ctor_get(x_194, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_194, 2); +lean_inc(x_200); +x_201 = lean_ctor_get(x_194, 3); +lean_inc(x_201); +x_202 = lean_ctor_get(x_194, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_194, 5); +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); +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; +} else { + lean_dec_ref(x_195); + x_210 = 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; +} else { + lean_dec_ref(x_196); x_214 = lean_box(0); } -x_215 = lean_ctor_get(x_210, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_210, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_210, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_210, 4); -lean_inc(x_218); -x_219 = lean_ctor_get(x_210, 5); +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_190); +lean_ctor_set(x_215, 3, x_213); +if (lean_is_scalar(x_210)) { + x_216 = lean_alloc_ctor(0, 6, 0); +} else { + x_216 = x_210; +} +lean_ctor_set(x_216, 0, x_205); +lean_ctor_set(x_216, 1, x_206); +lean_ctor_set(x_216, 2, x_215); +lean_ctor_set(x_216, 3, x_207); +lean_ctor_set(x_216, 4, x_208); +lean_ctor_set(x_216, 5, x_209); +if (lean_is_scalar(x_204)) { + x_217 = lean_alloc_ctor(0, 6, 0); +} else { + x_217 = x_204; +} +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_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); -if (lean_is_exclusive(x_210)) { - lean_ctor_release(x_210, 0); - lean_ctor_release(x_210, 1); - lean_ctor_release(x_210, 2); - lean_ctor_release(x_210, 3); - lean_ctor_release(x_210, 4); - lean_ctor_release(x_210, 5); - x_220 = x_210; -} else { - lean_dec_ref(x_210); - x_220 = lean_box(0); -} -x_221 = lean_ctor_get(x_211, 0); +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_211, 1); +x_222 = lean_ctor_get(x_193, 0); lean_inc(x_222); -x_223 = lean_ctor_get(x_211, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_211, 4); -lean_inc(x_224); -x_225 = lean_ctor_get(x_211, 5); -lean_inc(x_225); -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); - lean_ctor_release(x_211, 5); - x_226 = x_211; +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_211); - x_226 = lean_box(0); + lean_dec_ref(x_193); + x_223 = lean_box(0); } -x_227 = lean_ctor_get(x_212, 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_212, 1); +x_228 = lean_ctor_get(x_219, 5); lean_inc(x_228); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - lean_ctor_release(x_212, 2); - x_229 = x_212; +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_212); + 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_230 = lean_alloc_ctor(0, 3, 0); + x_242 = lean_alloc_ctor(0, 6, 0); } else { - x_230 = x_229; + x_242 = x_229; } -lean_ctor_set(x_230, 0, x_227); -lean_ctor_set(x_230, 1, x_228); -lean_ctor_set(x_230, 2, x_182); -if (lean_is_scalar(x_226)) { - x_231 = lean_alloc_ctor(0, 6, 0); +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_231 = x_226; + x_243 = x_223; } -lean_ctor_set(x_231, 0, x_221); -lean_ctor_set(x_231, 1, x_222); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_223); -lean_ctor_set(x_231, 4, x_224); -lean_ctor_set(x_231, 5, x_225); -if (lean_is_scalar(x_220)) { - x_232 = lean_alloc_ctor(0, 6, 0); -} else { - x_232 = x_220; -} -lean_ctor_set(x_232, 0, x_231); -lean_ctor_set(x_232, 1, x_215); -lean_ctor_set(x_232, 2, x_216); -lean_ctor_set(x_232, 3, x_217); -lean_ctor_set(x_232, 4, x_218); -lean_ctor_set(x_232, 5, x_219); -if (lean_is_scalar(x_214)) { - x_233 = lean_alloc_ctor(1, 2, 0); -} else { - x_233 = x_214; -} -lean_ctor_set(x_233, 0, x_213); -lean_ctor_set(x_233, 1, x_232); -return x_233; +lean_ctor_set(x_243, 0, x_222); +lean_ctor_set(x_243, 1, x_242); +return x_243; } } } @@ -24179,11 +24622,9 @@ lean_object* _init_l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___close _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = lean_box(0); -x_2 = l_Lean_prodToExpr___rarg___lambda__1___closed__4; -x_3 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_3, 0, x_2); -lean_ctor_set(x_3, 1, x_1); +x_1 = l_Lean_Expr_prod_x3f___closed__2; +x_2 = l_Lean_prodToExpr___rarg___lambda__1___closed__3; +x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } @@ -24193,6 +24634,18 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); x_2 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4; +x_3 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_3, 0, x_2); +lean_ctor_set(x_3, 1, x_1); +return x_3; +} +} +lean_object* _init_l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__5; x_3 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_3, 0, x_2); lean_ctor_set(x_3, 1, x_1); @@ -24228,10 +24681,10 @@ lean_inc(x_13); x_14 = lean_ctor_get(x_4, 0); lean_inc(x_14); x_15 = lean_box(0); -x_16 = l_Lean_prodToExpr___rarg___lambda__1___closed__4; +x_16 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4; x_17 = l_Lean_addMacroScope(x_14, x_16, x_13); x_18 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__3; -x_19 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__5; +x_19 = l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6; x_20 = lean_alloc_ctor(3, 4, 0); lean_ctor_set(x_20, 0, x_15); lean_ctor_set(x_20, 1, x_18); @@ -25193,10 +25646,10 @@ x_7 = lean_unsigned_to_nat(1u); x_8 = l_Lean_Syntax_getArg(x_1, x_7); x_9 = lean_unsigned_to_nat(2u); x_10 = l_Lean_Syntax_getArg(x_1, x_9); -x_11 = l_Lean_listToExpr___rarg___closed__8; +x_11 = l_Lean_Expr_listLitAux___main___closed__6; x_12 = l_Lean_mkTermIdFrom(x_6, x_11); lean_dec(x_6); -x_13 = l_Lean_listToExpr___rarg___closed__4; +x_13 = l_Lean_Expr_listLitAux___main___closed__4; x_14 = l_Lean_mkTermIdFrom(x_10, x_13); lean_dec(x_10); x_15 = l_Lean_Syntax_getArgs(x_8); @@ -25371,7 +25824,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l_Lean_arrayToExpr___rarg___lambda__1___closed__2; +x_2 = l_Lean_Expr_arrayLit_x3f___closed__2; x_3 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_3, 0, x_2); lean_ctor_set(x_3, 1, x_1); @@ -25481,7 +25934,7 @@ x_16 = lean_ctor_get(x_14, 1); lean_inc(x_16); lean_dec(x_14); x_17 = lean_box(0); -x_18 = l_Lean_arrayToExpr___rarg___lambda__1___closed__2; +x_18 = l_Lean_Expr_arrayLit_x3f___closed__2; x_19 = l_Lean_addMacroScope(x_15, x_18, x_12); x_20 = l_Lean_Elab_Term_elabArrayLit___closed__6; x_21 = l_Lean_Elab_Term_elabArrayLit___closed__8; @@ -27511,6 +27964,420 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg___lambda__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_3 = l_Lean_Message_toString(x_1); +x_4 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_4, 0, x_3); +x_5 = l_IO_println___at_Lean_Meta_MetaHasEval___spec__1(x_4, x_2); +return x_5; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string(""); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__2() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Elab_Term_MetaHasEval___rarg___lambda__1), 2, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__3() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("error: unsupported syntax"); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__3; +x_2 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__5() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("error: elaborator posponed"); +return x_1; +} +} +lean_object* _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__5; +x_2 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Lean_Elab_Term_MetaHasEval___rarg(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; 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; lean_object* x_16; 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; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_6 = 0; +x_7 = 1; +lean_inc(x_3); +x_8 = lean_alloc_ctor(0, 1, 7); +lean_ctor_set(x_8, 0, x_3); +lean_ctor_set_uint8(x_8, sizeof(void*)*1, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 1, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 2, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 3, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 4, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 5, x_6); +lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 6, x_7); +x_9 = l_Lean_getMaxRecDepth(x_3); +x_10 = l_Lean_LocalContext_Inhabited___closed__2; +x_11 = l_Array_empty___closed__1; +x_12 = lean_unsigned_to_nat(0u); +x_13 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_13, 0, x_8); +lean_ctor_set(x_13, 1, x_10); +lean_ctor_set(x_13, 2, x_11); +lean_ctor_set(x_13, 3, x_12); +lean_ctor_set(x_13, 4, x_9); +x_14 = lean_box(0); +x_15 = lean_box(0); +x_16 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__1; +x_17 = l_Lean_FileMap_Inhabited___closed__1; +x_18 = lean_box(0); +x_19 = l_Lean_firstFrontendMacroScope; +x_20 = 1; +x_21 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_21, 0, x_13); +lean_ctor_set(x_21, 1, x_16); +lean_ctor_set(x_21, 2, x_17); +lean_ctor_set(x_21, 3, x_12); +lean_ctor_set(x_21, 4, x_18); +lean_ctor_set(x_21, 5, x_14); +lean_ctor_set(x_21, 6, x_15); +lean_ctor_set(x_21, 7, x_15); +lean_ctor_set(x_21, 8, x_15); +lean_ctor_set(x_21, 9, x_19); +lean_ctor_set_uint8(x_21, sizeof(void*)*10, x_20); +lean_ctor_set_uint8(x_21, sizeof(void*)*10 + 1, x_20); +lean_ctor_set_uint8(x_21, sizeof(void*)*10 + 2, x_20); +x_22 = l_Lean_MetavarContext_Inhabited___closed__1; +x_23 = l_Lean_Meta_run___rarg___closed__5; +x_24 = l_Lean_NameGenerator_Inhabited___closed__3; +x_25 = l_Lean_TraceState_Inhabited___closed__1; +x_26 = l_PersistentArray_empty___closed__3; +x_27 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_27, 0, x_2); +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); +lean_ctor_set(x_27, 5, x_26); +x_28 = lean_unsigned_to_nat(1u); +x_29 = l_Lean_Unhygienic_run___rarg___closed__1; +x_30 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_30, 0, x_27); +lean_ctor_set(x_30, 1, x_15); +lean_ctor_set(x_30, 2, x_26); +lean_ctor_set(x_30, 3, x_28); +lean_ctor_set(x_30, 4, x_28); +lean_ctor_set(x_30, 5, x_29); +x_31 = lean_apply_2(x_4, x_21, x_30); +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; +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_33, 2); +lean_inc(x_34); +x_35 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__2; +x_36 = l_PersistentArray_forM___at___private_Init_Lean_Parser_Module_4__testModuleParserAux___main___spec__6(x_35, x_34, x_5); +lean_dec(x_34); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_37 = lean_ctor_get(x_36, 1); +lean_inc(x_37); +lean_dec(x_36); +x_38 = lean_ctor_get(x_33, 0); +lean_inc(x_38); +lean_dec(x_33); +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +lean_dec(x_38); +x_40 = lean_apply_4(x_1, x_39, x_3, x_32, x_37); +return x_40; +} +else +{ +uint8_t x_41; +lean_dec(x_33); +lean_dec(x_32); +lean_dec(x_3); +lean_dec(x_1); +x_41 = !lean_is_exclusive(x_36); +if (x_41 == 0) +{ +return x_36; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_36, 0); +x_43 = lean_ctor_get(x_36, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_36); +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_3); +lean_dec(x_1); +x_45 = lean_ctor_get(x_31, 0); +lean_inc(x_45); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +lean_dec(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; lean_object* x_51; +x_47 = lean_ctor_get(x_31, 1); +lean_inc(x_47); +lean_dec(x_31); +x_48 = lean_ctor_get(x_46, 0); +lean_inc(x_48); +lean_dec(x_46); +x_49 = lean_ctor_get(x_47, 2); +lean_inc(x_49); +lean_dec(x_47); +x_50 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__2; +x_51 = l_PersistentArray_forM___at___private_Init_Lean_Parser_Module_4__testModuleParserAux___main___spec__6(x_50, x_49, x_5); +lean_dec(x_49); +if (lean_obj_tag(x_51) == 0) +{ +uint8_t x_52; +x_52 = !lean_is_exclusive(x_51); +if (x_52 == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_53 = lean_ctor_get(x_51, 0); +lean_dec(x_53); +x_54 = l_Lean_Message_toString(x_48); +x_55 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_55, 0, x_54); +x_56 = l_Lean_Options_empty; +x_57 = l_Lean_Format_pretty(x_55, x_56); +x_58 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_58, 0, x_57); +lean_ctor_set_tag(x_51, 1); +lean_ctor_set(x_51, 0, x_58); +return x_51; +} +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; +x_59 = lean_ctor_get(x_51, 1); +lean_inc(x_59); +lean_dec(x_51); +x_60 = l_Lean_Message_toString(x_48); +x_61 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_61, 0, x_60); +x_62 = l_Lean_Options_empty; +x_63 = l_Lean_Format_pretty(x_61, x_62); +x_64 = lean_alloc_ctor(18, 1, 0); +lean_ctor_set(x_64, 0, x_63); +x_65 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_65, 0, x_64); +lean_ctor_set(x_65, 1, x_59); +return x_65; +} +} +else +{ +uint8_t x_66; +lean_dec(x_48); +x_66 = !lean_is_exclusive(x_51); +if (x_66 == 0) +{ +return x_51; +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_67 = lean_ctor_get(x_51, 0); +x_68 = lean_ctor_get(x_51, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_51); +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; +x_70 = lean_ctor_get(x_31, 1); +lean_inc(x_70); +lean_dec(x_31); +x_71 = lean_ctor_get(x_70, 2); +lean_inc(x_71); +lean_dec(x_70); +x_72 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__2; +x_73 = l_PersistentArray_forM___at___private_Init_Lean_Parser_Module_4__testModuleParserAux___main___spec__6(x_72, x_71, x_5); +lean_dec(x_71); +if (lean_obj_tag(x_73) == 0) +{ +uint8_t x_74; +x_74 = !lean_is_exclusive(x_73); +if (x_74 == 0) +{ +lean_object* x_75; lean_object* x_76; +x_75 = lean_ctor_get(x_73, 0); +lean_dec(x_75); +x_76 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__4; +lean_ctor_set_tag(x_73, 1); +lean_ctor_set(x_73, 0, x_76); +return x_73; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_73, 1); +lean_inc(x_77); +lean_dec(x_73); +x_78 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__4; +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_78); +lean_ctor_set(x_79, 1, x_77); +return x_79; +} +} +else +{ +uint8_t x_80; +x_80 = !lean_is_exclusive(x_73); +if (x_80 == 0) +{ +return x_73; +} +else +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_81 = lean_ctor_get(x_73, 0); +x_82 = lean_ctor_get(x_73, 1); +lean_inc(x_82); +lean_inc(x_81); +lean_dec(x_73); +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 +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_84 = lean_ctor_get(x_31, 1); +lean_inc(x_84); +lean_dec(x_31); +x_85 = lean_ctor_get(x_84, 2); +lean_inc(x_85); +lean_dec(x_84); +x_86 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__2; +x_87 = l_PersistentArray_forM___at___private_Init_Lean_Parser_Module_4__testModuleParserAux___main___spec__6(x_86, x_85, x_5); +lean_dec(x_85); +if (lean_obj_tag(x_87) == 0) +{ +uint8_t x_88; +x_88 = !lean_is_exclusive(x_87); +if (x_88 == 0) +{ +lean_object* x_89; lean_object* x_90; +x_89 = lean_ctor_get(x_87, 0); +lean_dec(x_89); +x_90 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__6; +lean_ctor_set_tag(x_87, 1); +lean_ctor_set(x_87, 0, x_90); +return x_87; +} +else +{ +lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_91 = lean_ctor_get(x_87, 1); +lean_inc(x_91); +lean_dec(x_87); +x_92 = l_Lean_Elab_Term_MetaHasEval___rarg___closed__6; +x_93 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_91); +return x_93; +} +} +else +{ +uint8_t x_94; +x_94 = !lean_is_exclusive(x_87); +if (x_94 == 0) +{ +return x_87; +} +else +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_87, 0); +x_96 = lean_ctor_get(x_87, 1); +lean_inc(x_96); +lean_inc(x_95); +lean_dec(x_87); +x_97 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_97, 0, x_95); +lean_ctor_set(x_97, 1, x_96); +return x_97; +} +} +} +} +} +} +lean_object* l_Lean_Elab_Term_MetaHasEval(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Elab_Term_MetaHasEval___rarg), 5, 0); +return x_2; +} +} lean_object* _init_l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1() { _start: { @@ -27537,73 +28404,104 @@ x_5 = l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1; x_6 = l_Lean_registerTraceClass(x_5, x_4); if (lean_obj_tag(x_6) == 0) { -uint8_t x_7; -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_6, 0); -lean_dec(x_8); -x_9 = lean_box(0); -lean_ctor_set(x_6, 0, x_9); -return x_6; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_6, 1); -lean_inc(x_10); +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_6, 1); +lean_inc(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_10); -return x_12; +x_8 = l_Lean_Elab_Term_logDbgTrace___closed__1; +x_9 = l_Lean_registerTraceClass(x_8, x_7); +if (lean_obj_tag(x_9) == 0) +{ +uint8_t x_10; +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_9, 0); +lean_dec(x_11); +x_12 = lean_box(0); +lean_ctor_set(x_9, 0, x_12); +return x_9; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_9, 1); +lean_inc(x_13); +lean_dec(x_9); +x_14 = lean_box(0); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_13); +return x_15; } } else { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_6); -if (x_13 == 0) +uint8_t x_16; +x_16 = !lean_is_exclusive(x_9); +if (x_16 == 0) +{ +return x_9; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_9, 0); +x_18 = lean_ctor_get(x_9, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_9); +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 +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_6); +if (x_20 == 0) { return x_6; } else { -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_6, 0); -x_15 = lean_ctor_get(x_6, 1); -lean_inc(x_15); -lean_inc(x_14); +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_6, 0); +x_22 = lean_ctor_get(x_6, 1); +lean_inc(x_22); +lean_inc(x_21); lean_dec(x_6); -x_16 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_15); -return x_16; +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; } } } else { -uint8_t x_17; -x_17 = !lean_is_exclusive(x_3); -if (x_17 == 0) +uint8_t x_24; +x_24 = !lean_is_exclusive(x_3); +if (x_24 == 0) { return x_3; } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_3, 0); -x_19 = lean_ctor_get(x_3, 1); -lean_inc(x_19); -lean_inc(x_18); +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_3, 0); +x_26 = lean_ctor_get(x_3, 1); +lean_inc(x_26); +lean_inc(x_25); lean_dec(x_3); -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; +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; } } } @@ -27754,6 +28652,14 @@ if (lean_io_result_is_error(res)) return res; l_Lean_Elab_Term_termElabAttribute = lean_io_result_get_value(res); lean_mark_persistent(l_Lean_Elab_Term_termElabAttribute); lean_dec_ref(res); +l_Lean_Elab_Term_logDbgTrace___closed__1 = _init_l_Lean_Elab_Term_logDbgTrace___closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_logDbgTrace___closed__1); +l_Lean_Elab_Term_throwErrorIfErrors___closed__1 = _init_l_Lean_Elab_Term_throwErrorIfErrors___closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_throwErrorIfErrors___closed__1); +l_Lean_Elab_Term_throwErrorIfErrors___closed__2 = _init_l_Lean_Elab_Term_throwErrorIfErrors___closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_throwErrorIfErrors___closed__2); +l_Lean_Elab_Term_throwErrorIfErrors___closed__3 = _init_l_Lean_Elab_Term_throwErrorIfErrors___closed__3(); +lean_mark_persistent(l_Lean_Elab_Term_throwErrorIfErrors___closed__3); l_Lean_Elab_Term_decLevel___closed__1 = _init_l_Lean_Elab_Term_decLevel___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_decLevel___closed__1); l_Lean_Elab_Term_decLevel___closed__2 = _init_l_Lean_Elab_Term_decLevel___closed__2(); @@ -27993,6 +28899,8 @@ l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4 = _init_l___pr lean_mark_persistent(l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__4); l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__5 = _init_l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__5(); lean_mark_persistent(l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__5); +l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6 = _init_l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Elab_Term_15__mkPairsAux___main___closed__6); l_Lean_Elab_Term_elabParen___closed__1 = _init_l_Lean_Elab_Term_elabParen___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_elabParen___closed__1); l_Lean_Elab_Term_elabParen___closed__2 = _init_l_Lean_Elab_Term_elabParen___closed__2(); @@ -28130,6 +29038,18 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabQuotedName___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabQuotedName(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__1 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__1); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__2 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__2); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__3 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__3(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__3); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__4 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__4(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__4); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__5 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__5(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__5); +l_Lean_Elab_Term_MetaHasEval___rarg___closed__6 = _init_l_Lean_Elab_Term_MetaHasEval___rarg___closed__6(); +lean_mark_persistent(l_Lean_Elab_Term_MetaHasEval___rarg___closed__6); l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1 = _init_l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1(); lean_mark_persistent(l___private_Init_Lean_Elab_Term_21__regTraceClasses___closed__1); res = l___private_Init_Lean_Elab_Term_21__regTraceClasses(lean_io_mk_world()); diff --git a/stage0/stdlib/Init/Lean/Meta/AppBuilder.c b/stage0/stdlib/Init/Lean/Meta/AppBuilder.c index d486e6e97a..394c5828a7 100644 --- a/stage0/stdlib/Init/Lean/Meta/AppBuilder.c +++ b/stage0/stdlib/Init/Lean/Meta/AppBuilder.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Init.Lean.Meta.AppBuilder -// Imports: Init.Default Init.Lean.Meta.SynthInstance +// Imports: Init.Default Init.Lean.Util.Recognizers Init.Lean.Meta.SynthInstance #include "runtime/lean.h" #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -13,16 +13,14 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l_Lean_Expr_eq_x3f___closed__1; -lean_object* l_Lean_Expr_iff_x3f(lean_object*); lean_object* l___private_Init_Lean_Util_Trace_2__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_eq_x3f___closed__2; +extern lean_object* l_Lean_Expr_eq_x3f___closed__2; lean_object* l_Lean_Expr_mvarId_x21(lean_object*); -lean_object* l_Lean_Expr_eq_x3f___boxed(lean_object*); lean_object* l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkHEqSymm___closed__2; lean_object* lean_mk_empty_array_with_capacity(lean_object*); lean_object* l_Lean_Meta_mkCongr___closed__1; +lean_object* l_Lean_Meta_mkExpectedTypeHint___closed__1; lean_object* l_Lean_mkApp6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_2__mkAppMFinal___closed__3; lean_object* l_Lean_Meta_mkHEqSymm___closed__1; @@ -37,6 +35,7 @@ lean_object* l_Lean_Meta_mkCongr(lean_object*, lean_object*, lean_object*, lean_ lean_object* l_Lean_Meta_mkCongrFun(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_Trace_3__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(lean_object*); lean_object* l_Lean_Meta_mkEqRec(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appFn_x21(lean_object*); uint8_t l_Lean_Expr_isAppOf(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_2__mkAppMFinal___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); @@ -44,6 +43,8 @@ lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); extern lean_object* l_Lean_Expr_getAppArgs___closed__1; lean_object* l_Lean_Meta_mkEqMP(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); +extern lean_object* l_Lean_mkTermIdFromIdent___closed__1; lean_object* l_Lean_Meta_mkCongrArg___closed__2; lean_object* l_Lean_Meta_mkEqNDRec___closed__3; lean_object* lean_nat_add(lean_object*, lean_object*); @@ -65,23 +66,18 @@ lean_object* l_Lean_Meta_mkNoConfusion___closed__3; lean_object* l_Lean_Meta_mkEqSymm(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_1__infer(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkCongrArg___closed__3; -lean_object* l_Lean_Expr_heq_x3f___closed__2; +extern lean_object* l_Lean_Expr_heq_x3f___closed__2; lean_object* l_Lean_Meta_mkNoConfusion___closed__1; -lean_object* l_Lean_Expr_iff_x3f___closed__2; lean_object* l_Lean_Meta_mkNoConfusion___closed__4; -lean_object* l_Lean_Expr_heq_x3f(lean_object*); lean_object* l_Lean_Meta_mkNoConfusion___closed__2; lean_object* lean_instantiate_type_lparams(lean_object*, lean_object*); lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_AppBuilder_2__mkAppMFinal___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkHEqRefl___closed__1; -lean_object* l_Lean_Expr_eq_x3f(lean_object*); lean_object* l_Lean_Meta_mkEqTrans___closed__1; -lean_object* l_Lean_Expr_iff_x3f___boxed(lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_2__mkAppMFinal(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkEqRec___closed__1; lean_object* lean_name_mk_string(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkEqNDRec(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_iff_x3f___closed__1; extern lean_object* l_Lean_mkRecFor___closed__1; lean_object* l_Lean_Meta_mkEqTrans___closed__2; lean_object* l_Lean_Meta_mkCongrFun___closed__1; @@ -100,17 +96,13 @@ uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); lean_object* l_Lean_Meta_mkEqOfHEq___closed__1; lean_object* l_Lean_Meta_mkEqOfHEq___closed__2; lean_object* l_Lean_Meta_mkEqRefl___closed__2; -lean_object* l_Lean_Expr_heq_x3f___closed__1; lean_object* l_Lean_Meta_mkEqNDRec___closed__1; -lean_object* l_Lean_Expr_heq_x3f___boxed(lean_object*); lean_object* l_Lean_ConstantInfo_lparams(lean_object*); lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_synthInstance(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_hasAssignableMVar(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_arrow_x3f(lean_object*); lean_object* l_Lean_Meta_mkEqNDRec___closed__2; lean_object* l_List_mapM___main___at_Lean_Meta_mkAppM___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkHEqSymm(lean_object*, lean_object*, lean_object*); @@ -135,11 +127,11 @@ lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_AppBuilder_2__ lean_object* l_Lean_Meta_getConstInfo(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkNoConfusion(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasLooseBVars(lean_object*); -lean_object* l_Lean_Expr_arrow_x3f___boxed(lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateMVars(lean_object*, lean_object*, lean_object*); lean_object* lean_mk_array(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_3__mkAppMAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkExpectedTypeHint(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_whnfD(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVar___rarg(lean_object*); extern lean_object* l_Lean_mkOptionalNode___closed__2; @@ -157,264 +149,85 @@ lean_object* l___private_Init_Lean_Meta_AppBuilder_2__mkAppMFinal___closed__2; lean_object* l_Lean_mkApp3(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_AppBuilder_3__mkAppMAux___main(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*); -lean_object* _init_l_Lean_Expr_eq_x3f___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("Eq"); -return x_1; -} -} -lean_object* _init_l_Lean_Expr_eq_x3f___closed__2() { +lean_object* _init_l_Lean_Meta_mkExpectedTypeHint___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l_Lean_Expr_eq_x3f___closed__1; +x_2 = l_Lean_mkTermIdFromIdent___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l_Lean_Expr_eq_x3f(lean_object* x_1) { +lean_object* l_Lean_Meta_mkExpectedTypeHint(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_2; lean_object* x_3; uint8_t x_4; -x_2 = l_Lean_Expr_eq_x3f___closed__2; -x_3 = lean_unsigned_to_nat(3u); -x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); -if (x_4 == 0) -{ lean_object* x_5; -x_5 = lean_box(0); -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; lean_object* x_21; -x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_6); -x_8 = lean_nat_sub(x_7, x_6); -x_9 = lean_unsigned_to_nat(1u); -x_10 = lean_nat_sub(x_8, x_9); -lean_dec(x_8); -x_11 = l_Lean_Expr_getRevArg_x21___main(x_1, x_10); -x_12 = lean_nat_sub(x_7, x_9); -x_13 = lean_nat_sub(x_12, x_9); -lean_dec(x_12); -x_14 = l_Lean_Expr_getRevArg_x21___main(x_1, x_13); -x_15 = lean_unsigned_to_nat(2u); -x_16 = lean_nat_sub(x_7, x_15); -lean_dec(x_7); -x_17 = lean_nat_sub(x_16, x_9); -lean_dec(x_16); -x_18 = l_Lean_Expr_getRevArg_x21___main(x_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); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_11); -lean_ctor_set(x_20, 1, x_19); -x_21 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_21, 0, x_20); -return x_21; -} -} -} -lean_object* l_Lean_Expr_eq_x3f___boxed(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = l_Lean_Expr_eq_x3f(x_1); -lean_dec(x_1); -return x_2; -} -} -lean_object* _init_l_Lean_Expr_iff_x3f___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("Iff"); -return x_1; -} -} -lean_object* _init_l_Lean_Expr_iff_x3f___closed__2() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = lean_box(0); -x_2 = l_Lean_Expr_iff_x3f___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; -} -} -lean_object* l_Lean_Expr_iff_x3f(lean_object* x_1) { -_start: -{ -lean_object* x_2; lean_object* x_3; uint8_t x_4; -x_2 = l_Lean_Expr_iff_x3f___closed__2; -x_3 = lean_unsigned_to_nat(2u); -x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); -if (x_4 == 0) -{ -lean_object* x_5; -x_5 = lean_box(0); -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; -x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_6); -x_8 = lean_nat_sub(x_7, x_6); -x_9 = lean_unsigned_to_nat(1u); -x_10 = lean_nat_sub(x_8, x_9); -lean_dec(x_8); -x_11 = l_Lean_Expr_getRevArg_x21___main(x_1, x_10); -x_12 = lean_nat_sub(x_7, x_9); -lean_dec(x_7); -x_13 = lean_nat_sub(x_12, x_9); -lean_dec(x_12); -x_14 = l_Lean_Expr_getRevArg_x21___main(x_1, x_13); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_11); -lean_ctor_set(x_15, 1, x_14); -x_16 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_16, 0, x_15); -return x_16; -} -} -} -lean_object* l_Lean_Expr_iff_x3f___boxed(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = l_Lean_Expr_iff_x3f(x_1); -lean_dec(x_1); -return x_2; -} -} -lean_object* _init_l_Lean_Expr_heq_x3f___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("HEq"); -return x_1; -} -} -lean_object* _init_l_Lean_Expr_heq_x3f___closed__2() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = lean_box(0); -x_2 = l_Lean_Expr_heq_x3f___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; -} -} -lean_object* l_Lean_Expr_heq_x3f(lean_object* x_1) { -_start: -{ -lean_object* x_2; lean_object* x_3; uint8_t x_4; -x_2 = l_Lean_Expr_heq_x3f___closed__2; -x_3 = lean_unsigned_to_nat(4u); -x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); -if (x_4 == 0) -{ -lean_object* x_5; -x_5 = lean_box(0); -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; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_6); -x_8 = lean_nat_sub(x_7, x_6); -x_9 = lean_unsigned_to_nat(1u); -x_10 = lean_nat_sub(x_8, x_9); -lean_dec(x_8); -x_11 = l_Lean_Expr_getRevArg_x21___main(x_1, x_10); -x_12 = lean_nat_sub(x_7, x_9); -x_13 = lean_nat_sub(x_12, x_9); -lean_dec(x_12); -x_14 = l_Lean_Expr_getRevArg_x21___main(x_1, x_13); -x_15 = lean_unsigned_to_nat(2u); -x_16 = lean_nat_sub(x_7, x_15); -x_17 = lean_nat_sub(x_16, x_9); -lean_dec(x_16); -x_18 = l_Lean_Expr_getRevArg_x21___main(x_1, x_17); -x_19 = lean_nat_sub(x_7, x_3); -lean_dec(x_7); -x_20 = lean_nat_sub(x_19, x_9); -lean_dec(x_19); -x_21 = l_Lean_Expr_getRevArg_x21___main(x_1, x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_18); -lean_ctor_set(x_22, 1, x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_14); -lean_ctor_set(x_23, 1, x_22); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_11); -lean_ctor_set(x_24, 1, x_23); -x_25 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_25, 0, x_24); -return x_25; -} -} -} -lean_object* l_Lean_Expr_heq_x3f___boxed(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = l_Lean_Expr_heq_x3f(x_1); -lean_dec(x_1); -return x_2; -} -} -lean_object* l_Lean_Expr_arrow_x3f(lean_object* x_1) { -_start: -{ -if (lean_obj_tag(x_1) == 7) -{ -lean_object* x_2; lean_object* x_3; uint8_t x_4; -x_2 = lean_ctor_get(x_1, 1); -x_3 = lean_ctor_get(x_1, 2); -x_4 = l_Lean_Expr_hasLooseBVars(x_3); -if (x_4 == 0) -{ -lean_object* x_5; lean_object* x_6; -lean_inc(x_3); lean_inc(x_2); -x_5 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_5, 0, x_2); -lean_ctor_set(x_5, 1, x_3); -x_6 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_6, 0, x_5); -return x_6; -} -else +x_5 = l_Lean_Meta_getLevel(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) { -lean_object* x_7; -x_7 = lean_box(0); -return x_7; -} -} -else +uint8_t x_6; +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) { -lean_object* x_8; +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_5, 0); x_8 = lean_box(0); -return x_8; +x_9 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_9, 0, x_7); +lean_ctor_set(x_9, 1, x_8); +x_10 = l_Lean_Meta_mkExpectedTypeHint___closed__1; +x_11 = l_Lean_mkConst(x_10, x_9); +x_12 = l_Lean_mkAppB(x_11, x_2, x_1); +lean_ctor_set(x_5, 0, x_12); +return x_5; } -} -} -lean_object* l_Lean_Expr_arrow_x3f___boxed(lean_object* x_1) { -_start: +else { -lean_object* x_2; -x_2 = l_Lean_Expr_arrow_x3f(x_1); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_13 = lean_ctor_get(x_5, 0); +x_14 = lean_ctor_get(x_5, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_5); +x_15 = lean_box(0); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_13); +lean_ctor_set(x_16, 1, x_15); +x_17 = l_Lean_Meta_mkExpectedTypeHint___closed__1; +x_18 = l_Lean_mkConst(x_17, x_16); +x_19 = l_Lean_mkAppB(x_18, x_2, x_1); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_14); +return x_20; +} +} +else +{ +uint8_t x_21; +lean_dec(x_2); lean_dec(x_1); -return x_2; +x_21 = !lean_is_exclusive(x_5); +if (x_21 == 0) +{ +return x_5; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_5, 0); +x_23 = lean_ctor_get(x_5, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_5); +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_Meta_mkEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { @@ -1044,259 +857,239 @@ return x_6; } 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; lean_object* x_36; lean_object* x_37; +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_free_object(x_6); -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_8, x_24); -x_26 = lean_nat_sub(x_25, x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_sub(x_26, x_27); -lean_dec(x_26); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_8, x_28); -x_30 = lean_nat_sub(x_25, x_27); -x_31 = lean_nat_sub(x_30, x_27); -lean_dec(x_30); -x_32 = l_Lean_Expr_getRevArg_x21___main(x_8, x_31); -x_33 = lean_unsigned_to_nat(2u); -x_34 = lean_nat_sub(x_25, x_33); +x_24 = l_Lean_Expr_appFn_x21(x_8); +x_25 = l_Lean_Expr_appFn_x21(x_24); +x_26 = l_Lean_Expr_appArg_x21(x_25); lean_dec(x_25); -x_35 = lean_nat_sub(x_34, x_27); -lean_dec(x_34); -x_36 = l_Lean_Expr_getRevArg_x21___main(x_8, x_35); +x_27 = l_Lean_Expr_appArg_x21(x_24); +lean_dec(x_24); +x_28 = l_Lean_Expr_appArg_x21(x_8); lean_dec(x_8); -lean_inc(x_29); -x_37 = l_Lean_Meta_getLevel(x_29, x_2, x_9); -if (lean_obj_tag(x_37) == 0) +lean_inc(x_26); +x_29 = l_Lean_Meta_getLevel(x_26, x_2, x_9); +if (lean_obj_tag(x_29) == 0) { -uint8_t x_38; -x_38 = !lean_is_exclusive(x_37); -if (x_38 == 0) +uint8_t x_30; +x_30 = !lean_is_exclusive(x_29); +if (x_30 == 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_37, 0); -x_40 = lean_box(0); -x_41 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -x_42 = l_Lean_Meta_mkEqSymm___closed__2; -x_43 = l_Lean_mkConst(x_42, x_41); -x_44 = l_Lean_mkApp4(x_43, x_29, x_32, x_36, x_1); -lean_ctor_set(x_37, 0, x_44); -return x_37; +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_31 = lean_ctor_get(x_29, 0); +x_32 = lean_box(0); +x_33 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_33, 0, x_31); +lean_ctor_set(x_33, 1, x_32); +x_34 = l_Lean_Meta_mkEqSymm___closed__2; +x_35 = l_Lean_mkConst(x_34, x_33); +x_36 = l_Lean_mkApp4(x_35, x_26, x_27, x_28, x_1); +lean_ctor_set(x_29, 0, x_36); +return x_29; } else { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_45 = lean_ctor_get(x_37, 0); -x_46 = lean_ctor_get(x_37, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_37); -x_47 = lean_box(0); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_45); -lean_ctor_set(x_48, 1, x_47); -x_49 = l_Lean_Meta_mkEqSymm___closed__2; -x_50 = l_Lean_mkConst(x_49, x_48); -x_51 = l_Lean_mkApp4(x_50, x_29, x_32, x_36, x_1); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_46); -return x_52; -} -} -else -{ -uint8_t x_53; -lean_dec(x_36); -lean_dec(x_32); +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_37 = lean_ctor_get(x_29, 0); +x_38 = lean_ctor_get(x_29, 1); +lean_inc(x_38); +lean_inc(x_37); lean_dec(x_29); +x_39 = lean_box(0); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_37); +lean_ctor_set(x_40, 1, x_39); +x_41 = l_Lean_Meta_mkEqSymm___closed__2; +x_42 = l_Lean_mkConst(x_41, x_40); +x_43 = l_Lean_mkApp4(x_42, x_26, x_27, x_28, x_1); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_38); +return x_44; +} +} +else +{ +uint8_t x_45; +lean_dec(x_28); +lean_dec(x_27); +lean_dec(x_26); lean_dec(x_1); -x_53 = !lean_is_exclusive(x_37); +x_45 = !lean_is_exclusive(x_29); +if (x_45 == 0) +{ +return x_29; +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_29, 0); +x_47 = lean_ctor_get(x_29, 1); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_29); +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_object* x_51; lean_object* x_52; uint8_t x_53; +x_49 = lean_ctor_get(x_6, 0); +x_50 = lean_ctor_get(x_6, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_6); +x_51 = l_Lean_Expr_eq_x3f___closed__2; +x_52 = lean_unsigned_to_nat(3u); +x_53 = l_Lean_Expr_isAppOfArity___main(x_49, x_51, x_52); if (x_53 == 0) { -return x_37; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_37, 0); -x_55 = lean_ctor_get(x_37, 1); -lean_inc(x_55); +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_dec(x_49); +x_54 = lean_ctor_get(x_50, 0); lean_inc(x_54); -lean_dec(x_37); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -return x_56; -} -} -} -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_57 = lean_ctor_get(x_6, 0); -x_58 = lean_ctor_get(x_6, 1); -lean_inc(x_58); +x_55 = lean_ctor_get(x_50, 1); +lean_inc(x_55); +x_56 = lean_ctor_get(x_2, 1); +lean_inc(x_56); +x_57 = lean_ctor_get(x_2, 0); lean_inc(x_57); -lean_dec(x_6); -x_59 = l_Lean_Expr_eq_x3f___closed__2; -x_60 = lean_unsigned_to_nat(3u); -x_61 = l_Lean_Expr_isAppOfArity___main(x_57, x_59, x_60); -if (x_61 == 0) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; 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_dec(x_57); -x_62 = lean_ctor_get(x_58, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_58, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_2, 1); -lean_inc(x_64); -x_65 = lean_ctor_get(x_2, 0); -lean_inc(x_65); lean_dec(x_2); -x_66 = lean_ctor_get(x_65, 0); -lean_inc(x_66); -lean_dec(x_65); -x_67 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_64); -lean_ctor_set(x_67, 3, x_66); -x_68 = l_Lean_mkOptionalNode___closed__2; -x_69 = lean_array_push(x_68, x_1); -x_70 = l_Lean_Meta_mkEqSymm___closed__2; -x_71 = l_Lean_Meta_mkEqSymm___closed__3; -x_72 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -lean_ctor_set(x_72, 2, x_69); -lean_ctor_set(x_72, 3, x_67); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_72); -lean_ctor_set(x_73, 1, x_58); -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; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_74 = lean_unsigned_to_nat(0u); -x_75 = l_Lean_Expr_getAppNumArgsAux___main(x_57, x_74); -x_76 = lean_nat_sub(x_75, x_74); -x_77 = lean_unsigned_to_nat(1u); -x_78 = lean_nat_sub(x_76, x_77); -lean_dec(x_76); -x_79 = l_Lean_Expr_getRevArg_x21___main(x_57, x_78); -x_80 = lean_nat_sub(x_75, x_77); -x_81 = lean_nat_sub(x_80, x_77); -lean_dec(x_80); -x_82 = l_Lean_Expr_getRevArg_x21___main(x_57, x_81); -x_83 = lean_unsigned_to_nat(2u); -x_84 = lean_nat_sub(x_75, x_83); -lean_dec(x_75); -x_85 = lean_nat_sub(x_84, x_77); -lean_dec(x_84); -x_86 = l_Lean_Expr_getRevArg_x21___main(x_57, x_85); +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); lean_dec(x_57); -lean_inc(x_79); -x_87 = l_Lean_Meta_getLevel(x_79, x_2, x_58); -if (lean_obj_tag(x_87) == 0) -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_88 = lean_ctor_get(x_87, 0); -lean_inc(x_88); -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_87); - x_90 = lean_box(0); -} -x_91 = lean_box(0); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_88); -lean_ctor_set(x_92, 1, x_91); -x_93 = l_Lean_Meta_mkEqSymm___closed__2; -x_94 = l_Lean_mkConst(x_93, x_92); -x_95 = l_Lean_mkApp4(x_94, x_79, x_82, x_86, x_1); -if (lean_is_scalar(x_90)) { - x_96 = lean_alloc_ctor(0, 2, 0); -} else { - x_96 = x_90; -} -lean_ctor_set(x_96, 0, x_95); -lean_ctor_set(x_96, 1, x_89); -return x_96; +x_59 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_56); +lean_ctor_set(x_59, 3, x_58); +x_60 = l_Lean_mkOptionalNode___closed__2; +x_61 = lean_array_push(x_60, x_1); +x_62 = l_Lean_Meta_mkEqSymm___closed__2; +x_63 = l_Lean_Meta_mkEqSymm___closed__3; +x_64 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +lean_ctor_set(x_64, 2, x_61); +lean_ctor_set(x_64, 3, x_59); +x_65 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_65, 0, x_64); +lean_ctor_set(x_65, 1, x_50); +return x_65; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -lean_dec(x_86); -lean_dec(x_82); -lean_dec(x_79); +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_66 = l_Lean_Expr_appFn_x21(x_49); +x_67 = l_Lean_Expr_appFn_x21(x_66); +x_68 = l_Lean_Expr_appArg_x21(x_67); +lean_dec(x_67); +x_69 = l_Lean_Expr_appArg_x21(x_66); +lean_dec(x_66); +x_70 = l_Lean_Expr_appArg_x21(x_49); +lean_dec(x_49); +lean_inc(x_68); +x_71 = l_Lean_Meta_getLevel(x_68, x_2, x_50); +if (lean_obj_tag(x_71) == 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; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_72 = lean_ctor_get(x_71, 0); +lean_inc(x_72); +x_73 = lean_ctor_get(x_71, 1); +lean_inc(x_73); +if (lean_is_exclusive(x_71)) { + lean_ctor_release(x_71, 0); + lean_ctor_release(x_71, 1); + x_74 = x_71; +} else { + lean_dec_ref(x_71); + x_74 = lean_box(0); +} +x_75 = lean_box(0); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_72); +lean_ctor_set(x_76, 1, x_75); +x_77 = l_Lean_Meta_mkEqSymm___closed__2; +x_78 = l_Lean_mkConst(x_77, x_76); +x_79 = l_Lean_mkApp4(x_78, x_68, x_69, x_70, x_1); +if (lean_is_scalar(x_74)) { + x_80 = lean_alloc_ctor(0, 2, 0); +} else { + x_80 = x_74; +} +lean_ctor_set(x_80, 0, x_79); +lean_ctor_set(x_80, 1, x_73); +return x_80; +} +else +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +lean_dec(x_70); +lean_dec(x_69); +lean_dec(x_68); lean_dec(x_1); -x_97 = lean_ctor_get(x_87, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_87, 1); -lean_inc(x_98); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - x_99 = x_87; +x_81 = lean_ctor_get(x_71, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_71, 1); +lean_inc(x_82); +if (lean_is_exclusive(x_71)) { + lean_ctor_release(x_71, 0); + lean_ctor_release(x_71, 1); + x_83 = x_71; } else { - lean_dec_ref(x_87); - x_99 = lean_box(0); + lean_dec_ref(x_71); + x_83 = lean_box(0); } -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_83)) { + x_84 = lean_alloc_ctor(1, 2, 0); } else { - x_100 = x_99; + x_84 = x_83; } -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -return x_100; +lean_ctor_set(x_84, 0, x_81); +lean_ctor_set(x_84, 1, x_82); +return x_84; } } } } else { -uint8_t x_101; +uint8_t x_85; lean_dec(x_2); lean_dec(x_1); -x_101 = !lean_is_exclusive(x_6); -if (x_101 == 0) +x_85 = !lean_is_exclusive(x_6); +if (x_85 == 0) { return x_6; } else { -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_6, 0); -x_103 = lean_ctor_get(x_6, 1); -lean_inc(x_103); -lean_inc(x_102); +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_6, 0); +x_87 = lean_ctor_get(x_6, 1); +lean_inc(x_87); +lean_inc(x_86); lean_dec(x_6); -x_104 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_104, 0, x_102); -lean_ctor_set(x_104, 1, x_103); -return x_104; +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; } } } else { -lean_object* x_105; +lean_object* x_89; lean_dec(x_2); -x_105 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_105, 0, x_1); -lean_ctor_set(x_105, 1, x_3); -return x_105; +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_1); +lean_ctor_set(x_89, 1, x_3); +return x_89; } } } @@ -1354,7 +1147,7 @@ lean_inc(x_2); x_12 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_2, x_3, 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; lean_object* x_17; lean_object* x_59; lean_object* x_108; lean_object* x_109; uint8_t x_110; uint8_t x_111; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_59; lean_object* x_92; lean_object* x_93; uint8_t x_94; uint8_t x_95; x_13 = lean_ctor_get(x_12, 0); lean_inc(x_13); x_14 = lean_ctor_get(x_12, 1); @@ -1367,103 +1160,93 @@ if (lean_is_exclusive(x_12)) { lean_dec_ref(x_12); x_15 = lean_box(0); } -x_108 = l_Lean_Expr_eq_x3f___closed__2; -x_109 = lean_unsigned_to_nat(3u); -x_110 = l_Lean_Expr_isAppOfArity___main(x_9, x_108, x_109); -x_111 = l_Lean_Expr_isAppOfArity___main(x_13, x_108, x_109); -if (x_110 == 0) +x_92 = l_Lean_Expr_eq_x3f___closed__2; +x_93 = lean_unsigned_to_nat(3u); +x_94 = l_Lean_Expr_isAppOfArity___main(x_9, x_92, x_93); +x_95 = l_Lean_Expr_isAppOfArity___main(x_13, x_92, x_93); +if (x_94 == 0) { lean_dec(x_9); -if (x_111 == 0) +if (x_95 == 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; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; +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_dec(x_15); lean_dec(x_13); lean_dec(x_11); -x_112 = lean_ctor_get(x_14, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_14, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_3, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_3, 0); -lean_inc(x_115); +x_96 = lean_ctor_get(x_14, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_14, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_3, 1); +lean_inc(x_98); +x_99 = lean_ctor_get(x_3, 0); +lean_inc(x_99); lean_dec(x_3); -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -lean_dec(x_115); -x_117 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_117, 0, x_112); -lean_ctor_set(x_117, 1, x_113); -lean_ctor_set(x_117, 2, x_114); -lean_ctor_set(x_117, 3, x_116); -x_118 = l_Lean_mkAppStx___closed__9; -x_119 = lean_array_push(x_118, x_1); -x_120 = lean_array_push(x_119, x_2); -x_121 = l_Lean_Meta_mkEqTrans___closed__2; -x_122 = l_Lean_Meta_mkEqSymm___closed__3; -x_123 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_123, 0, x_121); -lean_ctor_set(x_123, 1, x_122); -lean_ctor_set(x_123, 2, x_120); -lean_ctor_set(x_123, 3, x_117); -x_124 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_124, 0, x_123); -lean_ctor_set(x_124, 1, x_14); -return x_124; +x_100 = lean_ctor_get(x_99, 0); +lean_inc(x_100); +lean_dec(x_99); +x_101 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_101, 0, x_96); +lean_ctor_set(x_101, 1, x_97); +lean_ctor_set(x_101, 2, x_98); +lean_ctor_set(x_101, 3, x_100); +x_102 = l_Lean_mkAppStx___closed__9; +x_103 = lean_array_push(x_102, x_1); +x_104 = lean_array_push(x_103, x_2); +x_105 = l_Lean_Meta_mkEqTrans___closed__2; +x_106 = l_Lean_Meta_mkEqSymm___closed__3; +x_107 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_107, 0, x_105); +lean_ctor_set(x_107, 1, x_106); +lean_ctor_set(x_107, 2, x_104); +lean_ctor_set(x_107, 3, x_101); +x_108 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_108, 0, x_107); +lean_ctor_set(x_108, 1, x_14); +return x_108; } else { -lean_object* x_125; -x_125 = lean_box(0); -x_59 = x_125; -goto block_107; +lean_object* x_109; +x_109 = lean_box(0); +x_59 = x_109; +goto block_91; } } else { -lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -x_126 = lean_unsigned_to_nat(0u); -x_127 = l_Lean_Expr_getAppNumArgsAux___main(x_9, x_126); -x_128 = lean_nat_sub(x_127, x_126); -x_129 = lean_unsigned_to_nat(1u); -x_130 = lean_nat_sub(x_128, x_129); -lean_dec(x_128); -x_131 = l_Lean_Expr_getRevArg_x21___main(x_9, x_130); -x_132 = lean_nat_sub(x_127, x_129); -x_133 = lean_nat_sub(x_132, x_129); -lean_dec(x_132); -x_134 = l_Lean_Expr_getRevArg_x21___main(x_9, x_133); -x_135 = lean_unsigned_to_nat(2u); -x_136 = lean_nat_sub(x_127, x_135); -lean_dec(x_127); -x_137 = lean_nat_sub(x_136, x_129); -lean_dec(x_136); -x_138 = l_Lean_Expr_getRevArg_x21___main(x_9, x_137); +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 = l_Lean_Expr_appFn_x21(x_9); +x_111 = l_Lean_Expr_appFn_x21(x_110); +x_112 = l_Lean_Expr_appArg_x21(x_111); +lean_dec(x_111); +x_113 = l_Lean_Expr_appArg_x21(x_110); +lean_dec(x_110); +x_114 = l_Lean_Expr_appArg_x21(x_9); lean_dec(x_9); -x_139 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_139, 0, x_134); -lean_ctor_set(x_139, 1, x_138); -x_140 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_140, 0, x_131); -lean_ctor_set(x_140, 1, x_139); -if (x_111 == 0) +x_115 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_115, 0, x_113); +lean_ctor_set(x_115, 1, x_114); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_112); +lean_ctor_set(x_116, 1, x_115); +if (x_95 == 0) { -lean_object* x_141; +lean_object* x_117; lean_dec(x_13); lean_dec(x_11); -x_141 = lean_box(0); -x_16 = x_141; -x_17 = x_140; +x_117 = lean_box(0); +x_16 = x_117; +x_17 = x_116; goto block_58; } else { -lean_object* x_142; -x_142 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_142, 0, x_140); -x_59 = x_142; -goto block_107; +lean_object* x_118; +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_59 = x_118; +goto block_91; } } block_58: @@ -1605,7 +1388,7 @@ return x_57; } } } -block_107: +block_91: { if (lean_obj_tag(x_59) == 0) { @@ -1656,71 +1439,51 @@ lean_dec(x_11); x_73 = !lean_is_exclusive(x_59); if (x_73 == 0) { -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_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_74 = lean_ctor_get(x_59, 0); -x_75 = lean_unsigned_to_nat(0u); -x_76 = l_Lean_Expr_getAppNumArgsAux___main(x_13, x_75); -x_77 = lean_nat_sub(x_76, x_75); -x_78 = lean_unsigned_to_nat(1u); -x_79 = lean_nat_sub(x_77, x_78); -lean_dec(x_77); -x_80 = l_Lean_Expr_getRevArg_x21___main(x_13, x_79); -x_81 = lean_nat_sub(x_76, x_78); -x_82 = lean_nat_sub(x_81, x_78); -lean_dec(x_81); -x_83 = l_Lean_Expr_getRevArg_x21___main(x_13, x_82); -x_84 = lean_unsigned_to_nat(2u); -x_85 = lean_nat_sub(x_76, x_84); +x_75 = l_Lean_Expr_appFn_x21(x_13); +x_76 = l_Lean_Expr_appFn_x21(x_75); +x_77 = l_Lean_Expr_appArg_x21(x_76); lean_dec(x_76); -x_86 = lean_nat_sub(x_85, x_78); -lean_dec(x_85); -x_87 = l_Lean_Expr_getRevArg_x21___main(x_13, x_86); +x_78 = l_Lean_Expr_appArg_x21(x_75); +lean_dec(x_75); +x_79 = l_Lean_Expr_appArg_x21(x_13); lean_dec(x_13); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_83); -lean_ctor_set(x_88, 1, x_87); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_80); -lean_ctor_set(x_89, 1, x_88); -lean_ctor_set(x_59, 0, x_89); +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(0, 2, 0); +lean_ctor_set(x_81, 0, x_77); +lean_ctor_set(x_81, 1, x_80); +lean_ctor_set(x_59, 0, x_81); x_16 = x_59; x_17 = x_74; goto block_58; } 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; -x_90 = lean_ctor_get(x_59, 0); -lean_inc(x_90); +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_82 = lean_ctor_get(x_59, 0); +lean_inc(x_82); lean_dec(x_59); -x_91 = lean_unsigned_to_nat(0u); -x_92 = l_Lean_Expr_getAppNumArgsAux___main(x_13, x_91); -x_93 = lean_nat_sub(x_92, x_91); -x_94 = lean_unsigned_to_nat(1u); -x_95 = lean_nat_sub(x_93, x_94); -lean_dec(x_93); -x_96 = l_Lean_Expr_getRevArg_x21___main(x_13, x_95); -x_97 = lean_nat_sub(x_92, x_94); -x_98 = lean_nat_sub(x_97, x_94); -lean_dec(x_97); -x_99 = l_Lean_Expr_getRevArg_x21___main(x_13, x_98); -x_100 = lean_unsigned_to_nat(2u); -x_101 = lean_nat_sub(x_92, x_100); -lean_dec(x_92); -x_102 = lean_nat_sub(x_101, x_94); -lean_dec(x_101); -x_103 = l_Lean_Expr_getRevArg_x21___main(x_13, x_102); +x_83 = l_Lean_Expr_appFn_x21(x_13); +x_84 = l_Lean_Expr_appFn_x21(x_83); +x_85 = l_Lean_Expr_appArg_x21(x_84); +lean_dec(x_84); +x_86 = l_Lean_Expr_appArg_x21(x_83); +lean_dec(x_83); +x_87 = l_Lean_Expr_appArg_x21(x_13); lean_dec(x_13); -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_96); -lean_ctor_set(x_105, 1, x_104); -x_106 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_106, 0, x_105); -x_16 = x_106; -x_17 = x_90; +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_85); +lean_ctor_set(x_89, 1, x_88); +x_90 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_90, 0, x_89); +x_16 = x_90; +x_17 = x_82; goto block_58; } } @@ -1728,78 +1491,78 @@ goto block_58; } else { -uint8_t x_143; +uint8_t x_119; lean_dec(x_11); lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_143 = !lean_is_exclusive(x_12); -if (x_143 == 0) +x_119 = !lean_is_exclusive(x_12); +if (x_119 == 0) { return x_12; } else { -lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_144 = lean_ctor_get(x_12, 0); -x_145 = lean_ctor_get(x_12, 1); -lean_inc(x_145); -lean_inc(x_144); +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_12, 0); +x_121 = lean_ctor_get(x_12, 1); +lean_inc(x_121); +lean_inc(x_120); lean_dec(x_12); -x_146 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_146, 0, x_144); -lean_ctor_set(x_146, 1, x_145); -return x_146; +x_122 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_122, 0, x_120); +lean_ctor_set(x_122, 1, x_121); +return x_122; } } } else { -uint8_t x_147; +uint8_t x_123; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_147 = !lean_is_exclusive(x_8); -if (x_147 == 0) +x_123 = !lean_is_exclusive(x_8); +if (x_123 == 0) { return x_8; } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; -x_148 = lean_ctor_get(x_8, 0); -x_149 = lean_ctor_get(x_8, 1); -lean_inc(x_149); -lean_inc(x_148); +lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_124 = lean_ctor_get(x_8, 0); +x_125 = lean_ctor_get(x_8, 1); +lean_inc(x_125); +lean_inc(x_124); lean_dec(x_8); -x_150 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_150, 0, x_148); -lean_ctor_set(x_150, 1, x_149); -return x_150; +x_126 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_126, 0, x_124); +lean_ctor_set(x_126, 1, x_125); +return x_126; } } } else { -lean_object* x_151; +lean_object* x_127; lean_dec(x_3); lean_dec(x_2); -x_151 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_151, 0, x_1); -lean_ctor_set(x_151, 1, x_4); -return x_151; +x_127 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_127, 0, x_1); +lean_ctor_set(x_127, 1, x_4); +return x_127; } } else { -lean_object* x_152; +lean_object* x_128; lean_dec(x_3); lean_dec(x_1); -x_152 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_152, 0, x_2); -lean_ctor_set(x_152, 1, x_4); -return x_152; +x_128 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_128, 0, x_2); +lean_ctor_set(x_128, 1, x_4); +return x_128; } } } @@ -1881,269 +1644,247 @@ return x_6; } 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; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; +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_free_object(x_6); -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_8, x_24); -x_26 = lean_nat_sub(x_25, x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_sub(x_26, x_27); +x_24 = l_Lean_Expr_appFn_x21(x_8); +x_25 = l_Lean_Expr_appFn_x21(x_24); +x_26 = l_Lean_Expr_appFn_x21(x_25); +x_27 = l_Lean_Expr_appArg_x21(x_26); lean_dec(x_26); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_8, x_28); -x_30 = lean_nat_sub(x_25, x_27); -x_31 = lean_nat_sub(x_30, x_27); -lean_dec(x_30); -x_32 = l_Lean_Expr_getRevArg_x21___main(x_8, x_31); -x_33 = lean_unsigned_to_nat(2u); -x_34 = lean_nat_sub(x_25, x_33); -x_35 = lean_nat_sub(x_34, x_27); -lean_dec(x_34); -x_36 = l_Lean_Expr_getRevArg_x21___main(x_8, x_35); -x_37 = lean_nat_sub(x_25, x_11); +x_28 = l_Lean_Expr_appArg_x21(x_25); lean_dec(x_25); -x_38 = lean_nat_sub(x_37, x_27); -lean_dec(x_37); -x_39 = l_Lean_Expr_getRevArg_x21___main(x_8, x_38); +x_29 = l_Lean_Expr_appArg_x21(x_24); +lean_dec(x_24); +x_30 = l_Lean_Expr_appArg_x21(x_8); lean_dec(x_8); -lean_inc(x_29); -x_40 = l_Lean_Meta_getLevel(x_29, x_2, x_9); -if (lean_obj_tag(x_40) == 0) +lean_inc(x_27); +x_31 = l_Lean_Meta_getLevel(x_27, x_2, x_9); +if (lean_obj_tag(x_31) == 0) { -uint8_t x_41; -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +uint8_t x_32; +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 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; -x_42 = lean_ctor_get(x_40, 0); -x_43 = lean_box(0); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -x_45 = l_Lean_Meta_mkHEqSymm___closed__1; -x_46 = l_Lean_mkConst(x_45, x_44); -x_47 = l_Lean_mkApp5(x_46, x_29, x_36, x_32, x_39, x_1); -lean_ctor_set(x_40, 0, x_47); -return x_40; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_33 = lean_ctor_get(x_31, 0); +x_34 = lean_box(0); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_33); +lean_ctor_set(x_35, 1, x_34); +x_36 = l_Lean_Meta_mkHEqSymm___closed__1; +x_37 = l_Lean_mkConst(x_36, x_35); +x_38 = l_Lean_mkApp5(x_37, x_27, x_29, x_28, x_30, x_1); +lean_ctor_set(x_31, 0, x_38); +return x_31; } 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; -x_48 = lean_ctor_get(x_40, 0); -x_49 = lean_ctor_get(x_40, 1); +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_39 = lean_ctor_get(x_31, 0); +x_40 = lean_ctor_get(x_31, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_31); +x_41 = lean_box(0); +x_42 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_42, 0, x_39); +lean_ctor_set(x_42, 1, x_41); +x_43 = l_Lean_Meta_mkHEqSymm___closed__1; +x_44 = l_Lean_mkConst(x_43, x_42); +x_45 = l_Lean_mkApp5(x_44, x_27, x_29, x_28, x_30, x_1); +x_46 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_46, 1, x_40); +return x_46; +} +} +else +{ +uint8_t x_47; +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_27); +lean_dec(x_1); +x_47 = !lean_is_exclusive(x_31); +if (x_47 == 0) +{ +return x_31; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_31, 0); +x_49 = lean_ctor_get(x_31, 1); lean_inc(x_49); lean_inc(x_48); -lean_dec(x_40); -x_50 = lean_box(0); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_48); -lean_ctor_set(x_51, 1, x_50); -x_52 = l_Lean_Meta_mkHEqSymm___closed__1; -x_53 = l_Lean_mkConst(x_52, x_51); -x_54 = l_Lean_mkApp5(x_53, x_29, x_36, x_32, x_39, x_1); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_49); -return x_55; -} -} -else -{ -uint8_t x_56; -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_32); -lean_dec(x_29); -lean_dec(x_1); -x_56 = !lean_is_exclusive(x_40); -if (x_56 == 0) -{ -return x_40; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_40, 0); -x_58 = lean_ctor_get(x_40, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_40); -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_dec(x_31); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; } } } } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; uint8_t x_64; -x_60 = lean_ctor_get(x_6, 0); -x_61 = lean_ctor_get(x_6, 1); -lean_inc(x_61); -lean_inc(x_60); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_6, 0); +x_52 = lean_ctor_get(x_6, 1); +lean_inc(x_52); +lean_inc(x_51); lean_dec(x_6); -x_62 = l_Lean_Expr_heq_x3f___closed__2; -x_63 = lean_unsigned_to_nat(4u); -x_64 = l_Lean_Expr_isAppOfArity___main(x_60, x_62, x_63); -if (x_64 == 0) +x_53 = l_Lean_Expr_heq_x3f___closed__2; +x_54 = lean_unsigned_to_nat(4u); +x_55 = l_Lean_Expr_isAppOfArity___main(x_51, x_53, x_54); +if (x_55 == 0) { -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -lean_dec(x_60); -x_65 = lean_ctor_get(x_61, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_61, 1); -lean_inc(x_66); -x_67 = lean_ctor_get(x_2, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_2, 0); -lean_inc(x_68); +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_dec(x_51); +x_56 = lean_ctor_get(x_52, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_52, 1); +lean_inc(x_57); +x_58 = lean_ctor_get(x_2, 1); +lean_inc(x_58); +x_59 = lean_ctor_get(x_2, 0); +lean_inc(x_59); lean_dec(x_2); -x_69 = lean_ctor_get(x_68, 0); -lean_inc(x_69); +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +lean_dec(x_59); +x_61 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_61, 0, x_56); +lean_ctor_set(x_61, 1, x_57); +lean_ctor_set(x_61, 2, x_58); +lean_ctor_set(x_61, 3, x_60); +x_62 = l_Lean_mkOptionalNode___closed__2; +x_63 = lean_array_push(x_62, x_1); +x_64 = l_Lean_Meta_mkHEqSymm___closed__1; +x_65 = l_Lean_Meta_mkHEqSymm___closed__2; +x_66 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +lean_ctor_set(x_66, 2, x_63); +lean_ctor_set(x_66, 3, x_61); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_52); +return x_67; +} +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; +x_68 = l_Lean_Expr_appFn_x21(x_51); +x_69 = l_Lean_Expr_appFn_x21(x_68); +x_70 = l_Lean_Expr_appFn_x21(x_69); +x_71 = l_Lean_Expr_appArg_x21(x_70); +lean_dec(x_70); +x_72 = l_Lean_Expr_appArg_x21(x_69); +lean_dec(x_69); +x_73 = l_Lean_Expr_appArg_x21(x_68); lean_dec(x_68); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_65); -lean_ctor_set(x_70, 1, x_66); -lean_ctor_set(x_70, 2, x_67); -lean_ctor_set(x_70, 3, x_69); -x_71 = l_Lean_mkOptionalNode___closed__2; -x_72 = lean_array_push(x_71, x_1); -x_73 = l_Lean_Meta_mkHEqSymm___closed__1; -x_74 = l_Lean_Meta_mkHEqSymm___closed__2; -x_75 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -lean_ctor_set(x_75, 2, x_72); -lean_ctor_set(x_75, 3, x_70); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_61); -return x_76; +x_74 = l_Lean_Expr_appArg_x21(x_51); +lean_dec(x_51); +lean_inc(x_71); +x_75 = l_Lean_Meta_getLevel(x_71, x_2, x_52); +if (lean_obj_tag(x_75) == 0) +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_76 = lean_ctor_get(x_75, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_75, 1); +lean_inc(x_77); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + x_78 = x_75; +} else { + lean_dec_ref(x_75); + x_78 = lean_box(0); +} +x_79 = lean_box(0); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_76); +lean_ctor_set(x_80, 1, x_79); +x_81 = l_Lean_Meta_mkHEqSymm___closed__1; +x_82 = l_Lean_mkConst(x_81, x_80); +x_83 = l_Lean_mkApp5(x_82, x_71, x_73, x_72, x_74, x_1); +if (lean_is_scalar(x_78)) { + x_84 = lean_alloc_ctor(0, 2, 0); +} else { + x_84 = x_78; +} +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_77); +return x_84; } 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; lean_object* x_92; lean_object* x_93; -x_77 = lean_unsigned_to_nat(0u); -x_78 = l_Lean_Expr_getAppNumArgsAux___main(x_60, x_77); -x_79 = lean_nat_sub(x_78, x_77); -x_80 = lean_unsigned_to_nat(1u); -x_81 = lean_nat_sub(x_79, x_80); -lean_dec(x_79); -x_82 = l_Lean_Expr_getRevArg_x21___main(x_60, x_81); -x_83 = lean_nat_sub(x_78, x_80); -x_84 = lean_nat_sub(x_83, x_80); -lean_dec(x_83); -x_85 = l_Lean_Expr_getRevArg_x21___main(x_60, x_84); -x_86 = lean_unsigned_to_nat(2u); -x_87 = lean_nat_sub(x_78, x_86); -x_88 = lean_nat_sub(x_87, x_80); -lean_dec(x_87); -x_89 = l_Lean_Expr_getRevArg_x21___main(x_60, x_88); -x_90 = lean_nat_sub(x_78, x_63); -lean_dec(x_78); -x_91 = lean_nat_sub(x_90, x_80); -lean_dec(x_90); -x_92 = l_Lean_Expr_getRevArg_x21___main(x_60, x_91); -lean_dec(x_60); -lean_inc(x_82); -x_93 = l_Lean_Meta_getLevel(x_82, x_2, x_61); -if (lean_obj_tag(x_93) == 0) -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -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); -} -x_97 = lean_box(0); -x_98 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_98, 0, x_94); -lean_ctor_set(x_98, 1, x_97); -x_99 = l_Lean_Meta_mkHEqSymm___closed__1; -x_100 = l_Lean_mkConst(x_99, x_98); -x_101 = l_Lean_mkApp5(x_100, x_82, x_89, x_85, x_92, x_1); -if (lean_is_scalar(x_96)) { - x_102 = lean_alloc_ctor(0, 2, 0); -} else { - x_102 = x_96; -} -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_95); -return x_102; -} -else -{ -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -lean_dec(x_92); -lean_dec(x_89); -lean_dec(x_85); -lean_dec(x_82); +lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; +lean_dec(x_74); +lean_dec(x_73); +lean_dec(x_72); +lean_dec(x_71); lean_dec(x_1); -x_103 = lean_ctor_get(x_93, 0); -lean_inc(x_103); -x_104 = lean_ctor_get(x_93, 1); -lean_inc(x_104); -if (lean_is_exclusive(x_93)) { - lean_ctor_release(x_93, 0); - lean_ctor_release(x_93, 1); - x_105 = x_93; +x_85 = lean_ctor_get(x_75, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_75, 1); +lean_inc(x_86); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + x_87 = x_75; } else { - lean_dec_ref(x_93); - x_105 = lean_box(0); + lean_dec_ref(x_75); + x_87 = lean_box(0); } -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_87)) { + x_88 = lean_alloc_ctor(1, 2, 0); } else { - x_106 = x_105; + x_88 = x_87; } -lean_ctor_set(x_106, 0, x_103); -lean_ctor_set(x_106, 1, x_104); -return x_106; +lean_ctor_set(x_88, 0, x_85); +lean_ctor_set(x_88, 1, x_86); +return x_88; } } } } else { -uint8_t x_107; +uint8_t x_89; lean_dec(x_2); lean_dec(x_1); -x_107 = !lean_is_exclusive(x_6); -if (x_107 == 0) +x_89 = !lean_is_exclusive(x_6); +if (x_89 == 0) { return x_6; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_6, 0); -x_109 = lean_ctor_get(x_6, 1); -lean_inc(x_109); -lean_inc(x_108); +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_6, 0); +x_91 = lean_ctor_get(x_6, 1); +lean_inc(x_91); +lean_inc(x_90); lean_dec(x_6); -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; +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +return x_92; } } } else { -lean_object* x_111; +lean_object* x_93; lean_dec(x_2); -x_111 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_3); -return x_111; +x_93 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_93, 0, x_1); +lean_ctor_set(x_93, 1, x_3); +return x_93; } } } @@ -2193,7 +1934,7 @@ lean_inc(x_2); x_12 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_2, x_3, 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; lean_object* x_17; lean_object* x_63; lean_object* x_122; lean_object* x_123; uint8_t x_124; uint8_t x_125; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_63; lean_object* x_102; lean_object* x_103; uint8_t x_104; uint8_t x_105; x_13 = lean_ctor_get(x_12, 0); lean_inc(x_13); x_14 = lean_ctor_get(x_12, 1); @@ -2206,110 +1947,99 @@ if (lean_is_exclusive(x_12)) { lean_dec_ref(x_12); x_15 = lean_box(0); } -x_122 = l_Lean_Expr_heq_x3f___closed__2; -x_123 = lean_unsigned_to_nat(4u); -x_124 = l_Lean_Expr_isAppOfArity___main(x_9, x_122, x_123); -x_125 = l_Lean_Expr_isAppOfArity___main(x_13, x_122, x_123); -if (x_124 == 0) +x_102 = l_Lean_Expr_heq_x3f___closed__2; +x_103 = lean_unsigned_to_nat(4u); +x_104 = l_Lean_Expr_isAppOfArity___main(x_9, x_102, x_103); +x_105 = l_Lean_Expr_isAppOfArity___main(x_13, x_102, x_103); +if (x_104 == 0) { lean_dec(x_9); -if (x_125 == 0) +if (x_105 == 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_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_dec(x_15); lean_dec(x_13); lean_dec(x_11); -x_126 = lean_ctor_get(x_14, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_14, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_3, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_3, 0); -lean_inc(x_129); +x_106 = lean_ctor_get(x_14, 0); +lean_inc(x_106); +x_107 = lean_ctor_get(x_14, 1); +lean_inc(x_107); +x_108 = lean_ctor_get(x_3, 1); +lean_inc(x_108); +x_109 = lean_ctor_get(x_3, 0); +lean_inc(x_109); lean_dec(x_3); -x_130 = lean_ctor_get(x_129, 0); -lean_inc(x_130); -lean_dec(x_129); -x_131 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_131, 0, x_126); -lean_ctor_set(x_131, 1, x_127); -lean_ctor_set(x_131, 2, x_128); -lean_ctor_set(x_131, 3, x_130); -x_132 = l_Lean_mkAppStx___closed__9; -x_133 = lean_array_push(x_132, x_1); -x_134 = lean_array_push(x_133, x_2); -x_135 = l_Lean_Meta_mkHEqTrans___closed__1; -x_136 = l_Lean_Meta_mkHEqSymm___closed__2; -x_137 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_137, 0, x_135); -lean_ctor_set(x_137, 1, x_136); -lean_ctor_set(x_137, 2, x_134); -lean_ctor_set(x_137, 3, x_131); -x_138 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_138, 0, x_137); -lean_ctor_set(x_138, 1, x_14); -return x_138; +x_110 = lean_ctor_get(x_109, 0); +lean_inc(x_110); +lean_dec(x_109); +x_111 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_111, 0, x_106); +lean_ctor_set(x_111, 1, x_107); +lean_ctor_set(x_111, 2, x_108); +lean_ctor_set(x_111, 3, x_110); +x_112 = l_Lean_mkAppStx___closed__9; +x_113 = lean_array_push(x_112, x_1); +x_114 = lean_array_push(x_113, x_2); +x_115 = l_Lean_Meta_mkHEqTrans___closed__1; +x_116 = l_Lean_Meta_mkHEqSymm___closed__2; +x_117 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_117, 0, x_115); +lean_ctor_set(x_117, 1, x_116); +lean_ctor_set(x_117, 2, x_114); +lean_ctor_set(x_117, 3, x_111); +x_118 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_118, 0, x_117); +lean_ctor_set(x_118, 1, x_14); +return x_118; } else { -lean_object* x_139; -x_139 = lean_box(0); -x_63 = x_139; -goto block_121; +lean_object* x_119; +x_119 = lean_box(0); +x_63 = x_119; +goto block_101; } } 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; lean_object* x_157; lean_object* x_158; -x_140 = lean_unsigned_to_nat(0u); -x_141 = l_Lean_Expr_getAppNumArgsAux___main(x_9, x_140); -x_142 = lean_nat_sub(x_141, x_140); -x_143 = lean_unsigned_to_nat(1u); -x_144 = lean_nat_sub(x_142, x_143); -lean_dec(x_142); -x_145 = l_Lean_Expr_getRevArg_x21___main(x_9, x_144); -x_146 = lean_nat_sub(x_141, x_143); -x_147 = lean_nat_sub(x_146, x_143); -lean_dec(x_146); -x_148 = l_Lean_Expr_getRevArg_x21___main(x_9, x_147); -x_149 = lean_unsigned_to_nat(2u); -x_150 = lean_nat_sub(x_141, x_149); -x_151 = lean_nat_sub(x_150, x_143); -lean_dec(x_150); -x_152 = l_Lean_Expr_getRevArg_x21___main(x_9, x_151); -x_153 = lean_nat_sub(x_141, x_123); -lean_dec(x_141); -x_154 = lean_nat_sub(x_153, x_143); -lean_dec(x_153); -x_155 = l_Lean_Expr_getRevArg_x21___main(x_9, x_154); +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_120 = l_Lean_Expr_appFn_x21(x_9); +x_121 = l_Lean_Expr_appFn_x21(x_120); +x_122 = l_Lean_Expr_appFn_x21(x_121); +x_123 = l_Lean_Expr_appArg_x21(x_122); +lean_dec(x_122); +x_124 = l_Lean_Expr_appArg_x21(x_121); +lean_dec(x_121); +x_125 = l_Lean_Expr_appArg_x21(x_120); +lean_dec(x_120); +x_126 = l_Lean_Expr_appArg_x21(x_9); lean_dec(x_9); -x_156 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_156, 0, x_152); -lean_ctor_set(x_156, 1, x_155); -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_148); -lean_ctor_set(x_157, 1, x_156); -x_158 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_158, 0, x_145); -lean_ctor_set(x_158, 1, x_157); -if (x_125 == 0) +x_127 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_127, 0, x_125); +lean_ctor_set(x_127, 1, x_126); +x_128 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_128, 0, x_124); +lean_ctor_set(x_128, 1, x_127); +x_129 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_129, 0, x_123); +lean_ctor_set(x_129, 1, x_128); +if (x_105 == 0) { -lean_object* x_159; +lean_object* x_130; lean_dec(x_13); lean_dec(x_11); -x_159 = lean_box(0); -x_16 = x_159; -x_17 = x_158; +x_130 = lean_box(0); +x_16 = x_130; +x_17 = x_129; goto block_62; } else { -lean_object* x_160; -x_160 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_160, 0, x_158); -x_63 = x_160; -goto block_121; +lean_object* x_131; +x_131 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_131, 0, x_129); +x_63 = x_131; +goto block_101; } } block_62: @@ -2464,7 +2194,7 @@ return x_61; } } } -block_121: +block_101: { if (lean_obj_tag(x_63) == 0) { @@ -2515,87 +2245,63 @@ lean_dec(x_11); x_77 = !lean_is_exclusive(x_63); if (x_77 == 0) { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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_78 = lean_ctor_get(x_63, 0); -x_79 = lean_unsigned_to_nat(0u); -x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_13, x_79); -x_81 = lean_nat_sub(x_80, x_79); -x_82 = lean_unsigned_to_nat(1u); -x_83 = lean_nat_sub(x_81, x_82); +x_79 = l_Lean_Expr_appFn_x21(x_13); +x_80 = l_Lean_Expr_appFn_x21(x_79); +x_81 = l_Lean_Expr_appFn_x21(x_80); +x_82 = l_Lean_Expr_appArg_x21(x_81); lean_dec(x_81); -x_84 = l_Lean_Expr_getRevArg_x21___main(x_13, x_83); -x_85 = lean_nat_sub(x_80, x_82); -x_86 = lean_nat_sub(x_85, x_82); -lean_dec(x_85); -x_87 = l_Lean_Expr_getRevArg_x21___main(x_13, x_86); -x_88 = lean_unsigned_to_nat(2u); -x_89 = lean_nat_sub(x_80, x_88); -x_90 = lean_nat_sub(x_89, x_82); -lean_dec(x_89); -x_91 = l_Lean_Expr_getRevArg_x21___main(x_13, x_90); -x_92 = lean_unsigned_to_nat(4u); -x_93 = lean_nat_sub(x_80, x_92); +x_83 = l_Lean_Expr_appArg_x21(x_80); lean_dec(x_80); -x_94 = lean_nat_sub(x_93, x_82); -lean_dec(x_93); -x_95 = l_Lean_Expr_getRevArg_x21___main(x_13, x_94); +x_84 = l_Lean_Expr_appArg_x21(x_79); +lean_dec(x_79); +x_85 = l_Lean_Expr_appArg_x21(x_13); lean_dec(x_13); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_91); -lean_ctor_set(x_96, 1, x_95); -x_97 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_97, 0, x_87); -lean_ctor_set(x_97, 1, x_96); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_84); -lean_ctor_set(x_98, 1, x_97); -lean_ctor_set(x_63, 0, x_98); +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_84); +lean_ctor_set(x_86, 1, x_85); +x_87 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_87, 0, x_83); +lean_ctor_set(x_87, 1, x_86); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_82); +lean_ctor_set(x_88, 1, x_87); +lean_ctor_set(x_63, 0, x_88); x_16 = x_63; x_17 = x_78; goto block_62; } 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; 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_99 = lean_ctor_get(x_63, 0); -lean_inc(x_99); +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_89 = lean_ctor_get(x_63, 0); +lean_inc(x_89); lean_dec(x_63); -x_100 = lean_unsigned_to_nat(0u); -x_101 = l_Lean_Expr_getAppNumArgsAux___main(x_13, x_100); -x_102 = lean_nat_sub(x_101, x_100); -x_103 = lean_unsigned_to_nat(1u); -x_104 = lean_nat_sub(x_102, x_103); -lean_dec(x_102); -x_105 = l_Lean_Expr_getRevArg_x21___main(x_13, x_104); -x_106 = lean_nat_sub(x_101, x_103); -x_107 = lean_nat_sub(x_106, x_103); -lean_dec(x_106); -x_108 = l_Lean_Expr_getRevArg_x21___main(x_13, x_107); -x_109 = lean_unsigned_to_nat(2u); -x_110 = lean_nat_sub(x_101, x_109); -x_111 = lean_nat_sub(x_110, x_103); -lean_dec(x_110); -x_112 = l_Lean_Expr_getRevArg_x21___main(x_13, x_111); -x_113 = lean_unsigned_to_nat(4u); -x_114 = lean_nat_sub(x_101, x_113); -lean_dec(x_101); -x_115 = lean_nat_sub(x_114, x_103); -lean_dec(x_114); -x_116 = l_Lean_Expr_getRevArg_x21___main(x_13, x_115); +x_90 = l_Lean_Expr_appFn_x21(x_13); +x_91 = l_Lean_Expr_appFn_x21(x_90); +x_92 = l_Lean_Expr_appFn_x21(x_91); +x_93 = l_Lean_Expr_appArg_x21(x_92); +lean_dec(x_92); +x_94 = l_Lean_Expr_appArg_x21(x_91); +lean_dec(x_91); +x_95 = l_Lean_Expr_appArg_x21(x_90); +lean_dec(x_90); +x_96 = l_Lean_Expr_appArg_x21(x_13); lean_dec(x_13); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_112); -lean_ctor_set(x_117, 1, x_116); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_108); -lean_ctor_set(x_118, 1, x_117); -x_119 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_119, 0, x_105); -lean_ctor_set(x_119, 1, x_118); -x_120 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_120, 0, x_119); -x_16 = x_120; -x_17 = x_99; +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_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_94); +lean_ctor_set(x_98, 1, x_97); +x_99 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_99, 0, x_93); +lean_ctor_set(x_99, 1, x_98); +x_100 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_100, 0, x_99); +x_16 = x_100; +x_17 = x_89; goto block_62; } } @@ -2603,78 +2309,78 @@ goto block_62; } else { -uint8_t x_161; +uint8_t x_132; lean_dec(x_11); lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_161 = !lean_is_exclusive(x_12); -if (x_161 == 0) +x_132 = !lean_is_exclusive(x_12); +if (x_132 == 0) { return x_12; } else { -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_12, 0); -x_163 = lean_ctor_get(x_12, 1); -lean_inc(x_163); -lean_inc(x_162); +lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_133 = lean_ctor_get(x_12, 0); +x_134 = lean_ctor_get(x_12, 1); +lean_inc(x_134); +lean_inc(x_133); lean_dec(x_12); -x_164 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_164, 0, x_162); -lean_ctor_set(x_164, 1, x_163); -return x_164; +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 { -uint8_t x_165; +uint8_t x_136; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_165 = !lean_is_exclusive(x_8); -if (x_165 == 0) +x_136 = !lean_is_exclusive(x_8); +if (x_136 == 0) { return x_8; } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_8, 0); -x_167 = lean_ctor_get(x_8, 1); -lean_inc(x_167); -lean_inc(x_166); +lean_object* x_137; lean_object* x_138; lean_object* x_139; +x_137 = lean_ctor_get(x_8, 0); +x_138 = lean_ctor_get(x_8, 1); +lean_inc(x_138); +lean_inc(x_137); lean_dec(x_8); -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; +x_139 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_139, 0, x_137); +lean_ctor_set(x_139, 1, x_138); +return x_139; } } } else { -lean_object* x_169; +lean_object* x_140; lean_dec(x_3); lean_dec(x_2); -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_1); -lean_ctor_set(x_169, 1, x_4); -return x_169; +x_140 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_140, 0, x_1); +lean_ctor_set(x_140, 1, x_4); +return x_140; } } else { -lean_object* x_170; +lean_object* x_141; lean_dec(x_3); lean_dec(x_1); -x_170 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_170, 0, x_2); -lean_ctor_set(x_170, 1, x_4); -return x_170; +x_141 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_141, 0, x_2); +lean_ctor_set(x_141, 1, x_4); +return x_141; } } } @@ -2759,490 +2465,468 @@ return x_4; } 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_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_free_object(x_4); -x_22 = lean_unsigned_to_nat(0u); -x_23 = l_Lean_Expr_getAppNumArgsAux___main(x_6, x_22); -x_24 = lean_nat_sub(x_23, x_22); -x_25 = lean_unsigned_to_nat(1u); -x_26 = lean_nat_sub(x_24, x_25); +x_22 = l_Lean_Expr_appFn_x21(x_6); +x_23 = l_Lean_Expr_appFn_x21(x_22); +x_24 = l_Lean_Expr_appFn_x21(x_23); +x_25 = l_Lean_Expr_appArg_x21(x_24); lean_dec(x_24); -x_27 = l_Lean_Expr_getRevArg_x21___main(x_6, x_26); -x_28 = lean_nat_sub(x_23, x_25); -x_29 = lean_nat_sub(x_28, x_25); -lean_dec(x_28); -x_30 = l_Lean_Expr_getRevArg_x21___main(x_6, x_29); -x_31 = lean_unsigned_to_nat(2u); -x_32 = lean_nat_sub(x_23, x_31); -x_33 = lean_nat_sub(x_32, x_25); -lean_dec(x_32); -x_34 = l_Lean_Expr_getRevArg_x21___main(x_6, x_33); -x_35 = lean_nat_sub(x_23, x_9); +x_26 = l_Lean_Expr_appArg_x21(x_23); lean_dec(x_23); -x_36 = lean_nat_sub(x_35, x_25); -lean_dec(x_35); -x_37 = l_Lean_Expr_getRevArg_x21___main(x_6, x_36); +x_27 = l_Lean_Expr_appArg_x21(x_22); +lean_dec(x_22); +x_28 = l_Lean_Expr_appArg_x21(x_6); lean_dec(x_6); lean_inc(x_2); -lean_inc(x_34); lean_inc(x_27); -x_38 = l_Lean_Meta_isExprDefEq(x_27, x_34, x_2, x_7); -if (lean_obj_tag(x_38) == 0) +lean_inc(x_25); +x_29 = l_Lean_Meta_isExprDefEq(x_25, x_27, x_2, x_7); +if (lean_obj_tag(x_29) == 0) { -lean_object* x_39; uint8_t x_40; +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_unbox(x_30); +lean_dec(x_30); +if (x_31 == 0) +{ +uint8_t x_32; +lean_dec(x_28); +lean_dec(x_26); +lean_dec(x_1); +x_32 = !lean_is_exclusive(x_29); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; 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_29, 1); +x_34 = lean_ctor_get(x_29, 0); +lean_dec(x_34); +x_35 = lean_ctor_get(x_33, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +x_37 = lean_ctor_get(x_2, 1); +lean_inc(x_37); +x_38 = lean_ctor_get(x_2, 0); +lean_inc(x_38); +lean_dec(x_2); x_39 = lean_ctor_get(x_38, 0); lean_inc(x_39); -x_40 = lean_unbox(x_39); -lean_dec(x_39); -if (x_40 == 0) +lean_dec(x_38); +x_40 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_40, 0, x_35); +lean_ctor_set(x_40, 1, x_36); +lean_ctor_set(x_40, 2, x_37); +lean_ctor_set(x_40, 3, x_39); +x_41 = l_Lean_mkAppStx___closed__9; +x_42 = lean_array_push(x_41, x_25); +x_43 = lean_array_push(x_42, x_27); +x_44 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_45 = l_Lean_Meta_mkEqOfHEq___closed__3; +x_46 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_46, 0, x_44); +lean_ctor_set(x_46, 1, x_45); +lean_ctor_set(x_46, 2, x_43); +lean_ctor_set(x_46, 3, x_40); +lean_ctor_set_tag(x_29, 1); +lean_ctor_set(x_29, 0, x_46); +return x_29; +} +else { -uint8_t x_41; -lean_dec(x_37); -lean_dec(x_30); -lean_dec(x_1); -x_41 = !lean_is_exclusive(x_38); -if (x_41 == 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; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_42 = lean_ctor_get(x_38, 1); -x_43 = lean_ctor_get(x_38, 0); -lean_dec(x_43); -x_44 = lean_ctor_get(x_42, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_42, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_2, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_2, 0); +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_47 = lean_ctor_get(x_29, 1); lean_inc(x_47); -lean_dec(x_2); +lean_dec(x_29); x_48 = lean_ctor_get(x_47, 0); lean_inc(x_48); -lean_dec(x_47); -x_49 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_49, 0, x_44); -lean_ctor_set(x_49, 1, x_45); -lean_ctor_set(x_49, 2, x_46); -lean_ctor_set(x_49, 3, x_48); -x_50 = l_Lean_mkAppStx___closed__9; -x_51 = lean_array_push(x_50, x_27); -x_52 = lean_array_push(x_51, x_34); -x_53 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_54 = l_Lean_Meta_mkEqOfHEq___closed__3; -x_55 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_52); -lean_ctor_set(x_55, 3, x_49); -lean_ctor_set_tag(x_38, 1); -lean_ctor_set(x_38, 0, x_55); -return x_38; -} -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; -x_56 = lean_ctor_get(x_38, 1); -lean_inc(x_56); -lean_dec(x_38); -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -x_59 = lean_ctor_get(x_2, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_2, 0); -lean_inc(x_60); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +x_50 = lean_ctor_get(x_2, 1); +lean_inc(x_50); +x_51 = lean_ctor_get(x_2, 0); +lean_inc(x_51); lean_dec(x_2); -x_61 = lean_ctor_get(x_60, 0); +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +lean_dec(x_51); +x_53 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_53, 0, x_48); +lean_ctor_set(x_53, 1, x_49); +lean_ctor_set(x_53, 2, x_50); +lean_ctor_set(x_53, 3, x_52); +x_54 = l_Lean_mkAppStx___closed__9; +x_55 = lean_array_push(x_54, x_25); +x_56 = lean_array_push(x_55, x_27); +x_57 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_58 = l_Lean_Meta_mkEqOfHEq___closed__3; +x_59 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +lean_ctor_set(x_59, 2, x_56); +lean_ctor_set(x_59, 3, x_53); +x_60 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_47); +return x_60; +} +} +else +{ +lean_object* x_61; lean_object* x_62; +lean_dec(x_27); +x_61 = lean_ctor_get(x_29, 1); lean_inc(x_61); -lean_dec(x_60); -x_62 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_62, 0, x_57); -lean_ctor_set(x_62, 1, x_58); -lean_ctor_set(x_62, 2, x_59); -lean_ctor_set(x_62, 3, x_61); -x_63 = l_Lean_mkAppStx___closed__9; -x_64 = lean_array_push(x_63, x_27); -x_65 = lean_array_push(x_64, x_34); -x_66 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_67 = l_Lean_Meta_mkEqOfHEq___closed__3; -x_68 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_68, 0, x_66); -lean_ctor_set(x_68, 1, x_67); -lean_ctor_set(x_68, 2, x_65); -lean_ctor_set(x_68, 3, x_62); -x_69 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_56); -return x_69; -} +lean_dec(x_29); +lean_inc(x_25); +x_62 = l_Lean_Meta_getLevel(x_25, x_2, x_61); +if (lean_obj_tag(x_62) == 0) +{ +uint8_t x_63; +x_63 = !lean_is_exclusive(x_62); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_64 = lean_ctor_get(x_62, 0); +x_65 = lean_box(0); +x_66 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +x_67 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_68 = l_Lean_mkConst(x_67, x_66); +x_69 = l_Lean_mkApp4(x_68, x_25, x_26, x_28, x_1); +lean_ctor_set(x_62, 0, x_69); +return x_62; } else { -lean_object* x_70; lean_object* x_71; -lean_dec(x_34); -x_70 = lean_ctor_get(x_38, 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; +x_70 = lean_ctor_get(x_62, 0); +x_71 = lean_ctor_get(x_62, 1); +lean_inc(x_71); lean_inc(x_70); -lean_dec(x_38); -lean_inc(x_27); -x_71 = l_Lean_Meta_getLevel(x_27, x_2, 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; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_73 = lean_ctor_get(x_71, 0); -x_74 = lean_box(0); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -x_76 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_77 = l_Lean_mkConst(x_76, x_75); -x_78 = l_Lean_mkApp4(x_77, x_27, x_30, x_37, x_1); -lean_ctor_set(x_71, 0, x_78); -return x_71; +lean_dec(x_62); +x_72 = lean_box(0); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_70); +lean_ctor_set(x_73, 1, x_72); +x_74 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_75 = l_Lean_mkConst(x_74, x_73); +x_76 = l_Lean_mkApp4(x_75, x_25, x_26, x_28, x_1); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_76); +lean_ctor_set(x_77, 1, x_71); +return x_77; +} } else { -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_79 = lean_ctor_get(x_71, 0); -x_80 = lean_ctor_get(x_71, 1); +uint8_t x_78; +lean_dec(x_28); +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_62); +if (x_78 == 0) +{ +return x_62; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_62, 0); +x_80 = lean_ctor_get(x_62, 1); lean_inc(x_80); lean_inc(x_79); -lean_dec(x_71); -x_81 = lean_box(0); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_79); -lean_ctor_set(x_82, 1, x_81); -x_83 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_84 = l_Lean_mkConst(x_83, x_82); -x_85 = l_Lean_mkApp4(x_84, x_27, x_30, x_37, x_1); -x_86 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_86, 0, x_85); -lean_ctor_set(x_86, 1, x_80); -return x_86; +lean_dec(x_62); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} } } else { -uint8_t x_87; -lean_dec(x_37); -lean_dec(x_30); -lean_dec(x_27); -lean_dec(x_1); -x_87 = !lean_is_exclusive(x_71); -if (x_87 == 0) -{ -return x_71; -} -else -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_71, 0); -x_89 = lean_ctor_get(x_71, 1); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_71); -x_90 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_90, 0, x_88); -lean_ctor_set(x_90, 1, x_89); -return x_90; -} -} -} -} -else -{ -uint8_t x_91; -lean_dec(x_37); -lean_dec(x_34); -lean_dec(x_30); +uint8_t x_82; +lean_dec(x_28); lean_dec(x_27); +lean_dec(x_26); +lean_dec(x_25); lean_dec(x_2); lean_dec(x_1); -x_91 = !lean_is_exclusive(x_38); -if (x_91 == 0) +x_82 = !lean_is_exclusive(x_29); +if (x_82 == 0) { -return x_38; +return x_29; } else { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_38, 0); -x_93 = lean_ctor_get(x_38, 1); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_38); -x_94 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_94, 0, x_92); -lean_ctor_set(x_94, 1, x_93); -return x_94; +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_29, 0); +x_84 = lean_ctor_get(x_29, 1); +lean_inc(x_84); +lean_inc(x_83); +lean_dec(x_29); +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_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; uint8_t x_99; -x_95 = lean_ctor_get(x_4, 0); -x_96 = lean_ctor_get(x_4, 1); -lean_inc(x_96); -lean_inc(x_95); +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; uint8_t x_90; +x_86 = lean_ctor_get(x_4, 0); +x_87 = lean_ctor_get(x_4, 1); +lean_inc(x_87); +lean_inc(x_86); lean_dec(x_4); -x_97 = l_Lean_Expr_heq_x3f___closed__2; -x_98 = lean_unsigned_to_nat(4u); -x_99 = l_Lean_Expr_isAppOfArity___main(x_95, x_97, x_98); -if (x_99 == 0) +x_88 = l_Lean_Expr_heq_x3f___closed__2; +x_89 = lean_unsigned_to_nat(4u); +x_90 = l_Lean_Expr_isAppOfArity___main(x_86, x_88, x_89); +if (x_90 == 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_dec(x_95); -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_2, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_2, 0); -lean_inc(x_103); +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_dec(x_86); +x_91 = lean_ctor_get(x_87, 0); +lean_inc(x_91); +x_92 = lean_ctor_get(x_87, 1); +lean_inc(x_92); +x_93 = lean_ctor_get(x_2, 1); +lean_inc(x_93); +x_94 = lean_ctor_get(x_2, 0); +lean_inc(x_94); lean_dec(x_2); -x_104 = lean_ctor_get(x_103, 0); -lean_inc(x_104); -lean_dec(x_103); -x_105 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_105, 0, x_100); -lean_ctor_set(x_105, 1, x_101); -lean_ctor_set(x_105, 2, x_102); -lean_ctor_set(x_105, 3, x_104); -x_106 = l_Lean_mkOptionalNode___closed__2; -x_107 = lean_array_push(x_106, x_1); -x_108 = l_Lean_Meta_mkHEqTrans___closed__1; -x_109 = l_Lean_Meta_mkHEqSymm___closed__2; -x_110 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -lean_ctor_set(x_110, 2, x_107); -lean_ctor_set(x_110, 3, x_105); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_110); -lean_ctor_set(x_111, 1, x_96); -return x_111; +x_95 = lean_ctor_get(x_94, 0); +lean_inc(x_95); +lean_dec(x_94); +x_96 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_96, 0, x_91); +lean_ctor_set(x_96, 1, x_92); +lean_ctor_set(x_96, 2, x_93); +lean_ctor_set(x_96, 3, x_95); +x_97 = l_Lean_mkOptionalNode___closed__2; +x_98 = lean_array_push(x_97, x_1); +x_99 = l_Lean_Meta_mkHEqTrans___closed__1; +x_100 = l_Lean_Meta_mkHEqSymm___closed__2; +x_101 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_101, 0, x_99); +lean_ctor_set(x_101, 1, x_100); +lean_ctor_set(x_101, 2, x_98); +lean_ctor_set(x_101, 3, x_96); +x_102 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_102, 0, x_101); +lean_ctor_set(x_102, 1, x_87); +return x_102; } 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; lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_112 = lean_unsigned_to_nat(0u); -x_113 = l_Lean_Expr_getAppNumArgsAux___main(x_95, x_112); -x_114 = lean_nat_sub(x_113, x_112); -x_115 = lean_unsigned_to_nat(1u); -x_116 = lean_nat_sub(x_114, x_115); -lean_dec(x_114); -x_117 = l_Lean_Expr_getRevArg_x21___main(x_95, x_116); -x_118 = lean_nat_sub(x_113, x_115); -x_119 = lean_nat_sub(x_118, x_115); -lean_dec(x_118); -x_120 = l_Lean_Expr_getRevArg_x21___main(x_95, x_119); -x_121 = lean_unsigned_to_nat(2u); -x_122 = lean_nat_sub(x_113, x_121); -x_123 = lean_nat_sub(x_122, x_115); -lean_dec(x_122); -x_124 = l_Lean_Expr_getRevArg_x21___main(x_95, x_123); -x_125 = lean_nat_sub(x_113, x_98); -lean_dec(x_113); -x_126 = lean_nat_sub(x_125, x_115); -lean_dec(x_125); -x_127 = l_Lean_Expr_getRevArg_x21___main(x_95, x_126); -lean_dec(x_95); +lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_103 = l_Lean_Expr_appFn_x21(x_86); +x_104 = l_Lean_Expr_appFn_x21(x_103); +x_105 = l_Lean_Expr_appFn_x21(x_104); +x_106 = l_Lean_Expr_appArg_x21(x_105); +lean_dec(x_105); +x_107 = l_Lean_Expr_appArg_x21(x_104); +lean_dec(x_104); +x_108 = l_Lean_Expr_appArg_x21(x_103); +lean_dec(x_103); +x_109 = l_Lean_Expr_appArg_x21(x_86); +lean_dec(x_86); lean_inc(x_2); -lean_inc(x_124); -lean_inc(x_117); -x_128 = l_Lean_Meta_isExprDefEq(x_117, x_124, x_2, x_96); -if (lean_obj_tag(x_128) == 0) +lean_inc(x_108); +lean_inc(x_106); +x_110 = l_Lean_Meta_isExprDefEq(x_106, x_108, x_2, x_87); +if (lean_obj_tag(x_110) == 0) { -lean_object* x_129; uint8_t x_130; -x_129 = lean_ctor_get(x_128, 0); -lean_inc(x_129); -x_130 = lean_unbox(x_129); -lean_dec(x_129); -if (x_130 == 0) +lean_object* x_111; uint8_t x_112; +x_111 = lean_ctor_get(x_110, 0); +lean_inc(x_111); +x_112 = lean_unbox(x_111); +lean_dec(x_111); +if (x_112 == 0) { -lean_object* x_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_dec(x_127); -lean_dec(x_120); +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_dec(x_109); +lean_dec(x_107); lean_dec(x_1); -x_131 = lean_ctor_get(x_128, 1); -lean_inc(x_131); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_132 = x_128; +x_113 = lean_ctor_get(x_110, 1); +lean_inc(x_113); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + x_114 = x_110; } else { - lean_dec_ref(x_128); + lean_dec_ref(x_110); + x_114 = lean_box(0); +} +x_115 = lean_ctor_get(x_113, 0); +lean_inc(x_115); +x_116 = lean_ctor_get(x_113, 1); +lean_inc(x_116); +x_117 = lean_ctor_get(x_2, 1); +lean_inc(x_117); +x_118 = lean_ctor_get(x_2, 0); +lean_inc(x_118); +lean_dec(x_2); +x_119 = lean_ctor_get(x_118, 0); +lean_inc(x_119); +lean_dec(x_118); +x_120 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_120, 0, x_115); +lean_ctor_set(x_120, 1, x_116); +lean_ctor_set(x_120, 2, x_117); +lean_ctor_set(x_120, 3, x_119); +x_121 = l_Lean_mkAppStx___closed__9; +x_122 = lean_array_push(x_121, x_106); +x_123 = lean_array_push(x_122, x_108); +x_124 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_125 = l_Lean_Meta_mkEqOfHEq___closed__3; +x_126 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_126, 0, x_124); +lean_ctor_set(x_126, 1, x_125); +lean_ctor_set(x_126, 2, x_123); +lean_ctor_set(x_126, 3, x_120); +if (lean_is_scalar(x_114)) { + x_127 = lean_alloc_ctor(1, 2, 0); +} else { + x_127 = x_114; + lean_ctor_set_tag(x_127, 1); +} +lean_ctor_set(x_127, 0, x_126); +lean_ctor_set(x_127, 1, x_113); +return x_127; +} +else +{ +lean_object* x_128; lean_object* x_129; +lean_dec(x_108); +x_128 = lean_ctor_get(x_110, 1); +lean_inc(x_128); +lean_dec(x_110); +lean_inc(x_106); +x_129 = l_Lean_Meta_getLevel(x_106, 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; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +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_131, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_131, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_2, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_2, 0); -lean_inc(x_136); -lean_dec(x_2); -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -lean_dec(x_136); -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_135); -lean_ctor_set(x_138, 3, x_137); -x_139 = l_Lean_mkAppStx___closed__9; -x_140 = lean_array_push(x_139, x_117); -x_141 = lean_array_push(x_140, x_124); -x_142 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_143 = l_Lean_Meta_mkEqOfHEq___closed__3; -x_144 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_144, 0, x_142); -lean_ctor_set(x_144, 1, x_143); -lean_ctor_set(x_144, 2, x_141); -lean_ctor_set(x_144, 3, x_138); +x_133 = lean_box(0); +x_134 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_134, 0, x_130); +lean_ctor_set(x_134, 1, x_133); +x_135 = l_Lean_Meta_mkEqOfHEq___closed__2; +x_136 = l_Lean_mkConst(x_135, x_134); +x_137 = l_Lean_mkApp4(x_136, x_106, x_107, x_109, x_1); if (lean_is_scalar(x_132)) { - x_145 = lean_alloc_ctor(1, 2, 0); + x_138 = lean_alloc_ctor(0, 2, 0); } else { - x_145 = x_132; - lean_ctor_set_tag(x_145, 1); + x_138 = x_132; } -lean_ctor_set(x_145, 0, x_144); -lean_ctor_set(x_145, 1, x_131); -return x_145; +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_131); +return x_138; } else { -lean_object* x_146; lean_object* x_147; -lean_dec(x_124); -x_146 = lean_ctor_get(x_128, 1); -lean_inc(x_146); -lean_dec(x_128); -lean_inc(x_117); -x_147 = l_Lean_Meta_getLevel(x_117, x_2, x_146); -if (lean_obj_tag(x_147) == 0) -{ -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; -x_148 = lean_ctor_get(x_147, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_147, 1); -lean_inc(x_149); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_150 = x_147; -} else { - lean_dec_ref(x_147); - x_150 = lean_box(0); -} -x_151 = lean_box(0); -x_152 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_151); -x_153 = l_Lean_Meta_mkEqOfHEq___closed__2; -x_154 = l_Lean_mkConst(x_153, x_152); -x_155 = l_Lean_mkApp4(x_154, x_117, x_120, x_127, x_1); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 2, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_155); -lean_ctor_set(x_156, 1, x_149); -return x_156; -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -lean_dec(x_127); -lean_dec(x_120); -lean_dec(x_117); +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_109); +lean_dec(x_107); +lean_dec(x_106); lean_dec(x_1); -x_157 = lean_ctor_get(x_147, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_147, 1); -lean_inc(x_158); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_159 = x_147; +x_139 = lean_ctor_get(x_129, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 1); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + x_141 = x_129; } else { - lean_dec_ref(x_147); - x_159 = lean_box(0); + lean_dec_ref(x_129); + x_141 = lean_box(0); } -if (lean_is_scalar(x_159)) { - x_160 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(1, 2, 0); } else { - x_160 = x_159; + x_142 = x_141; } -lean_ctor_set(x_160, 0, x_157); -lean_ctor_set(x_160, 1, x_158); -return x_160; +lean_ctor_set(x_142, 0, x_139); +lean_ctor_set(x_142, 1, x_140); +return x_142; } } } else { -lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; -lean_dec(x_127); -lean_dec(x_124); -lean_dec(x_120); -lean_dec(x_117); +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; +lean_dec(x_109); +lean_dec(x_108); +lean_dec(x_107); +lean_dec(x_106); lean_dec(x_2); lean_dec(x_1); -x_161 = lean_ctor_get(x_128, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_128, 1); -lean_inc(x_162); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_163 = x_128; +x_143 = lean_ctor_get(x_110, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_110, 1); +lean_inc(x_144); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + x_145 = x_110; } else { - lean_dec_ref(x_128); - x_163 = lean_box(0); + lean_dec_ref(x_110); + x_145 = lean_box(0); } -if (lean_is_scalar(x_163)) { - x_164 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(1, 2, 0); } else { - x_164 = x_163; + x_146 = x_145; } -lean_ctor_set(x_164, 0, x_161); -lean_ctor_set(x_164, 1, x_162); -return x_164; +lean_ctor_set(x_146, 0, x_143); +lean_ctor_set(x_146, 1, x_144); +return x_146; } } } } else { -uint8_t x_165; +uint8_t x_147; lean_dec(x_2); lean_dec(x_1); -x_165 = !lean_is_exclusive(x_4); -if (x_165 == 0) +x_147 = !lean_is_exclusive(x_4); +if (x_147 == 0) { return x_4; } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_4, 0); -x_167 = lean_ctor_get(x_4, 1); -lean_inc(x_167); -lean_inc(x_166); +lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_148 = lean_ctor_get(x_4, 0); +x_149 = lean_ctor_get(x_4, 1); +lean_inc(x_149); +lean_inc(x_148); lean_dec(x_4); -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; +x_150 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_150, 0, x_148); +lean_ctor_set(x_150, 1, x_149); +return x_150; } } } @@ -3300,7 +2984,7 @@ lean_inc(x_1); x_9 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_3, x_7); 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_64; lean_object* x_81; lean_object* x_130; lean_object* x_131; uint8_t x_132; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_64; lean_object* x_81; lean_object* x_114; lean_object* x_115; uint8_t x_116; x_10 = lean_ctor_get(x_9, 0); lean_inc(x_10); x_11 = lean_ctor_get(x_9, 1); @@ -3313,75 +2997,75 @@ if (lean_is_exclusive(x_9)) { lean_dec_ref(x_9); x_12 = lean_box(0); } -x_130 = l_Lean_Expr_eq_x3f___closed__2; -x_131 = lean_unsigned_to_nat(3u); -x_132 = l_Lean_Expr_isAppOfArity___main(x_6, x_130, x_131); +x_114 = l_Lean_Expr_eq_x3f___closed__2; +x_115 = lean_unsigned_to_nat(3u); +x_116 = l_Lean_Expr_isAppOfArity___main(x_6, x_114, x_115); if (lean_obj_tag(x_10) == 7) { -lean_object* x_133; lean_object* x_134; uint8_t x_135; -x_133 = lean_ctor_get(x_10, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_10, 2); -lean_inc(x_134); +lean_object* x_117; lean_object* x_118; uint8_t x_119; +x_117 = lean_ctor_get(x_10, 1); +lean_inc(x_117); +x_118 = lean_ctor_get(x_10, 2); +lean_inc(x_118); lean_dec(x_10); -x_135 = l_Lean_Expr_hasLooseBVars(x_134); -if (x_135 == 0) +x_119 = l_Lean_Expr_hasLooseBVars(x_118); +if (x_119 == 0) { -lean_object* x_136; lean_object* x_137; -x_136 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_136, 0, x_133); -lean_ctor_set(x_136, 1, x_134); -x_137 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_137, 0, x_136); -if (x_132 == 0) +lean_object* x_120; lean_object* x_121; +x_120 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_120, 0, x_117); +lean_ctor_set(x_120, 1, x_118); +x_121 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_121, 0, x_120); +if (x_116 == 0) { lean_dec(x_6); -x_64 = x_137; +x_64 = x_121; goto block_80; } else { lean_dec(x_8); -x_81 = x_137; -goto block_129; +x_81 = x_121; +goto block_113; } } else { -lean_object* x_138; -lean_dec(x_134); -lean_dec(x_133); -x_138 = lean_box(0); -if (x_132 == 0) +lean_object* x_122; +lean_dec(x_118); +lean_dec(x_117); +x_122 = lean_box(0); +if (x_116 == 0) { lean_dec(x_6); -x_64 = x_138; +x_64 = x_122; goto block_80; } else { lean_dec(x_8); -x_81 = x_138; -goto block_129; +x_81 = x_122; +goto block_113; } } } else { -lean_object* x_139; +lean_object* x_123; lean_dec(x_10); -x_139 = lean_box(0); -if (x_132 == 0) +x_123 = lean_box(0); +if (x_116 == 0) { lean_dec(x_6); -x_64 = x_139; +x_64 = x_123; goto block_80; } else { lean_dec(x_8); -x_81 = x_139; -goto block_129; +x_81 = x_123; +goto block_113; } } block_63: @@ -3622,7 +3306,7 @@ x_14 = x_78; goto block_63; } } -block_129: +block_113: { if (lean_obj_tag(x_81) == 0) { @@ -3667,71 +3351,51 @@ uint8_t x_95; x_95 = !lean_is_exclusive(x_81); if (x_95 == 0) { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_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_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_96 = lean_ctor_get(x_81, 0); -x_97 = lean_unsigned_to_nat(0u); -x_98 = l_Lean_Expr_getAppNumArgsAux___main(x_6, x_97); -x_99 = lean_nat_sub(x_98, x_97); -x_100 = lean_unsigned_to_nat(1u); -x_101 = lean_nat_sub(x_99, x_100); -lean_dec(x_99); -x_102 = l_Lean_Expr_getRevArg_x21___main(x_6, x_101); -x_103 = lean_nat_sub(x_98, x_100); -x_104 = lean_nat_sub(x_103, x_100); -lean_dec(x_103); -x_105 = l_Lean_Expr_getRevArg_x21___main(x_6, x_104); -x_106 = lean_unsigned_to_nat(2u); -x_107 = lean_nat_sub(x_98, x_106); +x_97 = l_Lean_Expr_appFn_x21(x_6); +x_98 = l_Lean_Expr_appFn_x21(x_97); +x_99 = l_Lean_Expr_appArg_x21(x_98); lean_dec(x_98); -x_108 = lean_nat_sub(x_107, x_100); -lean_dec(x_107); -x_109 = l_Lean_Expr_getRevArg_x21___main(x_6, x_108); +x_100 = l_Lean_Expr_appArg_x21(x_97); +lean_dec(x_97); +x_101 = l_Lean_Expr_appArg_x21(x_6); lean_dec(x_6); -x_110 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_110, 0, x_105); -lean_ctor_set(x_110, 1, x_109); -x_111 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_111, 0, x_102); -lean_ctor_set(x_111, 1, x_110); -lean_ctor_set(x_81, 0, x_111); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_100); +lean_ctor_set(x_102, 1, x_101); +x_103 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_103, 0, x_99); +lean_ctor_set(x_103, 1, x_102); +lean_ctor_set(x_81, 0, x_103); x_13 = x_81; x_14 = x_96; goto block_63; } 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; lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_112 = lean_ctor_get(x_81, 0); -lean_inc(x_112); +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_81, 0); +lean_inc(x_104); lean_dec(x_81); -x_113 = lean_unsigned_to_nat(0u); -x_114 = l_Lean_Expr_getAppNumArgsAux___main(x_6, x_113); -x_115 = lean_nat_sub(x_114, x_113); -x_116 = lean_unsigned_to_nat(1u); -x_117 = lean_nat_sub(x_115, x_116); -lean_dec(x_115); -x_118 = l_Lean_Expr_getRevArg_x21___main(x_6, x_117); -x_119 = lean_nat_sub(x_114, x_116); -x_120 = lean_nat_sub(x_119, x_116); -lean_dec(x_119); -x_121 = l_Lean_Expr_getRevArg_x21___main(x_6, x_120); -x_122 = lean_unsigned_to_nat(2u); -x_123 = lean_nat_sub(x_114, x_122); -lean_dec(x_114); -x_124 = lean_nat_sub(x_123, x_116); -lean_dec(x_123); -x_125 = l_Lean_Expr_getRevArg_x21___main(x_6, x_124); +x_105 = l_Lean_Expr_appFn_x21(x_6); +x_106 = l_Lean_Expr_appFn_x21(x_105); +x_107 = l_Lean_Expr_appArg_x21(x_106); +lean_dec(x_106); +x_108 = l_Lean_Expr_appArg_x21(x_105); +lean_dec(x_105); +x_109 = l_Lean_Expr_appArg_x21(x_6); lean_dec(x_6); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_121); -lean_ctor_set(x_126, 1, x_125); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_118); -lean_ctor_set(x_127, 1, x_126); -x_128 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_128, 0, x_127); -x_13 = x_128; -x_14 = x_112; +x_110 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_110, 0, x_108); +lean_ctor_set(x_110, 1, x_109); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_107); +lean_ctor_set(x_111, 1, x_110); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_111); +x_13 = x_112; +x_14 = x_104; goto block_63; } } @@ -3739,55 +3403,55 @@ goto block_63; } else { -uint8_t x_140; +uint8_t x_124; lean_dec(x_8); lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_140 = !lean_is_exclusive(x_9); -if (x_140 == 0) +x_124 = !lean_is_exclusive(x_9); +if (x_124 == 0) { return x_9; } else { -lean_object* x_141; lean_object* x_142; lean_object* x_143; -x_141 = lean_ctor_get(x_9, 0); -x_142 = lean_ctor_get(x_9, 1); -lean_inc(x_142); -lean_inc(x_141); +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_9, 0); +x_126 = lean_ctor_get(x_9, 1); +lean_inc(x_126); +lean_inc(x_125); lean_dec(x_9); -x_143 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_143, 0, x_141); -lean_ctor_set(x_143, 1, x_142); -return x_143; +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_144; +uint8_t x_128; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_144 = !lean_is_exclusive(x_5); -if (x_144 == 0) +x_128 = !lean_is_exclusive(x_5); +if (x_128 == 0) { return x_5; } else { -lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_145 = lean_ctor_get(x_5, 0); -x_146 = lean_ctor_get(x_5, 1); -lean_inc(x_146); -lean_inc(x_145); +lean_object* x_129; lean_object* x_130; lean_object* x_131; +x_129 = lean_ctor_get(x_5, 0); +x_130 = lean_ctor_get(x_5, 1); +lean_inc(x_130); +lean_inc(x_129); lean_dec(x_5); -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_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; } } } @@ -3874,579 +3538,559 @@ return x_5; } 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; lean_object* x_36; lean_object* x_37; +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_free_object(x_5); -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_7, x_24); -x_26 = lean_nat_sub(x_25, x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_sub(x_26, x_27); -lean_dec(x_26); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_7, x_28); -x_30 = lean_nat_sub(x_25, x_27); -x_31 = lean_nat_sub(x_30, x_27); -lean_dec(x_30); -x_32 = l_Lean_Expr_getRevArg_x21___main(x_7, x_31); -x_33 = lean_unsigned_to_nat(2u); -x_34 = lean_nat_sub(x_25, x_33); +x_24 = l_Lean_Expr_appFn_x21(x_7); +x_25 = l_Lean_Expr_appFn_x21(x_24); +x_26 = l_Lean_Expr_appArg_x21(x_25); lean_dec(x_25); -x_35 = lean_nat_sub(x_34, x_27); -lean_dec(x_34); -x_36 = l_Lean_Expr_getRevArg_x21___main(x_7, x_35); +x_27 = l_Lean_Expr_appArg_x21(x_24); +lean_dec(x_24); +x_28 = l_Lean_Expr_appArg_x21(x_7); lean_dec(x_7); lean_inc(x_3); -x_37 = l_Lean_Meta_whnfD(x_29, x_3, x_8); -if (lean_obj_tag(x_37) == 0) +x_29 = l_Lean_Meta_whnfD(x_26, x_3, x_8); +if (lean_obj_tag(x_29) == 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); -if (lean_is_exclusive(x_37)) { - lean_ctor_release(x_37, 0); - lean_ctor_release(x_37, 1); - x_40 = x_37; +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +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_37); - x_40 = lean_box(0); + lean_dec_ref(x_29); + x_32 = lean_box(0); } -if (lean_obj_tag(x_38) == 7) +if (lean_obj_tag(x_30) == 7) { -lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_59; lean_object* x_60; lean_object* x_61; -lean_dec(x_40); -x_56 = lean_ctor_get(x_38, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_38, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_38, 2); -lean_inc(x_58); -lean_dec(x_38); -x_59 = 0; -lean_inc(x_57); -x_60 = l_Lean_mkLambda(x_56, x_59, x_57, x_58); -lean_dec(x_56); +lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; lean_object* x_52; lean_object* x_53; +lean_dec(x_32); +x_48 = lean_ctor_get(x_30, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_30, 1); +lean_inc(x_49); +x_50 = lean_ctor_get(x_30, 2); +lean_inc(x_50); +lean_dec(x_30); +x_51 = 0; +lean_inc(x_49); +x_52 = l_Lean_mkLambda(x_48, x_51, x_49, x_50); +lean_dec(x_48); lean_inc(x_3); -lean_inc(x_57); -x_61 = l_Lean_Meta_getLevel(x_57, x_3, x_39); -if (lean_obj_tag(x_61) == 0) +lean_inc(x_49); +x_53 = l_Lean_Meta_getLevel(x_49, x_3, x_31); +if (lean_obj_tag(x_53) == 0) { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -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); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_53, 1); +lean_inc(x_55); +lean_dec(x_53); lean_inc(x_2); -lean_inc(x_60); -x_64 = l_Lean_mkApp(x_60, x_2); -x_65 = l_Lean_Meta_getLevel(x_64, x_3, x_63); -if (lean_obj_tag(x_65) == 0) +lean_inc(x_52); +x_56 = l_Lean_mkApp(x_52, x_2); +x_57 = l_Lean_Meta_getLevel(x_56, x_3, x_55); +if (lean_obj_tag(x_57) == 0) { -uint8_t x_66; -x_66 = !lean_is_exclusive(x_65); -if (x_66 == 0) +uint8_t x_58; +x_58 = !lean_is_exclusive(x_57); +if (x_58 == 0) { -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_65, 0); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_59 = lean_ctor_get(x_57, 0); +x_60 = lean_box(0); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +x_62 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_62, 0, x_54); +lean_ctor_set(x_62, 1, x_61); +x_63 = l_Lean_Meta_mkCongrFun___closed__2; +x_64 = l_Lean_mkConst(x_63, x_62); +x_65 = l_Lean_mkApp6(x_64, x_49, x_52, x_27, x_28, x_1, x_2); +lean_ctor_set(x_57, 0, x_65); +return x_57; +} +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; +x_66 = lean_ctor_get(x_57, 0); +x_67 = lean_ctor_get(x_57, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_57); x_68 = lean_box(0); x_69 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_69, 0, x_67); +lean_ctor_set(x_69, 0, x_66); lean_ctor_set(x_69, 1, x_68); x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_62); +lean_ctor_set(x_70, 0, x_54); lean_ctor_set(x_70, 1, x_69); x_71 = l_Lean_Meta_mkCongrFun___closed__2; x_72 = l_Lean_mkConst(x_71, x_70); -x_73 = l_Lean_mkApp6(x_72, x_57, x_60, x_32, x_36, x_1, x_2); -lean_ctor_set(x_65, 0, x_73); -return x_65; +x_73 = l_Lean_mkApp6(x_72, x_49, x_52, x_27, x_28, x_1, x_2); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_73); +lean_ctor_set(x_74, 1, x_67); +return x_74; +} } 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; -x_74 = lean_ctor_get(x_65, 0); -x_75 = lean_ctor_get(x_65, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_65); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_76); +uint8_t x_75; +lean_dec(x_54); +lean_dec(x_52); +lean_dec(x_49); +lean_dec(x_28); +lean_dec(x_27); +lean_dec(x_2); +lean_dec(x_1); +x_75 = !lean_is_exclusive(x_57); +if (x_75 == 0) +{ +return x_57; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_57, 0); +x_77 = lean_ctor_get(x_57, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_57); x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_62); +lean_ctor_set(x_78, 0, x_76); lean_ctor_set(x_78, 1, x_77); -x_79 = l_Lean_Meta_mkCongrFun___closed__2; -x_80 = l_Lean_mkConst(x_79, x_78); -x_81 = l_Lean_mkApp6(x_80, x_57, x_60, x_32, x_36, x_1, x_2); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_81); -lean_ctor_set(x_82, 1, x_75); +return x_78; +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_52); +lean_dec(x_49); +lean_dec(x_28); +lean_dec(x_27); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_79 = !lean_is_exclusive(x_53); +if (x_79 == 0) +{ +return x_53; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_53, 0); +x_81 = lean_ctor_get(x_53, 1); +lean_inc(x_81); +lean_inc(x_80); +lean_dec(x_53); +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_62); -lean_dec(x_60); -lean_dec(x_57); -lean_dec(x_36); -lean_dec(x_32); -lean_dec(x_2); -lean_dec(x_1); -x_83 = !lean_is_exclusive(x_65); -if (x_83 == 0) -{ -return x_65; } else { -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_65, 0); -x_85 = lean_ctor_get(x_65, 1); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_65); -x_86 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_86, 0, x_84); -lean_ctor_set(x_86, 1, x_85); -return x_86; +lean_object* x_83; +lean_dec(x_30); +lean_dec(x_28); +lean_dec(x_27); +x_83 = lean_box(0); +x_33 = x_83; +goto block_47; } +block_47: +{ +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_dec(x_33); +x_34 = lean_ctor_get(x_31, 0); +lean_inc(x_34); +x_35 = lean_ctor_get(x_31, 1); +lean_inc(x_35); +x_36 = lean_ctor_get(x_3, 1); +lean_inc(x_36); +x_37 = lean_ctor_get(x_3, 0); +lean_inc(x_37); +lean_dec(x_3); +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +lean_dec(x_37); +x_39 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_36); +lean_ctor_set(x_39, 3, x_38); +x_40 = l_Lean_mkAppStx___closed__9; +x_41 = lean_array_push(x_40, x_1); +x_42 = lean_array_push(x_41, x_2); +x_43 = l_Lean_Meta_mkCongrFun___closed__2; +x_44 = l_Lean_Meta_mkCongrFun___closed__3; +x_45 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_44); +lean_ctor_set(x_45, 2, x_42); +lean_ctor_set(x_45, 3, x_39); +if (lean_is_scalar(x_32)) { + x_46 = lean_alloc_ctor(1, 2, 0); +} else { + x_46 = x_32; + lean_ctor_set_tag(x_46, 1); +} +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_46, 1, x_31); +return x_46; } } else { -uint8_t x_87; -lean_dec(x_60); -lean_dec(x_57); -lean_dec(x_36); -lean_dec(x_32); +uint8_t x_84; +lean_dec(x_28); +lean_dec(x_27); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_87 = !lean_is_exclusive(x_61); -if (x_87 == 0) +x_84 = !lean_is_exclusive(x_29); +if (x_84 == 0) { -return x_61; +return x_29; } else { -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_61, 0); -x_89 = lean_ctor_get(x_61, 1); +lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_85 = lean_ctor_get(x_29, 0); +x_86 = lean_ctor_get(x_29, 1); +lean_inc(x_86); +lean_inc(x_85); +lean_dec(x_29); +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 +{ +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_5, 0); +x_89 = lean_ctor_get(x_5, 1); lean_inc(x_89); lean_inc(x_88); -lean_dec(x_61); -x_90 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_90, 0, x_88); -lean_ctor_set(x_90, 1, x_89); -return x_90; -} -} -} -else -{ -lean_object* x_91; -lean_dec(x_38); -lean_dec(x_36); -lean_dec(x_32); -x_91 = lean_box(0); -x_41 = x_91; -goto block_55; -} -block_55: -{ -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_dec(x_41); -x_42 = lean_ctor_get(x_39, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 1); -lean_inc(x_43); -x_44 = lean_ctor_get(x_3, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_3, 0); -lean_inc(x_45); -lean_dec(x_3); -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -lean_dec(x_45); -x_47 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_47, 0, x_42); -lean_ctor_set(x_47, 1, x_43); -lean_ctor_set(x_47, 2, x_44); -lean_ctor_set(x_47, 3, x_46); -x_48 = l_Lean_mkAppStx___closed__9; -x_49 = lean_array_push(x_48, x_1); -x_50 = lean_array_push(x_49, x_2); -x_51 = l_Lean_Meta_mkCongrFun___closed__2; -x_52 = l_Lean_Meta_mkCongrFun___closed__3; -x_53 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -lean_ctor_set(x_53, 2, x_50); -lean_ctor_set(x_53, 3, x_47); -if (lean_is_scalar(x_40)) { - x_54 = lean_alloc_ctor(1, 2, 0); -} else { - x_54 = x_40; - lean_ctor_set_tag(x_54, 1); -} -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_39); -return x_54; -} -} -else -{ -uint8_t x_92; -lean_dec(x_36); -lean_dec(x_32); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_92 = !lean_is_exclusive(x_37); +lean_dec(x_5); +x_90 = l_Lean_Expr_eq_x3f___closed__2; +x_91 = lean_unsigned_to_nat(3u); +x_92 = l_Lean_Expr_isAppOfArity___main(x_88, x_90, x_91); if (x_92 == 0) { -return x_37; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_37, 0); -x_94 = lean_ctor_get(x_37, 1); -lean_inc(x_94); +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_dec(x_88); +x_93 = lean_ctor_get(x_89, 0); lean_inc(x_93); -lean_dec(x_37); -x_95 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_95, 0, x_93); -lean_ctor_set(x_95, 1, x_94); -return x_95; -} -} -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; uint8_t x_100; -x_96 = lean_ctor_get(x_5, 0); -x_97 = lean_ctor_get(x_5, 1); -lean_inc(x_97); +x_94 = lean_ctor_get(x_89, 1); +lean_inc(x_94); +x_95 = lean_ctor_get(x_3, 1); +lean_inc(x_95); +x_96 = lean_ctor_get(x_3, 0); lean_inc(x_96); -lean_dec(x_5); -x_98 = l_Lean_Expr_eq_x3f___closed__2; -x_99 = lean_unsigned_to_nat(3u); -x_100 = l_Lean_Expr_isAppOfArity___main(x_96, x_98, x_99); -if (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_object* x_111; lean_object* x_112; lean_object* x_113; -lean_dec(x_96); -x_101 = lean_ctor_get(x_97, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_3, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_3, 0); -lean_inc(x_104); lean_dec(x_3); -x_105 = lean_ctor_get(x_104, 0); -lean_inc(x_105); -lean_dec(x_104); -x_106 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_106, 0, x_101); -lean_ctor_set(x_106, 1, x_102); -lean_ctor_set(x_106, 2, x_103); -lean_ctor_set(x_106, 3, x_105); -x_107 = l_Lean_mkAppStx___closed__9; -x_108 = lean_array_push(x_107, x_1); -x_109 = lean_array_push(x_108, x_2); -x_110 = l_Lean_Meta_mkCongrFun___closed__2; -x_111 = l_Lean_Meta_mkEqSymm___closed__3; -x_112 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -lean_ctor_set(x_112, 2, x_109); -lean_ctor_set(x_112, 3, x_106); -x_113 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_113, 0, x_112); -lean_ctor_set(x_113, 1, x_97); -return x_113; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; -x_114 = lean_unsigned_to_nat(0u); -x_115 = l_Lean_Expr_getAppNumArgsAux___main(x_96, x_114); -x_116 = lean_nat_sub(x_115, x_114); -x_117 = lean_unsigned_to_nat(1u); -x_118 = lean_nat_sub(x_116, x_117); -lean_dec(x_116); -x_119 = l_Lean_Expr_getRevArg_x21___main(x_96, x_118); -x_120 = lean_nat_sub(x_115, x_117); -x_121 = lean_nat_sub(x_120, x_117); -lean_dec(x_120); -x_122 = l_Lean_Expr_getRevArg_x21___main(x_96, x_121); -x_123 = lean_unsigned_to_nat(2u); -x_124 = lean_nat_sub(x_115, x_123); -lean_dec(x_115); -x_125 = lean_nat_sub(x_124, x_117); -lean_dec(x_124); -x_126 = l_Lean_Expr_getRevArg_x21___main(x_96, x_125); +x_97 = lean_ctor_get(x_96, 0); +lean_inc(x_97); lean_dec(x_96); +x_98 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_98, 0, x_93); +lean_ctor_set(x_98, 1, x_94); +lean_ctor_set(x_98, 2, x_95); +lean_ctor_set(x_98, 3, x_97); +x_99 = l_Lean_mkAppStx___closed__9; +x_100 = lean_array_push(x_99, x_1); +x_101 = lean_array_push(x_100, x_2); +x_102 = l_Lean_Meta_mkCongrFun___closed__2; +x_103 = l_Lean_Meta_mkEqSymm___closed__3; +x_104 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_104, 0, x_102); +lean_ctor_set(x_104, 1, x_103); +lean_ctor_set(x_104, 2, x_101); +lean_ctor_set(x_104, 3, x_98); +x_105 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_105, 0, x_104); +lean_ctor_set(x_105, 1, x_89); +return x_105; +} +else +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_106 = l_Lean_Expr_appFn_x21(x_88); +x_107 = l_Lean_Expr_appFn_x21(x_106); +x_108 = l_Lean_Expr_appArg_x21(x_107); +lean_dec(x_107); +x_109 = l_Lean_Expr_appArg_x21(x_106); +lean_dec(x_106); +x_110 = l_Lean_Expr_appArg_x21(x_88); +lean_dec(x_88); lean_inc(x_3); -x_127 = l_Lean_Meta_whnfD(x_119, x_3, x_97); -if (lean_obj_tag(x_127) == 0) +x_111 = l_Lean_Meta_whnfD(x_108, x_3, x_89); +if (lean_obj_tag(x_111) == 0) { -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_127, 1); -lean_inc(x_129); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_130 = x_127; +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_112 = lean_ctor_get(x_111, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_111, 1); +lean_inc(x_113); +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + x_114 = x_111; } else { - lean_dec_ref(x_127); - x_130 = lean_box(0); + lean_dec_ref(x_111); + x_114 = lean_box(0); } -if (lean_obj_tag(x_128) == 7) +if (lean_obj_tag(x_112) == 7) { -lean_object* x_146; lean_object* x_147; lean_object* x_148; uint8_t x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_130); -x_146 = lean_ctor_get(x_128, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_128, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_128, 2); -lean_inc(x_148); -lean_dec(x_128); -x_149 = 0; -lean_inc(x_147); -x_150 = l_Lean_mkLambda(x_146, x_149, x_147, x_148); -lean_dec(x_146); -lean_inc(x_3); -lean_inc(x_147); -x_151 = l_Lean_Meta_getLevel(x_147, x_3, x_129); -if (lean_obj_tag(x_151) == 0) -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_152 = lean_ctor_get(x_151, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_151, 1); -lean_inc(x_153); -lean_dec(x_151); -lean_inc(x_2); -lean_inc(x_150); -x_154 = l_Lean_mkApp(x_150, x_2); -x_155 = l_Lean_Meta_getLevel(x_154, x_3, x_153); -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; -x_156 = lean_ctor_get(x_155, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_155, 1); -lean_inc(x_157); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_158 = x_155; -} else { - lean_dec_ref(x_155); - x_158 = lean_box(0); -} -x_159 = lean_box(0); -x_160 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_160, 0, x_156); -lean_ctor_set(x_160, 1, x_159); -x_161 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_161, 0, x_152); -lean_ctor_set(x_161, 1, x_160); -x_162 = l_Lean_Meta_mkCongrFun___closed__2; -x_163 = l_Lean_mkConst(x_162, x_161); -x_164 = l_Lean_mkApp6(x_163, x_147, x_150, x_122, x_126, x_1, x_2); -if (lean_is_scalar(x_158)) { - x_165 = lean_alloc_ctor(0, 2, 0); -} else { - x_165 = x_158; -} -lean_ctor_set(x_165, 0, x_164); -lean_ctor_set(x_165, 1, x_157); -return x_165; -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_152); -lean_dec(x_150); -lean_dec(x_147); -lean_dec(x_126); -lean_dec(x_122); -lean_dec(x_2); -lean_dec(x_1); -x_166 = lean_ctor_get(x_155, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_155, 1); -lean_inc(x_167); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - x_168 = x_155; -} else { - lean_dec_ref(x_155); - x_168 = lean_box(0); -} -if (lean_is_scalar(x_168)) { - x_169 = lean_alloc_ctor(1, 2, 0); -} else { - x_169 = x_168; -} -lean_ctor_set(x_169, 0, x_166); -lean_ctor_set(x_169, 1, x_167); -return x_169; -} -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -lean_dec(x_150); -lean_dec(x_147); -lean_dec(x_126); -lean_dec(x_122); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_170 = lean_ctor_get(x_151, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_151, 1); -lean_inc(x_171); -if (lean_is_exclusive(x_151)) { - lean_ctor_release(x_151, 0); - lean_ctor_release(x_151, 1); - x_172 = x_151; -} else { - lean_dec_ref(x_151); - 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(x_173, 0, x_170); -lean_ctor_set(x_173, 1, x_171); -return x_173; -} -} -else -{ -lean_object* x_174; -lean_dec(x_128); -lean_dec(x_126); -lean_dec(x_122); -x_174 = lean_box(0); -x_131 = x_174; -goto block_145; -} -block_145: -{ -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_dec(x_131); -x_132 = lean_ctor_get(x_129, 0); +lean_object* x_130; lean_object* x_131; lean_object* x_132; uint8_t x_133; lean_object* x_134; lean_object* x_135; +lean_dec(x_114); +x_130 = lean_ctor_get(x_112, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_112, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_112, 2); lean_inc(x_132); -x_133 = lean_ctor_get(x_129, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_3, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_3, 0); -lean_inc(x_135); -lean_dec(x_3); +lean_dec(x_112); +x_133 = 0; +lean_inc(x_131); +x_134 = l_Lean_mkLambda(x_130, x_133, x_131, x_132); +lean_dec(x_130); +lean_inc(x_3); +lean_inc(x_131); +x_135 = l_Lean_Meta_getLevel(x_131, x_3, x_113); +if (lean_obj_tag(x_135) == 0) +{ +lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; 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_137 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_137, 0, x_132); -lean_ctor_set(x_137, 1, x_133); -lean_ctor_set(x_137, 2, x_134); -lean_ctor_set(x_137, 3, x_136); -x_138 = l_Lean_mkAppStx___closed__9; -x_139 = lean_array_push(x_138, x_1); -x_140 = lean_array_push(x_139, x_2); -x_141 = l_Lean_Meta_mkCongrFun___closed__2; -x_142 = l_Lean_Meta_mkCongrFun___closed__3; -x_143 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_143, 0, x_141); -lean_ctor_set(x_143, 1, x_142); -lean_ctor_set(x_143, 2, x_140); -lean_ctor_set(x_143, 3, x_137); -if (lean_is_scalar(x_130)) { - x_144 = lean_alloc_ctor(1, 2, 0); +lean_inc(x_2); +lean_inc(x_134); +x_138 = l_Lean_mkApp(x_134, x_2); +x_139 = l_Lean_Meta_getLevel(x_138, x_3, x_137); +if (lean_obj_tag(x_139) == 0) +{ +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_140 = lean_ctor_get(x_139, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_139, 1); +lean_inc(x_141); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + x_142 = x_139; } else { - x_144 = x_130; - lean_ctor_set_tag(x_144, 1); + lean_dec_ref(x_139); + x_142 = lean_box(0); } -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_129); -return x_144; +x_143 = lean_box(0); +x_144 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_144, 0, x_140); +lean_ctor_set(x_144, 1, x_143); +x_145 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_145, 0, x_136); +lean_ctor_set(x_145, 1, x_144); +x_146 = l_Lean_Meta_mkCongrFun___closed__2; +x_147 = l_Lean_mkConst(x_146, x_145); +x_148 = l_Lean_mkApp6(x_147, x_131, x_134, x_109, x_110, x_1, x_2); +if (lean_is_scalar(x_142)) { + x_149 = lean_alloc_ctor(0, 2, 0); +} else { + x_149 = x_142; +} +lean_ctor_set(x_149, 0, x_148); +lean_ctor_set(x_149, 1, x_141); +return x_149; +} +else +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; +lean_dec(x_136); +lean_dec(x_134); +lean_dec(x_131); +lean_dec(x_110); +lean_dec(x_109); +lean_dec(x_2); +lean_dec(x_1); +x_150 = lean_ctor_get(x_139, 0); +lean_inc(x_150); +x_151 = lean_ctor_get(x_139, 1); +lean_inc(x_151); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + x_152 = x_139; +} else { + lean_dec_ref(x_139); + 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_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; -lean_dec(x_126); -lean_dec(x_122); +lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; +lean_dec(x_134); +lean_dec(x_131); +lean_dec(x_110); +lean_dec(x_109); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_175 = lean_ctor_get(x_127, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_127, 1); -lean_inc(x_176); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_177 = x_127; +x_154 = lean_ctor_get(x_135, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_135, 1); +lean_inc(x_155); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + x_156 = x_135; } else { - lean_dec_ref(x_127); - x_177 = lean_box(0); + lean_dec_ref(x_135); + x_156 = lean_box(0); } -if (lean_is_scalar(x_177)) { - x_178 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(1, 2, 0); } else { - x_178 = x_177; + x_157 = x_156; } -lean_ctor_set(x_178, 0, x_175); -lean_ctor_set(x_178, 1, x_176); -return x_178; +lean_ctor_set(x_157, 0, x_154); +lean_ctor_set(x_157, 1, x_155); +return x_157; +} +} +else +{ +lean_object* x_158; +lean_dec(x_112); +lean_dec(x_110); +lean_dec(x_109); +x_158 = lean_box(0); +x_115 = x_158; +goto block_129; +} +block_129: +{ +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_dec(x_115); +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_3, 1); +lean_inc(x_118); +x_119 = lean_ctor_get(x_3, 0); +lean_inc(x_119); +lean_dec(x_3); +x_120 = lean_ctor_get(x_119, 0); +lean_inc(x_120); +lean_dec(x_119); +x_121 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_121, 0, x_116); +lean_ctor_set(x_121, 1, x_117); +lean_ctor_set(x_121, 2, x_118); +lean_ctor_set(x_121, 3, x_120); +x_122 = l_Lean_mkAppStx___closed__9; +x_123 = lean_array_push(x_122, x_1); +x_124 = lean_array_push(x_123, x_2); +x_125 = l_Lean_Meta_mkCongrFun___closed__2; +x_126 = l_Lean_Meta_mkCongrFun___closed__3; +x_127 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_127, 0, x_125); +lean_ctor_set(x_127, 1, x_126); +lean_ctor_set(x_127, 2, x_124); +lean_ctor_set(x_127, 3, x_121); +if (lean_is_scalar(x_114)) { + x_128 = lean_alloc_ctor(1, 2, 0); +} else { + x_128 = x_114; + lean_ctor_set_tag(x_128, 1); +} +lean_ctor_set(x_128, 0, x_127); +lean_ctor_set(x_128, 1, x_113); +return x_128; +} +} +else +{ +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +lean_dec(x_110); +lean_dec(x_109); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_159 = lean_ctor_get(x_111, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_111, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + x_161 = x_111; +} else { + lean_dec_ref(x_111); + 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 { -uint8_t x_179; +uint8_t x_163; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_179 = !lean_is_exclusive(x_5); -if (x_179 == 0) +x_163 = !lean_is_exclusive(x_5); +if (x_163 == 0) { return x_5; } else { -lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_180 = lean_ctor_get(x_5, 0); -x_181 = lean_ctor_get(x_5, 1); -lean_inc(x_181); -lean_inc(x_180); +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_5, 0); +x_165 = lean_ctor_get(x_5, 1); +lean_inc(x_165); +lean_inc(x_164); lean_dec(x_5); -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; +x_166 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_166, 0, x_164); +lean_ctor_set(x_166, 1, x_165); +return x_166; } } } @@ -4516,69 +4160,52 @@ goto block_26; } else { -uint8_t 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; +uint8_t 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_100 = l_Lean_Expr_isAppOfArity___main(x_9, x_96, x_97); -x_101 = lean_unsigned_to_nat(0u); -x_102 = l_Lean_Expr_getAppNumArgsAux___main(x_6, x_101); -x_103 = lean_nat_sub(x_102, x_101); -x_104 = lean_unsigned_to_nat(1u); -x_105 = lean_nat_sub(x_103, x_104); -lean_dec(x_103); -x_106 = l_Lean_Expr_getRevArg_x21___main(x_6, x_105); -x_107 = lean_nat_sub(x_102, x_104); -x_108 = lean_nat_sub(x_107, x_104); -lean_dec(x_107); -x_109 = l_Lean_Expr_getRevArg_x21___main(x_6, x_108); -x_110 = lean_unsigned_to_nat(2u); -x_111 = lean_nat_sub(x_102, x_110); +x_101 = l_Lean_Expr_appFn_x21(x_6); +x_102 = l_Lean_Expr_appFn_x21(x_101); +x_103 = l_Lean_Expr_appArg_x21(x_102); lean_dec(x_102); -x_112 = lean_nat_sub(x_111, x_104); -lean_dec(x_111); -x_113 = l_Lean_Expr_getRevArg_x21___main(x_6, x_112); +x_104 = l_Lean_Expr_appArg_x21(x_101); +lean_dec(x_101); +x_105 = l_Lean_Expr_appArg_x21(x_6); lean_dec(x_6); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_109); -lean_ctor_set(x_114, 1, x_113); -x_115 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_115, 0, x_106); -lean_ctor_set(x_115, 1, x_114); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_104); +lean_ctor_set(x_106, 1, x_105); +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_103); +lean_ctor_set(x_107, 1, x_106); if (x_100 == 0) { -lean_object* x_116; +lean_object* x_108; lean_dec(x_9); -x_116 = lean_box(0); -x_27 = x_116; -x_28 = x_115; +x_108 = lean_box(0); +x_27 = x_108; +x_28 = x_107; goto block_95; } else { -lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_117 = l_Lean_Expr_getAppNumArgsAux___main(x_9, x_101); -x_118 = lean_nat_sub(x_117, x_101); -x_119 = lean_nat_sub(x_118, x_104); -lean_dec(x_118); -x_120 = l_Lean_Expr_getRevArg_x21___main(x_9, x_119); -x_121 = lean_nat_sub(x_117, x_104); -x_122 = lean_nat_sub(x_121, x_104); -lean_dec(x_121); -x_123 = l_Lean_Expr_getRevArg_x21___main(x_9, x_122); -x_124 = lean_nat_sub(x_117, x_110); -lean_dec(x_117); -x_125 = lean_nat_sub(x_124, x_104); -lean_dec(x_124); -x_126 = l_Lean_Expr_getRevArg_x21___main(x_9, x_125); +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_109 = l_Lean_Expr_appFn_x21(x_9); +x_110 = l_Lean_Expr_appFn_x21(x_109); +x_111 = l_Lean_Expr_appArg_x21(x_110); +lean_dec(x_110); +x_112 = l_Lean_Expr_appArg_x21(x_109); +lean_dec(x_109); +x_113 = l_Lean_Expr_appArg_x21(x_9); lean_dec(x_9); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_123); -lean_ctor_set(x_127, 1, x_126); -x_128 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_128, 0, x_120); -lean_ctor_set(x_128, 1, x_127); -x_129 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_129, 0, x_128); -x_27 = x_129; -x_28 = x_115; +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_112); +lean_ctor_set(x_114, 1, x_113); +x_115 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_115, 0, x_111); +lean_ctor_set(x_115, 1, x_114); +x_116 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_116, 0, x_115); +x_27 = x_116; +x_28 = x_107; goto block_95; } } @@ -4916,54 +4543,54 @@ return x_94; } else { -uint8_t x_130; +uint8_t x_117; lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_130 = !lean_is_exclusive(x_8); -if (x_130 == 0) +x_117 = !lean_is_exclusive(x_8); +if (x_117 == 0) { return x_8; } else { -lean_object* x_131; lean_object* x_132; lean_object* x_133; -x_131 = lean_ctor_get(x_8, 0); -x_132 = lean_ctor_get(x_8, 1); -lean_inc(x_132); -lean_inc(x_131); +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_8, 0); +x_119 = lean_ctor_get(x_8, 1); +lean_inc(x_119); +lean_inc(x_118); lean_dec(x_8); -x_133 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_133, 0, x_131); -lean_ctor_set(x_133, 1, x_132); -return x_133; +x_120 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_120, 0, x_118); +lean_ctor_set(x_120, 1, x_119); +return x_120; } } } else { -uint8_t x_134; +uint8_t x_121; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_134 = !lean_is_exclusive(x_5); -if (x_134 == 0) +x_121 = !lean_is_exclusive(x_5); +if (x_121 == 0) { return x_5; } else { -lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_135 = lean_ctor_get(x_5, 0); -x_136 = lean_ctor_get(x_5, 1); -lean_inc(x_136); -lean_inc(x_135); +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_5, 0); +x_123 = lean_ctor_get(x_5, 1); +lean_inc(x_123); +lean_inc(x_122); lean_dec(x_5); -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; +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; } } } @@ -7638,717 +7265,700 @@ return x_8; } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_free_object(x_8); -x_26 = lean_unsigned_to_nat(0u); -x_27 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_26); -x_28 = lean_nat_sub(x_27, x_26); -x_29 = lean_unsigned_to_nat(1u); -x_30 = lean_nat_sub(x_28, x_29); -lean_dec(x_28); -x_31 = l_Lean_Expr_getRevArg_x21___main(x_10, x_30); -x_32 = lean_nat_sub(x_27, x_29); -x_33 = lean_nat_sub(x_32, x_29); -lean_dec(x_32); -x_34 = l_Lean_Expr_getRevArg_x21___main(x_10, x_33); -x_35 = lean_unsigned_to_nat(2u); -x_36 = lean_nat_sub(x_27, x_35); +x_26 = l_Lean_Expr_appFn_x21(x_10); +x_27 = l_Lean_Expr_appFn_x21(x_26); +x_28 = l_Lean_Expr_appArg_x21(x_27); lean_dec(x_27); -x_37 = lean_nat_sub(x_36, x_29); -lean_dec(x_36); -x_38 = l_Lean_Expr_getRevArg_x21___main(x_10, x_37); +x_29 = l_Lean_Expr_appArg_x21(x_26); +lean_dec(x_26); +x_30 = l_Lean_Expr_appArg_x21(x_10); lean_dec(x_10); lean_inc(x_4); -lean_inc(x_31); -x_39 = l_Lean_Meta_getLevel(x_31, x_4, x_11); -if (lean_obj_tag(x_39) == 0) +lean_inc(x_28); +x_31 = l_Lean_Meta_getLevel(x_28, x_4, x_11); +if (lean_obj_tag(x_31) == 0) { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) +uint8_t x_32; +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_39, 0); -x_42 = lean_ctor_get(x_39, 1); +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_31, 0); +x_34 = lean_ctor_get(x_31, 1); lean_inc(x_4); lean_inc(x_1); -x_43 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_42); -if (lean_obj_tag(x_43) == 0) +x_35 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_34); +if (lean_obj_tag(x_35) == 0) { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_35, 1); +lean_inc(x_37); +if (lean_is_exclusive(x_35)) { + lean_ctor_release(x_35, 0); + lean_ctor_release(x_35, 1); + x_38 = x_35; +} else { + lean_dec_ref(x_35); + x_38 = lean_box(0); +} +if (lean_obj_tag(x_36) == 7) +{ +lean_object* x_53; +x_53 = lean_ctor_get(x_36, 2); +lean_inc(x_53); +lean_dec(x_36); +if (lean_obj_tag(x_53) == 3) +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; 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_dec(x_38); +lean_dec(x_4); +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +lean_dec(x_53); +x_55 = lean_box(0); +x_56 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_56, 0, x_33); +lean_ctor_set(x_56, 1, x_55); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_54); +lean_ctor_set(x_57, 1, x_56); +x_58 = l_Lean_Meta_mkEqNDRec___closed__2; +x_59 = l_Lean_mkConst(x_58, x_57); +x_60 = l_Lean_Meta_mkEqNDRec___closed__4; +x_61 = lean_array_push(x_60, x_28); +x_62 = lean_array_push(x_61, x_29); +x_63 = lean_array_push(x_62, x_1); +x_64 = lean_array_push(x_63, x_2); +x_65 = lean_array_push(x_64, x_30); +x_66 = lean_array_push(x_65, x_3); +x_67 = lean_unsigned_to_nat(0u); +x_68 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_66, x_66, x_67, x_59); +lean_dec(x_66); +lean_ctor_set(x_31, 1, x_37); +lean_ctor_set(x_31, 0, x_68); +return x_31; +} +else +{ +lean_object* x_69; +lean_dec(x_53); +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_69 = lean_box(0); +x_39 = x_69; +goto block_52; +} +} +else +{ +lean_object* x_70; +lean_dec(x_36); +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_70 = lean_box(0); +x_39 = x_70; +goto block_52; +} +block_52: +{ +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_dec(x_39); +x_40 = lean_ctor_get(x_37, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_37, 1); +lean_inc(x_41); +x_42 = lean_ctor_get(x_4, 1); +lean_inc(x_42); +x_43 = lean_ctor_get(x_4, 0); +lean_inc(x_43); +lean_dec(x_4); x_44 = lean_ctor_get(x_43, 0); lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - x_46 = x_43; +lean_dec(x_43); +x_45 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_42); +lean_ctor_set(x_45, 3, x_44); +x_46 = l_Lean_mkOptionalNode___closed__2; +x_47 = lean_array_push(x_46, x_1); +x_48 = l_Lean_Meta_mkEqNDRec___closed__2; +x_49 = l_Lean_Meta_mkEqNDRec___closed__3; +x_50 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +lean_ctor_set(x_50, 2, x_47); +lean_ctor_set(x_50, 3, x_45); +if (lean_is_scalar(x_38)) { + x_51 = lean_alloc_ctor(1, 2, 0); } else { - lean_dec_ref(x_43); - x_46 = lean_box(0); + x_51 = x_38; + lean_ctor_set_tag(x_51, 1); } -if (lean_obj_tag(x_44) == 7) -{ -lean_object* x_61; -x_61 = lean_ctor_get(x_44, 2); -lean_inc(x_61); -lean_dec(x_44); -if (lean_obj_tag(x_61) == 3) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -lean_dec(x_46); -lean_dec(x_4); -x_62 = lean_ctor_get(x_61, 0); -lean_inc(x_62); -lean_dec(x_61); -x_63 = lean_box(0); -x_64 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_64, 0, x_41); -lean_ctor_set(x_64, 1, x_63); -x_65 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_65, 0, x_62); -lean_ctor_set(x_65, 1, x_64); -x_66 = l_Lean_Meta_mkEqNDRec___closed__2; -x_67 = l_Lean_mkConst(x_66, x_65); -x_68 = l_Lean_Meta_mkEqNDRec___closed__4; -x_69 = lean_array_push(x_68, x_31); -x_70 = lean_array_push(x_69, x_34); -x_71 = lean_array_push(x_70, x_1); -x_72 = lean_array_push(x_71, x_2); -x_73 = lean_array_push(x_72, x_38); -x_74 = lean_array_push(x_73, x_3); -x_75 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_74, x_74, x_26, x_67); -lean_dec(x_74); -lean_ctor_set(x_39, 1, x_45); -lean_ctor_set(x_39, 0, x_75); -return x_39; -} -else -{ -lean_object* x_76; -lean_dec(x_61); -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_76 = lean_box(0); -x_47 = x_76; -goto block_60; +lean_ctor_set(x_51, 0, x_50); +lean_ctor_set(x_51, 1, x_37); +return x_51; } } else { -lean_object* x_77; -lean_dec(x_44); -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_77 = lean_box(0); -x_47 = x_77; -goto block_60; -} -block_60: -{ -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_dec(x_47); -x_48 = lean_ctor_get(x_45, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_45, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_4, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_4, 0); -lean_inc(x_51); -lean_dec(x_4); -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -lean_dec(x_51); -x_53 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_53, 0, x_48); -lean_ctor_set(x_53, 1, x_49); -lean_ctor_set(x_53, 2, x_50); -lean_ctor_set(x_53, 3, x_52); -x_54 = l_Lean_mkOptionalNode___closed__2; -x_55 = lean_array_push(x_54, x_1); -x_56 = l_Lean_Meta_mkEqNDRec___closed__2; -x_57 = l_Lean_Meta_mkEqNDRec___closed__3; -x_58 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_58, 0, x_56); -lean_ctor_set(x_58, 1, x_57); -lean_ctor_set(x_58, 2, x_55); -lean_ctor_set(x_58, 3, x_53); -if (lean_is_scalar(x_46)) { - x_59 = lean_alloc_ctor(1, 2, 0); -} else { - x_59 = x_46; - lean_ctor_set_tag(x_59, 1); -} -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_45); -return x_59; -} -} -else -{ -uint8_t x_78; -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); +uint8_t x_71; +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_78 = !lean_is_exclusive(x_43); -if (x_78 == 0) +x_71 = !lean_is_exclusive(x_35); +if (x_71 == 0) { -return x_43; +return x_35; } else { -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_43, 0); -x_80 = lean_ctor_get(x_43, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_43); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_35, 0); +x_73 = lean_ctor_get(x_35, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_35); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; } } } else { -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_39, 0); -x_83 = lean_ctor_get(x_39, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_39); +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_31, 0); +x_76 = lean_ctor_get(x_31, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_31); lean_inc(x_4); lean_inc(x_1); -x_84 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_83); -if (lean_obj_tag(x_84) == 0) +x_77 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_76); +if (lean_obj_tag(x_77) == 0) { -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_84, 1); -lean_inc(x_86); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_87 = x_84; +lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_78 = lean_ctor_get(x_77, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_77, 1); +lean_inc(x_79); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + x_80 = x_77; } else { - lean_dec_ref(x_84); - x_87 = lean_box(0); + lean_dec_ref(x_77); + x_80 = lean_box(0); } -if (lean_obj_tag(x_85) == 7) +if (lean_obj_tag(x_78) == 7) { -lean_object* x_102; -x_102 = lean_ctor_get(x_85, 2); -lean_inc(x_102); -lean_dec(x_85); -if (lean_obj_tag(x_102) == 3) +lean_object* x_95; +x_95 = lean_ctor_get(x_78, 2); +lean_inc(x_95); +lean_dec(x_78); +if (lean_obj_tag(x_95) == 3) { -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_dec(x_87); +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_dec(x_80); lean_dec(x_4); -x_103 = lean_ctor_get(x_102, 0); -lean_inc(x_103); -lean_dec(x_102); -x_104 = lean_box(0); -x_105 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_105, 0, x_82); -lean_ctor_set(x_105, 1, x_104); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_103); -lean_ctor_set(x_106, 1, x_105); -x_107 = l_Lean_Meta_mkEqNDRec___closed__2; -x_108 = l_Lean_mkConst(x_107, x_106); -x_109 = l_Lean_Meta_mkEqNDRec___closed__4; -x_110 = lean_array_push(x_109, x_31); -x_111 = lean_array_push(x_110, x_34); -x_112 = lean_array_push(x_111, x_1); -x_113 = lean_array_push(x_112, x_2); -x_114 = lean_array_push(x_113, x_38); -x_115 = lean_array_push(x_114, x_3); -x_116 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_115, x_115, x_26, x_108); -lean_dec(x_115); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_116); -lean_ctor_set(x_117, 1, x_86); +x_96 = lean_ctor_get(x_95, 0); +lean_inc(x_96); +lean_dec(x_95); +x_97 = lean_box(0); +x_98 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_98, 0, x_75); +lean_ctor_set(x_98, 1, x_97); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_96); +lean_ctor_set(x_99, 1, x_98); +x_100 = l_Lean_Meta_mkEqNDRec___closed__2; +x_101 = l_Lean_mkConst(x_100, x_99); +x_102 = l_Lean_Meta_mkEqNDRec___closed__4; +x_103 = lean_array_push(x_102, x_28); +x_104 = lean_array_push(x_103, x_29); +x_105 = lean_array_push(x_104, x_1); +x_106 = lean_array_push(x_105, x_2); +x_107 = lean_array_push(x_106, x_30); +x_108 = lean_array_push(x_107, x_3); +x_109 = lean_unsigned_to_nat(0u); +x_110 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_108, x_108, x_109, x_101); +lean_dec(x_108); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_79); +return x_111; +} +else +{ +lean_object* x_112; +lean_dec(x_95); +lean_dec(x_75); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_112 = lean_box(0); +x_81 = x_112; +goto block_94; +} +} +else +{ +lean_object* x_113; +lean_dec(x_78); +lean_dec(x_75); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_113 = lean_box(0); +x_81 = x_113; +goto block_94; +} +block_94: +{ +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_dec(x_81); +x_82 = lean_ctor_get(x_79, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_79, 1); +lean_inc(x_83); +x_84 = lean_ctor_get(x_4, 1); +lean_inc(x_84); +x_85 = lean_ctor_get(x_4, 0); +lean_inc(x_85); +lean_dec(x_4); +x_86 = lean_ctor_get(x_85, 0); +lean_inc(x_86); +lean_dec(x_85); +x_87 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_87, 0, x_82); +lean_ctor_set(x_87, 1, x_83); +lean_ctor_set(x_87, 2, x_84); +lean_ctor_set(x_87, 3, x_86); +x_88 = l_Lean_mkOptionalNode___closed__2; +x_89 = lean_array_push(x_88, x_1); +x_90 = l_Lean_Meta_mkEqNDRec___closed__2; +x_91 = l_Lean_Meta_mkEqNDRec___closed__3; +x_92 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +lean_ctor_set(x_92, 2, x_89); +lean_ctor_set(x_92, 3, x_87); +if (lean_is_scalar(x_80)) { + x_93 = lean_alloc_ctor(1, 2, 0); +} else { + x_93 = x_80; + lean_ctor_set_tag(x_93, 1); +} +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_79); +return x_93; +} +} +else +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; +lean_dec(x_75); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_114 = lean_ctor_get(x_77, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_77, 1); +lean_inc(x_115); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + x_116 = x_77; +} else { + lean_dec_ref(x_77); + 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 -{ -lean_object* x_118; -lean_dec(x_102); -lean_dec(x_82); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_118 = lean_box(0); -x_88 = x_118; -goto block_101; } } else { -lean_object* x_119; -lean_dec(x_85); -lean_dec(x_82); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_119 = lean_box(0); -x_88 = x_119; -goto block_101; -} -block_101: -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -lean_dec(x_88); -x_89 = lean_ctor_get(x_86, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_86, 1); -lean_inc(x_90); -x_91 = lean_ctor_get(x_4, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_4, 0); -lean_inc(x_92); -lean_dec(x_4); -x_93 = lean_ctor_get(x_92, 0); -lean_inc(x_93); -lean_dec(x_92); -x_94 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_94, 0, x_89); -lean_ctor_set(x_94, 1, x_90); -lean_ctor_set(x_94, 2, x_91); -lean_ctor_set(x_94, 3, x_93); -x_95 = l_Lean_mkOptionalNode___closed__2; -x_96 = lean_array_push(x_95, x_1); -x_97 = l_Lean_Meta_mkEqNDRec___closed__2; -x_98 = l_Lean_Meta_mkEqNDRec___closed__3; -x_99 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_99, 0, x_97); -lean_ctor_set(x_99, 1, x_98); -lean_ctor_set(x_99, 2, x_96); -lean_ctor_set(x_99, 3, x_94); -if (lean_is_scalar(x_87)) { - x_100 = lean_alloc_ctor(1, 2, 0); -} else { - x_100 = x_87; - lean_ctor_set_tag(x_100, 1); -} -lean_ctor_set(x_100, 0, x_99); -lean_ctor_set(x_100, 1, x_86); -return x_100; -} -} -else -{ -lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; -lean_dec(x_82); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); +uint8_t x_118; +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_120 = lean_ctor_get(x_84, 0); +x_118 = !lean_is_exclusive(x_31); +if (x_118 == 0) +{ +return x_31; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_31, 0); +x_120 = lean_ctor_get(x_31, 1); lean_inc(x_120); -x_121 = lean_ctor_get(x_84, 1); -lean_inc(x_121); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_122 = x_84; -} else { - lean_dec_ref(x_84); - x_122 = lean_box(0); -} -if (lean_is_scalar(x_122)) { - x_123 = lean_alloc_ctor(1, 2, 0); -} else { - x_123 = x_122; -} -lean_ctor_set(x_123, 0, x_120); -lean_ctor_set(x_123, 1, x_121); -return x_123; -} -} -} -else -{ -uint8_t x_124; -lean_dec(x_38); -lean_dec(x_34); +lean_inc(x_119); lean_dec(x_31); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_124 = !lean_is_exclusive(x_39); -if (x_124 == 0) -{ -return x_39; -} -else -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; -x_125 = lean_ctor_get(x_39, 0); -x_126 = lean_ctor_get(x_39, 1); -lean_inc(x_126); -lean_inc(x_125); -lean_dec(x_39); -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; +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_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; uint8_t x_132; -x_128 = lean_ctor_get(x_8, 0); -x_129 = lean_ctor_get(x_8, 1); -lean_inc(x_129); -lean_inc(x_128); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; uint8_t x_126; +x_122 = lean_ctor_get(x_8, 0); +x_123 = lean_ctor_get(x_8, 1); +lean_inc(x_123); +lean_inc(x_122); lean_dec(x_8); -x_130 = l_Lean_Expr_eq_x3f___closed__2; -x_131 = lean_unsigned_to_nat(3u); -x_132 = l_Lean_Expr_isAppOfArity___main(x_128, x_130, x_131); -if (x_132 == 0) +x_124 = l_Lean_Expr_eq_x3f___closed__2; +x_125 = lean_unsigned_to_nat(3u); +x_126 = l_Lean_Expr_isAppOfArity___main(x_122, x_124, x_125); +if (x_126 == 0) { -lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -lean_dec(x_128); +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_dec(x_122); lean_dec(x_2); lean_dec(x_1); -x_133 = lean_ctor_get(x_129, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_129, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_4, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_4, 0); -lean_inc(x_136); +x_127 = lean_ctor_get(x_123, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_123, 1); +lean_inc(x_128); +x_129 = lean_ctor_get(x_4, 1); +lean_inc(x_129); +x_130 = lean_ctor_get(x_4, 0); +lean_inc(x_130); lean_dec(x_4); -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -lean_dec(x_136); -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_135); -lean_ctor_set(x_138, 3, x_137); -x_139 = l_Lean_mkOptionalNode___closed__2; -x_140 = lean_array_push(x_139, x_3); -x_141 = l_Lean_Meta_mkEqNDRec___closed__2; -x_142 = l_Lean_Meta_mkEqSymm___closed__3; -x_143 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_143, 0, x_141); -lean_ctor_set(x_143, 1, x_142); -lean_ctor_set(x_143, 2, x_140); -lean_ctor_set(x_143, 3, x_138); -x_144 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_129); -return x_144; +x_131 = lean_ctor_get(x_130, 0); +lean_inc(x_131); +lean_dec(x_130); +x_132 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_132, 0, x_127); +lean_ctor_set(x_132, 1, x_128); +lean_ctor_set(x_132, 2, x_129); +lean_ctor_set(x_132, 3, x_131); +x_133 = l_Lean_mkOptionalNode___closed__2; +x_134 = lean_array_push(x_133, x_3); +x_135 = l_Lean_Meta_mkEqNDRec___closed__2; +x_136 = l_Lean_Meta_mkEqSymm___closed__3; +x_137 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_137, 0, x_135); +lean_ctor_set(x_137, 1, x_136); +lean_ctor_set(x_137, 2, x_134); +lean_ctor_set(x_137, 3, x_132); +x_138 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_123); +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; -x_145 = lean_unsigned_to_nat(0u); -x_146 = l_Lean_Expr_getAppNumArgsAux___main(x_128, x_145); -x_147 = lean_nat_sub(x_146, x_145); -x_148 = lean_unsigned_to_nat(1u); -x_149 = lean_nat_sub(x_147, x_148); -lean_dec(x_147); -x_150 = l_Lean_Expr_getRevArg_x21___main(x_128, x_149); -x_151 = lean_nat_sub(x_146, x_148); -x_152 = lean_nat_sub(x_151, x_148); -lean_dec(x_151); -x_153 = l_Lean_Expr_getRevArg_x21___main(x_128, x_152); -x_154 = lean_unsigned_to_nat(2u); -x_155 = lean_nat_sub(x_146, x_154); -lean_dec(x_146); -x_156 = lean_nat_sub(x_155, x_148); -lean_dec(x_155); -x_157 = l_Lean_Expr_getRevArg_x21___main(x_128, x_156); -lean_dec(x_128); +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_139 = l_Lean_Expr_appFn_x21(x_122); +x_140 = l_Lean_Expr_appFn_x21(x_139); +x_141 = l_Lean_Expr_appArg_x21(x_140); +lean_dec(x_140); +x_142 = l_Lean_Expr_appArg_x21(x_139); +lean_dec(x_139); +x_143 = l_Lean_Expr_appArg_x21(x_122); +lean_dec(x_122); lean_inc(x_4); -lean_inc(x_150); -x_158 = l_Lean_Meta_getLevel(x_150, x_4, x_129); -if (lean_obj_tag(x_158) == 0) +lean_inc(x_141); +x_144 = l_Lean_Meta_getLevel(x_141, x_4, x_123); +if (lean_obj_tag(x_144) == 0) { -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -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; +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_145 = lean_ctor_get(x_144, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_144, 1); +lean_inc(x_146); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + x_147 = x_144; } else { - lean_dec_ref(x_158); - x_161 = lean_box(0); + lean_dec_ref(x_144); + x_147 = lean_box(0); } lean_inc(x_4); lean_inc(x_1); -x_162 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_160); -if (lean_obj_tag(x_162) == 0) +x_148 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_146); +if (lean_obj_tag(x_148) == 0) { -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_163 = lean_ctor_get(x_162, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_162, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_165 = x_162; +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; +x_149 = lean_ctor_get(x_148, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_148, 1); +lean_inc(x_150); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + x_151 = x_148; } else { - lean_dec_ref(x_162); - x_165 = lean_box(0); + lean_dec_ref(x_148); + x_151 = lean_box(0); } -if (lean_obj_tag(x_163) == 7) +if (lean_obj_tag(x_149) == 7) { -lean_object* x_180; -x_180 = lean_ctor_get(x_163, 2); -lean_inc(x_180); -lean_dec(x_163); -if (lean_obj_tag(x_180) == 3) +lean_object* x_166; +x_166 = lean_ctor_get(x_149, 2); +lean_inc(x_166); +lean_dec(x_149); +if (lean_obj_tag(x_166) == 3) { -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_dec(x_165); +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_dec(x_151); lean_dec(x_4); -x_181 = lean_ctor_get(x_180, 0); -lean_inc(x_181); -lean_dec(x_180); -x_182 = lean_box(0); -x_183 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_183, 0, x_159); -lean_ctor_set(x_183, 1, x_182); -x_184 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_184, 0, x_181); -lean_ctor_set(x_184, 1, x_183); -x_185 = l_Lean_Meta_mkEqNDRec___closed__2; -x_186 = l_Lean_mkConst(x_185, x_184); -x_187 = l_Lean_Meta_mkEqNDRec___closed__4; -x_188 = lean_array_push(x_187, x_150); -x_189 = lean_array_push(x_188, x_153); -x_190 = lean_array_push(x_189, x_1); -x_191 = lean_array_push(x_190, x_2); -x_192 = lean_array_push(x_191, x_157); -x_193 = lean_array_push(x_192, x_3); -x_194 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_193, x_193, x_145, x_186); -lean_dec(x_193); -if (lean_is_scalar(x_161)) { - x_195 = lean_alloc_ctor(0, 2, 0); -} else { - x_195 = x_161; -} -lean_ctor_set(x_195, 0, x_194); -lean_ctor_set(x_195, 1, x_164); -return x_195; -} -else -{ -lean_object* x_196; -lean_dec(x_180); -lean_dec(x_161); -lean_dec(x_159); -lean_dec(x_157); -lean_dec(x_153); -lean_dec(x_150); -lean_dec(x_3); -lean_dec(x_2); -x_196 = lean_box(0); -x_166 = x_196; -goto block_179; -} -} -else -{ -lean_object* x_197; -lean_dec(x_163); -lean_dec(x_161); -lean_dec(x_159); -lean_dec(x_157); -lean_dec(x_153); -lean_dec(x_150); -lean_dec(x_3); -lean_dec(x_2); -x_197 = lean_box(0); -x_166 = x_197; -goto block_179; -} -block_179: -{ -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_dec(x_166); -x_167 = lean_ctor_get(x_164, 0); +x_167 = lean_ctor_get(x_166, 0); lean_inc(x_167); -x_168 = lean_ctor_get(x_164, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_4, 1); -lean_inc(x_169); -x_170 = lean_ctor_get(x_4, 0); -lean_inc(x_170); -lean_dec(x_4); -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -lean_dec(x_170); -x_172 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_172, 0, x_167); -lean_ctor_set(x_172, 1, x_168); -lean_ctor_set(x_172, 2, x_169); -lean_ctor_set(x_172, 3, x_171); -x_173 = l_Lean_mkOptionalNode___closed__2; -x_174 = lean_array_push(x_173, x_1); -x_175 = l_Lean_Meta_mkEqNDRec___closed__2; -x_176 = l_Lean_Meta_mkEqNDRec___closed__3; -x_177 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_177, 0, x_175); -lean_ctor_set(x_177, 1, x_176); -lean_ctor_set(x_177, 2, x_174); -lean_ctor_set(x_177, 3, x_172); -if (lean_is_scalar(x_165)) { - x_178 = lean_alloc_ctor(1, 2, 0); +lean_dec(x_166); +x_168 = lean_box(0); +x_169 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_169, 0, x_145); +lean_ctor_set(x_169, 1, x_168); +x_170 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_170, 0, x_167); +lean_ctor_set(x_170, 1, x_169); +x_171 = l_Lean_Meta_mkEqNDRec___closed__2; +x_172 = l_Lean_mkConst(x_171, x_170); +x_173 = l_Lean_Meta_mkEqNDRec___closed__4; +x_174 = lean_array_push(x_173, x_141); +x_175 = lean_array_push(x_174, x_142); +x_176 = lean_array_push(x_175, x_1); +x_177 = lean_array_push(x_176, x_2); +x_178 = lean_array_push(x_177, x_143); +x_179 = lean_array_push(x_178, x_3); +x_180 = lean_unsigned_to_nat(0u); +x_181 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_179, x_179, x_180, x_172); +lean_dec(x_179); +if (lean_is_scalar(x_147)) { + x_182 = lean_alloc_ctor(0, 2, 0); } else { - x_178 = x_165; - lean_ctor_set_tag(x_178, 1); + x_182 = x_147; } -lean_ctor_set(x_178, 0, x_177); -lean_ctor_set(x_178, 1, x_164); -return x_178; +lean_ctor_set(x_182, 0, x_181); +lean_ctor_set(x_182, 1, x_150); +return x_182; +} +else +{ +lean_object* x_183; +lean_dec(x_166); +lean_dec(x_147); +lean_dec(x_145); +lean_dec(x_143); +lean_dec(x_142); +lean_dec(x_141); +lean_dec(x_3); +lean_dec(x_2); +x_183 = lean_box(0); +x_152 = x_183; +goto block_165; } } else { -lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -lean_dec(x_161); -lean_dec(x_159); -lean_dec(x_157); -lean_dec(x_153); -lean_dec(x_150); -lean_dec(x_4); +lean_object* x_184; +lean_dec(x_149); +lean_dec(x_147); +lean_dec(x_145); +lean_dec(x_143); +lean_dec(x_142); +lean_dec(x_141); lean_dec(x_3); lean_dec(x_2); -lean_dec(x_1); -x_198 = lean_ctor_get(x_162, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_162, 1); -lean_inc(x_199); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_200 = x_162; -} else { - lean_dec_ref(x_162); - x_200 = lean_box(0); +x_184 = lean_box(0); +x_152 = x_184; +goto block_165; } -if (lean_is_scalar(x_200)) { - x_201 = lean_alloc_ctor(1, 2, 0); +block_165: +{ +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_dec(x_152); +x_153 = lean_ctor_get(x_150, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_150, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_4, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_4, 0); +lean_inc(x_156); +lean_dec(x_4); +x_157 = lean_ctor_get(x_156, 0); +lean_inc(x_157); +lean_dec(x_156); +x_158 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_155); +lean_ctor_set(x_158, 3, x_157); +x_159 = l_Lean_mkOptionalNode___closed__2; +x_160 = lean_array_push(x_159, x_1); +x_161 = l_Lean_Meta_mkEqNDRec___closed__2; +x_162 = l_Lean_Meta_mkEqNDRec___closed__3; +x_163 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_163, 0, x_161); +lean_ctor_set(x_163, 1, x_162); +lean_ctor_set(x_163, 2, x_160); +lean_ctor_set(x_163, 3, x_158); +if (lean_is_scalar(x_151)) { + x_164 = lean_alloc_ctor(1, 2, 0); } else { - x_201 = x_200; + x_164 = x_151; + lean_ctor_set_tag(x_164, 1); } -lean_ctor_set(x_201, 0, x_198); -lean_ctor_set(x_201, 1, x_199); -return x_201; +lean_ctor_set(x_164, 0, x_163); +lean_ctor_set(x_164, 1, x_150); +return x_164; } } else { -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; -lean_dec(x_157); -lean_dec(x_153); -lean_dec(x_150); +lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; +lean_dec(x_147); +lean_dec(x_145); +lean_dec(x_143); +lean_dec(x_142); +lean_dec(x_141); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_202 = lean_ctor_get(x_158, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_158, 1); -lean_inc(x_203); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_204 = x_158; +x_185 = lean_ctor_get(x_148, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_148, 1); +lean_inc(x_186); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + x_187 = x_148; } else { - lean_dec_ref(x_158); - x_204 = lean_box(0); + lean_dec_ref(x_148); + x_187 = lean_box(0); } -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_187)) { + x_188 = lean_alloc_ctor(1, 2, 0); } else { - x_205 = x_204; + x_188 = x_187; } -lean_ctor_set(x_205, 0, x_202); -lean_ctor_set(x_205, 1, x_203); -return x_205; +lean_ctor_set(x_188, 0, x_185); +lean_ctor_set(x_188, 1, x_186); +return x_188; +} +} +else +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_dec(x_143); +lean_dec(x_142); +lean_dec(x_141); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_189 = lean_ctor_get(x_144, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_144, 1); +lean_inc(x_190); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + x_191 = x_144; +} else { + lean_dec_ref(x_144); + x_191 = lean_box(0); +} +if (lean_is_scalar(x_191)) { + x_192 = lean_alloc_ctor(1, 2, 0); +} else { + x_192 = x_191; +} +lean_ctor_set(x_192, 0, x_189); +lean_ctor_set(x_192, 1, x_190); +return x_192; } } } } else { -uint8_t x_206; +uint8_t x_193; lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_206 = !lean_is_exclusive(x_8); -if (x_206 == 0) +x_193 = !lean_is_exclusive(x_8); +if (x_193 == 0) { return x_8; } else { -lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_207 = lean_ctor_get(x_8, 0); -x_208 = lean_ctor_get(x_8, 1); -lean_inc(x_208); -lean_inc(x_207); +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_8, 0); +x_195 = lean_ctor_get(x_8, 1); +lean_inc(x_195); +lean_inc(x_194); lean_dec(x_8); -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; +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 { -lean_object* x_210; +lean_object* x_197; lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_210 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_210, 0, x_2); -lean_ctor_set(x_210, 1, x_5); -return x_210; +x_197 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_197, 0, x_2); +lean_ctor_set(x_197, 1, x_5); +return x_197; } } } @@ -8424,782 +8034,765 @@ return x_8; } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_free_object(x_8); -x_26 = lean_unsigned_to_nat(0u); -x_27 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_26); -x_28 = lean_nat_sub(x_27, x_26); -x_29 = lean_unsigned_to_nat(1u); -x_30 = lean_nat_sub(x_28, x_29); -lean_dec(x_28); -x_31 = l_Lean_Expr_getRevArg_x21___main(x_10, x_30); -x_32 = lean_nat_sub(x_27, x_29); -x_33 = lean_nat_sub(x_32, x_29); -lean_dec(x_32); -x_34 = l_Lean_Expr_getRevArg_x21___main(x_10, x_33); -x_35 = lean_unsigned_to_nat(2u); -x_36 = lean_nat_sub(x_27, x_35); +x_26 = l_Lean_Expr_appFn_x21(x_10); +x_27 = l_Lean_Expr_appFn_x21(x_26); +x_28 = l_Lean_Expr_appArg_x21(x_27); lean_dec(x_27); -x_37 = lean_nat_sub(x_36, x_29); -lean_dec(x_36); -x_38 = l_Lean_Expr_getRevArg_x21___main(x_10, x_37); +x_29 = l_Lean_Expr_appArg_x21(x_26); +lean_dec(x_26); +x_30 = l_Lean_Expr_appArg_x21(x_10); lean_dec(x_10); lean_inc(x_4); -lean_inc(x_31); -x_39 = l_Lean_Meta_getLevel(x_31, x_4, x_11); -if (lean_obj_tag(x_39) == 0) +lean_inc(x_28); +x_31 = l_Lean_Meta_getLevel(x_28, x_4, x_11); +if (lean_obj_tag(x_31) == 0) { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) +uint8_t x_32; +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_39, 0); -x_42 = lean_ctor_get(x_39, 1); +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_31, 0); +x_34 = lean_ctor_get(x_31, 1); lean_inc(x_4); lean_inc(x_1); -x_43 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_42); -if (lean_obj_tag(x_43) == 0) +x_35 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_34); +if (lean_obj_tag(x_35) == 0) { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_35, 1); +lean_inc(x_37); +if (lean_is_exclusive(x_35)) { + lean_ctor_release(x_35, 0); + lean_ctor_release(x_35, 1); + x_38 = x_35; +} else { + lean_dec_ref(x_35); + x_38 = lean_box(0); +} +if (lean_obj_tag(x_36) == 7) +{ +lean_object* x_53; +x_53 = lean_ctor_get(x_36, 2); +lean_inc(x_53); +lean_dec(x_36); +if (lean_obj_tag(x_53) == 7) +{ +lean_object* x_54; +x_54 = lean_ctor_get(x_53, 2); +lean_inc(x_54); +lean_dec(x_53); +if (lean_obj_tag(x_54) == 3) +{ +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_dec(x_38); +lean_dec(x_4); +x_55 = lean_ctor_get(x_54, 0); +lean_inc(x_55); +lean_dec(x_54); +x_56 = lean_box(0); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_33); +lean_ctor_set(x_57, 1, x_56); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_55); +lean_ctor_set(x_58, 1, x_57); +x_59 = l_Lean_Meta_mkEqRec___closed__1; +x_60 = l_Lean_mkConst(x_59, x_58); +x_61 = l_Lean_Meta_mkEqNDRec___closed__4; +x_62 = lean_array_push(x_61, x_28); +x_63 = lean_array_push(x_62, x_29); +x_64 = lean_array_push(x_63, x_1); +x_65 = lean_array_push(x_64, x_2); +x_66 = lean_array_push(x_65, x_30); +x_67 = lean_array_push(x_66, x_3); +x_68 = lean_unsigned_to_nat(0u); +x_69 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_67, x_67, x_68, x_60); +lean_dec(x_67); +lean_ctor_set(x_31, 1, x_37); +lean_ctor_set(x_31, 0, x_69); +return x_31; +} +else +{ +lean_object* x_70; +lean_dec(x_54); +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_70 = lean_box(0); +x_39 = x_70; +goto block_52; +} +} +else +{ +lean_object* x_71; +lean_dec(x_53); +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_71 = lean_box(0); +x_39 = x_71; +goto block_52; +} +} +else +{ +lean_object* x_72; +lean_dec(x_36); +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_72 = lean_box(0); +x_39 = x_72; +goto block_52; +} +block_52: +{ +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_dec(x_39); +x_40 = lean_ctor_get(x_37, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_37, 1); +lean_inc(x_41); +x_42 = lean_ctor_get(x_4, 1); +lean_inc(x_42); +x_43 = lean_ctor_get(x_4, 0); +lean_inc(x_43); +lean_dec(x_4); x_44 = lean_ctor_get(x_43, 0); lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - x_46 = x_43; -} else { - lean_dec_ref(x_43); - x_46 = lean_box(0); -} -if (lean_obj_tag(x_44) == 7) -{ -lean_object* x_61; -x_61 = lean_ctor_get(x_44, 2); -lean_inc(x_61); -lean_dec(x_44); -if (lean_obj_tag(x_61) == 7) -{ -lean_object* x_62; -x_62 = lean_ctor_get(x_61, 2); -lean_inc(x_62); -lean_dec(x_61); -if (lean_obj_tag(x_62) == 3) -{ -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_dec(x_46); -lean_dec(x_4); -x_63 = lean_ctor_get(x_62, 0); -lean_inc(x_63); -lean_dec(x_62); -x_64 = lean_box(0); -x_65 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_65, 0, x_41); -lean_ctor_set(x_65, 1, x_64); -x_66 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_65); -x_67 = l_Lean_Meta_mkEqRec___closed__1; -x_68 = l_Lean_mkConst(x_67, x_66); -x_69 = l_Lean_Meta_mkEqNDRec___closed__4; -x_70 = lean_array_push(x_69, x_31); -x_71 = lean_array_push(x_70, x_34); -x_72 = lean_array_push(x_71, x_1); -x_73 = lean_array_push(x_72, x_2); -x_74 = lean_array_push(x_73, x_38); -x_75 = lean_array_push(x_74, x_3); -x_76 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_75, x_75, x_26, x_68); -lean_dec(x_75); -lean_ctor_set(x_39, 1, x_45); -lean_ctor_set(x_39, 0, x_76); -return x_39; -} -else -{ -lean_object* x_77; -lean_dec(x_62); -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_77 = lean_box(0); -x_47 = x_77; -goto block_60; -} -} -else -{ -lean_object* x_78; -lean_dec(x_61); -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_78 = lean_box(0); -x_47 = x_78; -goto block_60; -} -} -else -{ -lean_object* x_79; -lean_dec(x_44); -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_79 = lean_box(0); -x_47 = x_79; -goto block_60; -} -block_60: -{ -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_dec(x_47); -x_48 = lean_ctor_get(x_45, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_45, 1); -lean_inc(x_49); -x_50 = lean_ctor_get(x_4, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_4, 0); -lean_inc(x_51); -lean_dec(x_4); -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -lean_dec(x_51); -x_53 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_53, 0, x_48); -lean_ctor_set(x_53, 1, x_49); -lean_ctor_set(x_53, 2, x_50); -lean_ctor_set(x_53, 3, x_52); -x_54 = l_Lean_mkOptionalNode___closed__2; -x_55 = lean_array_push(x_54, x_1); -x_56 = l_Lean_Meta_mkEqRec___closed__1; -x_57 = l_Lean_Meta_mkEqNDRec___closed__3; -x_58 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_58, 0, x_56); -lean_ctor_set(x_58, 1, x_57); -lean_ctor_set(x_58, 2, x_55); -lean_ctor_set(x_58, 3, x_53); -if (lean_is_scalar(x_46)) { - x_59 = lean_alloc_ctor(1, 2, 0); -} else { - x_59 = x_46; - lean_ctor_set_tag(x_59, 1); -} -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_45); -return x_59; -} -} -else -{ -uint8_t x_80; -lean_free_object(x_39); -lean_dec(x_41); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_80 = !lean_is_exclusive(x_43); -if (x_80 == 0) -{ -return x_43; -} -else -{ -lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_43, 0); -x_82 = lean_ctor_get(x_43, 1); -lean_inc(x_82); -lean_inc(x_81); lean_dec(x_43); -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; +x_45 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_42); +lean_ctor_set(x_45, 3, x_44); +x_46 = l_Lean_mkOptionalNode___closed__2; +x_47 = lean_array_push(x_46, x_1); +x_48 = l_Lean_Meta_mkEqRec___closed__1; +x_49 = l_Lean_Meta_mkEqNDRec___closed__3; +x_50 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +lean_ctor_set(x_50, 2, x_47); +lean_ctor_set(x_50, 3, x_45); +if (lean_is_scalar(x_38)) { + x_51 = lean_alloc_ctor(1, 2, 0); +} else { + x_51 = x_38; + lean_ctor_set_tag(x_51, 1); +} +lean_ctor_set(x_51, 0, x_50); +lean_ctor_set(x_51, 1, x_37); +return x_51; +} +} +else +{ +uint8_t x_73; +lean_free_object(x_31); +lean_dec(x_33); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_73 = !lean_is_exclusive(x_35); +if (x_73 == 0) +{ +return x_35; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_35, 0); +x_75 = lean_ctor_get(x_35, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_35); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; } } } else { -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_39, 0); -x_85 = lean_ctor_get(x_39, 1); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_39); +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_31, 0); +x_78 = lean_ctor_get(x_31, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_31); lean_inc(x_4); lean_inc(x_1); -x_86 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_85); -if (lean_obj_tag(x_86) == 0) +x_79 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_78); +if (lean_obj_tag(x_79) == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_86, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 1); -lean_inc(x_88); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_89 = x_86; +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_80 = lean_ctor_get(x_79, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_79, 1); +lean_inc(x_81); +if (lean_is_exclusive(x_79)) { + lean_ctor_release(x_79, 0); + lean_ctor_release(x_79, 1); + x_82 = x_79; } else { - lean_dec_ref(x_86); - x_89 = lean_box(0); + lean_dec_ref(x_79); + x_82 = lean_box(0); } -if (lean_obj_tag(x_87) == 7) +if (lean_obj_tag(x_80) == 7) { -lean_object* x_104; -x_104 = lean_ctor_get(x_87, 2); -lean_inc(x_104); -lean_dec(x_87); -if (lean_obj_tag(x_104) == 7) +lean_object* x_97; +x_97 = lean_ctor_get(x_80, 2); +lean_inc(x_97); +lean_dec(x_80); +if (lean_obj_tag(x_97) == 7) { -lean_object* x_105; -x_105 = lean_ctor_get(x_104, 2); -lean_inc(x_105); -lean_dec(x_104); -if (lean_obj_tag(x_105) == 3) +lean_object* x_98; +x_98 = lean_ctor_get(x_97, 2); +lean_inc(x_98); +lean_dec(x_97); +if (lean_obj_tag(x_98) == 3) { -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_dec(x_89); +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_dec(x_82); lean_dec(x_4); -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -lean_dec(x_105); -x_107 = lean_box(0); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_84); -lean_ctor_set(x_108, 1, x_107); -x_109 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_109, 0, x_106); -lean_ctor_set(x_109, 1, x_108); -x_110 = l_Lean_Meta_mkEqRec___closed__1; -x_111 = l_Lean_mkConst(x_110, x_109); -x_112 = l_Lean_Meta_mkEqNDRec___closed__4; -x_113 = lean_array_push(x_112, x_31); -x_114 = lean_array_push(x_113, x_34); -x_115 = lean_array_push(x_114, x_1); -x_116 = lean_array_push(x_115, x_2); -x_117 = lean_array_push(x_116, x_38); -x_118 = lean_array_push(x_117, x_3); -x_119 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_118, x_118, x_26, x_111); -lean_dec(x_118); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_88); -return x_120; -} -else -{ -lean_object* x_121; -lean_dec(x_105); -lean_dec(x_84); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_121 = lean_box(0); -x_90 = x_121; -goto block_103; -} -} -else -{ -lean_object* x_122; -lean_dec(x_104); -lean_dec(x_84); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_122 = lean_box(0); -x_90 = x_122; -goto block_103; -} -} -else -{ -lean_object* x_123; -lean_dec(x_87); -lean_dec(x_84); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); -lean_dec(x_3); -lean_dec(x_2); -x_123 = lean_box(0); -x_90 = x_123; -goto block_103; -} -block_103: -{ -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_dec(x_90); -x_91 = lean_ctor_get(x_88, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_88, 1); -lean_inc(x_92); -x_93 = lean_ctor_get(x_4, 1); -lean_inc(x_93); -x_94 = lean_ctor_get(x_4, 0); -lean_inc(x_94); -lean_dec(x_4); -x_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -lean_dec(x_94); -x_96 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_96, 0, x_91); -lean_ctor_set(x_96, 1, x_92); -lean_ctor_set(x_96, 2, x_93); -lean_ctor_set(x_96, 3, x_95); -x_97 = l_Lean_mkOptionalNode___closed__2; -x_98 = lean_array_push(x_97, x_1); -x_99 = l_Lean_Meta_mkEqRec___closed__1; -x_100 = l_Lean_Meta_mkEqNDRec___closed__3; -x_101 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_101, 0, x_99); +x_99 = lean_ctor_get(x_98, 0); +lean_inc(x_99); +lean_dec(x_98); +x_100 = lean_box(0); +x_101 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_101, 0, x_77); lean_ctor_set(x_101, 1, x_100); -lean_ctor_set(x_101, 2, x_98); -lean_ctor_set(x_101, 3, x_96); -if (lean_is_scalar(x_89)) { - x_102 = lean_alloc_ctor(1, 2, 0); -} else { - x_102 = x_89; - lean_ctor_set_tag(x_102, 1); +x_102 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_102, 0, x_99); +lean_ctor_set(x_102, 1, x_101); +x_103 = l_Lean_Meta_mkEqRec___closed__1; +x_104 = l_Lean_mkConst(x_103, x_102); +x_105 = l_Lean_Meta_mkEqNDRec___closed__4; +x_106 = lean_array_push(x_105, x_28); +x_107 = lean_array_push(x_106, x_29); +x_108 = lean_array_push(x_107, x_1); +x_109 = lean_array_push(x_108, x_2); +x_110 = lean_array_push(x_109, x_30); +x_111 = lean_array_push(x_110, x_3); +x_112 = lean_unsigned_to_nat(0u); +x_113 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_111, x_111, x_112, x_104); +lean_dec(x_111); +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_113); +lean_ctor_set(x_114, 1, x_81); +return x_114; } -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_88); -return x_102; +else +{ +lean_object* x_115; +lean_dec(x_98); +lean_dec(x_77); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_115 = lean_box(0); +x_83 = x_115; +goto block_96; } } else { -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_84); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_31); +lean_object* x_116; +lean_dec(x_97); +lean_dec(x_77); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_116 = lean_box(0); +x_83 = x_116; +goto block_96; +} +} +else +{ +lean_object* x_117; +lean_dec(x_80); +lean_dec(x_77); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_117 = lean_box(0); +x_83 = x_117; +goto block_96; +} +block_96: +{ +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_dec(x_83); +x_84 = lean_ctor_get(x_81, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_81, 1); +lean_inc(x_85); +x_86 = lean_ctor_get(x_4, 1); +lean_inc(x_86); +x_87 = lean_ctor_get(x_4, 0); +lean_inc(x_87); +lean_dec(x_4); +x_88 = lean_ctor_get(x_87, 0); +lean_inc(x_88); +lean_dec(x_87); +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_86); +lean_ctor_set(x_89, 3, x_88); +x_90 = l_Lean_mkOptionalNode___closed__2; +x_91 = lean_array_push(x_90, x_1); +x_92 = l_Lean_Meta_mkEqRec___closed__1; +x_93 = l_Lean_Meta_mkEqNDRec___closed__3; +x_94 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_94, 0, x_92); +lean_ctor_set(x_94, 1, x_93); +lean_ctor_set(x_94, 2, x_91); +lean_ctor_set(x_94, 3, x_89); +if (lean_is_scalar(x_82)) { + x_95 = lean_alloc_ctor(1, 2, 0); +} else { + x_95 = x_82; + lean_ctor_set_tag(x_95, 1); +} +lean_ctor_set(x_95, 0, x_94); +lean_ctor_set(x_95, 1, x_81); +return x_95; +} +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; +lean_dec(x_77); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_124 = lean_ctor_get(x_86, 0); +x_118 = lean_ctor_get(x_79, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_79, 1); +lean_inc(x_119); +if (lean_is_exclusive(x_79)) { + lean_ctor_release(x_79, 0); + lean_ctor_release(x_79, 1); + x_120 = x_79; +} else { + lean_dec_ref(x_79); + 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 +{ +uint8_t x_122; +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_28); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_122 = !lean_is_exclusive(x_31); +if (x_122 == 0) +{ +return x_31; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_31, 0); +x_124 = lean_ctor_get(x_31, 1); lean_inc(x_124); -x_125 = lean_ctor_get(x_86, 1); -lean_inc(x_125); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_126 = x_86; -} else { - lean_dec_ref(x_86); - x_126 = lean_box(0); -} -if (lean_is_scalar(x_126)) { - x_127 = lean_alloc_ctor(1, 2, 0); -} else { - x_127 = x_126; -} -lean_ctor_set(x_127, 0, x_124); -lean_ctor_set(x_127, 1, x_125); -return x_127; -} -} -} -else -{ -uint8_t x_128; -lean_dec(x_38); -lean_dec(x_34); +lean_inc(x_123); lean_dec(x_31); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_128 = !lean_is_exclusive(x_39); -if (x_128 == 0) -{ -return x_39; -} -else -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_129 = lean_ctor_get(x_39, 0); -x_130 = lean_ctor_get(x_39, 1); -lean_inc(x_130); -lean_inc(x_129); -lean_dec(x_39); -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; +x_125 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_125, 0, x_123); +lean_ctor_set(x_125, 1, x_124); +return x_125; } } } } else { -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; uint8_t x_136; -x_132 = lean_ctor_get(x_8, 0); -x_133 = lean_ctor_get(x_8, 1); -lean_inc(x_133); -lean_inc(x_132); +lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; uint8_t x_130; +x_126 = lean_ctor_get(x_8, 0); +x_127 = lean_ctor_get(x_8, 1); +lean_inc(x_127); +lean_inc(x_126); lean_dec(x_8); -x_134 = l_Lean_Expr_eq_x3f___closed__2; -x_135 = lean_unsigned_to_nat(3u); -x_136 = l_Lean_Expr_isAppOfArity___main(x_132, x_134, x_135); -if (x_136 == 0) +x_128 = l_Lean_Expr_eq_x3f___closed__2; +x_129 = lean_unsigned_to_nat(3u); +x_130 = l_Lean_Expr_isAppOfArity___main(x_126, x_128, x_129); +if (x_130 == 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_dec(x_132); +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_dec(x_126); lean_dec(x_2); lean_dec(x_1); -x_137 = lean_ctor_get(x_133, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_133, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_4, 1); -lean_inc(x_139); -x_140 = lean_ctor_get(x_4, 0); -lean_inc(x_140); +x_131 = lean_ctor_get(x_127, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_127, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_4, 1); +lean_inc(x_133); +x_134 = lean_ctor_get(x_4, 0); +lean_inc(x_134); lean_dec(x_4); -x_141 = lean_ctor_get(x_140, 0); -lean_inc(x_141); -lean_dec(x_140); -x_142 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_142, 0, x_137); -lean_ctor_set(x_142, 1, x_138); -lean_ctor_set(x_142, 2, x_139); -lean_ctor_set(x_142, 3, x_141); -x_143 = l_Lean_mkOptionalNode___closed__2; -x_144 = lean_array_push(x_143, x_3); -x_145 = l_Lean_Meta_mkEqRec___closed__1; -x_146 = l_Lean_Meta_mkEqSymm___closed__3; -x_147 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_147, 0, x_145); -lean_ctor_set(x_147, 1, x_146); -lean_ctor_set(x_147, 2, x_144); -lean_ctor_set(x_147, 3, x_142); -x_148 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_148, 0, x_147); -lean_ctor_set(x_148, 1, x_133); -return x_148; +x_135 = lean_ctor_get(x_134, 0); +lean_inc(x_135); +lean_dec(x_134); +x_136 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_133); +lean_ctor_set(x_136, 3, x_135); +x_137 = l_Lean_mkOptionalNode___closed__2; +x_138 = lean_array_push(x_137, x_3); +x_139 = l_Lean_Meta_mkEqRec___closed__1; +x_140 = l_Lean_Meta_mkEqSymm___closed__3; +x_141 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_141, 0, x_139); +lean_ctor_set(x_141, 1, x_140); +lean_ctor_set(x_141, 2, x_138); +lean_ctor_set(x_141, 3, x_136); +x_142 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_142, 0, x_141); +lean_ctor_set(x_142, 1, x_127); +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; -x_149 = lean_unsigned_to_nat(0u); -x_150 = l_Lean_Expr_getAppNumArgsAux___main(x_132, x_149); -x_151 = lean_nat_sub(x_150, x_149); -x_152 = lean_unsigned_to_nat(1u); -x_153 = lean_nat_sub(x_151, x_152); -lean_dec(x_151); -x_154 = l_Lean_Expr_getRevArg_x21___main(x_132, x_153); -x_155 = lean_nat_sub(x_150, x_152); -x_156 = lean_nat_sub(x_155, x_152); -lean_dec(x_155); -x_157 = l_Lean_Expr_getRevArg_x21___main(x_132, x_156); -x_158 = lean_unsigned_to_nat(2u); -x_159 = lean_nat_sub(x_150, x_158); -lean_dec(x_150); -x_160 = lean_nat_sub(x_159, x_152); -lean_dec(x_159); -x_161 = l_Lean_Expr_getRevArg_x21___main(x_132, x_160); -lean_dec(x_132); +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_143 = l_Lean_Expr_appFn_x21(x_126); +x_144 = l_Lean_Expr_appFn_x21(x_143); +x_145 = l_Lean_Expr_appArg_x21(x_144); +lean_dec(x_144); +x_146 = l_Lean_Expr_appArg_x21(x_143); +lean_dec(x_143); +x_147 = l_Lean_Expr_appArg_x21(x_126); +lean_dec(x_126); lean_inc(x_4); -lean_inc(x_154); -x_162 = l_Lean_Meta_getLevel(x_154, x_4, x_133); -if (lean_obj_tag(x_162) == 0) +lean_inc(x_145); +x_148 = l_Lean_Meta_getLevel(x_145, x_4, x_127); +if (lean_obj_tag(x_148) == 0) { -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_163 = lean_ctor_get(x_162, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_162, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_165 = x_162; +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; +x_149 = lean_ctor_get(x_148, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_148, 1); +lean_inc(x_150); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + x_151 = x_148; } else { - lean_dec_ref(x_162); - x_165 = lean_box(0); + lean_dec_ref(x_148); + x_151 = lean_box(0); } lean_inc(x_4); lean_inc(x_1); -x_166 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_164); -if (lean_obj_tag(x_166) == 0) +x_152 = l___private_Init_Lean_Meta_AppBuilder_1__infer(x_1, x_4, x_150); +if (lean_obj_tag(x_152) == 0) { -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_167 = lean_ctor_get(x_166, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_166, 1); -lean_inc(x_168); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_169 = x_166; +lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; +x_153 = lean_ctor_get(x_152, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_152, 1); +lean_inc(x_154); +if (lean_is_exclusive(x_152)) { + lean_ctor_release(x_152, 0); + lean_ctor_release(x_152, 1); + x_155 = x_152; } else { - lean_dec_ref(x_166); - x_169 = lean_box(0); + lean_dec_ref(x_152); + x_155 = lean_box(0); } -if (lean_obj_tag(x_167) == 7) +if (lean_obj_tag(x_153) == 7) { -lean_object* x_184; -x_184 = lean_ctor_get(x_167, 2); -lean_inc(x_184); -lean_dec(x_167); -if (lean_obj_tag(x_184) == 7) +lean_object* x_170; +x_170 = lean_ctor_get(x_153, 2); +lean_inc(x_170); +lean_dec(x_153); +if (lean_obj_tag(x_170) == 7) { -lean_object* x_185; -x_185 = lean_ctor_get(x_184, 2); -lean_inc(x_185); -lean_dec(x_184); -if (lean_obj_tag(x_185) == 3) -{ -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_dec(x_169); -lean_dec(x_4); -x_186 = lean_ctor_get(x_185, 0); -lean_inc(x_186); -lean_dec(x_185); -x_187 = lean_box(0); -x_188 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_188, 0, x_163); -lean_ctor_set(x_188, 1, x_187); -x_189 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_189, 0, x_186); -lean_ctor_set(x_189, 1, x_188); -x_190 = l_Lean_Meta_mkEqRec___closed__1; -x_191 = l_Lean_mkConst(x_190, x_189); -x_192 = l_Lean_Meta_mkEqNDRec___closed__4; -x_193 = lean_array_push(x_192, x_154); -x_194 = lean_array_push(x_193, x_157); -x_195 = lean_array_push(x_194, x_1); -x_196 = lean_array_push(x_195, x_2); -x_197 = lean_array_push(x_196, x_161); -x_198 = lean_array_push(x_197, x_3); -x_199 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_198, x_198, x_149, x_191); -lean_dec(x_198); -if (lean_is_scalar(x_165)) { - x_200 = lean_alloc_ctor(0, 2, 0); -} else { - x_200 = x_165; -} -lean_ctor_set(x_200, 0, x_199); -lean_ctor_set(x_200, 1, x_168); -return x_200; -} -else -{ -lean_object* x_201; -lean_dec(x_185); -lean_dec(x_165); -lean_dec(x_163); -lean_dec(x_161); -lean_dec(x_157); -lean_dec(x_154); -lean_dec(x_3); -lean_dec(x_2); -x_201 = lean_box(0); -x_170 = x_201; -goto block_183; -} -} -else -{ -lean_object* x_202; -lean_dec(x_184); -lean_dec(x_165); -lean_dec(x_163); -lean_dec(x_161); -lean_dec(x_157); -lean_dec(x_154); -lean_dec(x_3); -lean_dec(x_2); -x_202 = lean_box(0); -x_170 = x_202; -goto block_183; -} -} -else -{ -lean_object* x_203; -lean_dec(x_167); -lean_dec(x_165); -lean_dec(x_163); -lean_dec(x_161); -lean_dec(x_157); -lean_dec(x_154); -lean_dec(x_3); -lean_dec(x_2); -x_203 = lean_box(0); -x_170 = x_203; -goto block_183; -} -block_183: -{ -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_dec(x_170); -x_171 = lean_ctor_get(x_168, 0); +lean_object* x_171; +x_171 = lean_ctor_get(x_170, 2); lean_inc(x_171); -x_172 = lean_ctor_get(x_168, 1); +lean_dec(x_170); +if (lean_obj_tag(x_171) == 3) +{ +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_dec(x_155); +lean_dec(x_4); +x_172 = lean_ctor_get(x_171, 0); lean_inc(x_172); -x_173 = lean_ctor_get(x_4, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_4, 0); -lean_inc(x_174); -lean_dec(x_4); -x_175 = lean_ctor_get(x_174, 0); -lean_inc(x_175); -lean_dec(x_174); -x_176 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_176, 0, x_171); -lean_ctor_set(x_176, 1, x_172); -lean_ctor_set(x_176, 2, x_173); -lean_ctor_set(x_176, 3, x_175); -x_177 = l_Lean_mkOptionalNode___closed__2; -x_178 = lean_array_push(x_177, x_1); -x_179 = l_Lean_Meta_mkEqRec___closed__1; -x_180 = l_Lean_Meta_mkEqNDRec___closed__3; -x_181 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_181, 0, x_179); -lean_ctor_set(x_181, 1, x_180); -lean_ctor_set(x_181, 2, x_178); -lean_ctor_set(x_181, 3, x_176); -if (lean_is_scalar(x_169)) { - x_182 = lean_alloc_ctor(1, 2, 0); +lean_dec(x_171); +x_173 = lean_box(0); +x_174 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_174, 0, x_149); +lean_ctor_set(x_174, 1, x_173); +x_175 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_175, 0, x_172); +lean_ctor_set(x_175, 1, x_174); +x_176 = l_Lean_Meta_mkEqRec___closed__1; +x_177 = l_Lean_mkConst(x_176, x_175); +x_178 = l_Lean_Meta_mkEqNDRec___closed__4; +x_179 = lean_array_push(x_178, x_145); +x_180 = lean_array_push(x_179, x_146); +x_181 = lean_array_push(x_180, x_1); +x_182 = lean_array_push(x_181, x_2); +x_183 = lean_array_push(x_182, x_147); +x_184 = lean_array_push(x_183, x_3); +x_185 = lean_unsigned_to_nat(0u); +x_186 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_184, x_184, x_185, x_177); +lean_dec(x_184); +if (lean_is_scalar(x_151)) { + x_187 = lean_alloc_ctor(0, 2, 0); } else { - x_182 = x_169; - lean_ctor_set_tag(x_182, 1); + x_187 = x_151; } -lean_ctor_set(x_182, 0, x_181); -lean_ctor_set(x_182, 1, x_168); -return x_182; +lean_ctor_set(x_187, 0, x_186); +lean_ctor_set(x_187, 1, x_154); +return x_187; +} +else +{ +lean_object* x_188; +lean_dec(x_171); +lean_dec(x_151); +lean_dec(x_149); +lean_dec(x_147); +lean_dec(x_146); +lean_dec(x_145); +lean_dec(x_3); +lean_dec(x_2); +x_188 = lean_box(0); +x_156 = x_188; +goto block_169; } } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -lean_dec(x_165); -lean_dec(x_163); -lean_dec(x_161); -lean_dec(x_157); -lean_dec(x_154); -lean_dec(x_4); +lean_object* x_189; +lean_dec(x_170); +lean_dec(x_151); +lean_dec(x_149); +lean_dec(x_147); +lean_dec(x_146); +lean_dec(x_145); lean_dec(x_3); lean_dec(x_2); -lean_dec(x_1); -x_204 = lean_ctor_get(x_166, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_166, 1); -lean_inc(x_205); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_206 = x_166; -} else { - lean_dec_ref(x_166); - 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; +x_189 = lean_box(0); +x_156 = x_189; +goto block_169; } } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; -lean_dec(x_161); -lean_dec(x_157); -lean_dec(x_154); +lean_object* x_190; +lean_dec(x_153); +lean_dec(x_151); +lean_dec(x_149); +lean_dec(x_147); +lean_dec(x_146); +lean_dec(x_145); +lean_dec(x_3); +lean_dec(x_2); +x_190 = lean_box(0); +x_156 = x_190; +goto block_169; +} +block_169: +{ +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_dec(x_156); +x_157 = lean_ctor_get(x_154, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_154, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_4, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_4, 0); +lean_inc(x_160); +lean_dec(x_4); +x_161 = lean_ctor_get(x_160, 0); +lean_inc(x_161); +lean_dec(x_160); +x_162 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_159); +lean_ctor_set(x_162, 3, x_161); +x_163 = l_Lean_mkOptionalNode___closed__2; +x_164 = lean_array_push(x_163, x_1); +x_165 = l_Lean_Meta_mkEqRec___closed__1; +x_166 = l_Lean_Meta_mkEqNDRec___closed__3; +x_167 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_167, 0, x_165); +lean_ctor_set(x_167, 1, x_166); +lean_ctor_set(x_167, 2, x_164); +lean_ctor_set(x_167, 3, x_162); +if (lean_is_scalar(x_155)) { + x_168 = lean_alloc_ctor(1, 2, 0); +} else { + x_168 = x_155; + lean_ctor_set_tag(x_168, 1); +} +lean_ctor_set(x_168, 0, x_167); +lean_ctor_set(x_168, 1, x_154); +return x_168; +} +} +else +{ +lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; +lean_dec(x_151); +lean_dec(x_149); +lean_dec(x_147); +lean_dec(x_146); +lean_dec(x_145); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_208 = lean_ctor_get(x_162, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_162, 1); -lean_inc(x_209); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_210 = x_162; +x_191 = lean_ctor_get(x_152, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_152, 1); +lean_inc(x_192); +if (lean_is_exclusive(x_152)) { + lean_ctor_release(x_152, 0); + lean_ctor_release(x_152, 1); + x_193 = x_152; } else { - lean_dec_ref(x_162); - x_210 = lean_box(0); + lean_dec_ref(x_152); + x_193 = lean_box(0); } -if (lean_is_scalar(x_210)) { - x_211 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_193)) { + x_194 = lean_alloc_ctor(1, 2, 0); } else { - x_211 = x_210; + x_194 = x_193; } -lean_ctor_set(x_211, 0, x_208); -lean_ctor_set(x_211, 1, x_209); -return x_211; +lean_ctor_set(x_194, 0, x_191); +lean_ctor_set(x_194, 1, x_192); +return x_194; +} +} +else +{ +lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; +lean_dec(x_147); +lean_dec(x_146); +lean_dec(x_145); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_195 = lean_ctor_get(x_148, 0); +lean_inc(x_195); +x_196 = lean_ctor_get(x_148, 1); +lean_inc(x_196); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + x_197 = x_148; +} else { + lean_dec_ref(x_148); + x_197 = lean_box(0); +} +if (lean_is_scalar(x_197)) { + x_198 = lean_alloc_ctor(1, 2, 0); +} else { + x_198 = x_197; +} +lean_ctor_set(x_198, 0, x_195); +lean_ctor_set(x_198, 1, x_196); +return x_198; } } } } else { -uint8_t x_212; +uint8_t x_199; lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_212 = !lean_is_exclusive(x_8); -if (x_212 == 0) +x_199 = !lean_is_exclusive(x_8); +if (x_199 == 0) { return x_8; } else { -lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_213 = lean_ctor_get(x_8, 0); -x_214 = lean_ctor_get(x_8, 1); -lean_inc(x_214); -lean_inc(x_213); +lean_object* x_200; lean_object* x_201; lean_object* x_202; +x_200 = lean_ctor_get(x_8, 0); +x_201 = lean_ctor_get(x_8, 1); +lean_inc(x_201); +lean_inc(x_200); lean_dec(x_8); -x_215 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_215, 0, x_213); -lean_ctor_set(x_215, 1, x_214); -return x_215; +x_202 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_202, 0, x_200); +lean_ctor_set(x_202, 1, x_201); +return x_202; } } } else { -lean_object* x_216; +lean_object* x_203; lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_216 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_216, 0, x_2); -lean_ctor_set(x_216, 1, x_5); -return x_216; +x_203 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_203, 0, x_2); +lean_ctor_set(x_203, 1, x_5); +return x_203; } } } @@ -9365,654 +8958,641 @@ return x_8; } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_free_object(x_8); -x_26 = lean_unsigned_to_nat(0u); -x_27 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_26); -x_28 = lean_nat_sub(x_27, x_26); -x_29 = lean_unsigned_to_nat(1u); -x_30 = lean_nat_sub(x_28, x_29); -lean_dec(x_28); -x_31 = l_Lean_Expr_getRevArg_x21___main(x_10, x_30); -x_32 = lean_nat_sub(x_27, x_29); -x_33 = lean_nat_sub(x_32, x_29); -lean_dec(x_32); -x_34 = l_Lean_Expr_getRevArg_x21___main(x_10, x_33); -x_35 = lean_unsigned_to_nat(2u); -x_36 = lean_nat_sub(x_27, x_35); +x_26 = l_Lean_Expr_appFn_x21(x_10); +x_27 = l_Lean_Expr_appFn_x21(x_26); +x_28 = l_Lean_Expr_appArg_x21(x_27); lean_dec(x_27); -x_37 = lean_nat_sub(x_36, x_29); -lean_dec(x_36); -x_38 = l_Lean_Expr_getRevArg_x21___main(x_10, x_37); +x_29 = l_Lean_Expr_appArg_x21(x_26); +lean_dec(x_26); +x_30 = l_Lean_Expr_appArg_x21(x_10); lean_dec(x_10); lean_inc(x_3); -x_39 = l_Lean_Meta_whnf(x_31, x_3, x_11); -if (lean_obj_tag(x_39) == 0) +x_31 = l_Lean_Meta_whnf(x_28, x_3, x_11); +if (lean_obj_tag(x_31) == 0) { -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_57; lean_object* x_58; -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; +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_49; lean_object* x_50; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_31, 1); +lean_inc(x_33); +if (lean_is_exclusive(x_31)) { + lean_ctor_release(x_31, 0); + lean_ctor_release(x_31, 1); + x_34 = x_31; } else { - lean_dec_ref(x_39); - x_42 = lean_box(0); + lean_dec_ref(x_31); + x_34 = lean_box(0); } -x_57 = lean_ctor_get(x_41, 0); -lean_inc(x_57); -x_58 = l_Lean_Expr_getAppFn___main(x_40); -if (lean_obj_tag(x_58) == 4) +x_49 = lean_ctor_get(x_33, 0); +lean_inc(x_49); +x_50 = l_Lean_Expr_getAppFn___main(x_32); +if (lean_obj_tag(x_50) == 4) { -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); -lean_dec(x_58); -x_61 = lean_environment_find(x_57, x_59); -if (lean_obj_tag(x_61) == 0) +lean_object* x_51; lean_object* x_52; lean_object* x_53; +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_environment_find(x_49, x_51); +if (lean_obj_tag(x_53) == 0) { -lean_object* x_62; -lean_dec(x_60); -lean_dec(x_38); -lean_dec(x_34); +lean_object* x_54; +lean_dec(x_52); +lean_dec(x_30); +lean_dec(x_29); lean_dec(x_2); lean_dec(x_1); -x_62 = lean_box(0); -x_43 = x_62; -goto block_56; +x_54 = lean_box(0); +x_35 = x_54; +goto block_48; } else { -lean_object* x_63; -x_63 = lean_ctor_get(x_61, 0); -lean_inc(x_63); -lean_dec(x_61); -if (lean_obj_tag(x_63) == 5) +lean_object* x_55; +x_55 = lean_ctor_get(x_53, 0); +lean_inc(x_55); +lean_dec(x_53); +if (lean_obj_tag(x_55) == 5) { -lean_object* x_64; lean_object* x_65; -lean_dec(x_42); -x_64 = lean_ctor_get(x_63, 0); -lean_inc(x_64); -lean_dec(x_63); +lean_object* x_56; lean_object* x_57; +lean_dec(x_34); +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +lean_dec(x_55); lean_inc(x_1); -x_65 = l_Lean_Meta_getLevel(x_1, x_3, x_41); -if (lean_obj_tag(x_65) == 0) +x_57 = l_Lean_Meta_getLevel(x_1, x_3, x_33); +if (lean_obj_tag(x_57) == 0) { -uint8_t x_66; -x_66 = !lean_is_exclusive(x_65); -if (x_66 == 0) +uint8_t x_58; +x_58 = !lean_is_exclusive(x_57); +if (x_58 == 0) { -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_65, 0); -x_68 = lean_ctor_get(x_64, 0); -lean_inc(x_68); -lean_dec(x_64); -x_69 = lean_ctor_get(x_68, 0); -lean_inc(x_69); -lean_dec(x_68); -x_70 = l_Lean_Meta_mkNoConfusion___closed__1; -x_71 = lean_name_mk_string(x_69, x_70); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_60); -x_73 = l_Lean_mkConst(x_71, x_72); -x_74 = l_Lean_Expr_getAppNumArgsAux___main(x_40, x_26); -x_75 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_74); -x_76 = lean_mk_array(x_74, x_75); -x_77 = lean_nat_sub(x_74, x_29); -lean_dec(x_74); -x_78 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_40, x_76, x_77); -x_79 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; -x_80 = lean_array_push(x_79, x_1); -x_81 = lean_array_push(x_80, x_34); -x_82 = lean_array_push(x_81, x_38); -x_83 = lean_array_push(x_82, x_2); -x_84 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_83, x_83, x_26, x_78); -lean_dec(x_83); -x_85 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_84, x_84, x_26, x_73); -lean_dec(x_84); -lean_ctor_set(x_65, 0, x_85); -return x_65; +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; +x_59 = lean_ctor_get(x_57, 0); +x_60 = lean_ctor_get(x_56, 0); +lean_inc(x_60); +lean_dec(x_56); +x_61 = lean_ctor_get(x_60, 0); +lean_inc(x_61); +lean_dec(x_60); +x_62 = l_Lean_Meta_mkNoConfusion___closed__1; +x_63 = lean_name_mk_string(x_61, x_62); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_52); +x_65 = l_Lean_mkConst(x_63, x_64); +x_66 = lean_unsigned_to_nat(0u); +x_67 = l_Lean_Expr_getAppNumArgsAux___main(x_32, x_66); +x_68 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_67); +x_69 = lean_mk_array(x_67, x_68); +x_70 = lean_unsigned_to_nat(1u); +x_71 = lean_nat_sub(x_67, x_70); +lean_dec(x_67); +x_72 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_32, x_69, x_71); +x_73 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; +x_74 = lean_array_push(x_73, x_1); +x_75 = lean_array_push(x_74, x_29); +x_76 = lean_array_push(x_75, x_30); +x_77 = lean_array_push(x_76, x_2); +x_78 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_77, x_77, x_66, x_72); +lean_dec(x_77); +x_79 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_78, x_78, x_66, x_65); +lean_dec(x_78); +lean_ctor_set(x_57, 0, x_79); +return x_57; } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_86 = lean_ctor_get(x_65, 0); -x_87 = lean_ctor_get(x_65, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_65); -x_88 = lean_ctor_get(x_64, 0); -lean_inc(x_88); -lean_dec(x_64); -x_89 = lean_ctor_get(x_88, 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; 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_80 = lean_ctor_get(x_57, 0); +x_81 = lean_ctor_get(x_57, 1); +lean_inc(x_81); +lean_inc(x_80); +lean_dec(x_57); +x_82 = lean_ctor_get(x_56, 0); +lean_inc(x_82); +lean_dec(x_56); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +lean_dec(x_82); +x_84 = l_Lean_Meta_mkNoConfusion___closed__1; +x_85 = lean_name_mk_string(x_83, x_84); +x_86 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_86, 0, x_80); +lean_ctor_set(x_86, 1, x_52); +x_87 = l_Lean_mkConst(x_85, x_86); +x_88 = lean_unsigned_to_nat(0u); +x_89 = l_Lean_Expr_getAppNumArgsAux___main(x_32, x_88); +x_90 = l_Lean_Expr_getAppArgs___closed__1; lean_inc(x_89); -lean_dec(x_88); -x_90 = l_Lean_Meta_mkNoConfusion___closed__1; -x_91 = lean_name_mk_string(x_89, x_90); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_86); -lean_ctor_set(x_92, 1, x_60); -x_93 = l_Lean_mkConst(x_91, x_92); -x_94 = l_Lean_Expr_getAppNumArgsAux___main(x_40, x_26); -x_95 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_94); -x_96 = lean_mk_array(x_94, x_95); -x_97 = lean_nat_sub(x_94, x_29); -lean_dec(x_94); -x_98 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_40, x_96, x_97); -x_99 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; -x_100 = lean_array_push(x_99, x_1); -x_101 = lean_array_push(x_100, x_34); -x_102 = lean_array_push(x_101, x_38); -x_103 = lean_array_push(x_102, x_2); -x_104 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_103, x_103, x_26, x_98); -lean_dec(x_103); -x_105 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_104, x_104, x_26, x_93); -lean_dec(x_104); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_87); +x_91 = lean_mk_array(x_89, x_90); +x_92 = lean_unsigned_to_nat(1u); +x_93 = lean_nat_sub(x_89, x_92); +lean_dec(x_89); +x_94 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_32, x_91, x_93); +x_95 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; +x_96 = lean_array_push(x_95, x_1); +x_97 = lean_array_push(x_96, x_29); +x_98 = lean_array_push(x_97, x_30); +x_99 = lean_array_push(x_98, x_2); +x_100 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_99, x_99, x_88, x_94); +lean_dec(x_99); +x_101 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_100, x_100, x_88, x_87); +lean_dec(x_100); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_101); +lean_ctor_set(x_102, 1, x_81); +return x_102; +} +} +else +{ +uint8_t x_103; +lean_dec(x_56); +lean_dec(x_52); +lean_dec(x_32); +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_2); +lean_dec(x_1); +x_103 = !lean_is_exclusive(x_57); +if (x_103 == 0) +{ +return x_57; +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_57, 0); +x_105 = lean_ctor_get(x_57, 1); +lean_inc(x_105); +lean_inc(x_104); +lean_dec(x_57); +x_106 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_106, 0, x_104); +lean_ctor_set(x_106, 1, x_105); return x_106; } } +} else { -uint8_t x_107; -lean_dec(x_64); -lean_dec(x_60); -lean_dec(x_40); -lean_dec(x_38); -lean_dec(x_34); +lean_object* x_107; +lean_dec(x_55); +lean_dec(x_52); +lean_dec(x_30); +lean_dec(x_29); lean_dec(x_2); lean_dec(x_1); -x_107 = !lean_is_exclusive(x_65); -if (x_107 == 0) -{ -return x_65; -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_65, 0); -x_109 = lean_ctor_get(x_65, 1); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_65); -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; +x_107 = lean_box(0); +x_35 = x_107; +goto block_48; } } } else { -lean_object* x_111; -lean_dec(x_63); -lean_dec(x_60); -lean_dec(x_38); -lean_dec(x_34); +lean_object* x_108; +lean_dec(x_50); +lean_dec(x_49); +lean_dec(x_30); +lean_dec(x_29); lean_dec(x_2); lean_dec(x_1); -x_111 = lean_box(0); -x_43 = x_111; -goto block_56; +x_108 = lean_box(0); +x_35 = x_108; +goto block_48; } -} -} -else +block_48: { -lean_object* x_112; -lean_dec(x_58); -lean_dec(x_57); -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_2); -lean_dec(x_1); -x_112 = lean_box(0); -x_43 = x_112; -goto block_56; -} -block_56: -{ -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_dec(x_43); -x_44 = lean_ctor_get(x_41, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_41, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_3, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_3, 0); -lean_inc(x_47); +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_dec(x_35); +x_36 = lean_ctor_get(x_33, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_33, 1); +lean_inc(x_37); +x_38 = lean_ctor_get(x_3, 1); +lean_inc(x_38); +x_39 = lean_ctor_get(x_3, 0); +lean_inc(x_39); lean_dec(x_3); -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -lean_dec(x_47); -x_49 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_49, 0, x_44); -lean_ctor_set(x_49, 1, x_45); -lean_ctor_set(x_49, 2, x_46); -lean_ctor_set(x_49, 3, x_48); -x_50 = l_Lean_mkOptionalNode___closed__2; -x_51 = lean_array_push(x_50, x_40); -x_52 = l_Lean_Meta_mkNoConfusion___closed__2; -x_53 = l_Lean_Meta_mkNoConfusion___closed__4; -x_54 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -lean_ctor_set(x_54, 2, x_51); -lean_ctor_set(x_54, 3, x_49); -if (lean_is_scalar(x_42)) { - x_55 = lean_alloc_ctor(1, 2, 0); -} else { - x_55 = x_42; - lean_ctor_set_tag(x_55, 1); -} -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_41); -return x_55; -} -} -else -{ -uint8_t x_113; -lean_dec(x_38); -lean_dec(x_34); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_113 = !lean_is_exclusive(x_39); -if (x_113 == 0) -{ -return x_39; -} -else -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_114 = lean_ctor_get(x_39, 0); -x_115 = lean_ctor_get(x_39, 1); -lean_inc(x_115); -lean_inc(x_114); +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); lean_dec(x_39); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_114); -lean_ctor_set(x_116, 1, x_115); -return x_116; -} -} -} -} -else -{ -lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; uint8_t x_121; -x_117 = lean_ctor_get(x_8, 0); -x_118 = lean_ctor_get(x_8, 1); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_8); -x_119 = l_Lean_Expr_eq_x3f___closed__2; -x_120 = lean_unsigned_to_nat(3u); -x_121 = l_Lean_Expr_isAppOfArity___main(x_117, x_119, x_120); -if (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_dec(x_117); -lean_dec(x_1); -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_3, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_3, 0); -lean_inc(x_125); -lean_dec(x_3); -x_126 = lean_ctor_get(x_125, 0); -lean_inc(x_126); -lean_dec(x_125); -x_127 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_127, 0, x_122); -lean_ctor_set(x_127, 1, x_123); -lean_ctor_set(x_127, 2, x_124); -lean_ctor_set(x_127, 3, x_126); -x_128 = l_Lean_mkOptionalNode___closed__2; -x_129 = lean_array_push(x_128, x_2); -x_130 = l_Lean_Meta_mkNoConfusion___closed__2; -x_131 = l_Lean_Meta_mkNoConfusion___closed__3; -x_132 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_132, 0, x_130); -lean_ctor_set(x_132, 1, x_131); -lean_ctor_set(x_132, 2, x_129); -lean_ctor_set(x_132, 3, x_127); -x_133 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_118); -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; -x_134 = lean_unsigned_to_nat(0u); -x_135 = l_Lean_Expr_getAppNumArgsAux___main(x_117, x_134); -x_136 = lean_nat_sub(x_135, x_134); -x_137 = lean_unsigned_to_nat(1u); -x_138 = lean_nat_sub(x_136, x_137); -lean_dec(x_136); -x_139 = l_Lean_Expr_getRevArg_x21___main(x_117, x_138); -x_140 = lean_nat_sub(x_135, x_137); -x_141 = lean_nat_sub(x_140, x_137); -lean_dec(x_140); -x_142 = l_Lean_Expr_getRevArg_x21___main(x_117, x_141); -x_143 = lean_unsigned_to_nat(2u); -x_144 = lean_nat_sub(x_135, x_143); -lean_dec(x_135); -x_145 = lean_nat_sub(x_144, x_137); -lean_dec(x_144); -x_146 = l_Lean_Expr_getRevArg_x21___main(x_117, x_145); -lean_dec(x_117); -lean_inc(x_3); -x_147 = l_Lean_Meta_whnf(x_139, x_3, x_118); -if (lean_obj_tag(x_147) == 0) -{ -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_165; lean_object* x_166; -x_148 = lean_ctor_get(x_147, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_147, 1); -lean_inc(x_149); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_150 = x_147; +x_41 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_37); +lean_ctor_set(x_41, 2, x_38); +lean_ctor_set(x_41, 3, x_40); +x_42 = l_Lean_mkOptionalNode___closed__2; +x_43 = lean_array_push(x_42, x_32); +x_44 = l_Lean_Meta_mkNoConfusion___closed__2; +x_45 = l_Lean_Meta_mkNoConfusion___closed__4; +x_46 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_46, 0, x_44); +lean_ctor_set(x_46, 1, x_45); +lean_ctor_set(x_46, 2, x_43); +lean_ctor_set(x_46, 3, x_41); +if (lean_is_scalar(x_34)) { + x_47 = lean_alloc_ctor(1, 2, 0); } else { - lean_dec_ref(x_147); - x_150 = lean_box(0); + x_47 = x_34; + lean_ctor_set_tag(x_47, 1); } -x_165 = lean_ctor_get(x_149, 0); -lean_inc(x_165); -x_166 = l_Lean_Expr_getAppFn___main(x_148); -if (lean_obj_tag(x_166) == 4) +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_33); +return x_47; +} +} +else { -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_environment_find(x_165, x_167); -if (lean_obj_tag(x_169) == 0) -{ -lean_object* x_170; -lean_dec(x_168); -lean_dec(x_146); -lean_dec(x_142); +uint8_t x_109; +lean_dec(x_30); +lean_dec(x_29); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_170 = lean_box(0); -x_151 = x_170; -goto block_164; +x_109 = !lean_is_exclusive(x_31); +if (x_109 == 0) +{ +return x_31; } else { -lean_object* x_171; -x_171 = lean_ctor_get(x_169, 0); -lean_inc(x_171); -lean_dec(x_169); -if (lean_obj_tag(x_171) == 5) +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_31, 0); +x_111 = lean_ctor_get(x_31, 1); +lean_inc(x_111); +lean_inc(x_110); +lean_dec(x_31); +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_172; lean_object* x_173; -lean_dec(x_150); -x_172 = lean_ctor_get(x_171, 0); -lean_inc(x_172); -lean_dec(x_171); +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; uint8_t x_117; +x_113 = lean_ctor_get(x_8, 0); +x_114 = lean_ctor_get(x_8, 1); +lean_inc(x_114); +lean_inc(x_113); +lean_dec(x_8); +x_115 = l_Lean_Expr_eq_x3f___closed__2; +x_116 = lean_unsigned_to_nat(3u); +x_117 = l_Lean_Expr_isAppOfArity___main(x_113, x_115, 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; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; +lean_dec(x_113); +lean_dec(x_1); +x_118 = lean_ctor_get(x_114, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_114, 1); +lean_inc(x_119); +x_120 = lean_ctor_get(x_3, 1); +lean_inc(x_120); +x_121 = lean_ctor_get(x_3, 0); +lean_inc(x_121); +lean_dec(x_3); +x_122 = lean_ctor_get(x_121, 0); +lean_inc(x_122); +lean_dec(x_121); +x_123 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_123, 0, x_118); +lean_ctor_set(x_123, 1, x_119); +lean_ctor_set(x_123, 2, x_120); +lean_ctor_set(x_123, 3, x_122); +x_124 = l_Lean_mkOptionalNode___closed__2; +x_125 = lean_array_push(x_124, x_2); +x_126 = l_Lean_Meta_mkNoConfusion___closed__2; +x_127 = l_Lean_Meta_mkNoConfusion___closed__3; +x_128 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +lean_ctor_set(x_128, 2, x_125); +lean_ctor_set(x_128, 3, x_123); +x_129 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_129, 0, x_128); +lean_ctor_set(x_129, 1, x_114); +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; +x_130 = l_Lean_Expr_appFn_x21(x_113); +x_131 = l_Lean_Expr_appFn_x21(x_130); +x_132 = l_Lean_Expr_appArg_x21(x_131); +lean_dec(x_131); +x_133 = l_Lean_Expr_appArg_x21(x_130); +lean_dec(x_130); +x_134 = l_Lean_Expr_appArg_x21(x_113); +lean_dec(x_113); +lean_inc(x_3); +x_135 = l_Lean_Meta_whnf(x_132, x_3, x_114); +if (lean_obj_tag(x_135) == 0) +{ +lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_153; lean_object* x_154; +x_136 = lean_ctor_get(x_135, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_135, 1); +lean_inc(x_137); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + x_138 = x_135; +} else { + lean_dec_ref(x_135); + x_138 = lean_box(0); +} +x_153 = lean_ctor_get(x_137, 0); +lean_inc(x_153); +x_154 = l_Lean_Expr_getAppFn___main(x_136); +if (lean_obj_tag(x_154) == 4) +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; +x_155 = lean_ctor_get(x_154, 0); +lean_inc(x_155); +x_156 = lean_ctor_get(x_154, 1); +lean_inc(x_156); +lean_dec(x_154); +x_157 = lean_environment_find(x_153, x_155); +if (lean_obj_tag(x_157) == 0) +{ +lean_object* x_158; +lean_dec(x_156); +lean_dec(x_134); +lean_dec(x_133); +lean_dec(x_2); +lean_dec(x_1); +x_158 = lean_box(0); +x_139 = x_158; +goto block_152; +} +else +{ +lean_object* x_159; +x_159 = lean_ctor_get(x_157, 0); +lean_inc(x_159); +lean_dec(x_157); +if (lean_obj_tag(x_159) == 5) +{ +lean_object* x_160; lean_object* x_161; +lean_dec(x_138); +x_160 = lean_ctor_get(x_159, 0); +lean_inc(x_160); +lean_dec(x_159); lean_inc(x_1); -x_173 = l_Lean_Meta_getLevel(x_1, x_3, x_149); -if (lean_obj_tag(x_173) == 0) +x_161 = l_Lean_Meta_getLevel(x_1, x_3, x_137); +if (lean_obj_tag(x_161) == 0) { -lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_174 = lean_ctor_get(x_173, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_173, 1); -lean_inc(x_175); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - x_176 = x_173; +lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; +x_162 = lean_ctor_get(x_161, 0); +lean_inc(x_162); +x_163 = lean_ctor_get(x_161, 1); +lean_inc(x_163); +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + x_164 = x_161; } else { - lean_dec_ref(x_173); - x_176 = lean_box(0); + lean_dec_ref(x_161); + x_164 = lean_box(0); } -x_177 = lean_ctor_get(x_172, 0); -lean_inc(x_177); +x_165 = lean_ctor_get(x_160, 0); +lean_inc(x_165); +lean_dec(x_160); +x_166 = lean_ctor_get(x_165, 0); +lean_inc(x_166); +lean_dec(x_165); +x_167 = l_Lean_Meta_mkNoConfusion___closed__1; +x_168 = lean_name_mk_string(x_166, x_167); +x_169 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_169, 0, x_162); +lean_ctor_set(x_169, 1, x_156); +x_170 = l_Lean_mkConst(x_168, x_169); +x_171 = lean_unsigned_to_nat(0u); +x_172 = l_Lean_Expr_getAppNumArgsAux___main(x_136, x_171); +x_173 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_172); +x_174 = lean_mk_array(x_172, x_173); +x_175 = lean_unsigned_to_nat(1u); +x_176 = lean_nat_sub(x_172, x_175); lean_dec(x_172); -x_178 = lean_ctor_get(x_177, 0); -lean_inc(x_178); -lean_dec(x_177); -x_179 = l_Lean_Meta_mkNoConfusion___closed__1; -x_180 = lean_name_mk_string(x_178, x_179); -x_181 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_181, 0, x_174); -lean_ctor_set(x_181, 1, x_168); -x_182 = l_Lean_mkConst(x_180, x_181); -x_183 = l_Lean_Expr_getAppNumArgsAux___main(x_148, x_134); -x_184 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_183); -x_185 = lean_mk_array(x_183, x_184); -x_186 = lean_nat_sub(x_183, x_137); +x_177 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_136, x_174, x_176); +x_178 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; +x_179 = lean_array_push(x_178, x_1); +x_180 = lean_array_push(x_179, x_133); +x_181 = lean_array_push(x_180, x_134); +x_182 = lean_array_push(x_181, x_2); +x_183 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_182, x_182, x_171, x_177); +lean_dec(x_182); +x_184 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_183, x_183, x_171, x_170); lean_dec(x_183); -x_187 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_148, x_185, x_186); -x_188 = l_PersistentHashMap_mkCollisionNode___rarg___closed__1; -x_189 = lean_array_push(x_188, x_1); -x_190 = lean_array_push(x_189, x_142); -x_191 = lean_array_push(x_190, x_146); -x_192 = lean_array_push(x_191, x_2); -x_193 = l_Array_iterateMAux___main___at_Array_append___spec__1___rarg(x_192, x_192, x_134, x_187); -lean_dec(x_192); -x_194 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_193, x_193, x_134, x_182); -lean_dec(x_193); -if (lean_is_scalar(x_176)) { - x_195 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_164)) { + x_185 = lean_alloc_ctor(0, 2, 0); } else { - x_195 = x_176; + x_185 = x_164; } -lean_ctor_set(x_195, 0, x_194); -lean_ctor_set(x_195, 1, x_175); +lean_ctor_set(x_185, 0, x_184); +lean_ctor_set(x_185, 1, x_163); +return x_185; +} +else +{ +lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; +lean_dec(x_160); +lean_dec(x_156); +lean_dec(x_136); +lean_dec(x_134); +lean_dec(x_133); +lean_dec(x_2); +lean_dec(x_1); +x_186 = lean_ctor_get(x_161, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_161, 1); +lean_inc(x_187); +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + x_188 = x_161; +} else { + lean_dec_ref(x_161); + 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_dec(x_159); +lean_dec(x_156); +lean_dec(x_134); +lean_dec(x_133); +lean_dec(x_2); +lean_dec(x_1); +x_190 = lean_box(0); +x_139 = x_190; +goto block_152; +} +} +} +else +{ +lean_object* x_191; +lean_dec(x_154); +lean_dec(x_153); +lean_dec(x_134); +lean_dec(x_133); +lean_dec(x_2); +lean_dec(x_1); +x_191 = lean_box(0); +x_139 = x_191; +goto block_152; +} +block_152: +{ +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_dec(x_139); +x_140 = lean_ctor_get(x_137, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_137, 1); +lean_inc(x_141); +x_142 = lean_ctor_get(x_3, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_3, 0); +lean_inc(x_143); +lean_dec(x_3); +x_144 = lean_ctor_get(x_143, 0); +lean_inc(x_144); +lean_dec(x_143); +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_142); +lean_ctor_set(x_145, 3, x_144); +x_146 = l_Lean_mkOptionalNode___closed__2; +x_147 = lean_array_push(x_146, x_136); +x_148 = l_Lean_Meta_mkNoConfusion___closed__2; +x_149 = l_Lean_Meta_mkNoConfusion___closed__4; +x_150 = lean_alloc_ctor(16, 4, 0); +lean_ctor_set(x_150, 0, x_148); +lean_ctor_set(x_150, 1, x_149); +lean_ctor_set(x_150, 2, x_147); +lean_ctor_set(x_150, 3, x_145); +if (lean_is_scalar(x_138)) { + x_151 = lean_alloc_ctor(1, 2, 0); +} else { + x_151 = x_138; + lean_ctor_set_tag(x_151, 1); +} +lean_ctor_set(x_151, 0, x_150); +lean_ctor_set(x_151, 1, x_137); +return x_151; +} +} +else +{ +lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; +lean_dec(x_134); +lean_dec(x_133); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_192 = lean_ctor_get(x_135, 0); +lean_inc(x_192); +x_193 = lean_ctor_get(x_135, 1); +lean_inc(x_193); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + x_194 = x_135; +} else { + lean_dec_ref(x_135); + x_194 = lean_box(0); +} +if (lean_is_scalar(x_194)) { + x_195 = lean_alloc_ctor(1, 2, 0); +} else { + x_195 = x_194; +} +lean_ctor_set(x_195, 0, x_192); +lean_ctor_set(x_195, 1, x_193); return x_195; } -else -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -lean_dec(x_172); -lean_dec(x_168); -lean_dec(x_148); -lean_dec(x_146); -lean_dec(x_142); -lean_dec(x_2); -lean_dec(x_1); -x_196 = lean_ctor_get(x_173, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_173, 1); -lean_inc(x_197); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - x_198 = x_173; -} else { - lean_dec_ref(x_173); - x_198 = lean_box(0); -} -if (lean_is_scalar(x_198)) { - x_199 = lean_alloc_ctor(1, 2, 0); -} else { - x_199 = x_198; -} -lean_ctor_set(x_199, 0, x_196); -lean_ctor_set(x_199, 1, x_197); -return x_199; -} -} -else -{ -lean_object* x_200; -lean_dec(x_171); -lean_dec(x_168); -lean_dec(x_146); -lean_dec(x_142); -lean_dec(x_2); -lean_dec(x_1); -x_200 = lean_box(0); -x_151 = x_200; -goto block_164; } } } else { -lean_object* x_201; -lean_dec(x_166); -lean_dec(x_165); -lean_dec(x_146); -lean_dec(x_142); -lean_dec(x_2); -lean_dec(x_1); -x_201 = lean_box(0); -x_151 = x_201; -goto block_164; -} -block_164: -{ -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_dec(x_151); -x_152 = lean_ctor_get(x_149, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_149, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_3, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_3, 0); -lean_inc(x_155); -lean_dec(x_3); -x_156 = lean_ctor_get(x_155, 0); -lean_inc(x_156); -lean_dec(x_155); -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_154); -lean_ctor_set(x_157, 3, x_156); -x_158 = l_Lean_mkOptionalNode___closed__2; -x_159 = lean_array_push(x_158, x_148); -x_160 = l_Lean_Meta_mkNoConfusion___closed__2; -x_161 = l_Lean_Meta_mkNoConfusion___closed__4; -x_162 = lean_alloc_ctor(16, 4, 0); -lean_ctor_set(x_162, 0, x_160); -lean_ctor_set(x_162, 1, x_161); -lean_ctor_set(x_162, 2, x_159); -lean_ctor_set(x_162, 3, x_157); -if (lean_is_scalar(x_150)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_150; - lean_ctor_set_tag(x_163, 1); -} -lean_ctor_set(x_163, 0, x_162); -lean_ctor_set(x_163, 1, x_149); -return x_163; -} -} -else -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; -lean_dec(x_146); -lean_dec(x_142); +uint8_t x_196; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_202 = lean_ctor_get(x_147, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_147, 1); -lean_inc(x_203); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_204 = x_147; -} else { - lean_dec_ref(x_147); - x_204 = lean_box(0); -} -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(1, 2, 0); -} else { - x_205 = x_204; -} -lean_ctor_set(x_205, 0, x_202); -lean_ctor_set(x_205, 1, x_203); -return x_205; -} -} -} -} -else -{ -uint8_t x_206; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_206 = !lean_is_exclusive(x_8); -if (x_206 == 0) +x_196 = !lean_is_exclusive(x_8); +if (x_196 == 0) { return x_8; } else { -lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_207 = lean_ctor_get(x_8, 0); -x_208 = lean_ctor_get(x_8, 1); -lean_inc(x_208); -lean_inc(x_207); +lean_object* x_197; lean_object* x_198; lean_object* x_199; +x_197 = lean_ctor_get(x_8, 0); +x_198 = lean_ctor_get(x_8, 1); +lean_inc(x_198); +lean_inc(x_197); lean_dec(x_8); -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; +x_199 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_199, 0, x_197); +lean_ctor_set(x_199, 1, x_198); +return x_199; } } } else { -uint8_t x_210; +uint8_t x_200; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_210 = !lean_is_exclusive(x_5); -if (x_210 == 0) +x_200 = !lean_is_exclusive(x_5); +if (x_200 == 0) { return x_5; } else { -lean_object* x_211; lean_object* x_212; lean_object* x_213; -x_211 = lean_ctor_get(x_5, 0); -x_212 = lean_ctor_get(x_5, 1); -lean_inc(x_212); -lean_inc(x_211); +lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_201 = lean_ctor_get(x_5, 0); +x_202 = lean_ctor_get(x_5, 1); +lean_inc(x_202); +lean_inc(x_201); lean_dec(x_5); -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; +x_203 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_203, 0, x_201); +lean_ctor_set(x_203, 1, x_202); +return x_203; } } } } lean_object* initialize_Init_Default(lean_object*); +lean_object* initialize_Init_Lean_Util_Recognizers(lean_object*); lean_object* initialize_Init_Lean_Meta_SynthInstance(lean_object*); static bool _G_initialized = false; lean_object* initialize_Init_Lean_Meta_AppBuilder(lean_object* w) { @@ -10022,21 +9602,14 @@ _G_initialized = true; res = initialize_Init_Default(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Init_Lean_Util_Recognizers(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Init_Lean_Meta_SynthInstance(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l_Lean_Expr_eq_x3f___closed__1 = _init_l_Lean_Expr_eq_x3f___closed__1(); -lean_mark_persistent(l_Lean_Expr_eq_x3f___closed__1); -l_Lean_Expr_eq_x3f___closed__2 = _init_l_Lean_Expr_eq_x3f___closed__2(); -lean_mark_persistent(l_Lean_Expr_eq_x3f___closed__2); -l_Lean_Expr_iff_x3f___closed__1 = _init_l_Lean_Expr_iff_x3f___closed__1(); -lean_mark_persistent(l_Lean_Expr_iff_x3f___closed__1); -l_Lean_Expr_iff_x3f___closed__2 = _init_l_Lean_Expr_iff_x3f___closed__2(); -lean_mark_persistent(l_Lean_Expr_iff_x3f___closed__2); -l_Lean_Expr_heq_x3f___closed__1 = _init_l_Lean_Expr_heq_x3f___closed__1(); -lean_mark_persistent(l_Lean_Expr_heq_x3f___closed__1); -l_Lean_Expr_heq_x3f___closed__2 = _init_l_Lean_Expr_heq_x3f___closed__2(); -lean_mark_persistent(l_Lean_Expr_heq_x3f___closed__2); +l_Lean_Meta_mkExpectedTypeHint___closed__1 = _init_l_Lean_Meta_mkExpectedTypeHint___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkExpectedTypeHint___closed__1); l_Lean_Meta_mkEqRefl___closed__1 = _init_l_Lean_Meta_mkEqRefl___closed__1(); lean_mark_persistent(l_Lean_Meta_mkEqRefl___closed__1); l_Lean_Meta_mkEqRefl___closed__2 = _init_l_Lean_Meta_mkEqRefl___closed__2(); diff --git a/stage0/stdlib/Init/Lean/Meta/Basic.c b/stage0/stdlib/Init/Lean/Meta/Basic.c index 53c4b11a09..54426bdd5d 100644 --- a/stage0/stdlib/Init/Lean/Meta/Basic.c +++ b/stage0/stdlib/Init/Lean/Meta/Basic.c @@ -169,6 +169,7 @@ lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAux___at lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2(lean_object*); lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_EStateM_bind___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4; 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; @@ -448,6 +449,7 @@ lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4(lea uint8_t lean_is_class(lean_object*, lean_object*); lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVar___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3; lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_NameGenerator_Inhabited___closed__3; lean_object* l___private_Init_Lean_Meta_Basic_8__lambdaMetaTelescopeAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -6829,82 +6831,89 @@ return x_9; } else { -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_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_inc(x_19); lean_inc(x_18); lean_dec(x_11); -x_20 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -lean_ctor_set(x_20, 2, x_7); -lean_ctor_set(x_10, 2, x_20); +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; } } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_10, 0); -x_22 = lean_ctor_get(x_10, 1); -x_23 = lean_ctor_get(x_10, 3); -x_24 = lean_ctor_get(x_10, 4); -x_25 = 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; +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_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); -lean_inc(x_21); lean_dec(x_10); -x_26 = lean_ctor_get(x_11, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_11, 1); +x_27 = lean_ctor_get(x_11, 0); lean_inc(x_27); +x_28 = lean_ctor_get(x_11, 1); +lean_inc(x_28); +x_29 = lean_ctor_get(x_11, 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); - x_28 = x_11; + lean_ctor_release(x_11, 3); + x_30 = x_11; } else { lean_dec_ref(x_11); - x_28 = lean_box(0); + x_30 = lean_box(0); } -if (lean_is_scalar(x_28)) { - x_29 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_30)) { + x_31 = lean_alloc_ctor(0, 4, 0); } else { - x_29 = x_28; + x_31 = x_30; } -lean_ctor_set(x_29, 0, x_26); -lean_ctor_set(x_29, 1, x_27); -lean_ctor_set(x_29, 2, x_7); -x_30 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_30, 0, x_21); -lean_ctor_set(x_30, 1, x_22); -lean_ctor_set(x_30, 2, x_29); -lean_ctor_set(x_30, 3, x_23); -lean_ctor_set(x_30, 4, x_24); -lean_ctor_set(x_30, 5, x_25); -lean_ctor_set(x_9, 1, x_30); +lean_ctor_set(x_31, 0, x_27); +lean_ctor_set(x_31, 1, x_28); +lean_ctor_set(x_31, 2, x_7); +lean_ctor_set(x_31, 3, x_29); +x_32 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_32, 0, x_22); +lean_ctor_set(x_32, 1, x_23); +lean_ctor_set(x_32, 2, x_31); +lean_ctor_set(x_32, 3, x_24); +lean_ctor_set(x_32, 4, x_25); +lean_ctor_set(x_32, 5, x_26); +lean_ctor_set(x_9, 1, x_32); return x_9; } } else { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_31 = lean_ctor_get(x_9, 0); -lean_inc(x_31); -lean_dec(x_9); -x_32 = lean_ctor_get(x_10, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_10, 1); +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); -x_34 = lean_ctor_get(x_10, 3); +lean_dec(x_9); +x_34 = lean_ctor_get(x_10, 0); lean_inc(x_34); -x_35 = lean_ctor_get(x_10, 4); +x_35 = lean_ctor_get(x_10, 1); lean_inc(x_35); -x_36 = lean_ctor_get(x_10, 5); +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); @@ -6912,592 +6921,630 @@ if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 3); lean_ctor_release(x_10, 4); lean_ctor_release(x_10, 5); - x_37 = x_10; + x_39 = x_10; } else { lean_dec_ref(x_10); - x_37 = lean_box(0); + x_39 = lean_box(0); } -x_38 = lean_ctor_get(x_11, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_11, 1); -lean_inc(x_39); +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); +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); - x_40 = x_11; + lean_ctor_release(x_11, 3); + x_43 = x_11; } else { lean_dec_ref(x_11); - x_40 = lean_box(0); + x_43 = lean_box(0); } -if (lean_is_scalar(x_40)) { - x_41 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_43)) { + x_44 = lean_alloc_ctor(0, 4, 0); } else { - x_41 = x_40; + x_44 = x_43; } -lean_ctor_set(x_41, 0, x_38); -lean_ctor_set(x_41, 1, x_39); -lean_ctor_set(x_41, 2, x_7); -if (lean_is_scalar(x_37)) { - x_42 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_44, 0, x_40); +lean_ctor_set(x_44, 1, x_41); +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_42 = x_37; + x_45 = x_39; } -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); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_31); -lean_ctor_set(x_43, 1, x_42); -return x_43; +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; } } else { -lean_object* x_44; lean_object* x_45; uint8_t x_46; -x_44 = lean_ctor_get(x_9, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_44, 2); -lean_inc(x_45); -x_46 = !lean_is_exclusive(x_9); -if (x_46 == 0) -{ -lean_object* x_47; uint8_t x_48; +lean_object* x_47; lean_object* x_48; uint8_t x_49; x_47 = lean_ctor_get(x_9, 1); -lean_dec(x_47); -x_48 = !lean_is_exclusive(x_44); -if (x_48 == 0) +lean_inc(x_47); +x_48 = lean_ctor_get(x_47, 2); +lean_inc(x_48); +x_49 = !lean_is_exclusive(x_9); +if (x_49 == 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_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_51; -x_51 = lean_ctor_get(x_45, 2); -lean_dec(x_51); -lean_ctor_set(x_45, 2, x_7); +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_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_45, 0); -x_53 = lean_ctor_get(x_45, 1); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_45); -x_54 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -lean_ctor_set(x_54, 2, x_7); -lean_ctor_set(x_44, 2, x_54); -return x_9; -} -} -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; -x_55 = lean_ctor_get(x_44, 0); -x_56 = lean_ctor_get(x_44, 1); -x_57 = lean_ctor_get(x_44, 3); -x_58 = lean_ctor_get(x_44, 4); -x_59 = lean_ctor_get(x_44, 5); -lean_inc(x_59); -lean_inc(x_58); +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_44); -x_60 = lean_ctor_get(x_45, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_45, 1); -lean_inc(x_61); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - x_62 = x_45; -} else { - lean_dec_ref(x_45); - x_62 = lean_box(0); -} -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 3, 0); -} else { - x_63 = x_62; -} -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_61); -lean_ctor_set(x_63, 2, x_7); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_55); -lean_ctor_set(x_64, 1, x_56); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_57); -lean_ctor_set(x_64, 4, x_58); -lean_ctor_set(x_64, 5, x_59); -lean_ctor_set(x_9, 1, x_64); +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_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_9, 0); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_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); -lean_dec(x_9); -x_66 = lean_ctor_get(x_44, 0); +x_66 = lean_ctor_get(x_48, 3); lean_inc(x_66); -x_67 = lean_ctor_get(x_44, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_44, 3); -lean_inc(x_68); -x_69 = lean_ctor_get(x_44, 4); -lean_inc(x_69); -x_70 = lean_ctor_get(x_44, 5); +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); -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_71 = x_44; -} else { - lean_dec_ref(x_44); - x_71 = lean_box(0); -} -x_72 = lean_ctor_get(x_45, 0); +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_45, 1); +x_73 = lean_ctor_get(x_47, 3); 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); - x_74 = x_45; +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; } else { - lean_dec_ref(x_45); - x_74 = lean_box(0); + lean_dec_ref(x_47); + x_76 = lean_box(0); } -if (lean_is_scalar(x_74)) { - x_75 = lean_alloc_ctor(0, 3, 0); -} else { - x_75 = x_74; -} -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_7); -if (lean_is_scalar(x_71)) { - x_76 = lean_alloc_ctor(0, 6, 0); -} else { - x_76 = x_71; -} -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_67); -lean_ctor_set(x_76, 2, x_75); -lean_ctor_set(x_76, 3, x_68); -lean_ctor_set(x_76, 4, x_69); -lean_ctor_set(x_76, 5, x_70); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_65); -lean_ctor_set(x_77, 1, x_76); -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; -x_78 = lean_ctor_get(x_5, 0); -x_79 = lean_ctor_get(x_5, 1); -x_80 = lean_ctor_get(x_5, 2); -lean_inc(x_80); -lean_inc(x_79); +x_77 = lean_ctor_get(x_48, 0); +lean_inc(x_77); +x_78 = lean_ctor_get(x_48, 1); lean_inc(x_78); -lean_dec(x_5); -x_81 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_82 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_82, 0, x_78); -lean_ctor_set(x_82, 1, x_79); +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; +} else { + lean_dec_ref(x_48); + 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_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_3, 2, x_82); -x_83 = lean_apply_2(x_1, x_2, x_3); -if (lean_obj_tag(x_83) == 0) +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; +} +} +} +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; -x_84 = lean_ctor_get(x_83, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_84, 2); -lean_inc(x_85); -x_86 = lean_ctor_get(x_83, 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; +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); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_87 = x_83; -} else { - lean_dec_ref(x_83); - x_87 = lean_box(0); -} -x_88 = lean_ctor_get(x_84, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_84, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_84, 3); -lean_inc(x_90); -x_91 = lean_ctor_get(x_84, 4); +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_inc(x_91); -x_92 = lean_ctor_get(x_84, 5); +x_92 = lean_ctor_get(x_91, 2); lean_inc(x_92); -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_93 = x_84; +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_84); - x_93 = lean_box(0); + lean_dec_ref(x_90); + x_94 = lean_box(0); } -x_94 = lean_ctor_get(x_85, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_85, 1); +x_95 = lean_ctor_get(x_91, 0); lean_inc(x_95); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - x_96 = x_85; +x_96 = lean_ctor_get(x_91, 1); +lean_inc(x_96); +x_97 = lean_ctor_get(x_91, 3); +lean_inc(x_97); +x_98 = lean_ctor_get(x_91, 4); +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; } else { - lean_dec_ref(x_85); - x_96 = lean_box(0); + lean_dec_ref(x_91); + x_100 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 3, 0); -} else { - x_97 = x_96; -} -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_80); -if (lean_is_scalar(x_93)) { - x_98 = lean_alloc_ctor(0, 6, 0); -} else { - x_98 = x_93; -} -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); -if (lean_is_scalar(x_87)) { - x_99 = lean_alloc_ctor(0, 2, 0); -} else { - x_99 = x_87; -} -lean_ctor_set(x_99, 0, x_86); -lean_ctor_set(x_99, 1, x_98); -return x_99; -} -else -{ -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_100 = lean_ctor_get(x_83, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_100, 2); +x_101 = lean_ctor_get(x_92, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_83, 0); +x_102 = lean_ctor_get(x_92, 1); lean_inc(x_102); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_103 = x_83; +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; } else { - lean_dec_ref(x_83); - x_103 = lean_box(0); + lean_dec_ref(x_92); + x_104 = lean_box(0); } -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_100, 3); -lean_inc(x_106); -x_107 = lean_ctor_get(x_100, 4); -lean_inc(x_107); -x_108 = lean_ctor_get(x_100, 5); +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_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); -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); - lean_ctor_release(x_100, 5); - x_109 = x_100; -} else { - lean_dec_ref(x_100); - x_109 = lean_box(0); -} -x_110 = lean_ctor_get(x_101, 0); +x_109 = lean_ctor_get(x_108, 2); +lean_inc(x_109); +x_110 = lean_ctor_get(x_90, 0); lean_inc(x_110); -x_111 = lean_ctor_get(x_101, 1); -lean_inc(x_111); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - lean_ctor_release(x_101, 2); - x_112 = x_101; +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_101); - x_112 = lean_box(0); + lean_dec_ref(x_90); + x_111 = lean_box(0); } -if (lean_is_scalar(x_112)) { - x_113 = lean_alloc_ctor(0, 3, 0); -} else { - x_113 = x_112; -} -lean_ctor_set(x_113, 0, x_110); -lean_ctor_set(x_113, 1, x_111); -lean_ctor_set(x_113, 2, x_80); -if (lean_is_scalar(x_109)) { - x_114 = lean_alloc_ctor(0, 6, 0); -} else { - x_114 = x_109; -} -lean_ctor_set(x_114, 0, x_104); -lean_ctor_set(x_114, 1, x_105); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_106); -lean_ctor_set(x_114, 4, x_107); -lean_ctor_set(x_114, 5, x_108); -if (lean_is_scalar(x_103)) { - x_115 = lean_alloc_ctor(1, 2, 0); -} else { - x_115 = x_103; -} -lean_ctor_set(x_115, 0, x_102); -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; -x_116 = lean_ctor_get(x_3, 2); -x_117 = lean_ctor_get(x_3, 0); -x_118 = lean_ctor_get(x_3, 1); -x_119 = lean_ctor_get(x_3, 3); -x_120 = lean_ctor_get(x_3, 4); -x_121 = lean_ctor_get(x_3, 5); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); +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_inc(x_118); -lean_inc(x_117); -lean_dec(x_3); -x_122 = lean_ctor_get(x_116, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_116, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 2); -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); - x_125 = x_116; +x_119 = lean_ctor_get(x_109, 1); +lean_inc(x_119); +x_120 = lean_ctor_get(x_109, 3); +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; } else { - lean_dec_ref(x_116); - x_125 = lean_box(0); + lean_dec_ref(x_109); + x_121 = lean_box(0); } -x_126 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_125)) { - x_127 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_121)) { + x_122 = lean_alloc_ctor(0, 4, 0); } else { - x_127 = x_125; + x_122 = x_121; } -lean_ctor_set(x_127, 0, x_122); -lean_ctor_set(x_127, 1, x_123); -lean_ctor_set(x_127, 2, x_126); -x_128 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_128, 0, x_117); -lean_ctor_set(x_128, 1, x_118); -lean_ctor_set(x_128, 2, x_127); -lean_ctor_set(x_128, 3, x_119); -lean_ctor_set(x_128, 4, x_120); -lean_ctor_set(x_128, 5, x_121); -x_129 = lean_apply_2(x_1, 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; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; -x_130 = lean_ctor_get(x_129, 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_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 { - lean_dec_ref(x_129); - x_133 = lean_box(0); + x_123 = x_117; } -x_134 = lean_ctor_get(x_130, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_130, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_130, 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; +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 { - lean_dec_ref(x_130); - x_139 = lean_box(0); + x_124 = x_111; } -x_140 = lean_ctor_get(x_131, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_131, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - x_142 = x_131; -} else { - lean_dec_ref(x_131); - x_142 = lean_box(0); +lean_ctor_set(x_124, 0, x_110); +lean_ctor_set(x_124, 1, x_123); +return x_124; } -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(0, 3, 0); -} else { - x_143 = x_142; } -lean_ctor_set(x_143, 0, x_140); -lean_ctor_set(x_143, 1, x_141); -lean_ctor_set(x_143, 2, x_124); -if (lean_is_scalar(x_139)) { - x_144 = lean_alloc_ctor(0, 6, 0); -} else { - x_144 = x_139; -} -lean_ctor_set(x_144, 0, x_134); -lean_ctor_set(x_144, 1, x_135); -lean_ctor_set(x_144, 2, x_143); -lean_ctor_set(x_144, 3, x_136); -lean_ctor_set(x_144, 4, x_137); -lean_ctor_set(x_144, 5, x_138); -if (lean_is_scalar(x_133)) { - x_145 = lean_alloc_ctor(0, 2, 0); -} else { - x_145 = x_133; -} -lean_ctor_set(x_145, 0, x_132); -lean_ctor_set(x_145, 1, x_144); -return x_145; } else { -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; -x_146 = lean_ctor_get(x_129, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_146, 2); -lean_inc(x_147); -x_148 = lean_ctor_get(x_129, 0); -lean_inc(x_148); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - x_149 = 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_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_inc(x_126); +lean_dec(x_3); +x_131 = lean_ctor_get(x_125, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_125, 1); +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; } else { - lean_dec_ref(x_129); + lean_dec_ref(x_125); + x_135 = 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); +} else { + x_137 = x_135; +} +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) +{ +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_inc(x_141); +x_142 = lean_ctor_get(x_139, 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_inc(x_144); +x_145 = lean_ctor_get(x_140, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_140, 3); +lean_inc(x_146); +x_147 = lean_ctor_get(x_140, 4); +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; +} else { + lean_dec_ref(x_140); x_149 = lean_box(0); } -x_150 = lean_ctor_get(x_146, 0); +x_150 = lean_ctor_get(x_141, 0); lean_inc(x_150); -x_151 = lean_ctor_get(x_146, 1); +x_151 = lean_ctor_get(x_141, 1); lean_inc(x_151); -x_152 = lean_ctor_get(x_146, 3); +x_152 = lean_ctor_get(x_141, 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_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; } else { - lean_dec_ref(x_146); - x_155 = lean_box(0); + lean_dec_ref(x_141); + x_153 = 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); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - lean_ctor_release(x_147, 2); - x_158 = x_147; +if (lean_is_scalar(x_153)) { + x_154 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_147); - x_158 = lean_box(0); + x_154 = x_153; } -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(0, 3, 0); -} else { - x_159 = x_158; -} -lean_ctor_set(x_159, 0, x_156); -lean_ctor_set(x_159, 1, x_157); -lean_ctor_set(x_159, 2, x_124); -if (lean_is_scalar(x_155)) { - x_160 = lean_alloc_ctor(0, 6, 0); -} else { - x_160 = x_155; -} -lean_ctor_set(x_160, 0, x_150); -lean_ctor_set(x_160, 1, x_151); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_152); -lean_ctor_set(x_160, 4, x_153); -lean_ctor_set(x_160, 5, x_154); +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_161 = lean_alloc_ctor(1, 2, 0); + x_155 = lean_alloc_ctor(0, 6, 0); } else { - x_161 = x_149; + x_155 = x_149; } -lean_ctor_set(x_161, 0, x_148); -lean_ctor_set(x_161, 1, x_160); -return x_161; +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_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; } } } @@ -7567,82 +7614,89 @@ return x_15; } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; +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_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_dec(x_17); -x_26 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -lean_ctor_set(x_26, 2, x_9); -lean_ctor_set(x_16, 2, x_26); +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_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_27 = lean_ctor_get(x_16, 0); -x_28 = lean_ctor_get(x_16, 1); -x_29 = lean_ctor_get(x_16, 3); -x_30 = lean_ctor_get(x_16, 4); -x_31 = lean_ctor_get(x_16, 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; 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_inc(x_29); lean_inc(x_28); -lean_inc(x_27); lean_dec(x_16); -x_32 = lean_ctor_get(x_17, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_17, 1); +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); - x_34 = x_17; + lean_ctor_release(x_17, 3); + x_36 = x_17; } else { lean_dec_ref(x_17); - x_34 = lean_box(0); + x_36 = lean_box(0); } -if (lean_is_scalar(x_34)) { - x_35 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_36)) { + x_37 = lean_alloc_ctor(0, 4, 0); } else { - x_35 = x_34; + x_37 = x_36; } -lean_ctor_set(x_35, 0, x_32); -lean_ctor_set(x_35, 1, x_33); -lean_ctor_set(x_35, 2, x_9); -x_36 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_36, 0, x_27); -lean_ctor_set(x_36, 1, x_28); -lean_ctor_set(x_36, 2, x_35); -lean_ctor_set(x_36, 3, x_29); -lean_ctor_set(x_36, 4, x_30); -lean_ctor_set(x_36, 5, x_31); -lean_ctor_set(x_15, 1, 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_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; } } 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; -x_37 = lean_ctor_get(x_15, 0); -lean_inc(x_37); -lean_dec(x_15); -x_38 = lean_ctor_get(x_16, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_16, 1); +lean_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); -x_40 = lean_ctor_get(x_16, 3); +lean_dec(x_15); +x_40 = lean_ctor_get(x_16, 0); lean_inc(x_40); -x_41 = lean_ctor_get(x_16, 4); +x_41 = lean_ctor_get(x_16, 1); lean_inc(x_41); -x_42 = lean_ctor_get(x_16, 5); +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_inc(x_44); if (lean_is_exclusive(x_16)) { lean_ctor_release(x_16, 0); lean_ctor_release(x_16, 1); @@ -7650,849 +7704,895 @@ if (lean_is_exclusive(x_16)) { lean_ctor_release(x_16, 3); lean_ctor_release(x_16, 4); lean_ctor_release(x_16, 5); - x_43 = x_16; + x_45 = x_16; } else { lean_dec_ref(x_16); - x_43 = lean_box(0); + x_45 = lean_box(0); } -x_44 = lean_ctor_get(x_17, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_17, 1); -lean_inc(x_45); +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); +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); - x_46 = x_17; + lean_ctor_release(x_17, 3); + x_49 = x_17; } else { lean_dec_ref(x_17); - x_46 = lean_box(0); + x_49 = lean_box(0); } -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_49)) { + x_50 = lean_alloc_ctor(0, 4, 0); } else { - x_47 = x_46; + x_50 = x_49; } -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_45); -lean_ctor_set(x_47, 2, x_9); -if (lean_is_scalar(x_43)) { - x_48 = lean_alloc_ctor(0, 6, 0); +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_48 = x_43; + x_51 = x_45; } -lean_ctor_set(x_48, 0, x_38); -lean_ctor_set(x_48, 1, x_39); -lean_ctor_set(x_48, 2, x_47); -lean_ctor_set(x_48, 3, x_40); -lean_ctor_set(x_48, 4, x_41); -lean_ctor_set(x_48, 5, x_42); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_37); -lean_ctor_set(x_49, 1, x_48); -return x_49; +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_50; lean_object* x_51; uint8_t x_52; -x_50 = lean_ctor_get(x_15, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_50, 2); -lean_inc(x_51); -x_52 = !lean_is_exclusive(x_15); -if (x_52 == 0) -{ -lean_object* x_53; uint8_t x_54; +lean_object* x_53; lean_object* x_54; uint8_t x_55; x_53 = lean_ctor_get(x_15, 1); -lean_dec(x_53); -x_54 = !lean_is_exclusive(x_50); -if (x_54 == 0) +lean_inc(x_53); +x_54 = lean_ctor_get(x_53, 2); +lean_inc(x_54); +x_55 = !lean_is_exclusive(x_15); +if (x_55 == 0) { -lean_object* x_55; uint8_t x_56; -x_55 = lean_ctor_get(x_50, 2); -lean_dec(x_55); -x_56 = !lean_is_exclusive(x_51); -if (x_56 == 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_57; -x_57 = lean_ctor_get(x_51, 2); -lean_dec(x_57); -lean_ctor_set(x_51, 2, x_9); +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_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_51, 0); -x_59 = lean_ctor_get(x_51, 1); -lean_inc(x_59); -lean_inc(x_58); -lean_dec(x_51); -x_60 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_60, 0, x_58); -lean_ctor_set(x_60, 1, x_59); -lean_ctor_set(x_60, 2, x_9); -lean_ctor_set(x_50, 2, x_60); -return x_15; -} -} -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; -x_61 = lean_ctor_get(x_50, 0); -x_62 = lean_ctor_get(x_50, 1); -x_63 = lean_ctor_get(x_50, 3); -x_64 = lean_ctor_get(x_50, 4); -x_65 = lean_ctor_get(x_50, 5); -lean_inc(x_65); -lean_inc(x_64); +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_50); -x_66 = lean_ctor_get(x_51, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_51, 1); -lean_inc(x_67); -if (lean_is_exclusive(x_51)) { - lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - lean_ctor_release(x_51, 2); - x_68 = x_51; -} else { - lean_dec_ref(x_51); - x_68 = lean_box(0); -} -if (lean_is_scalar(x_68)) { - x_69 = lean_alloc_ctor(0, 3, 0); -} else { - x_69 = x_68; -} -lean_ctor_set(x_69, 0, x_66); -lean_ctor_set(x_69, 1, x_67); -lean_ctor_set(x_69, 2, x_9); -x_70 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_70, 0, x_61); -lean_ctor_set(x_70, 1, x_62); -lean_ctor_set(x_70, 2, x_69); -lean_ctor_set(x_70, 3, x_63); -lean_ctor_set(x_70, 4, x_64); -lean_ctor_set(x_70, 5, x_65); -lean_ctor_set(x_15, 1, x_70); +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_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_71 = lean_ctor_get(x_15, 0); +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; 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); -lean_dec(x_15); -x_72 = lean_ctor_get(x_50, 0); +x_72 = lean_ctor_get(x_54, 3); lean_inc(x_72); -x_73 = lean_ctor_get(x_50, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_50, 3); -lean_inc(x_74); -x_75 = lean_ctor_get(x_50, 4); -lean_inc(x_75); -x_76 = lean_ctor_get(x_50, 5); +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; +} else { + lean_dec_ref(x_54); + x_73 = lean_box(0); +} +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(0, 4, 0); +} else { + x_74 = x_73; +} +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; +} +} +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); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - lean_ctor_release(x_50, 4); - lean_ctor_release(x_50, 5); - x_77 = x_50; -} else { - lean_dec_ref(x_50); - x_77 = lean_box(0); -} -x_78 = lean_ctor_get(x_51, 0); +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_51, 1); +x_79 = lean_ctor_get(x_53, 3); lean_inc(x_79); -if (lean_is_exclusive(x_51)) { - lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - lean_ctor_release(x_51, 2); - x_80 = x_51; +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_51); - x_80 = lean_box(0); + lean_dec_ref(x_53); + x_82 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 3, 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 { - x_81 = x_80; + lean_dec_ref(x_54); + x_86 = lean_box(0); } -lean_ctor_set(x_81, 0, x_78); -lean_ctor_set(x_81, 1, x_79); -lean_ctor_set(x_81, 2, x_9); -if (lean_is_scalar(x_77)) { - x_82 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 4, 0); } else { - x_82 = x_77; + x_87 = x_86; } -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); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_71); -lean_ctor_set(x_83, 1, x_82); -return x_83; +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_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_84 = lean_ctor_get(x_4, 0); -x_85 = lean_ctor_get(x_4, 1); -x_86 = lean_ctor_get(x_4, 2); -x_87 = lean_ctor_get(x_4, 3); -x_88 = lean_ctor_get(x_4, 4); -lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_4); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_1); -lean_ctor_set(x_89, 1, x_2); -x_90 = lean_array_push(x_86, x_89); -x_91 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_91, 0, x_84); -lean_ctor_set(x_91, 1, x_85); -lean_ctor_set(x_91, 2, x_90); -lean_ctor_set(x_91, 3, x_87); -lean_ctor_set(x_91, 4, x_88); -x_92 = lean_apply_2(x_3, x_91, x_5); -if (lean_obj_tag(x_92) == 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; lean_object* x_108; -x_93 = lean_ctor_get(x_92, 1); -lean_inc(x_93); -x_94 = lean_ctor_get(x_93, 2); +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); -x_95 = lean_ctor_get(x_92, 0); -lean_inc(x_95); -if (lean_is_exclusive(x_92)) { - lean_ctor_release(x_92, 0); - lean_ctor_release(x_92, 1); - x_96 = x_92; -} else { - lean_dec_ref(x_92); - x_96 = lean_box(0); -} -x_97 = lean_ctor_get(x_93, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_93, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_93, 3); +lean_inc(x_93); +lean_inc(x_92); +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_93, 4); +x_100 = lean_ctor_get(x_99, 2); lean_inc(x_100); -x_101 = lean_ctor_get(x_93, 5); +x_101 = lean_ctor_get(x_98, 0); lean_inc(x_101); -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_102 = x_93; +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_93); + lean_dec_ref(x_98); x_102 = lean_box(0); } -x_103 = lean_ctor_get(x_94, 0); +x_103 = lean_ctor_get(x_99, 0); lean_inc(x_103); -x_104 = lean_ctor_get(x_94, 1); +x_104 = lean_ctor_get(x_99, 1); 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); - x_105 = x_94; +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_94); - x_105 = lean_box(0); + lean_dec_ref(x_99); + x_108 = lean_box(0); } -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 3, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_103); -lean_ctor_set(x_106, 1, x_104); -lean_ctor_set(x_106, 2, x_9); -if (lean_is_scalar(x_102)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_102; -} -lean_ctor_set(x_107, 0, x_97); -lean_ctor_set(x_107, 1, x_98); -lean_ctor_set(x_107, 2, x_106); -lean_ctor_set(x_107, 3, x_99); -lean_ctor_set(x_107, 4, x_100); -lean_ctor_set(x_107, 5, x_101); -if (lean_is_scalar(x_96)) { - x_108 = lean_alloc_ctor(0, 2, 0); -} else { - x_108 = x_96; -} -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; lean_object* x_124; -x_109 = lean_ctor_get(x_92, 1); +x_109 = lean_ctor_get(x_100, 0); lean_inc(x_109); -x_110 = lean_ctor_get(x_109, 2); +x_110 = lean_ctor_get(x_100, 1); lean_inc(x_110); -x_111 = lean_ctor_get(x_92, 0); +x_111 = lean_ctor_get(x_100, 3); lean_inc(x_111); -if (lean_is_exclusive(x_92)) { - lean_ctor_release(x_92, 0); - lean_ctor_release(x_92, 1); - x_112 = x_92; +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_92); + lean_dec_ref(x_100); x_112 = lean_box(0); } -x_113 = lean_ctor_get(x_109, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_109, 1); -lean_inc(x_114); -x_115 = lean_ctor_get(x_109, 3); -lean_inc(x_115); -x_116 = lean_ctor_get(x_109, 4); -lean_inc(x_116); -x_117 = lean_ctor_get(x_109, 5); -lean_inc(x_117); -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_118 = x_109; -} else { - lean_dec_ref(x_109); - x_118 = lean_box(0); -} -x_119 = lean_ctor_get(x_110, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_110, 1); -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); - x_121 = x_110; -} else { - lean_dec_ref(x_110); - x_121 = lean_box(0); -} -if (lean_is_scalar(x_121)) { - x_122 = lean_alloc_ctor(0, 3, 0); -} else { - x_122 = x_121; -} -lean_ctor_set(x_122, 0, x_119); -lean_ctor_set(x_122, 1, x_120); -lean_ctor_set(x_122, 2, x_9); -if (lean_is_scalar(x_118)) { - x_123 = lean_alloc_ctor(0, 6, 0); -} else { - x_123 = x_118; -} -lean_ctor_set(x_123, 0, x_113); -lean_ctor_set(x_123, 1, x_114); -lean_ctor_set(x_123, 2, x_122); -lean_ctor_set(x_123, 3, x_115); -lean_ctor_set(x_123, 4, x_116); -lean_ctor_set(x_123, 5, x_117); if (lean_is_scalar(x_112)) { - x_124 = lean_alloc_ctor(1, 2, 0); + x_113 = lean_alloc_ctor(0, 4, 0); } else { - x_124 = x_112; + x_113 = x_112; } -lean_ctor_set(x_124, 0, x_111); -lean_ctor_set(x_124, 1, x_123); -return x_124; +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_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_7, 0); -x_126 = lean_ctor_get(x_7, 1); -x_127 = lean_ctor_get(x_7, 2); -lean_inc(x_127); -lean_inc(x_126); -lean_inc(x_125); -lean_dec(x_7); -x_128 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_129 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_129, 0, x_125); -lean_ctor_set(x_129, 1, x_126); -lean_ctor_set(x_129, 2, x_128); -lean_ctor_set(x_5, 2, x_129); -x_130 = lean_ctor_get(x_4, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_4, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_4, 2); -lean_inc(x_132); -x_133 = lean_ctor_get(x_4, 3); -lean_inc(x_133); -x_134 = lean_ctor_get(x_4, 4); +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_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); +lean_inc(x_140); +x_141 = lean_ctor_get(x_4, 2); +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_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_135 = x_4; + x_144 = x_4; } else { lean_dec_ref(x_4); - x_135 = lean_box(0); + x_144 = lean_box(0); } -x_136 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_136, 0, x_1); -lean_ctor_set(x_136, 1, x_2); -x_137 = lean_array_push(x_132, x_136); -if (lean_is_scalar(x_135)) { - x_138 = lean_alloc_ctor(0, 5, 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_138 = x_135; + x_147 = x_144; } -lean_ctor_set(x_138, 0, x_130); -lean_ctor_set(x_138, 1, x_131); -lean_ctor_set(x_138, 2, x_137); -lean_ctor_set(x_138, 3, x_133); -lean_ctor_set(x_138, 4, x_134); -x_139 = lean_apply_2(x_3, x_138, x_5); -if (lean_obj_tag(x_139) == 0) +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_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_139, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_140, 2); -lean_inc(x_141); -x_142 = lean_ctor_get(x_139, 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_inc(x_144); -x_145 = lean_ctor_get(x_140, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_140, 3); -lean_inc(x_146); -x_147 = lean_ctor_get(x_140, 4); -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; -} else { - lean_dec_ref(x_140); - x_149 = lean_box(0); -} -x_150 = lean_ctor_get(x_141, 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_141, 1); +x_151 = lean_ctor_get(x_148, 0); lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - x_152 = x_141; +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_141); + lean_dec_ref(x_148); x_152 = lean_box(0); } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 3, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_150); -lean_ctor_set(x_153, 1, x_151); -lean_ctor_set(x_153, 2, x_127); -if (lean_is_scalar(x_149)) { - x_154 = lean_alloc_ctor(0, 6, 0); -} else { - x_154 = x_149; -} -lean_ctor_set(x_154, 0, x_144); -lean_ctor_set(x_154, 1, x_145); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_146); -lean_ctor_set(x_154, 4, x_147); -lean_ctor_set(x_154, 5, x_148); -if (lean_is_scalar(x_143)) { - x_155 = lean_alloc_ctor(0, 2, 0); -} else { - x_155 = x_143; -} -lean_ctor_set(x_155, 0, x_142); -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_139, 1); +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_156, 2); +x_157 = lean_ctor_get(x_149, 5); lean_inc(x_157); -x_158 = lean_ctor_get(x_139, 0); -lean_inc(x_158); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_159 = x_139; +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_139); - x_159 = lean_box(0); + lean_dec_ref(x_149); + x_158 = lean_box(0); } -x_160 = lean_ctor_get(x_156, 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_156, 1); +x_161 = lean_ctor_get(x_150, 3); 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; +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_156); - x_165 = lean_box(0); + lean_dec_ref(x_150); + x_162 = lean_box(0); } -x_166 = lean_ctor_get(x_157, 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_157, 1); +x_167 = lean_ctor_get(x_166, 2); lean_inc(x_167); -if (lean_is_exclusive(x_157)) { - lean_ctor_release(x_157, 0); - lean_ctor_release(x_157, 1); - lean_ctor_release(x_157, 2); - x_168 = x_157; +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_157); - x_168 = lean_box(0); + lean_dec_ref(x_148); + x_169 = lean_box(0); } -if (lean_is_scalar(x_168)) { - x_169 = lean_alloc_ctor(0, 3, 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 { - x_169 = x_168; + lean_dec_ref(x_166); + x_175 = lean_box(0); } -lean_ctor_set(x_169, 0, x_166); -lean_ctor_set(x_169, 1, x_167); -lean_ctor_set(x_169, 2, x_127); -if (lean_is_scalar(x_165)) { - x_170 = lean_alloc_ctor(0, 6, 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 { - x_170 = x_165; + lean_dec_ref(x_167); + x_179 = lean_box(0); } -lean_ctor_set(x_170, 0, x_160); -lean_ctor_set(x_170, 1, x_161); -lean_ctor_set(x_170, 2, x_169); -lean_ctor_set(x_170, 3, x_162); -lean_ctor_set(x_170, 4, x_163); -lean_ctor_set(x_170, 5, x_164); -if (lean_is_scalar(x_159)) { - x_171 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_179)) { + x_180 = lean_alloc_ctor(0, 4, 0); } else { - x_171 = x_159; + x_180 = x_179; } -lean_ctor_set(x_171, 0, x_158); -lean_ctor_set(x_171, 1, x_170); -return x_171; +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_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_172 = lean_ctor_get(x_5, 2); -x_173 = lean_ctor_get(x_5, 0); -x_174 = lean_ctor_get(x_5, 1); -x_175 = lean_ctor_get(x_5, 3); -x_176 = lean_ctor_get(x_5, 4); -x_177 = lean_ctor_get(x_5, 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_5); -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); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - lean_ctor_release(x_172, 2); - x_181 = x_172; -} else { - lean_dec_ref(x_172); - x_181 = lean_box(0); -} -x_182 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_181)) { - x_183 = lean_alloc_ctor(0, 3, 0); -} else { - x_183 = x_181; -} -lean_ctor_set(x_183, 0, x_178); -lean_ctor_set(x_183, 1, x_179); -lean_ctor_set(x_183, 2, x_182); -x_184 = lean_alloc_ctor(0, 6, 0); -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_ctor_get(x_4, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_4, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_4, 2); -lean_inc(x_187); -x_188 = lean_ctor_get(x_4, 3); +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); -x_189 = lean_ctor_get(x_4, 4); +lean_inc(x_187); +lean_inc(x_186); +lean_inc(x_183); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_5); +x_189 = lean_ctor_get(x_183, 0); lean_inc(x_189); +x_190 = lean_ctor_get(x_183, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_183, 2); +lean_inc(x_191); +x_192 = lean_ctor_get(x_183, 3); +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); 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_190 = x_4; + x_202 = x_4; } else { lean_dec_ref(x_4); - x_190 = lean_box(0); + x_202 = lean_box(0); } -x_191 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_191, 0, x_1); -lean_ctor_set(x_191, 1, x_2); -x_192 = lean_array_push(x_187, x_191); -if (lean_is_scalar(x_190)) { - x_193 = lean_alloc_ctor(0, 5, 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); } else { - x_193 = x_190; + x_205 = x_202; } -lean_ctor_set(x_193, 0, x_185); -lean_ctor_set(x_193, 1, x_186); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_188); -lean_ctor_set(x_193, 4, x_189); -x_194 = lean_apply_2(x_3, x_193, x_184); -if (lean_obj_tag(x_194) == 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_2(x_3, x_205, x_196); +if (lean_obj_tag(x_206) == 0) { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_195 = lean_ctor_get(x_194, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_195, 2); -lean_inc(x_196); -x_197 = lean_ctor_get(x_194, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_194)) { - lean_ctor_release(x_194, 0); - lean_ctor_release(x_194, 1); - x_198 = x_194; +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_194); - x_198 = lean_box(0); + lean_dec_ref(x_206); + x_210 = 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); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 4); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 5); -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; +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_195); - x_204 = lean_box(0); + lean_dec_ref(x_207); + x_216 = lean_box(0); } -x_205 = lean_ctor_get(x_196, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 1); -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); - x_207 = x_196; +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_196); - x_207 = lean_box(0); + lean_dec_ref(x_208); + x_220 = lean_box(0); } -if (lean_is_scalar(x_207)) { - x_208 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_220)) { + x_221 = lean_alloc_ctor(0, 4, 0); } else { - x_208 = x_207; + x_221 = x_220; } -lean_ctor_set(x_208, 0, x_205); -lean_ctor_set(x_208, 1, x_206); -lean_ctor_set(x_208, 2, x_180); -if (lean_is_scalar(x_204)) { - x_209 = lean_alloc_ctor(0, 6, 0); +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_209 = x_204; + x_222 = x_216; } -lean_ctor_set(x_209, 0, x_199); -lean_ctor_set(x_209, 1, x_200); -lean_ctor_set(x_209, 2, x_208); -lean_ctor_set(x_209, 3, x_201); -lean_ctor_set(x_209, 4, x_202); -lean_ctor_set(x_209, 5, x_203); -if (lean_is_scalar(x_198)) { - x_210 = lean_alloc_ctor(0, 2, 0); +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_210 = x_198; + x_223 = x_210; } -lean_ctor_set(x_210, 0, x_197); -lean_ctor_set(x_210, 1, x_209); -return x_210; +lean_ctor_set(x_223, 0, x_209); +lean_ctor_set(x_223, 1, x_222); +return x_223; } else { -lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_211 = lean_ctor_get(x_194, 1); -lean_inc(x_211); -x_212 = lean_ctor_get(x_211, 2); -lean_inc(x_212); -x_213 = lean_ctor_get(x_194, 0); -lean_inc(x_213); -if (lean_is_exclusive(x_194)) { - lean_ctor_release(x_194, 0); - lean_ctor_release(x_194, 1); - x_214 = x_194; +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_194); - x_214 = lean_box(0); + lean_dec_ref(x_206); + x_227 = lean_box(0); } -x_215 = lean_ctor_get(x_211, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_211, 1); -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); -x_219 = lean_ctor_get(x_211, 5); -lean_inc(x_219); -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); - lean_ctor_release(x_211, 5); - x_220 = x_211; +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; } else { - lean_dec_ref(x_211); - x_220 = lean_box(0); + lean_dec_ref(x_224); + x_233 = lean_box(0); } -x_221 = lean_ctor_get(x_212, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_212, 1); -lean_inc(x_222); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - lean_ctor_release(x_212, 2); - x_223 = x_212; +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; } else { - lean_dec_ref(x_212); - x_223 = lean_box(0); + lean_dec_ref(x_225); + x_237 = lean_box(0); } -if (lean_is_scalar(x_223)) { - x_224 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_237)) { + x_238 = lean_alloc_ctor(0, 4, 0); } else { - x_224 = x_223; + x_238 = x_237; } -lean_ctor_set(x_224, 0, x_221); -lean_ctor_set(x_224, 1, x_222); -lean_ctor_set(x_224, 2, x_180); -if (lean_is_scalar(x_220)) { - x_225 = lean_alloc_ctor(0, 6, 0); +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); } else { - x_225 = x_220; + x_239 = x_233; } -lean_ctor_set(x_225, 0, x_215); -lean_ctor_set(x_225, 1, x_216); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_217); -lean_ctor_set(x_225, 4, x_218); -lean_ctor_set(x_225, 5, x_219); -if (lean_is_scalar(x_214)) { - x_226 = lean_alloc_ctor(1, 2, 0); +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); } else { - x_226 = x_214; + x_240 = x_227; } -lean_ctor_set(x_226, 0, x_213); -lean_ctor_set(x_226, 1, x_225); -return x_226; +lean_ctor_set(x_240, 0, x_226); +lean_ctor_set(x_240, 1, x_239); +return x_240; } } } @@ -8626,82 +8726,89 @@ return x_34; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; +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_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_44); -lean_ctor_set(x_45, 2, x_28); -lean_ctor_set(x_35, 2, x_45); +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; } } 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; -x_46 = lean_ctor_get(x_35, 0); -x_47 = lean_ctor_get(x_35, 1); -x_48 = lean_ctor_get(x_35, 3); -x_49 = lean_ctor_get(x_35, 4); -x_50 = lean_ctor_get(x_35, 5); +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_inc(x_48); lean_inc(x_47); -lean_inc(x_46); lean_dec(x_35); -x_51 = lean_ctor_get(x_36, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_36, 1); +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); - x_53 = x_36; + lean_ctor_release(x_36, 3); + x_55 = x_36; } else { lean_dec_ref(x_36); - x_53 = lean_box(0); + x_55 = lean_box(0); } -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 4, 0); } else { - x_54 = x_53; + x_56 = x_55; } -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_28); -x_55 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_55, 0, x_46); -lean_ctor_set(x_55, 1, x_47); -lean_ctor_set(x_55, 2, x_54); -lean_ctor_set(x_55, 3, x_48); -lean_ctor_set(x_55, 4, x_49); -lean_ctor_set(x_55, 5, x_50); -lean_ctor_set(x_34, 1, x_55); +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; } } 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; -x_56 = lean_ctor_get(x_34, 0); -lean_inc(x_56); -lean_dec(x_34); -x_57 = lean_ctor_get(x_35, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_35, 1); +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); -x_59 = lean_ctor_get(x_35, 3); +lean_dec(x_34); +x_59 = lean_ctor_get(x_35, 0); lean_inc(x_59); -x_60 = lean_ctor_get(x_35, 4); +x_60 = lean_ctor_get(x_35, 1); lean_inc(x_60); -x_61 = lean_ctor_get(x_35, 5); +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); @@ -8709,1900 +8816,1999 @@ if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 3); lean_ctor_release(x_35, 4); lean_ctor_release(x_35, 5); - x_62 = x_35; + x_64 = x_35; } else { lean_dec_ref(x_35); - x_62 = lean_box(0); + x_64 = lean_box(0); } -x_63 = lean_ctor_get(x_36, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_36, 1); -lean_inc(x_64); +x_65 = lean_ctor_get(x_36, 0); +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); - x_65 = x_36; + lean_ctor_release(x_36, 3); + x_68 = x_36; } else { lean_dec_ref(x_36); - x_65 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_69 = x_68; } -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_28); -if (lean_is_scalar(x_62)) { - x_67 = lean_alloc_ctor(0, 6, 0); +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_67 = x_62; + x_70 = x_64; } -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_56); -lean_ctor_set(x_68, 1, x_67); -return x_68; +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; } } else { -lean_object* x_69; lean_object* x_70; uint8_t x_71; -x_69 = lean_ctor_get(x_34, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_69, 2); -lean_inc(x_70); -x_71 = !lean_is_exclusive(x_34); -if (x_71 == 0) -{ -lean_object* x_72; uint8_t x_73; +lean_object* x_72; lean_object* x_73; uint8_t x_74; x_72 = lean_ctor_get(x_34, 1); -lean_dec(x_72); -x_73 = !lean_is_exclusive(x_69); -if (x_73 == 0) +lean_inc(x_72); +x_73 = lean_ctor_get(x_72, 2); +lean_inc(x_73); +x_74 = !lean_is_exclusive(x_34); +if (x_74 == 0) { -lean_object* x_74; uint8_t x_75; -x_74 = lean_ctor_get(x_69, 2); -lean_dec(x_74); -x_75 = !lean_is_exclusive(x_70); -if (x_75 == 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_76; -x_76 = lean_ctor_get(x_70, 2); -lean_dec(x_76); -lean_ctor_set(x_70, 2, x_28); +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_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -lean_ctor_set(x_79, 2, x_28); -lean_ctor_set(x_69, 2, x_79); -return x_34; -} -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_80 = lean_ctor_get(x_69, 0); -x_81 = lean_ctor_get(x_69, 1); -x_82 = lean_ctor_get(x_69, 3); -x_83 = lean_ctor_get(x_69, 4); -x_84 = lean_ctor_get(x_69, 5); -lean_inc(x_84); -lean_inc(x_83); +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_69); -x_85 = lean_ctor_get(x_70, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_70, 1); -lean_inc(x_86); -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_87 = x_70; -} else { - lean_dec_ref(x_70); - x_87 = lean_box(0); -} -if (lean_is_scalar(x_87)) { - x_88 = lean_alloc_ctor(0, 3, 0); -} else { - x_88 = x_87; -} -lean_ctor_set(x_88, 0, x_85); -lean_ctor_set(x_88, 1, x_86); -lean_ctor_set(x_88, 2, x_28); -x_89 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_89, 0, x_80); -lean_ctor_set(x_89, 1, x_81); -lean_ctor_set(x_89, 2, x_88); -lean_ctor_set(x_89, 3, x_82); -lean_ctor_set(x_89, 4, x_83); -lean_ctor_set(x_89, 5, x_84); -lean_ctor_set(x_34, 1, x_89); +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_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_90 = lean_ctor_get(x_34, 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; +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); -lean_dec(x_34); -x_91 = lean_ctor_get(x_69, 0); +x_91 = lean_ctor_get(x_73, 3); lean_inc(x_91); -x_92 = lean_ctor_get(x_69, 1); -lean_inc(x_92); -x_93 = lean_ctor_get(x_69, 3); -lean_inc(x_93); -x_94 = lean_ctor_get(x_69, 4); -lean_inc(x_94); -x_95 = lean_ctor_get(x_69, 5); +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; +} else { + lean_dec_ref(x_73); + 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_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); -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_96 = x_69; -} else { - lean_dec_ref(x_69); - x_96 = lean_box(0); -} -x_97 = lean_ctor_get(x_70, 0); +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_70, 1); +x_98 = lean_ctor_get(x_72, 3); lean_inc(x_98); -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_99 = x_70; +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; } else { - lean_dec_ref(x_70); - x_99 = lean_box(0); + lean_dec_ref(x_72); + x_101 = lean_box(0); } -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 3, 0); +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 { - x_100 = x_99; + lean_dec_ref(x_73); + x_105 = lean_box(0); } -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -lean_ctor_set(x_100, 2, x_28); -if (lean_is_scalar(x_96)) { - x_101 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_105)) { + x_106 = lean_alloc_ctor(0, 4, 0); } else { - x_101 = x_96; + x_106 = x_105; } -lean_ctor_set(x_101, 0, x_91); -lean_ctor_set(x_101, 1, x_92); -lean_ctor_set(x_101, 2, x_100); -lean_ctor_set(x_101, 3, x_93); -lean_ctor_set(x_101, 4, x_94); -lean_ctor_set(x_101, 5, x_95); -x_102 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_102, 0, x_90); -lean_ctor_set(x_102, 1, x_101); -return x_102; +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_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_22); -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_withNewLocalInstances___main___rarg(x_1, x_2, x_24, x_4, x_110, x_21); -if (lean_obj_tag(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; 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_112 = lean_ctor_get(x_111, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_112, 2); +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); -x_114 = lean_ctor_get(x_111, 0); -lean_inc(x_114); -if (lean_is_exclusive(x_111)) { - lean_ctor_release(x_111, 0); - lean_ctor_release(x_111, 1); - x_115 = x_111; -} else { - lean_dec_ref(x_111); - x_115 = lean_box(0); -} -x_116 = lean_ctor_get(x_112, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_112, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_112, 3); +lean_inc(x_112); +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_112, 4); +x_119 = lean_ctor_get(x_118, 2); lean_inc(x_119); -x_120 = lean_ctor_get(x_112, 5); +x_120 = lean_ctor_get(x_117, 0); lean_inc(x_120); -if (lean_is_exclusive(x_112)) { - lean_ctor_release(x_112, 0); - lean_ctor_release(x_112, 1); - lean_ctor_release(x_112, 2); - lean_ctor_release(x_112, 3); - lean_ctor_release(x_112, 4); - lean_ctor_release(x_112, 5); - x_121 = x_112; +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_112); + lean_dec_ref(x_117); x_121 = lean_box(0); } -x_122 = lean_ctor_get(x_113, 0); +x_122 = lean_ctor_get(x_118, 0); lean_inc(x_122); -x_123 = lean_ctor_get(x_113, 1); +x_123 = lean_ctor_get(x_118, 1); 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); - x_124 = x_113; +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_113); - x_124 = lean_box(0); + lean_dec_ref(x_118); + x_127 = lean_box(0); } -if (lean_is_scalar(x_124)) { - x_125 = lean_alloc_ctor(0, 3, 0); -} else { - x_125 = x_124; -} -lean_ctor_set(x_125, 0, x_122); -lean_ctor_set(x_125, 1, x_123); -lean_ctor_set(x_125, 2, x_28); -if (lean_is_scalar(x_121)) { - x_126 = lean_alloc_ctor(0, 6, 0); -} else { - x_126 = x_121; -} -lean_ctor_set(x_126, 0, x_116); -lean_ctor_set(x_126, 1, x_117); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_118); -lean_ctor_set(x_126, 4, x_119); -lean_ctor_set(x_126, 5, x_120); -if (lean_is_scalar(x_115)) { - x_127 = lean_alloc_ctor(0, 2, 0); -} else { - x_127 = x_115; -} -lean_ctor_set(x_127, 0, x_114); -lean_ctor_set(x_127, 1, x_126); -return x_127; -} -else -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; -x_128 = lean_ctor_get(x_111, 1); +x_128 = lean_ctor_get(x_119, 0); lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 2); +x_129 = lean_ctor_get(x_119, 1); lean_inc(x_129); -x_130 = lean_ctor_get(x_111, 0); +x_130 = lean_ctor_get(x_119, 3); lean_inc(x_130); -if (lean_is_exclusive(x_111)) { - lean_ctor_release(x_111, 0); - lean_ctor_release(x_111, 1); - x_131 = x_111; +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_111); + lean_dec_ref(x_119); x_131 = lean_box(0); } -x_132 = lean_ctor_get(x_128, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_128, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_128, 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; -} else { - lean_dec_ref(x_128); - x_137 = 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); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - lean_ctor_release(x_129, 2); - x_140 = x_129; -} else { - lean_dec_ref(x_129); - x_140 = lean_box(0); -} -if (lean_is_scalar(x_140)) { - x_141 = lean_alloc_ctor(0, 3, 0); -} else { - x_141 = x_140; -} -lean_ctor_set(x_141, 0, x_138); -lean_ctor_set(x_141, 1, x_139); -lean_ctor_set(x_141, 2, x_28); -if (lean_is_scalar(x_137)) { - x_142 = lean_alloc_ctor(0, 6, 0); -} else { - x_142 = x_137; -} -lean_ctor_set(x_142, 0, x_132); -lean_ctor_set(x_142, 1, x_133); -lean_ctor_set(x_142, 2, x_141); -lean_ctor_set(x_142, 3, x_134); -lean_ctor_set(x_142, 4, x_135); -lean_ctor_set(x_142, 5, x_136); if (lean_is_scalar(x_131)) { - x_143 = lean_alloc_ctor(1, 2, 0); + x_132 = lean_alloc_ctor(0, 4, 0); } else { - x_143 = x_131; + x_132 = x_131; } -lean_ctor_set(x_143, 0, x_130); -lean_ctor_set(x_143, 1, x_142); -return x_143; +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); +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_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_inc(x_135); +x_136 = lean_ctor_get(x_135, 2); +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); +} +x_139 = lean_ctor_get(x_135, 0); +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); +} +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; +} 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_28); +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_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_144 = lean_ctor_get(x_26, 0); -x_145 = lean_ctor_get(x_26, 1); -x_146 = lean_ctor_get(x_26, 2); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_dec(x_26); -x_147 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_148 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_148, 0, x_144); -lean_ctor_set(x_148, 1, x_145); -lean_ctor_set(x_148, 2, x_147); -lean_ctor_set(x_21, 2, x_148); -x_149 = lean_ctor_get(x_5, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_5, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_5, 2); -lean_inc(x_151); -x_152 = lean_ctor_get(x_5, 3); -lean_inc(x_152); -x_153 = lean_ctor_get(x_5, 4); +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); 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_154 = x_5; + x_163 = x_5; } else { lean_dec_ref(x_5); - x_154 = lean_box(0); + x_163 = lean_box(0); } -x_155 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_155, 0, x_22); -lean_ctor_set(x_155, 1, x_10); -x_156 = lean_array_push(x_151, x_155); -if (lean_is_scalar(x_154)) { - x_157 = lean_alloc_ctor(0, 5, 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); } else { - x_157 = x_154; + x_166 = x_163; } -lean_ctor_set(x_157, 0, x_149); -lean_ctor_set(x_157, 1, x_150); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_152); -lean_ctor_set(x_157, 4, x_153); -x_158 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_24, x_4, x_157, x_21); -if (lean_obj_tag(x_158) == 0) +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_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; -x_159 = lean_ctor_get(x_158, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_159, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_158, 0); -lean_inc(x_161); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_162 = x_158; -} else { - lean_dec_ref(x_158); - x_162 = lean_box(0); -} -x_163 = lean_ctor_get(x_159, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_159, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_159, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_159, 5); -lean_inc(x_167); -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); - lean_ctor_release(x_159, 5); - x_168 = x_159; -} else { - lean_dec_ref(x_159); - x_168 = lean_box(0); -} -x_169 = lean_ctor_get(x_160, 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_160, 1); +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); - x_171 = x_160; +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_160); + lean_dec_ref(x_167); x_171 = lean_box(0); } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 3, 0); -} else { - x_172 = x_171; -} -lean_ctor_set(x_172, 0, x_169); -lean_ctor_set(x_172, 1, x_170); -lean_ctor_set(x_172, 2, x_146); -if (lean_is_scalar(x_168)) { - x_173 = lean_alloc_ctor(0, 6, 0); -} else { - x_173 = x_168; -} -lean_ctor_set(x_173, 0, x_163); -lean_ctor_set(x_173, 1, x_164); -lean_ctor_set(x_173, 2, x_172); -lean_ctor_set(x_173, 3, x_165); -lean_ctor_set(x_173, 4, x_166); -lean_ctor_set(x_173, 5, x_167); -if (lean_is_scalar(x_162)) { - x_174 = lean_alloc_ctor(0, 2, 0); -} else { - x_174 = x_162; -} -lean_ctor_set(x_174, 0, x_161); -lean_ctor_set(x_174, 1, x_173); -return x_174; -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -x_175 = lean_ctor_get(x_158, 1); +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_175, 2); +x_176 = lean_ctor_get(x_168, 5); lean_inc(x_176); -x_177 = lean_ctor_get(x_158, 0); -lean_inc(x_177); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_178 = x_158; +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_158); - x_178 = lean_box(0); + lean_dec_ref(x_168); + x_177 = lean_box(0); } -x_179 = lean_ctor_get(x_175, 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_175, 1); +x_180 = lean_ctor_get(x_169, 3); lean_inc(x_180); -x_181 = lean_ctor_get(x_175, 3); -lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 4); -lean_inc(x_182); -x_183 = lean_ctor_get(x_175, 5); -lean_inc(x_183); -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_184 = x_175; +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_175); - x_184 = lean_box(0); + lean_dec_ref(x_169); + x_181 = lean_box(0); } -x_185 = lean_ctor_get(x_176, 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; +} +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_inc(x_185); -x_186 = lean_ctor_get(x_176, 1); +x_186 = lean_ctor_get(x_185, 2); lean_inc(x_186); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - lean_ctor_release(x_176, 2); - x_187 = x_176; +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; } else { - lean_dec_ref(x_176); - x_187 = lean_box(0); + lean_dec_ref(x_167); + x_188 = lean_box(0); } -if (lean_is_scalar(x_187)) { - x_188 = lean_alloc_ctor(0, 3, 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 { - x_188 = x_187; + lean_dec_ref(x_185); + x_194 = lean_box(0); } -lean_ctor_set(x_188, 0, x_185); -lean_ctor_set(x_188, 1, x_186); -lean_ctor_set(x_188, 2, x_146); -if (lean_is_scalar(x_184)) { - x_189 = lean_alloc_ctor(0, 6, 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 { - x_189 = x_184; + lean_dec_ref(x_186); + x_198 = lean_box(0); } -lean_ctor_set(x_189, 0, x_179); -lean_ctor_set(x_189, 1, x_180); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_181); -lean_ctor_set(x_189, 4, x_182); -lean_ctor_set(x_189, 5, x_183); -if (lean_is_scalar(x_178)) { - x_190 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_198)) { + x_199 = lean_alloc_ctor(0, 4, 0); } else { - x_190 = x_178; + x_199 = x_198; } -lean_ctor_set(x_190, 0, x_177); -lean_ctor_set(x_190, 1, x_189); -return x_190; +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); +} 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(1, 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; } } } 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; 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_191 = lean_ctor_get(x_21, 2); -x_192 = lean_ctor_get(x_21, 0); -x_193 = lean_ctor_get(x_21, 1); -x_194 = lean_ctor_get(x_21, 3); -x_195 = lean_ctor_get(x_21, 4); -x_196 = lean_ctor_get(x_21, 5); -lean_inc(x_196); -lean_inc(x_195); -lean_inc(x_194); -lean_inc(x_191); -lean_inc(x_193); -lean_inc(x_192); -lean_dec(x_21); -x_197 = lean_ctor_get(x_191, 0); -lean_inc(x_197); -x_198 = lean_ctor_get(x_191, 1); -lean_inc(x_198); -x_199 = lean_ctor_get(x_191, 2); -lean_inc(x_199); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - lean_ctor_release(x_191, 2); - x_200 = x_191; -} else { - lean_dec_ref(x_191); - x_200 = lean_box(0); -} -x_201 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_200)) { - x_202 = lean_alloc_ctor(0, 3, 0); -} else { - x_202 = x_200; -} -lean_ctor_set(x_202, 0, x_197); -lean_ctor_set(x_202, 1, x_198); -lean_ctor_set(x_202, 2, x_201); -x_203 = lean_alloc_ctor(0, 6, 0); -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); -x_204 = lean_ctor_get(x_5, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_5, 1); -lean_inc(x_205); -x_206 = lean_ctor_get(x_5, 2); -lean_inc(x_206); -x_207 = lean_ctor_get(x_5, 3); +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); -x_208 = lean_ctor_get(x_5, 4); +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_209 = x_5; + x_221 = x_5; } else { lean_dec_ref(x_5); - x_209 = lean_box(0); + x_221 = lean_box(0); } -x_210 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_210, 0, x_22); -lean_ctor_set(x_210, 1, x_10); -x_211 = lean_array_push(x_206, x_210); -if (lean_is_scalar(x_209)) { - x_212 = lean_alloc_ctor(0, 5, 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_212 = x_209; + x_224 = x_221; } -lean_ctor_set(x_212, 0, x_204); -lean_ctor_set(x_212, 1, x_205); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_207); -lean_ctor_set(x_212, 4, x_208); -x_213 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_24, x_4, x_212, x_203); -if (lean_obj_tag(x_213) == 0) +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_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_214 = lean_ctor_get(x_213, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_214, 2); -lean_inc(x_215); -x_216 = lean_ctor_get(x_213, 0); -lean_inc(x_216); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - x_217 = x_213; +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_213); - x_217 = lean_box(0); + lean_dec_ref(x_225); + x_229 = lean_box(0); } -x_218 = lean_ctor_get(x_214, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_214, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_214, 3); -lean_inc(x_220); -x_221 = lean_ctor_get(x_214, 4); -lean_inc(x_221); -x_222 = lean_ctor_get(x_214, 5); -lean_inc(x_222); -if (lean_is_exclusive(x_214)) { - lean_ctor_release(x_214, 0); - lean_ctor_release(x_214, 1); - lean_ctor_release(x_214, 2); - lean_ctor_release(x_214, 3); - lean_ctor_release(x_214, 4); - lean_ctor_release(x_214, 5); - x_223 = x_214; +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_214); - x_223 = lean_box(0); + lean_dec_ref(x_226); + x_235 = lean_box(0); } -x_224 = lean_ctor_get(x_215, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_215, 1); -lean_inc(x_225); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - x_226 = x_215; +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_215); - x_226 = lean_box(0); + lean_dec_ref(x_227); + x_239 = lean_box(0); } -if (lean_is_scalar(x_226)) { - x_227 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_239)) { + x_240 = lean_alloc_ctor(0, 4, 0); } else { - x_227 = x_226; + x_240 = x_239; } -lean_ctor_set(x_227, 0, x_224); -lean_ctor_set(x_227, 1, x_225); -lean_ctor_set(x_227, 2, x_199); -if (lean_is_scalar(x_223)) { - x_228 = lean_alloc_ctor(0, 6, 0); +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_228 = x_223; + x_241 = x_235; } -lean_ctor_set(x_228, 0, x_218); -lean_ctor_set(x_228, 1, x_219); -lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_220); -lean_ctor_set(x_228, 4, x_221); -lean_ctor_set(x_228, 5, x_222); -if (lean_is_scalar(x_217)) { - x_229 = lean_alloc_ctor(0, 2, 0); +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_229 = x_217; + x_242 = x_229; } -lean_ctor_set(x_229, 0, x_216); -lean_ctor_set(x_229, 1, x_228); -return 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_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_230 = lean_ctor_get(x_213, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_230, 2); -lean_inc(x_231); -x_232 = lean_ctor_get(x_213, 0); -lean_inc(x_232); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - x_233 = x_213; +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_213); - x_233 = lean_box(0); + lean_dec_ref(x_225); + x_246 = 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; +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_230); - x_239 = lean_box(0); + lean_dec_ref(x_243); + x_252 = 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); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - x_242 = x_231; +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_231); - x_242 = lean_box(0); + lean_dec_ref(x_244); + x_256 = lean_box(0); } -if (lean_is_scalar(x_242)) { - x_243 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 4, 0); } else { - x_243 = x_242; + x_257 = x_256; } -lean_ctor_set(x_243, 0, x_240); -lean_ctor_set(x_243, 1, x_241); -lean_ctor_set(x_243, 2, x_199); -if (lean_is_scalar(x_239)) { - x_244 = lean_alloc_ctor(0, 6, 0); +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_244 = x_239; + x_258 = x_252; } -lean_ctor_set(x_244, 0, x_234); -lean_ctor_set(x_244, 1, x_235); -lean_ctor_set(x_244, 2, x_243); -lean_ctor_set(x_244, 3, x_236); -lean_ctor_set(x_244, 4, x_237); -lean_ctor_set(x_244, 5, x_238); -if (lean_is_scalar(x_233)) { - x_245 = lean_alloc_ctor(1, 2, 0); +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_245 = x_233; + x_259 = x_246; } -lean_ctor_set(x_245, 0, x_232); -lean_ctor_set(x_245, 1, x_244); -return x_245; +lean_ctor_set(x_259, 0, x_245); +lean_ctor_set(x_259, 1, x_258); +return x_259; } } } default: { -lean_object* x_246; lean_object* x_247; -x_246 = lean_ctor_get(x_15, 1); -lean_inc(x_246); +lean_object* x_260; lean_object* x_261; +x_260 = lean_ctor_get(x_15, 1); +lean_inc(x_260); lean_dec(x_15); lean_inc(x_1); lean_inc(x_5); -x_247 = lean_apply_3(x_1, x_14, x_5, x_246); -if (lean_obj_tag(x_247) == 0) +x_261 = lean_apply_3(x_1, x_14, x_5, x_260); +if (lean_obj_tag(x_261) == 0) { -lean_object* x_248; -x_248 = lean_ctor_get(x_247, 0); -lean_inc(x_248); -if (lean_obj_tag(x_248) == 0) +lean_object* x_262; +x_262 = lean_ctor_get(x_261, 0); +lean_inc(x_262); +if (lean_obj_tag(x_262) == 0) { -lean_object* x_249; lean_object* x_250; lean_object* x_251; +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_dec(x_10); -x_249 = lean_ctor_get(x_247, 1); -lean_inc(x_249); -lean_dec(x_247); -x_250 = lean_unsigned_to_nat(1u); -x_251 = lean_nat_add(x_3, x_250); +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); lean_dec(x_3); -x_3 = x_251; -x_6 = x_249; +x_3 = x_265; +x_6 = x_263; goto _start; } else { -lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; uint8_t x_257; -x_253 = lean_ctor_get(x_247, 1); -lean_inc(x_253); -lean_dec(x_247); -x_254 = lean_ctor_get(x_248, 0); -lean_inc(x_254); -lean_dec(x_248); -x_255 = lean_unsigned_to_nat(1u); -x_256 = lean_nat_add(x_3, x_255); -lean_dec(x_3); -x_257 = !lean_is_exclusive(x_253); -if (x_257 == 0) -{ -lean_object* x_258; uint8_t x_259; -x_258 = lean_ctor_get(x_253, 2); -x_259 = !lean_is_exclusive(x_258); -if (x_259 == 0) -{ -lean_object* x_260; lean_object* x_261; uint8_t x_262; -x_260 = lean_ctor_get(x_258, 2); -x_261 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_258, 2, x_261); -x_262 = !lean_is_exclusive(x_5); -if (x_262 == 0) -{ -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; -x_263 = lean_ctor_get(x_5, 2); -x_264 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_264, 0, x_254); -lean_ctor_set(x_264, 1, x_10); -x_265 = lean_array_push(x_263, x_264); -lean_ctor_set(x_5, 2, x_265); -x_266 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_256, x_4, x_5, x_253); -if (lean_obj_tag(x_266) == 0) -{ -lean_object* x_267; lean_object* x_268; uint8_t x_269; -x_267 = lean_ctor_get(x_266, 1); +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); -x_268 = lean_ctor_get(x_267, 2); +lean_dec(x_261); +x_268 = lean_ctor_get(x_262, 0); lean_inc(x_268); -x_269 = !lean_is_exclusive(x_266); -if (x_269 == 0) -{ -lean_object* x_270; uint8_t x_271; -x_270 = lean_ctor_get(x_266, 1); -lean_dec(x_270); +lean_dec(x_262); +x_269 = lean_unsigned_to_nat(1u); +x_270 = lean_nat_add(x_3, x_269); +lean_dec(x_3); x_271 = !lean_is_exclusive(x_267); if (x_271 == 0) { lean_object* x_272; uint8_t x_273; x_272 = lean_ctor_get(x_267, 2); -lean_dec(x_272); -x_273 = !lean_is_exclusive(x_268); +x_273 = !lean_is_exclusive(x_272); if (x_273 == 0) { -lean_object* x_274; -x_274 = lean_ctor_get(x_268, 2); -lean_dec(x_274); -lean_ctor_set(x_268, 2, x_260); -return x_266; -} -else +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_275; lean_object* x_276; lean_object* x_277; -x_275 = lean_ctor_get(x_268, 0); -x_276 = lean_ctor_get(x_268, 1); -lean_inc(x_276); -lean_inc(x_275); -lean_dec(x_268); -x_277 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_277, 0, x_275); -lean_ctor_set(x_277, 1, x_276); -lean_ctor_set(x_277, 2, x_260); -lean_ctor_set(x_267, 2, x_277); -return x_266; -} -} -else +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_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; -x_278 = lean_ctor_get(x_267, 0); -x_279 = lean_ctor_get(x_267, 1); -x_280 = lean_ctor_get(x_267, 3); -x_281 = lean_ctor_get(x_267, 4); -x_282 = lean_ctor_get(x_267, 5); -lean_inc(x_282); +lean_object* x_281; lean_object* x_282; uint8_t x_283; +x_281 = lean_ctor_get(x_280, 1); lean_inc(x_281); -lean_inc(x_280); -lean_inc(x_279); -lean_inc(x_278); -lean_dec(x_267); -x_283 = lean_ctor_get(x_268, 0); -lean_inc(x_283); -x_284 = lean_ctor_get(x_268, 1); -lean_inc(x_284); -if (lean_is_exclusive(x_268)) { - lean_ctor_release(x_268, 0); - lean_ctor_release(x_268, 1); - lean_ctor_release(x_268, 2); - x_285 = x_268; -} else { - lean_dec_ref(x_268); - x_285 = lean_box(0); -} -if (lean_is_scalar(x_285)) { - x_286 = lean_alloc_ctor(0, 3, 0); -} else { - x_286 = x_285; -} -lean_ctor_set(x_286, 0, x_283); -lean_ctor_set(x_286, 1, x_284); -lean_ctor_set(x_286, 2, x_260); -x_287 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_287, 0, x_278); -lean_ctor_set(x_287, 1, x_279); -lean_ctor_set(x_287, 2, x_286); -lean_ctor_set(x_287, 3, x_280); -lean_ctor_set(x_287, 4, x_281); -lean_ctor_set(x_287, 5, x_282); -lean_ctor_set(x_266, 1, x_287); -return x_266; -} +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_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; -x_288 = lean_ctor_get(x_266, 0); -lean_inc(x_288); -lean_dec(x_266); -x_289 = lean_ctor_get(x_267, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_267, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_267, 3); +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); -x_292 = lean_ctor_get(x_267, 4); -lean_inc(x_292); -x_293 = lean_ctor_get(x_267, 5); -lean_inc(x_293); -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_294 = x_267; -} else { - lean_dec_ref(x_267); - x_294 = lean_box(0); +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; } -x_295 = lean_ctor_get(x_268, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_268, 1); +} +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); -if (lean_is_exclusive(x_268)) { - lean_ctor_release(x_268, 0); - lean_ctor_release(x_268, 1); - lean_ctor_release(x_268, 2); - x_297 = x_268; +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_inc(x_299); +x_300 = lean_ctor_get(x_282, 3); +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_268); - x_297 = lean_box(0); + lean_dec_ref(x_282); + x_301 = lean_box(0); } -if (lean_is_scalar(x_297)) { - x_298 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_301)) { + x_302 = lean_alloc_ctor(0, 4, 0); } else { - x_298 = x_297; + x_302 = x_301; } -lean_ctor_set(x_298, 0, x_295); -lean_ctor_set(x_298, 1, x_296); -lean_ctor_set(x_298, 2, x_260); -if (lean_is_scalar(x_294)) { - x_299 = lean_alloc_ctor(0, 6, 0); -} else { - x_299 = x_294; -} -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); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_288); -lean_ctor_set(x_300, 1, x_299); -return x_300; +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_301; lean_object* x_302; uint8_t x_303; -x_301 = lean_ctor_get(x_266, 1); -lean_inc(x_301); -x_302 = lean_ctor_get(x_301, 2); -lean_inc(x_302); -x_303 = !lean_is_exclusive(x_266); -if (x_303 == 0) -{ -lean_object* x_304; uint8_t x_305; -x_304 = lean_ctor_get(x_266, 1); -lean_dec(x_304); -x_305 = !lean_is_exclusive(x_301); -if (x_305 == 0) -{ -lean_object* x_306; uint8_t x_307; -x_306 = lean_ctor_get(x_301, 2); -lean_dec(x_306); -x_307 = !lean_is_exclusive(x_302); -if (x_307 == 0) -{ -lean_object* x_308; -x_308 = lean_ctor_get(x_302, 2); -lean_dec(x_308); -lean_ctor_set(x_302, 2, x_260); -return x_266; -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_302, 0); -x_310 = lean_ctor_get(x_302, 1); -lean_inc(x_310); +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_inc(x_309); -lean_dec(x_302); -x_311 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_311, 0, x_309); -lean_ctor_set(x_311, 1, x_310); -lean_ctor_set(x_311, 2, x_260); -lean_ctor_set(x_301, 2, x_311); -return x_266; +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); } -} -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; -x_312 = lean_ctor_get(x_301, 0); -x_313 = lean_ctor_get(x_301, 1); -x_314 = lean_ctor_get(x_301, 3); -x_315 = lean_ctor_get(x_301, 4); -x_316 = lean_ctor_get(x_301, 5); -lean_inc(x_316); -lean_inc(x_315); -lean_inc(x_314); -lean_inc(x_313); +x_311 = lean_ctor_get(x_282, 0); +lean_inc(x_311); +x_312 = lean_ctor_get(x_282, 1); lean_inc(x_312); -lean_dec(x_301); -x_317 = lean_ctor_get(x_302, 0); -lean_inc(x_317); -x_318 = lean_ctor_get(x_302, 1); +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); -if (lean_is_exclusive(x_302)) { - lean_ctor_release(x_302, 0); - lean_ctor_release(x_302, 1); - lean_ctor_release(x_302, 2); - x_319 = x_302; -} else { - lean_dec_ref(x_302); - x_319 = lean_box(0); -} -if (lean_is_scalar(x_319)) { - x_320 = lean_alloc_ctor(0, 3, 0); -} else { - x_320 = x_319; -} -lean_ctor_set(x_320, 0, x_317); -lean_ctor_set(x_320, 1, x_318); -lean_ctor_set(x_320, 2, x_260); -x_321 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_321, 0, x_312); -lean_ctor_set(x_321, 1, x_313); -lean_ctor_set(x_321, 2, x_320); -lean_ctor_set(x_321, 3, x_314); -lean_ctor_set(x_321, 4, x_315); -lean_ctor_set(x_321, 5, x_316); -lean_ctor_set(x_266, 1, x_321); -return x_266; -} +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_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_322 = lean_ctor_get(x_266, 0); -lean_inc(x_322); -lean_dec(x_266); -x_323 = lean_ctor_get(x_301, 0); -lean_inc(x_323); -x_324 = lean_ctor_get(x_301, 1); -lean_inc(x_324); -x_325 = lean_ctor_get(x_301, 3); -lean_inc(x_325); -x_326 = lean_ctor_get(x_301, 4); -lean_inc(x_326); -x_327 = lean_ctor_get(x_301, 5); +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); -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); - lean_ctor_release(x_301, 5); - x_328 = x_301; -} else { - lean_dec_ref(x_301); - x_328 = lean_box(0); -} -x_329 = lean_ctor_get(x_302, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_302, 1); -lean_inc(x_330); -if (lean_is_exclusive(x_302)) { - lean_ctor_release(x_302, 0); - lean_ctor_release(x_302, 1); - lean_ctor_release(x_302, 2); - x_331 = x_302; -} else { - lean_dec_ref(x_302); - x_331 = lean_box(0); -} -if (lean_is_scalar(x_331)) { - x_332 = lean_alloc_ctor(0, 3, 0); -} else { - x_332 = x_331; -} -lean_ctor_set(x_332, 0, x_329); -lean_ctor_set(x_332, 1, x_330); -lean_ctor_set(x_332, 2, x_260); -if (lean_is_scalar(x_328)) { - x_333 = lean_alloc_ctor(0, 6, 0); -} else { - x_333 = x_328; -} -lean_ctor_set(x_333, 0, x_323); -lean_ctor_set(x_333, 1, x_324); -lean_ctor_set(x_333, 2, x_332); -lean_ctor_set(x_333, 3, x_325); -lean_ctor_set(x_333, 4, x_326); -lean_ctor_set(x_333, 5, x_327); -x_334 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_334, 0, x_322); -lean_ctor_set(x_334, 1, x_333); -return x_334; -} +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_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_335 = lean_ctor_get(x_5, 0); -x_336 = lean_ctor_get(x_5, 1); -x_337 = lean_ctor_get(x_5, 2); -x_338 = lean_ctor_get(x_5, 3); -x_339 = lean_ctor_get(x_5, 4); -lean_inc(x_339); -lean_inc(x_338); -lean_inc(x_337); -lean_inc(x_336); +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); -lean_dec(x_5); -x_340 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_340, 0, x_254); -lean_ctor_set(x_340, 1, x_10); -x_341 = lean_array_push(x_337, x_340); -x_342 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_342, 0, x_335); -lean_ctor_set(x_342, 1, x_336); -lean_ctor_set(x_342, 2, x_341); -lean_ctor_set(x_342, 3, x_338); -lean_ctor_set(x_342, 4, x_339); -x_343 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_256, x_4, x_342, x_253); -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; -x_344 = lean_ctor_get(x_343, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_344, 2); -lean_inc(x_345); -x_346 = lean_ctor_get(x_343, 0); -lean_inc(x_346); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - x_347 = x_343; +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_343); + 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_344, 0); +x_348 = lean_ctor_get(x_319, 0); lean_inc(x_348); -x_349 = lean_ctor_get(x_344, 1); +x_349 = lean_ctor_get(x_319, 1); lean_inc(x_349); -x_350 = lean_ctor_get(x_344, 3); +x_350 = lean_ctor_get(x_319, 3); lean_inc(x_350); -x_351 = lean_ctor_get(x_344, 4); -lean_inc(x_351); -x_352 = lean_ctor_get(x_344, 5); -lean_inc(x_352); -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_353 = x_344; +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_344); - x_353 = lean_box(0); + lean_dec_ref(x_319); + x_351 = lean_box(0); } -x_354 = lean_ctor_get(x_345, 0); -lean_inc(x_354); -x_355 = lean_ctor_get(x_345, 1); -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); - x_356 = x_345; +if (lean_is_scalar(x_351)) { + x_352 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_345); - x_356 = lean_box(0); + x_352 = x_351; } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 3, 0); -} else { - x_357 = x_356; -} -lean_ctor_set(x_357, 0, x_354); -lean_ctor_set(x_357, 1, x_355); -lean_ctor_set(x_357, 2, x_260); -if (lean_is_scalar(x_353)) { - x_358 = lean_alloc_ctor(0, 6, 0); -} else { - x_358 = x_353; -} -lean_ctor_set(x_358, 0, x_348); -lean_ctor_set(x_358, 1, x_349); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_350); -lean_ctor_set(x_358, 4, x_351); -lean_ctor_set(x_358, 5, x_352); +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_359 = lean_alloc_ctor(0, 2, 0); + x_353 = lean_alloc_ctor(0, 6, 0); } else { - x_359 = x_347; + 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; +} } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; } else { -lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_360 = lean_ctor_get(x_343, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_360, 2); -lean_inc(x_361); -x_362 = lean_ctor_get(x_343, 0); -lean_inc(x_362); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - x_363 = x_343; -} else { - lean_dec_ref(x_343); - x_363 = lean_box(0); -} -x_364 = lean_ctor_get(x_360, 0); +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_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) +{ +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_360, 1); +x_365 = lean_ctor_get(x_364, 2); lean_inc(x_365); -x_366 = lean_ctor_get(x_360, 3); +x_366 = lean_ctor_get(x_363, 0); lean_inc(x_366); -x_367 = lean_ctor_get(x_360, 4); -lean_inc(x_367); -x_368 = lean_ctor_get(x_360, 5); +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); -if (lean_is_exclusive(x_360)) { - lean_ctor_release(x_360, 0); - lean_ctor_release(x_360, 1); - lean_ctor_release(x_360, 2); - lean_ctor_release(x_360, 3); - lean_ctor_release(x_360, 4); - lean_ctor_release(x_360, 5); - x_369 = x_360; -} else { - lean_dec_ref(x_360); - x_369 = lean_box(0); -} -x_370 = lean_ctor_get(x_361, 0); +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_361, 1); +x_371 = lean_ctor_get(x_364, 4); lean_inc(x_371); -if (lean_is_exclusive(x_361)) { - lean_ctor_release(x_361, 0); - lean_ctor_release(x_361, 1); - lean_ctor_release(x_361, 2); - x_372 = x_361; +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_361); - x_372 = lean_box(0); + lean_dec_ref(x_364); + x_373 = lean_box(0); } -if (lean_is_scalar(x_372)) { - x_373 = lean_alloc_ctor(0, 3, 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 { - x_373 = x_372; + lean_dec_ref(x_365); + x_377 = lean_box(0); } -lean_ctor_set(x_373, 0, x_370); -lean_ctor_set(x_373, 1, x_371); -lean_ctor_set(x_373, 2, x_260); -if (lean_is_scalar(x_369)) { - x_374 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_377)) { + x_378 = lean_alloc_ctor(0, 4, 0); } else { - x_374 = x_369; + x_378 = x_377; } -lean_ctor_set(x_374, 0, x_364); -lean_ctor_set(x_374, 1, x_365); -lean_ctor_set(x_374, 2, x_373); -lean_ctor_set(x_374, 3, x_366); -lean_ctor_set(x_374, 4, x_367); -lean_ctor_set(x_374, 5, x_368); -if (lean_is_scalar(x_363)) { - x_375 = lean_alloc_ctor(1, 2, 0); +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_375 = x_363; -} -lean_ctor_set(x_375, 0, x_362); -lean_ctor_set(x_375, 1, x_374); -return x_375; + 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; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; -x_376 = lean_ctor_get(x_258, 0); -x_377 = lean_ctor_get(x_258, 1); -x_378 = lean_ctor_get(x_258, 2); -lean_inc(x_378); -lean_inc(x_377); -lean_inc(x_376); -lean_dec(x_258); -x_379 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_380 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_380, 0, x_376); -lean_ctor_set(x_380, 1, x_377); -lean_ctor_set(x_380, 2, x_379); -lean_ctor_set(x_253, 2, x_380); -x_381 = lean_ctor_get(x_5, 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_363, 1); lean_inc(x_381); -x_382 = lean_ctor_get(x_5, 1); +x_382 = lean_ctor_get(x_381, 2); lean_inc(x_382); -x_383 = lean_ctor_get(x_5, 2); +x_383 = lean_ctor_get(x_363, 0); lean_inc(x_383); -x_384 = lean_ctor_get(x_5, 3); -lean_inc(x_384); -x_385 = lean_ctor_get(x_5, 4); +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); +} +x_385 = lean_ctor_get(x_381, 0); lean_inc(x_385); -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_386 = x_5; +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_5); - x_386 = lean_box(0); + lean_dec_ref(x_381); + x_390 = lean_box(0); } -x_387 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_387, 0, x_254); -lean_ctor_set(x_387, 1, x_10); -x_388 = lean_array_push(x_383, x_387); -if (lean_is_scalar(x_386)) { - x_389 = lean_alloc_ctor(0, 5, 0); -} else { - x_389 = x_386; -} -lean_ctor_set(x_389, 0, x_381); -lean_ctor_set(x_389, 1, x_382); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_389, 3, x_384); -lean_ctor_set(x_389, 4, x_385); -x_390 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_256, x_4, x_389, x_253); -if (lean_obj_tag(x_390) == 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; lean_object* x_406; -x_391 = lean_ctor_get(x_390, 1); +x_391 = lean_ctor_get(x_382, 0); lean_inc(x_391); -x_392 = lean_ctor_get(x_391, 2); +x_392 = lean_ctor_get(x_382, 1); lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); +x_393 = lean_ctor_get(x_382, 3); lean_inc(x_393); -if (lean_is_exclusive(x_390)) { - lean_ctor_release(x_390, 0); - lean_ctor_release(x_390, 1); - x_394 = x_390; +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_390); + lean_dec_ref(x_382); x_394 = lean_box(0); } -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); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 3, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_401); -lean_ctor_set(x_404, 1, x_402); -lean_ctor_set(x_404, 2, x_378); -if (lean_is_scalar(x_400)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_400; -} -lean_ctor_set(x_405, 0, x_395); -lean_ctor_set(x_405, 1, x_396); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_397); -lean_ctor_set(x_405, 4, x_398); -lean_ctor_set(x_405, 5, x_399); if (lean_is_scalar(x_394)) { - x_406 = lean_alloc_ctor(0, 2, 0); + x_395 = lean_alloc_ctor(0, 4, 0); } else { - x_406 = x_394; + 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_274); +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(1, 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_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; } else { -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; -x_407 = lean_ctor_get(x_390, 1); +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_407, 2); +x_408 = lean_ctor_get(x_5, 4); lean_inc(x_408); -x_409 = lean_ctor_get(x_390, 0); -lean_inc(x_409); -if (lean_is_exclusive(x_390)) { - lean_ctor_release(x_390, 0); - lean_ctor_release(x_390, 1); - x_410 = x_390; -} else { - lean_dec_ref(x_390); - x_410 = lean_box(0); -} -x_411 = lean_ctor_get(x_407, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_407, 1); -lean_inc(x_412); -x_413 = lean_ctor_get(x_407, 3); -lean_inc(x_413); -x_414 = lean_ctor_get(x_407, 4); -lean_inc(x_414); -x_415 = lean_ctor_get(x_407, 5); -lean_inc(x_415); -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_416 = x_407; -} else { - lean_dec_ref(x_407); - x_416 = lean_box(0); -} -x_417 = lean_ctor_get(x_408, 0); -lean_inc(x_417); -x_418 = lean_ctor_get(x_408, 1); -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); - 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, 3, 0); -} else { - x_420 = x_419; -} -lean_ctor_set(x_420, 0, x_417); -lean_ctor_set(x_420, 1, x_418); -lean_ctor_set(x_420, 2, x_378); -if (lean_is_scalar(x_416)) { - x_421 = lean_alloc_ctor(0, 6, 0); -} else { - x_421 = x_416; -} -lean_ctor_set(x_421, 0, x_411); -lean_ctor_set(x_421, 1, x_412); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_413); -lean_ctor_set(x_421, 4, x_414); -lean_ctor_set(x_421, 5, x_415); -if (lean_is_scalar(x_410)) { - x_422 = lean_alloc_ctor(1, 2, 0); -} else { - x_422 = x_410; -} -lean_ctor_set(x_422, 0, x_409); -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; 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_423 = lean_ctor_get(x_253, 2); -x_424 = lean_ctor_get(x_253, 0); -x_425 = lean_ctor_get(x_253, 1); -x_426 = lean_ctor_get(x_253, 3); -x_427 = lean_ctor_get(x_253, 4); -x_428 = lean_ctor_get(x_253, 5); -lean_inc(x_428); -lean_inc(x_427); -lean_inc(x_426); -lean_inc(x_423); -lean_inc(x_425); -lean_inc(x_424); -lean_dec(x_253); -x_429 = lean_ctor_get(x_423, 0); -lean_inc(x_429); -x_430 = lean_ctor_get(x_423, 1); -lean_inc(x_430); -x_431 = lean_ctor_get(x_423, 2); -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); - x_432 = x_423; -} else { - lean_dec_ref(x_423); - x_432 = lean_box(0); -} -x_433 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_432)) { - x_434 = lean_alloc_ctor(0, 3, 0); -} else { - x_434 = x_432; -} -lean_ctor_set(x_434, 0, x_429); -lean_ctor_set(x_434, 1, x_430); -lean_ctor_set(x_434, 2, x_433); -x_435 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_435, 0, x_424); -lean_ctor_set(x_435, 1, x_425); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_426); -lean_ctor_set(x_435, 4, x_427); -lean_ctor_set(x_435, 5, x_428); -x_436 = lean_ctor_get(x_5, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_5, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_5, 2); -lean_inc(x_438); -x_439 = lean_ctor_get(x_5, 3); -lean_inc(x_439); -x_440 = lean_ctor_get(x_5, 4); -lean_inc(x_440); 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_441 = x_5; + x_409 = x_5; } else { lean_dec_ref(x_5); - x_441 = lean_box(0); + x_409 = lean_box(0); } -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_254); -lean_ctor_set(x_442, 1, x_10); -x_443 = lean_array_push(x_438, x_442); -if (lean_is_scalar(x_441)) { - x_444 = lean_alloc_ctor(0, 5, 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); } else { - x_444 = x_441; + x_412 = x_409; } -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___rarg(x_1, x_2, x_256, x_4, x_444, x_435); -if (lean_obj_tag(x_445) == 0) +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_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_446 = lean_ctor_get(x_445, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_446, 2); -lean_inc(x_447); -x_448 = lean_ctor_get(x_445, 0); -lean_inc(x_448); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - x_449 = x_445; +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_445); - x_449 = lean_box(0); + lean_dec_ref(x_413); + x_417 = lean_box(0); } -x_450 = lean_ctor_get(x_446, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_446, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_446, 3); -lean_inc(x_452); -x_453 = lean_ctor_get(x_446, 4); +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; +} +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); +} +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_400); +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(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; +} +} +} +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); -x_454 = lean_ctor_get(x_446, 5); +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); -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_455 = x_446; -} else { - lean_dec_ref(x_446); - x_455 = lean_box(0); -} -x_456 = lean_ctor_get(x_447, 0); +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_447, 1); +x_457 = lean_ctor_get(x_448, 3); lean_inc(x_457); -if (lean_is_exclusive(x_447)) { - lean_ctor_release(x_447, 0); - lean_ctor_release(x_447, 1); - lean_ctor_release(x_447, 2); - x_458 = x_447; +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; } else { - lean_dec_ref(x_447); + lean_dec_ref(x_448); x_458 = lean_box(0); } +x_459 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_458)) { - x_459 = lean_alloc_ctor(0, 3, 0); + x_460 = lean_alloc_ctor(0, 4, 0); } else { - x_459 = x_458; + x_460 = x_458; } -lean_ctor_set(x_459, 0, x_456); -lean_ctor_set(x_459, 1, x_457); -lean_ctor_set(x_459, 2, x_431); -if (lean_is_scalar(x_455)) { - x_460 = lean_alloc_ctor(0, 6, 0); -} else { - x_460 = x_455; -} -lean_ctor_set(x_460, 0, x_450); -lean_ctor_set(x_460, 1, x_451); +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_452); -lean_ctor_set(x_460, 4, x_453); -lean_ctor_set(x_460, 5, x_454); -if (lean_is_scalar(x_449)) { - x_461 = lean_alloc_ctor(0, 2, 0); -} else { - x_461 = x_449; -} -lean_ctor_set(x_461, 0, x_448); -lean_ctor_set(x_461, 1, x_460); -return x_461; -} -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; -x_462 = lean_ctor_get(x_445, 1); +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_462, 2); +x_463 = lean_ctor_get(x_5, 1); lean_inc(x_463); -x_464 = lean_ctor_get(x_445, 0); +x_464 = lean_ctor_get(x_5, 2); lean_inc(x_464); -if (lean_is_exclusive(x_445)) { - lean_ctor_release(x_445, 0); - lean_ctor_release(x_445, 1); - x_465 = x_445; -} else { - lean_dec_ref(x_445); - x_465 = lean_box(0); -} -x_466 = lean_ctor_get(x_462, 0); +x_465 = lean_ctor_get(x_5, 3); +lean_inc(x_465); +x_466 = lean_ctor_get(x_5, 4); lean_inc(x_466); -x_467 = lean_ctor_get(x_462, 1); -lean_inc(x_467); -x_468 = lean_ctor_get(x_462, 3); -lean_inc(x_468); -x_469 = lean_ctor_get(x_462, 4); -lean_inc(x_469); -x_470 = lean_ctor_get(x_462, 5); -lean_inc(x_470); -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); - lean_ctor_release(x_462, 4); - lean_ctor_release(x_462, 5); - x_471 = x_462; +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; } else { - lean_dec_ref(x_462); - x_471 = lean_box(0); + lean_dec_ref(x_5); + x_467 = lean_box(0); } -x_472 = lean_ctor_get(x_463, 0); +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); +} else { + x_470 = x_467; +} +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_463, 1); +x_473 = lean_ctor_get(x_472, 2); lean_inc(x_473); -if (lean_is_exclusive(x_463)) { - lean_ctor_release(x_463, 0); - lean_ctor_release(x_463, 1); - lean_ctor_release(x_463, 2); - x_474 = x_463; +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; } else { - lean_dec_ref(x_463); - x_474 = lean_box(0); + lean_dec_ref(x_471); + x_475 = lean_box(0); } -if (lean_is_scalar(x_474)) { - x_475 = lean_alloc_ctor(0, 3, 0); +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 { - x_475 = x_474; + lean_dec_ref(x_472); + x_481 = lean_box(0); } -lean_ctor_set(x_475, 0, x_472); -lean_ctor_set(x_475, 1, x_473); -lean_ctor_set(x_475, 2, x_431); -if (lean_is_scalar(x_471)) { - x_476 = lean_alloc_ctor(0, 6, 0); +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 { - x_476 = x_471; + lean_dec_ref(x_473); + x_485 = lean_box(0); } -lean_ctor_set(x_476, 0, x_466); -lean_ctor_set(x_476, 1, x_467); -lean_ctor_set(x_476, 2, x_475); -lean_ctor_set(x_476, 3, x_468); -lean_ctor_set(x_476, 4, x_469); -lean_ctor_set(x_476, 5, x_470); -if (lean_is_scalar(x_465)) { - x_477 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_485)) { + x_486 = lean_alloc_ctor(0, 4, 0); } else { - x_477 = x_465; + x_486 = x_485; } -lean_ctor_set(x_477, 0, x_464); -lean_ctor_set(x_477, 1, x_476); -return x_477; +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_478; +uint8_t x_506; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_478 = !lean_is_exclusive(x_247); -if (x_478 == 0) +x_506 = !lean_is_exclusive(x_261); +if (x_506 == 0) { -return x_247; +return x_261; } else { -lean_object* x_479; lean_object* x_480; lean_object* x_481; -x_479 = lean_ctor_get(x_247, 0); -x_480 = lean_ctor_get(x_247, 1); -lean_inc(x_480); -lean_inc(x_479); -lean_dec(x_247); -x_481 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_481, 0, x_479); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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; } } } @@ -10610,58 +10816,58 @@ return x_481; } else { -uint8_t x_482; +uint8_t x_510; 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_482 = !lean_is_exclusive(x_15); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_15); +if (x_510 == 0) { return x_15; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_15, 0); -x_484 = lean_ctor_get(x_15, 1); -lean_inc(x_484); -lean_inc(x_483); +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_dec(x_15); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } else { -uint8_t x_486; +uint8_t x_514; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_486 = !lean_is_exclusive(x_11); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_11); +if (x_514 == 0) { return x_11; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_11, 0); -x_488 = lean_ctor_get(x_11, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_11); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } @@ -11278,82 +11484,89 @@ return x_42; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; +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_53 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -lean_ctor_set(x_53, 2, x_36); -lean_ctor_set(x_43, 2, x_53); +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; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_54 = lean_ctor_get(x_43, 0); -x_55 = lean_ctor_get(x_43, 1); -x_56 = lean_ctor_get(x_43, 3); -x_57 = lean_ctor_get(x_43, 4); -x_58 = lean_ctor_get(x_43, 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; +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_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_43); -x_59 = lean_ctor_get(x_44, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_44, 1); +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); - x_61 = x_44; + lean_ctor_release(x_44, 3); + x_63 = x_44; } else { lean_dec_ref(x_44); - x_61 = lean_box(0); + x_63 = lean_box(0); } -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 4, 0); } else { - x_62 = x_61; + x_64 = x_63; } -lean_ctor_set(x_62, 0, x_59); -lean_ctor_set(x_62, 1, x_60); -lean_ctor_set(x_62, 2, x_36); -x_63 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_63, 0, x_54); -lean_ctor_set(x_63, 1, x_55); -lean_ctor_set(x_63, 2, x_62); -lean_ctor_set(x_63, 3, x_56); -lean_ctor_set(x_63, 4, x_57); -lean_ctor_set(x_63, 5, x_58); -lean_ctor_set(x_42, 1, 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, 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; } } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_64 = lean_ctor_get(x_42, 0); -lean_inc(x_64); -lean_dec(x_42); -x_65 = lean_ctor_get(x_43, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_43, 1); +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); -x_67 = lean_ctor_get(x_43, 3); +lean_dec(x_42); +x_67 = lean_ctor_get(x_43, 0); lean_inc(x_67); -x_68 = lean_ctor_get(x_43, 4); +x_68 = lean_ctor_get(x_43, 1); lean_inc(x_68); -x_69 = lean_ctor_get(x_43, 5); +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); @@ -11361,1897 +11574,1996 @@ if (lean_is_exclusive(x_43)) { lean_ctor_release(x_43, 3); lean_ctor_release(x_43, 4); lean_ctor_release(x_43, 5); - x_70 = x_43; + x_72 = x_43; } else { lean_dec_ref(x_43); - x_70 = lean_box(0); + x_72 = lean_box(0); } -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_44, 1); -lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +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); - x_73 = x_44; + lean_ctor_release(x_44, 3); + x_76 = x_44; } else { lean_dec_ref(x_44); - x_73 = lean_box(0); + x_76 = lean_box(0); } -if (lean_is_scalar(x_73)) { - x_74 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 4, 0); } else { - x_74 = x_73; + x_77 = x_76; } -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_36); -if (lean_is_scalar(x_70)) { - x_75 = lean_alloc_ctor(0, 6, 0); +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_75 = x_70; + x_78 = x_72; } -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); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_64); -lean_ctor_set(x_76, 1, x_75); -return x_76; +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; } } else { -lean_object* x_77; lean_object* x_78; uint8_t x_79; -x_77 = lean_ctor_get(x_42, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_77, 2); -lean_inc(x_78); -x_79 = !lean_is_exclusive(x_42); -if (x_79 == 0) -{ -lean_object* x_80; uint8_t x_81; +lean_object* x_80; lean_object* x_81; uint8_t x_82; x_80 = lean_ctor_get(x_42, 1); -lean_dec(x_80); -x_81 = !lean_is_exclusive(x_77); -if (x_81 == 0) +lean_inc(x_80); +x_81 = lean_ctor_get(x_80, 2); +lean_inc(x_81); +x_82 = !lean_is_exclusive(x_42); +if (x_82 == 0) { -lean_object* x_82; uint8_t x_83; -x_82 = lean_ctor_get(x_77, 2); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_78); -if (x_83 == 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_84; -x_84 = lean_ctor_get(x_78, 2); -lean_dec(x_84); -lean_ctor_set(x_78, 2, x_36); +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_85; lean_object* x_86; lean_object* x_87; -x_85 = lean_ctor_get(x_78, 0); -x_86 = lean_ctor_get(x_78, 1); -lean_inc(x_86); -lean_inc(x_85); -lean_dec(x_78); -x_87 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_87, 0, x_85); -lean_ctor_set(x_87, 1, x_86); -lean_ctor_set(x_87, 2, x_36); -lean_ctor_set(x_77, 2, x_87); -return x_42; -} -} -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; -x_88 = lean_ctor_get(x_77, 0); -x_89 = lean_ctor_get(x_77, 1); -x_90 = lean_ctor_get(x_77, 3); -x_91 = lean_ctor_get(x_77, 4); -x_92 = lean_ctor_get(x_77, 5); -lean_inc(x_92); -lean_inc(x_91); +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_77); -x_93 = lean_ctor_get(x_78, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_78, 1); -lean_inc(x_94); -if (lean_is_exclusive(x_78)) { - lean_ctor_release(x_78, 0); - lean_ctor_release(x_78, 1); - lean_ctor_release(x_78, 2); - x_95 = x_78; -} else { - lean_dec_ref(x_78); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 3, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_93); -lean_ctor_set(x_96, 1, x_94); -lean_ctor_set(x_96, 2, x_36); -x_97 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_89); -lean_ctor_set(x_97, 2, x_96); -lean_ctor_set(x_97, 3, x_90); -lean_ctor_set(x_97, 4, x_91); -lean_ctor_set(x_97, 5, x_92); -lean_ctor_set(x_42, 1, x_97); +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_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_98 = lean_ctor_get(x_42, 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_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); -lean_dec(x_42); -x_99 = lean_ctor_get(x_77, 0); +x_99 = lean_ctor_get(x_81, 3); lean_inc(x_99); -x_100 = lean_ctor_get(x_77, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_77, 3); -lean_inc(x_101); -x_102 = lean_ctor_get(x_77, 4); -lean_inc(x_102); -x_103 = lean_ctor_get(x_77, 5); +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; +} else { + lean_dec_ref(x_81); + x_100 = lean_box(0); +} +if (lean_is_scalar(x_100)) { + x_101 = lean_alloc_ctor(0, 4, 0); +} else { + x_101 = x_100; +} +lean_ctor_set(x_101, 0, x_97); +lean_ctor_set(x_101, 1, x_98); +lean_ctor_set(x_101, 2, x_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); -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_104 = x_77; -} else { - lean_dec_ref(x_77); - x_104 = lean_box(0); -} -x_105 = lean_ctor_get(x_78, 0); +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_78, 1); +x_106 = lean_ctor_get(x_80, 3); lean_inc(x_106); -if (lean_is_exclusive(x_78)) { - lean_ctor_release(x_78, 0); - lean_ctor_release(x_78, 1); - lean_ctor_release(x_78, 2); - x_107 = x_78; +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; } else { - lean_dec_ref(x_78); - x_107 = lean_box(0); + lean_dec_ref(x_80); + x_109 = lean_box(0); } -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 3, 0); +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 { - x_108 = x_107; + lean_dec_ref(x_81); + x_113 = lean_box(0); } -lean_ctor_set(x_108, 0, x_105); -lean_ctor_set(x_108, 1, x_106); -lean_ctor_set(x_108, 2, x_36); -if (lean_is_scalar(x_104)) { - x_109 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_113)) { + x_114 = lean_alloc_ctor(0, 4, 0); } else { - x_109 = x_104; + x_114 = x_113; } -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); -x_110 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_110, 0, x_98); -lean_ctor_set(x_110, 1, x_109); -return x_110; +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_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_111 = lean_ctor_get(x_4, 0); -x_112 = lean_ctor_get(x_4, 1); -x_113 = lean_ctor_get(x_4, 2); -x_114 = lean_ctor_get(x_4, 3); -x_115 = lean_ctor_get(x_4, 4); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_inc(x_111); -lean_dec(x_4); -x_116 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_116, 0, x_30); -lean_ctor_set(x_116, 1, x_18); -x_117 = lean_array_push(x_113, x_116); -x_118 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_118, 0, x_111); -lean_ctor_set(x_118, 1, x_112); -lean_ctor_set(x_118, 2, x_117); -lean_ctor_set(x_118, 3, x_114); -lean_ctor_set(x_118, 4, x_115); -x_119 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_118, x_29); -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; 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_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_120, 2); +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); -x_122 = lean_ctor_get(x_119, 0); -lean_inc(x_122); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_123 = x_119; -} else { - lean_dec_ref(x_119); - x_123 = lean_box(0); -} -x_124 = lean_ctor_get(x_120, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_120, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_120, 3); +lean_inc(x_120); +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_120, 4); +x_127 = lean_ctor_get(x_126, 2); lean_inc(x_127); -x_128 = lean_ctor_get(x_120, 5); +x_128 = lean_ctor_get(x_125, 0); lean_inc(x_128); -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); - lean_ctor_release(x_120, 5); - x_129 = x_120; +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_129 = x_125; } else { - lean_dec_ref(x_120); + lean_dec_ref(x_125); x_129 = lean_box(0); } -x_130 = lean_ctor_get(x_121, 0); +x_130 = lean_ctor_get(x_126, 0); lean_inc(x_130); -x_131 = lean_ctor_get(x_121, 1); +x_131 = lean_ctor_get(x_126, 1); lean_inc(x_131); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - x_132 = x_121; +x_132 = lean_ctor_get(x_126, 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; } else { - lean_dec_ref(x_121); - x_132 = lean_box(0); + lean_dec_ref(x_126); + x_135 = lean_box(0); } -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 3, 0); -} else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_130); -lean_ctor_set(x_133, 1, x_131); -lean_ctor_set(x_133, 2, x_36); -if (lean_is_scalar(x_129)) { - x_134 = lean_alloc_ctor(0, 6, 0); -} else { - x_134 = x_129; -} -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); -if (lean_is_scalar(x_123)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_123; -} -lean_ctor_set(x_135, 0, x_122); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} -else -{ -lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_136 = lean_ctor_get(x_119, 1); +x_136 = lean_ctor_get(x_127, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_136, 2); +x_137 = lean_ctor_get(x_127, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_119, 0); +x_138 = lean_ctor_get(x_127, 3); lean_inc(x_138); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_139 = x_119; +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; } else { - lean_dec_ref(x_119); + lean_dec_ref(x_127); x_139 = lean_box(0); } -x_140 = lean_ctor_get(x_136, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_136, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_136, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_136, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_136, 5); -lean_inc(x_144); -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_145 = x_136; -} else { - lean_dec_ref(x_136); - x_145 = lean_box(0); -} -x_146 = lean_ctor_get(x_137, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_137, 1); -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); - x_148 = x_137; -} else { - lean_dec_ref(x_137); - x_148 = lean_box(0); -} -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 3, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_146); -lean_ctor_set(x_149, 1, x_147); -lean_ctor_set(x_149, 2, x_36); -if (lean_is_scalar(x_145)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_145; -} -lean_ctor_set(x_150, 0, x_140); -lean_ctor_set(x_150, 1, x_141); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_142); -lean_ctor_set(x_150, 4, x_143); -lean_ctor_set(x_150, 5, x_144); if (lean_is_scalar(x_139)) { - x_151 = lean_alloc_ctor(1, 2, 0); + x_140 = lean_alloc_ctor(0, 4, 0); } else { - x_151 = x_139; + x_140 = x_139; } -lean_ctor_set(x_151, 0, x_138); -lean_ctor_set(x_151, 1, x_150); -return x_151; +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); +if (lean_is_scalar(x_129)) { + x_142 = lean_alloc_ctor(0, 2, 0); +} else { + x_142 = x_129; +} +lean_ctor_set(x_142, 0, x_128); +lean_ctor_set(x_142, 1, x_141); +return x_142; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_143 = lean_ctor_get(x_125, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_143, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_125, 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); +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; +} else { + lean_dec_ref(x_143); + x_152 = 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; +} else { + lean_dec_ref(x_144); + x_156 = lean_box(0); +} +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_36); +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); +if (lean_is_scalar(x_146)) { + x_159 = lean_alloc_ctor(1, 2, 0); +} else { + x_159 = x_146; +} +lean_ctor_set(x_159, 0, x_145); +lean_ctor_set(x_159, 1, x_158); +return x_159; } } } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_152 = lean_ctor_get(x_34, 0); -x_153 = lean_ctor_get(x_34, 1); -x_154 = lean_ctor_get(x_34, 2); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); -lean_dec(x_34); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_156, 0, x_152); -lean_ctor_set(x_156, 1, x_153); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_29, 2, x_156); -x_157 = lean_ctor_get(x_4, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_4, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_4, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_4, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_4, 4); +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); 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_162 = x_4; + x_171 = x_4; } else { lean_dec_ref(x_4); - x_162 = lean_box(0); + x_171 = lean_box(0); } -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_30); -lean_ctor_set(x_163, 1, x_18); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 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); } else { - x_165 = x_162; + x_174 = x_171; } -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_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_165, x_29); -if (lean_obj_tag(x_166) == 0) +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_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_167 = lean_ctor_get(x_166, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_167, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_166, 0); -lean_inc(x_169); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_170 = x_166; -} else { - lean_dec_ref(x_166); - x_170 = lean_box(0); -} -x_171 = lean_ctor_get(x_167, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_167, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_167, 3); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 4); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 5); -lean_inc(x_175); -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_176 = x_167; -} else { - lean_dec_ref(x_167); - x_176 = lean_box(0); -} -x_177 = lean_ctor_get(x_168, 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_168, 1); +x_178 = lean_ctor_get(x_175, 0); 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); - x_179 = x_168; +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_168); + lean_dec_ref(x_175); x_179 = lean_box(0); } -if (lean_is_scalar(x_179)) { - x_180 = lean_alloc_ctor(0, 3, 0); -} else { - x_180 = x_179; -} -lean_ctor_set(x_180, 0, x_177); -lean_ctor_set(x_180, 1, x_178); -lean_ctor_set(x_180, 2, x_154); -if (lean_is_scalar(x_176)) { - x_181 = lean_alloc_ctor(0, 6, 0); -} else { - x_181 = x_176; -} -lean_ctor_set(x_181, 0, x_171); -lean_ctor_set(x_181, 1, x_172); -lean_ctor_set(x_181, 2, x_180); -lean_ctor_set(x_181, 3, x_173); -lean_ctor_set(x_181, 4, x_174); -lean_ctor_set(x_181, 5, x_175); -if (lean_is_scalar(x_170)) { - x_182 = lean_alloc_ctor(0, 2, 0); -} else { - x_182 = x_170; -} -lean_ctor_set(x_182, 0, x_169); -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; -x_183 = lean_ctor_get(x_166, 1); +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_183, 2); +x_184 = lean_ctor_get(x_176, 5); lean_inc(x_184); -x_185 = lean_ctor_get(x_166, 0); -lean_inc(x_185); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_186 = x_166; +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_166); - x_186 = lean_box(0); + lean_dec_ref(x_176); + x_185 = lean_box(0); } -x_187 = lean_ctor_get(x_183, 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_183, 1); +x_188 = lean_ctor_get(x_177, 3); lean_inc(x_188); -x_189 = lean_ctor_get(x_183, 3); -lean_inc(x_189); -x_190 = lean_ctor_get(x_183, 4); -lean_inc(x_190); -x_191 = lean_ctor_get(x_183, 5); -lean_inc(x_191); -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_192 = x_183; +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_183); - x_192 = lean_box(0); + lean_dec_ref(x_177); + x_189 = lean_box(0); } -x_193 = lean_ctor_get(x_184, 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; +} +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_inc(x_193); -x_194 = lean_ctor_get(x_184, 1); +x_194 = lean_ctor_get(x_193, 2); 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); - x_195 = x_184; +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; } else { - lean_dec_ref(x_184); - x_195 = lean_box(0); + lean_dec_ref(x_175); + x_196 = lean_box(0); } -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 4); +lean_inc(x_200); +x_201 = lean_ctor_get(x_193, 5); +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 { - x_196 = x_195; + lean_dec_ref(x_193); + x_202 = lean_box(0); } -lean_ctor_set(x_196, 0, x_193); -lean_ctor_set(x_196, 1, x_194); -lean_ctor_set(x_196, 2, x_154); -if (lean_is_scalar(x_192)) { - x_197 = lean_alloc_ctor(0, 6, 0); +x_203 = lean_ctor_get(x_194, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_194, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_194, 3); +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; } else { - x_197 = x_192; + lean_dec_ref(x_194); + x_206 = lean_box(0); } -lean_ctor_set(x_197, 0, x_187); -lean_ctor_set(x_197, 1, x_188); -lean_ctor_set(x_197, 2, x_196); -lean_ctor_set(x_197, 3, x_189); -lean_ctor_set(x_197, 4, x_190); -lean_ctor_set(x_197, 5, x_191); -if (lean_is_scalar(x_186)) { - x_198 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); } else { - x_198 = x_186; + x_207 = x_206; } -lean_ctor_set(x_198, 0, x_185); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_208 = x_202; +} +lean_ctor_set(x_208, 0, x_197); +lean_ctor_set(x_208, 1, x_198); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_199); +lean_ctor_set(x_208, 4, x_200); +lean_ctor_set(x_208, 5, x_201); +if (lean_is_scalar(x_196)) { + x_209 = lean_alloc_ctor(1, 2, 0); +} else { + x_209 = x_196; +} +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; } } } 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; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; -x_199 = lean_ctor_get(x_29, 2); -x_200 = lean_ctor_get(x_29, 0); -x_201 = lean_ctor_get(x_29, 1); -x_202 = lean_ctor_get(x_29, 3); -x_203 = lean_ctor_get(x_29, 4); -x_204 = lean_ctor_get(x_29, 5); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_inc(x_199); -lean_inc(x_201); -lean_inc(x_200); -lean_dec(x_29); -x_205 = lean_ctor_get(x_199, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_199, 1); -lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 2); -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); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_208)) { - x_210 = lean_alloc_ctor(0, 3, 0); -} else { - x_210 = x_208; -} -lean_ctor_set(x_210, 0, x_205); -lean_ctor_set(x_210, 1, x_206); -lean_ctor_set(x_210, 2, x_209); -x_211 = lean_alloc_ctor(0, 6, 0); -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); -x_212 = lean_ctor_get(x_4, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_4, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_4, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_4, 3); +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); -x_216 = lean_ctor_get(x_4, 4); +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_217 = x_4; + x_229 = x_4; } else { lean_dec_ref(x_4); - x_217 = lean_box(0); + x_229 = lean_box(0); } -x_218 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_218, 0, x_30); -lean_ctor_set(x_218, 1, x_18); -x_219 = lean_array_push(x_214, x_218); -if (lean_is_scalar(x_217)) { - x_220 = lean_alloc_ctor(0, 5, 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_220 = x_217; + x_232 = x_229; } -lean_ctor_set(x_220, 0, x_212); -lean_ctor_set(x_220, 1, x_213); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_215); -lean_ctor_set(x_220, 4, x_216); -x_221 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_220, x_211); -if (lean_obj_tag(x_221) == 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_isClassExpensive___main___spec__3(x_1, x_2, x_32, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; -x_222 = lean_ctor_get(x_221, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_222, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_221, 0); -lean_inc(x_224); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_225 = x_221; +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_221); - x_225 = lean_box(0); + lean_dec_ref(x_233); + x_237 = lean_box(0); } -x_226 = lean_ctor_get(x_222, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_222, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_222, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_222, 4); -lean_inc(x_229); -x_230 = lean_ctor_get(x_222, 5); -lean_inc(x_230); -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_231 = x_222; +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_222); - x_231 = lean_box(0); + lean_dec_ref(x_234); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_223, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_223, 1); -lean_inc(x_233); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - lean_ctor_release(x_223, 2); - x_234 = x_223; +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_223); - x_234 = lean_box(0); + lean_dec_ref(x_235); + x_247 = lean_box(0); } -if (lean_is_scalar(x_234)) { - x_235 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_247)) { + x_248 = lean_alloc_ctor(0, 4, 0); } else { - x_235 = x_234; + x_248 = x_247; } -lean_ctor_set(x_235, 0, x_232); -lean_ctor_set(x_235, 1, x_233); -lean_ctor_set(x_235, 2, x_207); -if (lean_is_scalar(x_231)) { - x_236 = lean_alloc_ctor(0, 6, 0); +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_236 = x_231; + x_249 = x_243; } -lean_ctor_set(x_236, 0, x_226); -lean_ctor_set(x_236, 1, x_227); -lean_ctor_set(x_236, 2, x_235); -lean_ctor_set(x_236, 3, x_228); -lean_ctor_set(x_236, 4, x_229); -lean_ctor_set(x_236, 5, x_230); -if (lean_is_scalar(x_225)) { - x_237 = lean_alloc_ctor(0, 2, 0); +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_237 = x_225; + x_250 = x_237; } -lean_ctor_set(x_237, 0, x_224); -lean_ctor_set(x_237, 1, x_236); -return 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_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; -x_238 = lean_ctor_get(x_221, 1); -lean_inc(x_238); -x_239 = lean_ctor_get(x_238, 2); -lean_inc(x_239); -x_240 = lean_ctor_get(x_221, 0); -lean_inc(x_240); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_241 = x_221; +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_221); - x_241 = lean_box(0); + lean_dec_ref(x_233); + x_254 = 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; +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_238); - x_247 = lean_box(0); + lean_dec_ref(x_251); + x_260 = 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); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - lean_ctor_release(x_239, 2); - x_250 = x_239; +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_239); - x_250 = lean_box(0); + lean_dec_ref(x_252); + x_264 = lean_box(0); } -if (lean_is_scalar(x_250)) { - x_251 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(0, 4, 0); } else { - x_251 = x_250; + x_265 = x_264; } -lean_ctor_set(x_251, 0, x_248); -lean_ctor_set(x_251, 1, x_249); -lean_ctor_set(x_251, 2, x_207); -if (lean_is_scalar(x_247)) { - x_252 = lean_alloc_ctor(0, 6, 0); +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_252 = x_247; + x_266 = x_260; } -lean_ctor_set(x_252, 0, x_242); -lean_ctor_set(x_252, 1, x_243); -lean_ctor_set(x_252, 2, x_251); -lean_ctor_set(x_252, 3, x_244); -lean_ctor_set(x_252, 4, x_245); -lean_ctor_set(x_252, 5, x_246); -if (lean_is_scalar(x_241)) { - x_253 = lean_alloc_ctor(1, 2, 0); +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_253 = x_241; + x_267 = x_254; } -lean_ctor_set(x_253, 0, x_240); -lean_ctor_set(x_253, 1, x_252); -return x_253; +lean_ctor_set(x_267, 0, x_253); +lean_ctor_set(x_267, 1, x_266); +return x_267; } } } default: { -lean_object* x_254; lean_object* x_255; -x_254 = lean_ctor_get(x_23, 1); -lean_inc(x_254); +lean_object* x_268; lean_object* x_269; +x_268 = lean_ctor_get(x_23, 1); +lean_inc(x_268); lean_dec(x_23); lean_inc(x_4); -x_255 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_254); -if (lean_obj_tag(x_255) == 0) +x_269 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_268); +if (lean_obj_tag(x_269) == 0) { -lean_object* x_256; -x_256 = lean_ctor_get(x_255, 0); -lean_inc(x_256); -if (lean_obj_tag(x_256) == 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_257; lean_object* x_258; lean_object* x_259; +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_dec(x_18); -x_257 = lean_ctor_get(x_255, 1); -lean_inc(x_257); -lean_dec(x_255); -x_258 = lean_unsigned_to_nat(1u); -x_259 = lean_nat_add(x_3, x_258); +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); lean_dec(x_3); -x_3 = x_259; -x_5 = x_257; +x_3 = x_273; +x_5 = x_271; goto _start; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; uint8_t x_265; -x_261 = lean_ctor_get(x_255, 1); -lean_inc(x_261); -lean_dec(x_255); -x_262 = lean_ctor_get(x_256, 0); -lean_inc(x_262); -lean_dec(x_256); -x_263 = lean_unsigned_to_nat(1u); -x_264 = lean_nat_add(x_3, x_263); -lean_dec(x_3); -x_265 = !lean_is_exclusive(x_261); -if (x_265 == 0) -{ -lean_object* x_266; uint8_t x_267; -x_266 = lean_ctor_get(x_261, 2); -x_267 = !lean_is_exclusive(x_266); -if (x_267 == 0) -{ -lean_object* x_268; lean_object* x_269; uint8_t x_270; -x_268 = lean_ctor_get(x_266, 2); -x_269 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_266, 2, x_269); -x_270 = !lean_is_exclusive(x_4); -if (x_270 == 0) -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; -x_271 = lean_ctor_get(x_4, 2); -x_272 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_272, 0, x_262); -lean_ctor_set(x_272, 1, x_18); -x_273 = lean_array_push(x_271, x_272); -lean_ctor_set(x_4, 2, x_273); -x_274 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_264, x_4, x_261); -if (lean_obj_tag(x_274) == 0) -{ -lean_object* x_275; lean_object* x_276; uint8_t x_277; -x_275 = lean_ctor_get(x_274, 1); +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); -x_276 = lean_ctor_get(x_275, 2); +lean_dec(x_269); +x_276 = lean_ctor_get(x_270, 0); lean_inc(x_276); -x_277 = !lean_is_exclusive(x_274); -if (x_277 == 0) -{ -lean_object* x_278; uint8_t x_279; -x_278 = lean_ctor_get(x_274, 1); -lean_dec(x_278); +lean_dec(x_270); +x_277 = lean_unsigned_to_nat(1u); +x_278 = lean_nat_add(x_3, x_277); +lean_dec(x_3); x_279 = !lean_is_exclusive(x_275); if (x_279 == 0) { lean_object* x_280; uint8_t x_281; x_280 = lean_ctor_get(x_275, 2); -lean_dec(x_280); -x_281 = !lean_is_exclusive(x_276); +x_281 = !lean_is_exclusive(x_280); if (x_281 == 0) { -lean_object* x_282; -x_282 = lean_ctor_get(x_276, 2); -lean_dec(x_282); -lean_ctor_set(x_276, 2, x_268); -return x_274; -} -else +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_283; lean_object* x_284; lean_object* x_285; -x_283 = lean_ctor_get(x_276, 0); -x_284 = lean_ctor_get(x_276, 1); -lean_inc(x_284); -lean_inc(x_283); -lean_dec(x_276); -x_285 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_285, 0, x_283); -lean_ctor_set(x_285, 1, x_284); -lean_ctor_set(x_285, 2, x_268); -lean_ctor_set(x_275, 2, x_285); -return x_274; -} -} -else +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_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_286 = lean_ctor_get(x_275, 0); -x_287 = lean_ctor_get(x_275, 1); -x_288 = lean_ctor_get(x_275, 3); -x_289 = lean_ctor_get(x_275, 4); -x_290 = lean_ctor_get(x_275, 5); -lean_inc(x_290); +lean_object* x_289; lean_object* x_290; uint8_t x_291; +x_289 = lean_ctor_get(x_288, 1); lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_dec(x_275); -x_291 = lean_ctor_get(x_276, 0); -lean_inc(x_291); -x_292 = lean_ctor_get(x_276, 1); -lean_inc(x_292); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - x_293 = x_276; -} else { - lean_dec_ref(x_276); - x_293 = lean_box(0); -} -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 3, 0); -} else { - x_294 = x_293; -} -lean_ctor_set(x_294, 0, x_291); -lean_ctor_set(x_294, 1, x_292); -lean_ctor_set(x_294, 2, x_268); -x_295 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_295, 0, x_286); -lean_ctor_set(x_295, 1, x_287); -lean_ctor_set(x_295, 2, x_294); -lean_ctor_set(x_295, 3, x_288); -lean_ctor_set(x_295, 4, x_289); -lean_ctor_set(x_295, 5, x_290); -lean_ctor_set(x_274, 1, x_295); -return x_274; -} +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_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_296 = lean_ctor_get(x_274, 0); -lean_inc(x_296); -lean_dec(x_274); -x_297 = lean_ctor_get(x_275, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_275, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_275, 3); +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); -x_300 = lean_ctor_get(x_275, 4); -lean_inc(x_300); -x_301 = lean_ctor_get(x_275, 5); -lean_inc(x_301); -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); - lean_ctor_release(x_275, 4); - lean_ctor_release(x_275, 5); - x_302 = x_275; -} else { - lean_dec_ref(x_275); - x_302 = lean_box(0); +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; } -x_303 = lean_ctor_get(x_276, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_276, 1); +} +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); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - x_305 = x_276; +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_inc(x_307); +x_308 = lean_ctor_get(x_290, 3); +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_276); - x_305 = lean_box(0); + lean_dec_ref(x_290); + x_309 = lean_box(0); } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_309)) { + x_310 = lean_alloc_ctor(0, 4, 0); } else { - x_306 = x_305; + x_310 = x_309; } -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_268); -if (lean_is_scalar(x_302)) { - x_307 = lean_alloc_ctor(0, 6, 0); -} else { - x_307 = x_302; -} -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); -x_308 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_308, 0, x_296); -lean_ctor_set(x_308, 1, x_307); -return x_308; +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_309; lean_object* x_310; uint8_t x_311; -x_309 = lean_ctor_get(x_274, 1); -lean_inc(x_309); -x_310 = lean_ctor_get(x_309, 2); -lean_inc(x_310); -x_311 = !lean_is_exclusive(x_274); -if (x_311 == 0) -{ -lean_object* x_312; uint8_t x_313; -x_312 = lean_ctor_get(x_274, 1); -lean_dec(x_312); -x_313 = !lean_is_exclusive(x_309); -if (x_313 == 0) -{ -lean_object* x_314; uint8_t x_315; -x_314 = lean_ctor_get(x_309, 2); -lean_dec(x_314); -x_315 = !lean_is_exclusive(x_310); -if (x_315 == 0) -{ -lean_object* x_316; -x_316 = lean_ctor_get(x_310, 2); -lean_dec(x_316); -lean_ctor_set(x_310, 2, x_268); -return x_274; -} -else -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; -x_317 = lean_ctor_get(x_310, 0); -x_318 = lean_ctor_get(x_310, 1); -lean_inc(x_318); +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_inc(x_317); -lean_dec(x_310); -x_319 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_319, 0, x_317); -lean_ctor_set(x_319, 1, x_318); -lean_ctor_set(x_319, 2, x_268); -lean_ctor_set(x_309, 2, x_319); -return x_274; +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); } -} -else -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_320 = lean_ctor_get(x_309, 0); -x_321 = lean_ctor_get(x_309, 1); -x_322 = lean_ctor_get(x_309, 3); -x_323 = lean_ctor_get(x_309, 4); -x_324 = lean_ctor_get(x_309, 5); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); +x_319 = lean_ctor_get(x_290, 0); +lean_inc(x_319); +x_320 = lean_ctor_get(x_290, 1); lean_inc(x_320); -lean_dec(x_309); -x_325 = lean_ctor_get(x_310, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_310, 1); +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); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - x_327 = x_310; -} else { - lean_dec_ref(x_310); - x_327 = lean_box(0); -} -if (lean_is_scalar(x_327)) { - x_328 = lean_alloc_ctor(0, 3, 0); -} else { - x_328 = x_327; -} -lean_ctor_set(x_328, 0, x_325); -lean_ctor_set(x_328, 1, x_326); -lean_ctor_set(x_328, 2, x_268); -x_329 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_329, 0, x_320); -lean_ctor_set(x_329, 1, x_321); -lean_ctor_set(x_329, 2, x_328); -lean_ctor_set(x_329, 3, x_322); -lean_ctor_set(x_329, 4, x_323); -lean_ctor_set(x_329, 5, x_324); -lean_ctor_set(x_274, 1, x_329); -return x_274; -} +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_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; -x_330 = lean_ctor_get(x_274, 0); -lean_inc(x_330); -lean_dec(x_274); -x_331 = lean_ctor_get(x_309, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_309, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_309, 3); -lean_inc(x_333); -x_334 = lean_ctor_get(x_309, 4); -lean_inc(x_334); -x_335 = lean_ctor_get(x_309, 5); +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); -if (lean_is_exclusive(x_309)) { - lean_ctor_release(x_309, 0); - lean_ctor_release(x_309, 1); - lean_ctor_release(x_309, 2); - lean_ctor_release(x_309, 3); - lean_ctor_release(x_309, 4); - lean_ctor_release(x_309, 5); - x_336 = x_309; -} else { - lean_dec_ref(x_309); - x_336 = lean_box(0); -} -x_337 = lean_ctor_get(x_310, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_310, 1); -lean_inc(x_338); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - x_339 = x_310; -} else { - lean_dec_ref(x_310); - x_339 = lean_box(0); -} -if (lean_is_scalar(x_339)) { - x_340 = lean_alloc_ctor(0, 3, 0); -} else { - x_340 = x_339; -} -lean_ctor_set(x_340, 0, x_337); -lean_ctor_set(x_340, 1, x_338); -lean_ctor_set(x_340, 2, x_268); -if (lean_is_scalar(x_336)) { - x_341 = lean_alloc_ctor(0, 6, 0); -} else { - x_341 = x_336; -} -lean_ctor_set(x_341, 0, x_331); -lean_ctor_set(x_341, 1, x_332); -lean_ctor_set(x_341, 2, x_340); -lean_ctor_set(x_341, 3, x_333); -lean_ctor_set(x_341, 4, x_334); -lean_ctor_set(x_341, 5, x_335); -x_342 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_342, 0, x_330); -lean_ctor_set(x_342, 1, x_341); -return x_342; -} +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_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_343 = lean_ctor_get(x_4, 0); -x_344 = lean_ctor_get(x_4, 1); -x_345 = lean_ctor_get(x_4, 2); -x_346 = lean_ctor_get(x_4, 3); -x_347 = lean_ctor_get(x_4, 4); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); +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); -lean_dec(x_4); -x_348 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_348, 0, x_262); -lean_ctor_set(x_348, 1, x_18); -x_349 = lean_array_push(x_345, x_348); -x_350 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_350, 0, x_343); -lean_ctor_set(x_350, 1, x_344); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_346); -lean_ctor_set(x_350, 4, x_347); -x_351 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_264, x_350, x_261); -if (lean_obj_tag(x_351) == 0) -{ -lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; -x_352 = lean_ctor_get(x_351, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_352, 2); -lean_inc(x_353); -x_354 = lean_ctor_get(x_351, 0); -lean_inc(x_354); -if (lean_is_exclusive(x_351)) { - lean_ctor_release(x_351, 0); - lean_ctor_release(x_351, 1); - x_355 = x_351; +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_351); + 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_352, 0); +x_356 = lean_ctor_get(x_327, 0); lean_inc(x_356); -x_357 = lean_ctor_get(x_352, 1); +x_357 = lean_ctor_get(x_327, 1); lean_inc(x_357); -x_358 = lean_ctor_get(x_352, 3); +x_358 = lean_ctor_get(x_327, 3); lean_inc(x_358); -x_359 = lean_ctor_get(x_352, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_352, 5); -lean_inc(x_360); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - lean_ctor_release(x_352, 2); - lean_ctor_release(x_352, 3); - lean_ctor_release(x_352, 4); - lean_ctor_release(x_352, 5); - x_361 = x_352; +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_352); - x_361 = lean_box(0); + lean_dec_ref(x_327); + x_359 = lean_box(0); } -x_362 = lean_ctor_get(x_353, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_353, 1); -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); - x_364 = x_353; +if (lean_is_scalar(x_359)) { + x_360 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_353); - x_364 = lean_box(0); + x_360 = x_359; } -if (lean_is_scalar(x_364)) { - x_365 = lean_alloc_ctor(0, 3, 0); -} else { - x_365 = x_364; -} -lean_ctor_set(x_365, 0, x_362); -lean_ctor_set(x_365, 1, x_363); -lean_ctor_set(x_365, 2, x_268); -if (lean_is_scalar(x_361)) { - x_366 = lean_alloc_ctor(0, 6, 0); -} else { - x_366 = x_361; -} -lean_ctor_set(x_366, 0, x_356); -lean_ctor_set(x_366, 1, x_357); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_358); -lean_ctor_set(x_366, 4, x_359); -lean_ctor_set(x_366, 5, x_360); +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_367 = lean_alloc_ctor(0, 2, 0); + x_361 = lean_alloc_ctor(0, 6, 0); } else { - x_367 = x_355; + 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; +} } -lean_ctor_set(x_367, 0, x_354); -lean_ctor_set(x_367, 1, x_366); -return x_367; } else { -lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_368 = lean_ctor_get(x_351, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_351, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_351)) { - lean_ctor_release(x_351, 0); - lean_ctor_release(x_351, 1); - x_371 = x_351; -} else { - lean_dec_ref(x_351); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); +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_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) +{ +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_368, 1); +x_373 = lean_ctor_get(x_372, 2); lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); +x_374 = lean_ctor_get(x_371, 0); lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); +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); -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); +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_369, 1); +x_379 = lean_ctor_get(x_372, 4); lean_inc(x_379); -if (lean_is_exclusive(x_369)) { - lean_ctor_release(x_369, 0); - lean_ctor_release(x_369, 1); - lean_ctor_release(x_369, 2); - x_380 = x_369; +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_369); - x_380 = lean_box(0); + lean_dec_ref(x_372); + x_381 = lean_box(0); } -if (lean_is_scalar(x_380)) { - x_381 = lean_alloc_ctor(0, 3, 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 { - x_381 = x_380; + lean_dec_ref(x_373); + x_385 = lean_box(0); } -lean_ctor_set(x_381, 0, x_378); -lean_ctor_set(x_381, 1, x_379); -lean_ctor_set(x_381, 2, x_268); -if (lean_is_scalar(x_377)) { - x_382 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_385)) { + x_386 = lean_alloc_ctor(0, 4, 0); } else { - x_382 = x_377; + x_386 = x_385; } -lean_ctor_set(x_382, 0, x_372); -lean_ctor_set(x_382, 1, x_373); -lean_ctor_set(x_382, 2, x_381); -lean_ctor_set(x_382, 3, x_374); -lean_ctor_set(x_382, 4, x_375); -lean_ctor_set(x_382, 5, x_376); -if (lean_is_scalar(x_371)) { - x_383 = lean_alloc_ctor(1, 2, 0); +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_383 = x_371; -} -lean_ctor_set(x_383, 0, x_370); -lean_ctor_set(x_383, 1, x_382); -return x_383; + 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; } 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; -x_384 = lean_ctor_get(x_266, 0); -x_385 = lean_ctor_get(x_266, 1); -x_386 = lean_ctor_get(x_266, 2); -lean_inc(x_386); -lean_inc(x_385); -lean_inc(x_384); -lean_dec(x_266); -x_387 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_388 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_388, 0, x_384); -lean_ctor_set(x_388, 1, x_385); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_261, 2, x_388); -x_389 = lean_ctor_get(x_4, 0); +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_4, 1); +x_390 = lean_ctor_get(x_389, 2); lean_inc(x_390); -x_391 = lean_ctor_get(x_4, 2); +x_391 = lean_ctor_get(x_371, 0); lean_inc(x_391); -x_392 = lean_ctor_get(x_4, 3); -lean_inc(x_392); -x_393 = lean_ctor_get(x_4, 4); +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); +} +x_393 = lean_ctor_get(x_389, 0); lean_inc(x_393); -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_394 = x_4; +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_4); - x_394 = lean_box(0); + lean_dec_ref(x_389); + x_398 = lean_box(0); } -x_395 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_395, 0, x_262); -lean_ctor_set(x_395, 1, x_18); -x_396 = lean_array_push(x_391, x_395); -if (lean_is_scalar(x_394)) { - x_397 = lean_alloc_ctor(0, 5, 0); -} else { - x_397 = x_394; -} -lean_ctor_set(x_397, 0, x_389); -lean_ctor_set(x_397, 1, x_390); -lean_ctor_set(x_397, 2, x_396); -lean_ctor_set(x_397, 3, x_392); -lean_ctor_set(x_397, 4, x_393); -x_398 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_264, x_397, x_261); -if (lean_obj_tag(x_398) == 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; lean_object* x_414; -x_399 = lean_ctor_get(x_398, 1); +x_399 = lean_ctor_get(x_390, 0); lean_inc(x_399); -x_400 = lean_ctor_get(x_399, 2); +x_400 = lean_ctor_get(x_390, 1); lean_inc(x_400); -x_401 = lean_ctor_get(x_398, 0); +x_401 = lean_ctor_get(x_390, 3); lean_inc(x_401); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - x_402 = 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); + x_402 = x_390; } else { - lean_dec_ref(x_398); + lean_dec_ref(x_390); x_402 = lean_box(0); } -x_403 = lean_ctor_get(x_399, 0); -lean_inc(x_403); -x_404 = lean_ctor_get(x_399, 1); -lean_inc(x_404); -x_405 = lean_ctor_get(x_399, 3); -lean_inc(x_405); -x_406 = lean_ctor_get(x_399, 4); -lean_inc(x_406); -x_407 = lean_ctor_get(x_399, 5); -lean_inc(x_407); -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_408 = x_399; -} else { - lean_dec_ref(x_399); - x_408 = lean_box(0); -} -x_409 = lean_ctor_get(x_400, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_400, 1); -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); - x_411 = x_400; -} else { - lean_dec_ref(x_400); - x_411 = lean_box(0); -} -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 3, 0); -} else { - x_412 = x_411; -} -lean_ctor_set(x_412, 0, x_409); -lean_ctor_set(x_412, 1, x_410); -lean_ctor_set(x_412, 2, x_386); -if (lean_is_scalar(x_408)) { - x_413 = lean_alloc_ctor(0, 6, 0); -} else { - x_413 = x_408; -} -lean_ctor_set(x_413, 0, x_403); -lean_ctor_set(x_413, 1, x_404); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_405); -lean_ctor_set(x_413, 4, x_406); -lean_ctor_set(x_413, 5, x_407); if (lean_is_scalar(x_402)) { - x_414 = lean_alloc_ctor(0, 2, 0); + x_403 = lean_alloc_ctor(0, 4, 0); } else { - x_414 = x_402; + x_403 = x_402; +} +lean_ctor_set(x_403, 0, x_399); +lean_ctor_set(x_403, 1, x_400); +lean_ctor_set(x_403, 2, x_282); +lean_ctor_set(x_403, 3, x_401); +if (lean_is_scalar(x_398)) { + x_404 = lean_alloc_ctor(0, 6, 0); +} else { + x_404 = x_398; +} +lean_ctor_set(x_404, 0, x_393); +lean_ctor_set(x_404, 1, x_394); +lean_ctor_set(x_404, 2, x_403); +lean_ctor_set(x_404, 3, x_395); +lean_ctor_set(x_404, 4, x_396); +lean_ctor_set(x_404, 5, x_397); +if (lean_is_scalar(x_392)) { + x_405 = lean_alloc_ctor(1, 2, 0); +} else { + x_405 = x_392; +} +lean_ctor_set(x_405, 0, x_391); +lean_ctor_set(x_405, 1, x_404); +return x_405; +} } -lean_ctor_set(x_414, 0, x_401); -lean_ctor_set(x_414, 1, x_413); -return x_414; } else { -lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; -x_415 = lean_ctor_get(x_398, 1); +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; +x_406 = lean_ctor_get(x_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_415, 2); +x_416 = lean_ctor_get(x_4, 4); lean_inc(x_416); -x_417 = lean_ctor_get(x_398, 0); -lean_inc(x_417); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - x_418 = x_398; -} else { - lean_dec_ref(x_398); - x_418 = lean_box(0); -} -x_419 = lean_ctor_get(x_415, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_415, 1); -lean_inc(x_420); -x_421 = lean_ctor_get(x_415, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_415, 4); -lean_inc(x_422); -x_423 = lean_ctor_get(x_415, 5); -lean_inc(x_423); -if (lean_is_exclusive(x_415)) { - lean_ctor_release(x_415, 0); - lean_ctor_release(x_415, 1); - lean_ctor_release(x_415, 2); - lean_ctor_release(x_415, 3); - lean_ctor_release(x_415, 4); - lean_ctor_release(x_415, 5); - x_424 = x_415; -} else { - lean_dec_ref(x_415); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_416, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_416, 1); -lean_inc(x_426); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - lean_ctor_release(x_416, 2); - x_427 = x_416; -} else { - lean_dec_ref(x_416); - x_427 = lean_box(0); -} -if (lean_is_scalar(x_427)) { - x_428 = lean_alloc_ctor(0, 3, 0); -} else { - x_428 = x_427; -} -lean_ctor_set(x_428, 0, x_425); -lean_ctor_set(x_428, 1, x_426); -lean_ctor_set(x_428, 2, x_386); -if (lean_is_scalar(x_424)) { - x_429 = lean_alloc_ctor(0, 6, 0); -} else { - x_429 = x_424; -} -lean_ctor_set(x_429, 0, x_419); -lean_ctor_set(x_429, 1, x_420); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_421); -lean_ctor_set(x_429, 4, x_422); -lean_ctor_set(x_429, 5, x_423); -if (lean_is_scalar(x_418)) { - x_430 = lean_alloc_ctor(1, 2, 0); -} else { - x_430 = x_418; -} -lean_ctor_set(x_430, 0, x_417); -lean_ctor_set(x_430, 1, x_429); -return x_430; -} -} -} -else -{ -lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_431 = lean_ctor_get(x_261, 2); -x_432 = lean_ctor_get(x_261, 0); -x_433 = lean_ctor_get(x_261, 1); -x_434 = lean_ctor_get(x_261, 3); -x_435 = lean_ctor_get(x_261, 4); -x_436 = lean_ctor_get(x_261, 5); -lean_inc(x_436); -lean_inc(x_435); -lean_inc(x_434); -lean_inc(x_431); -lean_inc(x_433); -lean_inc(x_432); -lean_dec(x_261); -x_437 = lean_ctor_get(x_431, 0); -lean_inc(x_437); -x_438 = lean_ctor_get(x_431, 1); -lean_inc(x_438); -x_439 = lean_ctor_get(x_431, 2); -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); - x_440 = x_431; -} else { - lean_dec_ref(x_431); - x_440 = lean_box(0); -} -x_441 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_440)) { - x_442 = lean_alloc_ctor(0, 3, 0); -} else { - x_442 = x_440; -} -lean_ctor_set(x_442, 0, x_437); -lean_ctor_set(x_442, 1, x_438); -lean_ctor_set(x_442, 2, x_441); -x_443 = lean_alloc_ctor(0, 6, 0); -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); -x_444 = lean_ctor_get(x_4, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_4, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_4, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_4, 3); -lean_inc(x_447); -x_448 = lean_ctor_get(x_4, 4); -lean_inc(x_448); 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_449 = x_4; + x_417 = x_4; } else { lean_dec_ref(x_4); - x_449 = lean_box(0); + x_417 = lean_box(0); } -x_450 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_450, 0, x_262); -lean_ctor_set(x_450, 1, x_18); -x_451 = lean_array_push(x_446, x_450); -if (lean_is_scalar(x_449)) { - x_452 = lean_alloc_ctor(0, 5, 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); } else { - x_452 = x_449; + x_420 = x_417; } -lean_ctor_set(x_452, 0, x_444); -lean_ctor_set(x_452, 1, x_445); -lean_ctor_set(x_452, 2, x_451); -lean_ctor_set(x_452, 3, x_447); -lean_ctor_set(x_452, 4, x_448); -x_453 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_264, x_452, x_443); -if (lean_obj_tag(x_453) == 0) +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_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; -x_454 = lean_ctor_get(x_453, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_454, 2); -lean_inc(x_455); -x_456 = lean_ctor_get(x_453, 0); -lean_inc(x_456); -if (lean_is_exclusive(x_453)) { - lean_ctor_release(x_453, 0); - lean_ctor_release(x_453, 1); - x_457 = x_453; +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_453); - x_457 = lean_box(0); + lean_dec_ref(x_421); + x_425 = lean_box(0); } -x_458 = lean_ctor_get(x_454, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_454, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_454, 3); -lean_inc(x_460); -x_461 = lean_ctor_get(x_454, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_439); + x_448 = 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; +} else { + lean_dec_ref(x_440); + x_452 = lean_box(0); +} +if (lean_is_scalar(x_452)) { + x_453 = lean_alloc_ctor(0, 4, 0); +} else { + x_453 = x_452; +} +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); +} else { + x_454 = x_448; +} +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); +} else { + x_455 = x_442; +} +lean_ctor_set(x_455, 0, x_441); +lean_ctor_set(x_455, 1, x_454); +return x_455; +} +} +} +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); -x_462 = lean_ctor_get(x_454, 5); +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); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - lean_ctor_release(x_454, 2); - lean_ctor_release(x_454, 3); - lean_ctor_release(x_454, 4); - lean_ctor_release(x_454, 5); - x_463 = x_454; -} else { - lean_dec_ref(x_454); - x_463 = lean_box(0); -} -x_464 = lean_ctor_get(x_455, 0); +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_455, 1); +x_465 = lean_ctor_get(x_456, 3); lean_inc(x_465); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - lean_ctor_release(x_455, 2); - x_466 = x_455; +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; } else { - lean_dec_ref(x_455); + lean_dec_ref(x_456); x_466 = lean_box(0); } +x_467 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_466)) { - x_467 = lean_alloc_ctor(0, 3, 0); + x_468 = lean_alloc_ctor(0, 4, 0); } else { - x_467 = x_466; + x_468 = x_466; } -lean_ctor_set(x_467, 0, x_464); -lean_ctor_set(x_467, 1, x_465); -lean_ctor_set(x_467, 2, x_439); -if (lean_is_scalar(x_463)) { - x_468 = lean_alloc_ctor(0, 6, 0); -} else { - x_468 = x_463; -} -lean_ctor_set(x_468, 0, x_458); -lean_ctor_set(x_468, 1, x_459); +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_460); -lean_ctor_set(x_468, 4, x_461); -lean_ctor_set(x_468, 5, x_462); -if (lean_is_scalar(x_457)) { - x_469 = lean_alloc_ctor(0, 2, 0); -} else { - x_469 = x_457; -} -lean_ctor_set(x_469, 0, x_456); -lean_ctor_set(x_469, 1, x_468); -return x_469; -} -else -{ -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_470 = lean_ctor_get(x_453, 1); +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_470, 2); +x_471 = lean_ctor_get(x_4, 1); lean_inc(x_471); -x_472 = lean_ctor_get(x_453, 0); +x_472 = lean_ctor_get(x_4, 2); lean_inc(x_472); -if (lean_is_exclusive(x_453)) { - lean_ctor_release(x_453, 0); - lean_ctor_release(x_453, 1); - x_473 = x_453; -} else { - lean_dec_ref(x_453); - x_473 = lean_box(0); -} -x_474 = lean_ctor_get(x_470, 0); +x_473 = lean_ctor_get(x_4, 3); +lean_inc(x_473); +x_474 = lean_ctor_get(x_4, 4); lean_inc(x_474); -x_475 = lean_ctor_get(x_470, 1); -lean_inc(x_475); -x_476 = lean_ctor_get(x_470, 3); -lean_inc(x_476); -x_477 = lean_ctor_get(x_470, 4); -lean_inc(x_477); -x_478 = lean_ctor_get(x_470, 5); -lean_inc(x_478); -if (lean_is_exclusive(x_470)) { - lean_ctor_release(x_470, 0); - lean_ctor_release(x_470, 1); - lean_ctor_release(x_470, 2); - lean_ctor_release(x_470, 3); - lean_ctor_release(x_470, 4); - lean_ctor_release(x_470, 5); - x_479 = x_470; +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; } else { - lean_dec_ref(x_470); - x_479 = lean_box(0); + lean_dec_ref(x_4); + x_475 = lean_box(0); } -x_480 = lean_ctor_get(x_471, 0); +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); +} else { + x_478 = x_475; +} +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_471, 1); +x_481 = lean_ctor_get(x_480, 2); lean_inc(x_481); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - lean_ctor_release(x_471, 2); - x_482 = x_471; +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; } else { - lean_dec_ref(x_471); - x_482 = lean_box(0); + lean_dec_ref(x_479); + x_483 = lean_box(0); } -if (lean_is_scalar(x_482)) { - x_483 = lean_alloc_ctor(0, 3, 0); +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 { - x_483 = x_482; + lean_dec_ref(x_480); + x_489 = lean_box(0); } -lean_ctor_set(x_483, 0, x_480); -lean_ctor_set(x_483, 1, x_481); -lean_ctor_set(x_483, 2, x_439); -if (lean_is_scalar(x_479)) { - x_484 = lean_alloc_ctor(0, 6, 0); +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 { - x_484 = x_479; + lean_dec_ref(x_481); + x_493 = lean_box(0); } -lean_ctor_set(x_484, 0, x_474); -lean_ctor_set(x_484, 1, x_475); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_476); -lean_ctor_set(x_484, 4, x_477); -lean_ctor_set(x_484, 5, x_478); -if (lean_is_scalar(x_473)) { - x_485 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_493)) { + x_494 = lean_alloc_ctor(0, 4, 0); } else { - x_485 = x_473; + x_494 = x_493; } -lean_ctor_set(x_485, 0, x_472); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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_486; +uint8_t x_514; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_486 = !lean_is_exclusive(x_255); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_269); +if (x_514 == 0) { -return x_255; +return x_269; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_255, 0); -x_488 = lean_ctor_get(x_255, 1); -lean_inc(x_488); -lean_inc(x_487); -lean_dec(x_255); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } @@ -13259,54 +13571,54 @@ return x_489; } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_490 = !lean_is_exclusive(x_23); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_23); +if (x_518 == 0) { return x_23; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_23, 0); -x_492 = lean_ctor_get(x_23, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_23); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } else { -uint8_t x_494; +uint8_t x_522; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_494 = !lean_is_exclusive(x_19); -if (x_494 == 0) +x_522 = !lean_is_exclusive(x_19); +if (x_522 == 0) { return x_19; } else { -lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_495 = lean_ctor_get(x_19, 0); -x_496 = lean_ctor_get(x_19, 1); -lean_inc(x_496); -lean_inc(x_495); +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_dec(x_19); -x_497 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_497, 0, x_495); -lean_ctor_set(x_497, 1, x_496); -return x_497; +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; } } } @@ -13571,82 +13883,89 @@ return x_43; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; +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_54 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -lean_ctor_set(x_54, 2, x_37); -lean_ctor_set(x_44, 2, x_54); +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; } } 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; -x_55 = lean_ctor_get(x_44, 0); -x_56 = lean_ctor_get(x_44, 1); -x_57 = lean_ctor_get(x_44, 3); -x_58 = lean_ctor_get(x_44, 4); -x_59 = lean_ctor_get(x_44, 5); +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +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_inc(x_57); lean_inc(x_56); -lean_inc(x_55); lean_dec(x_44); -x_60 = lean_ctor_get(x_45, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_45, 1); +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); - x_62 = x_45; + lean_ctor_release(x_45, 3); + x_64 = x_45; } else { lean_dec_ref(x_45); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 4, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_61); -lean_ctor_set(x_63, 2, x_37); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_55); -lean_ctor_set(x_64, 1, x_56); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_57); -lean_ctor_set(x_64, 4, x_58); -lean_ctor_set(x_64, 5, x_59); -lean_ctor_set(x_43, 1, x_64); +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; } } 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_43, 0); -lean_inc(x_65); -lean_dec(x_43); -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_44, 1); +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); -x_68 = lean_ctor_get(x_44, 3); +lean_dec(x_43); +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_44, 4); +x_69 = lean_ctor_get(x_44, 1); lean_inc(x_69); -x_70 = lean_ctor_get(x_44, 5); +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); @@ -13654,1877 +13973,1976 @@ if (lean_is_exclusive(x_44)) { lean_ctor_release(x_44, 3); lean_ctor_release(x_44, 4); lean_ctor_release(x_44, 5); - x_71 = x_44; + x_73 = x_44; } else { lean_dec_ref(x_44); - x_71 = lean_box(0); + x_73 = lean_box(0); } -x_72 = lean_ctor_get(x_45, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 1); -lean_inc(x_73); +x_74 = lean_ctor_get(x_45, 0); +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); - x_74 = x_45; + lean_ctor_release(x_45, 3); + x_77 = x_45; } else { lean_dec_ref(x_45); - x_74 = lean_box(0); + x_77 = lean_box(0); } -if (lean_is_scalar(x_74)) { - x_75 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(0, 4, 0); } else { - x_75 = x_74; + x_78 = x_77; } -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_37); -if (lean_is_scalar(x_71)) { - x_76 = lean_alloc_ctor(0, 6, 0); +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_76 = x_71; + x_79 = x_73; } -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_67); -lean_ctor_set(x_76, 2, x_75); -lean_ctor_set(x_76, 3, x_68); -lean_ctor_set(x_76, 4, x_69); -lean_ctor_set(x_76, 5, x_70); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_65); -lean_ctor_set(x_77, 1, x_76); -return x_77; +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; } } else { -lean_object* x_78; lean_object* x_79; uint8_t x_80; -x_78 = lean_ctor_get(x_43, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 2); -lean_inc(x_79); -x_80 = !lean_is_exclusive(x_43); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; +lean_object* x_81; lean_object* x_82; uint8_t x_83; x_81 = lean_ctor_get(x_43, 1); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_78); -if (x_82 == 0) +lean_inc(x_81); +x_82 = lean_ctor_get(x_81, 2); +lean_inc(x_82); +x_83 = !lean_is_exclusive(x_43); +if (x_83 == 0) { -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_78, 2); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_79); -if (x_84 == 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_85; -x_85 = lean_ctor_get(x_79, 2); -lean_dec(x_85); -lean_ctor_set(x_79, 2, x_37); +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_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_79, 0); -x_87 = lean_ctor_get(x_79, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_79); -x_88 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -lean_ctor_set(x_88, 2, x_37); -lean_ctor_set(x_78, 2, x_88); -return x_43; -} -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_89 = lean_ctor_get(x_78, 0); -x_90 = lean_ctor_get(x_78, 1); -x_91 = lean_ctor_get(x_78, 3); -x_92 = lean_ctor_get(x_78, 4); -x_93 = lean_ctor_get(x_78, 5); -lean_inc(x_93); -lean_inc(x_92); +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_78); -x_94 = lean_ctor_get(x_79, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_79, 1); -lean_inc(x_95); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - x_96 = x_79; -} else { - lean_dec_ref(x_79); - x_96 = lean_box(0); -} -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 3, 0); -} else { - x_97 = x_96; -} -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_37); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_89); -lean_ctor_set(x_98, 1, x_90); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_91); -lean_ctor_set(x_98, 4, x_92); -lean_ctor_set(x_98, 5, x_93); -lean_ctor_set(x_43, 1, x_98); +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_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_99 = lean_ctor_get(x_43, 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; +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); -lean_dec(x_43); -x_100 = lean_ctor_get(x_78, 0); +x_100 = lean_ctor_get(x_82, 3); lean_inc(x_100); -x_101 = lean_ctor_get(x_78, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_78, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_78, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_78, 5); +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; +} else { + lean_dec_ref(x_82); + 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_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); -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_105 = x_78; -} else { - lean_dec_ref(x_78); - x_105 = lean_box(0); -} -x_106 = lean_ctor_get(x_79, 0); +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_79, 1); +x_107 = lean_ctor_get(x_81, 3); lean_inc(x_107); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - x_108 = x_79; +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; } else { - lean_dec_ref(x_79); - x_108 = lean_box(0); + lean_dec_ref(x_81); + x_110 = lean_box(0); } -if (lean_is_scalar(x_108)) { - x_109 = lean_alloc_ctor(0, 3, 0); +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 { - x_109 = x_108; + lean_dec_ref(x_82); + x_114 = lean_box(0); } -lean_ctor_set(x_109, 0, x_106); -lean_ctor_set(x_109, 1, x_107); -lean_ctor_set(x_109, 2, x_37); -if (lean_is_scalar(x_105)) { - x_110 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_114)) { + x_115 = lean_alloc_ctor(0, 4, 0); } else { - x_110 = x_105; + x_115 = x_114; } -lean_ctor_set(x_110, 0, x_100); -lean_ctor_set(x_110, 1, x_101); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_102); -lean_ctor_set(x_110, 4, x_103); -lean_ctor_set(x_110, 5, x_104); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_99); -lean_ctor_set(x_111, 1, x_110); -return x_111; +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_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_11, 0); -x_113 = lean_ctor_get(x_11, 1); -x_114 = lean_ctor_get(x_11, 2); -x_115 = lean_ctor_get(x_11, 3); -x_116 = lean_ctor_get(x_11, 4); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_11); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_31); -lean_ctor_set(x_117, 1, x_19); -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_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_119, x_30); -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; -x_121 = lean_ctor_get(x_120, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_121, 2); +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); -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; -} else { - lean_dec_ref(x_120); - x_124 = lean_box(0); -} -x_125 = lean_ctor_get(x_121, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_121, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_121, 3); +lean_inc(x_121); +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_121, 4); +x_128 = lean_ctor_get(x_127, 2); lean_inc(x_128); -x_129 = lean_ctor_get(x_121, 5); +x_129 = lean_ctor_get(x_126, 0); 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_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + x_130 = x_126; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_126); x_130 = lean_box(0); } -x_131 = lean_ctor_get(x_122, 0); +x_131 = lean_ctor_get(x_127, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_122, 1); +x_132 = lean_ctor_get(x_127, 1); 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); - x_133 = x_122; +x_133 = lean_ctor_get(x_127, 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; } else { - lean_dec_ref(x_122); - x_133 = lean_box(0); + lean_dec_ref(x_127); + x_136 = lean_box(0); } -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(0, 3, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_131); -lean_ctor_set(x_134, 1, x_132); -lean_ctor_set(x_134, 2, x_37); -if (lean_is_scalar(x_130)) { - x_135 = lean_alloc_ctor(0, 6, 0); -} else { - x_135 = x_130; -} -lean_ctor_set(x_135, 0, x_125); -lean_ctor_set(x_135, 1, x_126); -lean_ctor_set(x_135, 2, x_134); -lean_ctor_set(x_135, 3, x_127); -lean_ctor_set(x_135, 4, x_128); -lean_ctor_set(x_135, 5, x_129); -if (lean_is_scalar(x_124)) { - x_136 = lean_alloc_ctor(0, 2, 0); -} else { - x_136 = x_124; -} -lean_ctor_set(x_136, 0, x_123); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -x_137 = lean_ctor_get(x_120, 1); +x_137 = lean_ctor_get(x_128, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_137, 2); +x_138 = lean_ctor_get(x_128, 1); lean_inc(x_138); -x_139 = lean_ctor_get(x_120, 0); +x_139 = lean_ctor_get(x_128, 3); lean_inc(x_139); -if (lean_is_exclusive(x_120)) { - lean_ctor_release(x_120, 0); - lean_ctor_release(x_120, 1); - x_140 = x_120; +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; } else { - lean_dec_ref(x_120); + lean_dec_ref(x_128); x_140 = lean_box(0); } -x_141 = lean_ctor_get(x_137, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_137, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_137, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_137, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_137, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - lean_ctor_release(x_137, 2); - lean_ctor_release(x_137, 3); - lean_ctor_release(x_137, 4); - lean_ctor_release(x_137, 5); - x_146 = x_137; -} else { - lean_dec_ref(x_137); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_138, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_138, 1); -lean_inc(x_148); -if (lean_is_exclusive(x_138)) { - lean_ctor_release(x_138, 0); - lean_ctor_release(x_138, 1); - lean_ctor_release(x_138, 2); - x_149 = x_138; -} else { - lean_dec_ref(x_138); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 3, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_147); -lean_ctor_set(x_150, 1, x_148); -lean_ctor_set(x_150, 2, x_37); -if (lean_is_scalar(x_146)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_146; -} -lean_ctor_set(x_151, 0, x_141); -lean_ctor_set(x_151, 1, x_142); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_143); -lean_ctor_set(x_151, 4, x_144); -lean_ctor_set(x_151, 5, x_145); if (lean_is_scalar(x_140)) { - x_152 = lean_alloc_ctor(1, 2, 0); + x_141 = lean_alloc_ctor(0, 4, 0); } else { - x_152 = x_140; + x_141 = x_140; } -lean_ctor_set(x_152, 0, x_139); -lean_ctor_set(x_152, 1, x_151); -return x_152; +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); +if (lean_is_scalar(x_130)) { + x_143 = lean_alloc_ctor(0, 2, 0); +} else { + x_143 = x_130; +} +lean_ctor_set(x_143, 0, x_129); +lean_ctor_set(x_143, 1, x_142); +return x_143; +} +else +{ +lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; +x_144 = lean_ctor_get(x_126, 1); +lean_inc(x_144); +x_145 = lean_ctor_get(x_144, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_126, 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); +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; +} else { + lean_dec_ref(x_144); + x_153 = 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; +} else { + lean_dec_ref(x_145); + 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_37); +lean_ctor_set(x_158, 3, x_156); +if (lean_is_scalar(x_153)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_153; +} +lean_ctor_set(x_159, 0, x_148); +lean_ctor_set(x_159, 1, x_149); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_150); +lean_ctor_set(x_159, 4, x_151); +lean_ctor_set(x_159, 5, x_152); +if (lean_is_scalar(x_147)) { + x_160 = lean_alloc_ctor(1, 2, 0); +} else { + x_160 = x_147; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; } } } else { -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_153 = lean_ctor_get(x_35, 0); -x_154 = lean_ctor_get(x_35, 1); -x_155 = lean_ctor_get(x_35, 2); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_dec(x_35); -x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_157 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_157, 0, x_153); -lean_ctor_set(x_157, 1, x_154); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_30, 2, x_157); -x_158 = lean_ctor_get(x_11, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_11, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_11, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_11, 3); -lean_inc(x_161); -x_162 = lean_ctor_get(x_11, 4); +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); 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_163 = x_11; + x_172 = x_11; } else { lean_dec_ref(x_11); - x_163 = lean_box(0); + x_172 = lean_box(0); } -x_164 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_164, 0, x_31); -lean_ctor_set(x_164, 1, x_19); -x_165 = lean_array_push(x_160, x_164); -if (lean_is_scalar(x_163)) { - x_166 = lean_alloc_ctor(0, 5, 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); } else { - x_166 = x_163; + x_175 = x_172; } -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_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_166, x_30); -if (lean_obj_tag(x_167) == 0) +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_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; -x_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_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_169, 1); +x_179 = lean_ctor_get(x_176, 0); lean_inc(x_179); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - x_180 = x_169; +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_169); + lean_dec_ref(x_176); x_180 = lean_box(0); } -if (lean_is_scalar(x_180)) { - x_181 = lean_alloc_ctor(0, 3, 0); -} else { - x_181 = x_180; -} -lean_ctor_set(x_181, 0, x_178); -lean_ctor_set(x_181, 1, x_179); -lean_ctor_set(x_181, 2, x_155); -if (lean_is_scalar(x_177)) { - x_182 = lean_alloc_ctor(0, 6, 0); -} else { - x_182 = x_177; -} -lean_ctor_set(x_182, 0, x_172); -lean_ctor_set(x_182, 1, x_173); -lean_ctor_set(x_182, 2, x_181); -lean_ctor_set(x_182, 3, x_174); -lean_ctor_set(x_182, 4, x_175); -lean_ctor_set(x_182, 5, x_176); -if (lean_is_scalar(x_171)) { - x_183 = lean_alloc_ctor(0, 2, 0); -} else { - x_183 = x_171; -} -lean_ctor_set(x_183, 0, x_170); -lean_ctor_set(x_183, 1, x_182); -return x_183; -} -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; lean_object* x_199; -x_184 = lean_ctor_get(x_167, 1); +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_184, 2); +x_185 = lean_ctor_get(x_177, 5); lean_inc(x_185); -x_186 = lean_ctor_get(x_167, 0); -lean_inc(x_186); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - x_187 = x_167; +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_167); - x_187 = lean_box(0); + lean_dec_ref(x_177); + x_186 = lean_box(0); } -x_188 = lean_ctor_get(x_184, 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_184, 1); +x_189 = lean_ctor_get(x_178, 3); lean_inc(x_189); -x_190 = lean_ctor_get(x_184, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_184, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_184, 5); -lean_inc(x_192); -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_193 = x_184; +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_184); - x_193 = lean_box(0); + lean_dec_ref(x_178); + x_190 = lean_box(0); } -x_194 = lean_ctor_get(x_185, 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; +} +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_inc(x_194); -x_195 = lean_ctor_get(x_185, 1); +x_195 = lean_ctor_get(x_194, 2); 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); - x_196 = x_185; +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; } else { - lean_dec_ref(x_185); - x_196 = lean_box(0); + lean_dec_ref(x_176); + x_197 = lean_box(0); } -if (lean_is_scalar(x_196)) { - x_197 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_200); +x_201 = lean_ctor_get(x_194, 4); +lean_inc(x_201); +x_202 = lean_ctor_get(x_194, 5); +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 { - x_197 = x_196; + lean_dec_ref(x_194); + x_203 = lean_box(0); } -lean_ctor_set(x_197, 0, x_194); -lean_ctor_set(x_197, 1, x_195); -lean_ctor_set(x_197, 2, x_155); -if (lean_is_scalar(x_193)) { - x_198 = lean_alloc_ctor(0, 6, 0); +x_204 = lean_ctor_get(x_195, 0); +lean_inc(x_204); +x_205 = lean_ctor_get(x_195, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_195, 3); +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; } else { - x_198 = x_193; + lean_dec_ref(x_195); + x_207 = lean_box(0); } -lean_ctor_set(x_198, 0, x_188); -lean_ctor_set(x_198, 1, x_189); -lean_ctor_set(x_198, 2, x_197); -lean_ctor_set(x_198, 3, x_190); -lean_ctor_set(x_198, 4, x_191); -lean_ctor_set(x_198, 5, x_192); -if (lean_is_scalar(x_187)) { - x_199 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 4, 0); } else { - x_199 = x_187; + x_208 = x_207; } -lean_ctor_set(x_199, 0, x_186); -lean_ctor_set(x_199, 1, x_198); -return x_199; +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); +} 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(1, 2, 0); +} else { + x_210 = x_197; +} +lean_ctor_set(x_210, 0, x_196); +lean_ctor_set(x_210, 1, x_209); +return x_210; } } } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; 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_200 = lean_ctor_get(x_30, 2); -x_201 = lean_ctor_get(x_30, 0); -x_202 = lean_ctor_get(x_30, 1); -x_203 = lean_ctor_get(x_30, 3); -x_204 = lean_ctor_get(x_30, 4); -x_205 = lean_ctor_get(x_30, 5); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_200); -lean_inc(x_202); -lean_inc(x_201); -lean_dec(x_30); -x_206 = lean_ctor_get(x_200, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_200, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_200, 2); -lean_inc(x_208); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - x_209 = x_200; -} else { - lean_dec_ref(x_200); - x_209 = lean_box(0); -} -x_210 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_209)) { - x_211 = lean_alloc_ctor(0, 3, 0); -} else { - x_211 = x_209; -} -lean_ctor_set(x_211, 0, x_206); -lean_ctor_set(x_211, 1, x_207); -lean_ctor_set(x_211, 2, x_210); -x_212 = 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); -x_213 = lean_ctor_get(x_11, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_11, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_11, 2); -lean_inc(x_215); -x_216 = lean_ctor_get(x_11, 3); +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); -x_217 = lean_ctor_get(x_11, 4); +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_218 = x_11; + x_230 = x_11; } else { lean_dec_ref(x_11); - x_218 = lean_box(0); + x_230 = lean_box(0); } -x_219 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_219, 0, x_31); -lean_ctor_set(x_219, 1, x_19); -x_220 = lean_array_push(x_215, x_219); -if (lean_is_scalar(x_218)) { - x_221 = lean_alloc_ctor(0, 5, 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_221 = x_218; + x_233 = x_230; } -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_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_221, x_212); -if (lean_obj_tag(x_222) == 0) +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_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; -x_223 = lean_ctor_get(x_222, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_223, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_222, 0); -lean_inc(x_225); -if (lean_is_exclusive(x_222)) { - lean_ctor_release(x_222, 0); - lean_ctor_release(x_222, 1); - x_226 = x_222; +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_222); - x_226 = lean_box(0); + lean_dec_ref(x_234); + x_238 = lean_box(0); } -x_227 = lean_ctor_get(x_223, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_223, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_223, 4); -lean_inc(x_230); -x_231 = lean_ctor_get(x_223, 5); -lean_inc(x_231); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - lean_ctor_release(x_223, 2); - lean_ctor_release(x_223, 3); - lean_ctor_release(x_223, 4); - lean_ctor_release(x_223, 5); - x_232 = x_223; +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_223); - x_232 = lean_box(0); + lean_dec_ref(x_235); + x_244 = lean_box(0); } -x_233 = lean_ctor_get(x_224, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_224, 1); -lean_inc(x_234); -if (lean_is_exclusive(x_224)) { - lean_ctor_release(x_224, 0); - lean_ctor_release(x_224, 1); - lean_ctor_release(x_224, 2); - x_235 = x_224; +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_224); - x_235 = lean_box(0); + lean_dec_ref(x_236); + x_248 = lean_box(0); } -if (lean_is_scalar(x_235)) { - x_236 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_248)) { + x_249 = lean_alloc_ctor(0, 4, 0); } else { - x_236 = x_235; + x_249 = x_248; } -lean_ctor_set(x_236, 0, x_233); -lean_ctor_set(x_236, 1, x_234); -lean_ctor_set(x_236, 2, x_208); -if (lean_is_scalar(x_232)) { - x_237 = lean_alloc_ctor(0, 6, 0); +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_237 = x_232; + x_250 = x_244; } -lean_ctor_set(x_237, 0, x_227); -lean_ctor_set(x_237, 1, x_228); -lean_ctor_set(x_237, 2, x_236); -lean_ctor_set(x_237, 3, x_229); -lean_ctor_set(x_237, 4, x_230); -lean_ctor_set(x_237, 5, x_231); -if (lean_is_scalar(x_226)) { - x_238 = lean_alloc_ctor(0, 2, 0); +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_238 = x_226; + x_251 = x_238; } -lean_ctor_set(x_238, 0, x_225); -lean_ctor_set(x_238, 1, x_237); -return 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_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_239 = lean_ctor_get(x_222, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_239, 2); -lean_inc(x_240); -x_241 = lean_ctor_get(x_222, 0); -lean_inc(x_241); -if (lean_is_exclusive(x_222)) { - lean_ctor_release(x_222, 0); - lean_ctor_release(x_222, 1); - x_242 = x_222; +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_222); - x_242 = lean_box(0); + lean_dec_ref(x_234); + x_255 = lean_box(0); } -x_243 = lean_ctor_get(x_239, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_239, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_239, 3); -lean_inc(x_245); -x_246 = lean_ctor_get(x_239, 4); -lean_inc(x_246); -x_247 = lean_ctor_get(x_239, 5); -lean_inc(x_247); -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); - lean_ctor_release(x_239, 4); - lean_ctor_release(x_239, 5); - x_248 = x_239; +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_239); - x_248 = lean_box(0); + lean_dec_ref(x_252); + x_261 = lean_box(0); } -x_249 = lean_ctor_get(x_240, 0); -lean_inc(x_249); -x_250 = lean_ctor_get(x_240, 1); -lean_inc(x_250); -if (lean_is_exclusive(x_240)) { - lean_ctor_release(x_240, 0); - lean_ctor_release(x_240, 1); - lean_ctor_release(x_240, 2); - x_251 = x_240; +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_240); - x_251 = lean_box(0); + lean_dec_ref(x_253); + x_265 = lean_box(0); } -if (lean_is_scalar(x_251)) { - x_252 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_265)) { + x_266 = lean_alloc_ctor(0, 4, 0); } else { - x_252 = x_251; + x_266 = x_265; } -lean_ctor_set(x_252, 0, x_249); -lean_ctor_set(x_252, 1, x_250); -lean_ctor_set(x_252, 2, x_208); -if (lean_is_scalar(x_248)) { - x_253 = lean_alloc_ctor(0, 6, 0); +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_253 = x_248; + x_267 = x_261; } -lean_ctor_set(x_253, 0, x_243); -lean_ctor_set(x_253, 1, x_244); -lean_ctor_set(x_253, 2, x_252); -lean_ctor_set(x_253, 3, x_245); -lean_ctor_set(x_253, 4, x_246); -lean_ctor_set(x_253, 5, x_247); -if (lean_is_scalar(x_242)) { - x_254 = lean_alloc_ctor(1, 2, 0); +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_254 = x_242; + x_268 = x_255; } -lean_ctor_set(x_254, 0, x_241); -lean_ctor_set(x_254, 1, x_253); -return x_254; +lean_ctor_set(x_268, 0, x_254); +lean_ctor_set(x_268, 1, x_267); +return x_268; } } } default: { -lean_object* x_255; lean_object* x_256; -x_255 = lean_ctor_get(x_24, 1); -lean_inc(x_255); +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_24, 1); +lean_inc(x_269); lean_dec(x_24); lean_inc(x_11); -x_256 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_255); -if (lean_obj_tag(x_256) == 0) +x_270 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_269); +if (lean_obj_tag(x_270) == 0) { -lean_object* x_257; -x_257 = lean_ctor_get(x_256, 0); -lean_inc(x_257); -if (lean_obj_tag(x_257) == 0) +lean_object* x_271; +x_271 = lean_ctor_get(x_270, 0); +lean_inc(x_271); +if (lean_obj_tag(x_271) == 0) { -lean_object* x_258; lean_object* x_259; lean_object* x_260; +lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_dec(x_19); -x_258 = lean_ctor_get(x_256, 1); -lean_inc(x_258); -lean_dec(x_256); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_10, x_259); +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); lean_dec(x_10); -x_10 = x_260; -x_12 = x_258; +x_10 = x_274; +x_12 = x_272; goto _start; } else { -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_262 = lean_ctor_get(x_256, 1); -lean_inc(x_262); -lean_dec(x_256); -x_263 = lean_ctor_get(x_257, 0); -lean_inc(x_263); -lean_dec(x_257); -x_264 = lean_unsigned_to_nat(1u); -x_265 = lean_nat_add(x_10, x_264); -lean_dec(x_10); -x_266 = !lean_is_exclusive(x_262); -if (x_266 == 0) -{ -lean_object* x_267; uint8_t x_268; -x_267 = lean_ctor_get(x_262, 2); -x_268 = !lean_is_exclusive(x_267); -if (x_268 == 0) -{ -lean_object* x_269; lean_object* x_270; uint8_t x_271; -x_269 = lean_ctor_get(x_267, 2); -x_270 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_267, 2, x_270); -x_271 = !lean_is_exclusive(x_11); -if (x_271 == 0) -{ -lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_272 = lean_ctor_get(x_11, 2); -x_273 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_273, 0, x_263); -lean_ctor_set(x_273, 1, x_19); -x_274 = lean_array_push(x_272, x_273); -lean_ctor_set(x_11, 2, x_274); -x_275 = 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_265, x_11, x_262); -if (lean_obj_tag(x_275) == 0) -{ -lean_object* x_276; lean_object* x_277; uint8_t x_278; -x_276 = lean_ctor_get(x_275, 1); +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); -x_277 = lean_ctor_get(x_276, 2); +lean_dec(x_270); +x_277 = lean_ctor_get(x_271, 0); lean_inc(x_277); -x_278 = !lean_is_exclusive(x_275); -if (x_278 == 0) -{ -lean_object* x_279; uint8_t x_280; -x_279 = lean_ctor_get(x_275, 1); -lean_dec(x_279); +lean_dec(x_271); +x_278 = lean_unsigned_to_nat(1u); +x_279 = lean_nat_add(x_10, x_278); +lean_dec(x_10); x_280 = !lean_is_exclusive(x_276); if (x_280 == 0) { lean_object* x_281; uint8_t x_282; x_281 = lean_ctor_get(x_276, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_277); +x_282 = !lean_is_exclusive(x_281); if (x_282 == 0) { -lean_object* x_283; -x_283 = lean_ctor_get(x_277, 2); -lean_dec(x_283); -lean_ctor_set(x_277, 2, x_269); -return x_275; -} -else +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_284; lean_object* x_285; lean_object* x_286; -x_284 = lean_ctor_get(x_277, 0); -x_285 = lean_ctor_get(x_277, 1); -lean_inc(x_285); -lean_inc(x_284); -lean_dec(x_277); -x_286 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_286, 0, x_284); -lean_ctor_set(x_286, 1, x_285); -lean_ctor_set(x_286, 2, x_269); -lean_ctor_set(x_276, 2, x_286); -return x_275; -} -} -else +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_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_287 = lean_ctor_get(x_276, 0); -x_288 = lean_ctor_get(x_276, 1); -x_289 = lean_ctor_get(x_276, 3); -x_290 = lean_ctor_get(x_276, 4); -x_291 = lean_ctor_get(x_276, 5); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_289, 1); lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_dec(x_276); -x_292 = lean_ctor_get(x_277, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_277, 1); -lean_inc(x_293); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - x_294 = x_277; -} else { - lean_dec_ref(x_277); - x_294 = lean_box(0); -} -if (lean_is_scalar(x_294)) { - x_295 = lean_alloc_ctor(0, 3, 0); -} else { - x_295 = x_294; -} -lean_ctor_set(x_295, 0, x_292); -lean_ctor_set(x_295, 1, x_293); -lean_ctor_set(x_295, 2, x_269); -x_296 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_296, 0, x_287); -lean_ctor_set(x_296, 1, x_288); -lean_ctor_set(x_296, 2, x_295); -lean_ctor_set(x_296, 3, x_289); -lean_ctor_set(x_296, 4, x_290); -lean_ctor_set(x_296, 5, x_291); -lean_ctor_set(x_275, 1, x_296); -return x_275; -} +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_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_297 = lean_ctor_get(x_275, 0); -lean_inc(x_297); -lean_dec(x_275); -x_298 = lean_ctor_get(x_276, 0); -lean_inc(x_298); -x_299 = lean_ctor_get(x_276, 1); -lean_inc(x_299); -x_300 = lean_ctor_get(x_276, 3); +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); -x_301 = lean_ctor_get(x_276, 4); -lean_inc(x_301); -x_302 = lean_ctor_get(x_276, 5); -lean_inc(x_302); -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_303 = x_276; -} else { - lean_dec_ref(x_276); - x_303 = lean_box(0); +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; } -x_304 = lean_ctor_get(x_277, 0); -lean_inc(x_304); -x_305 = lean_ctor_get(x_277, 1); +} +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); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - x_306 = x_277; +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_inc(x_308); +x_309 = lean_ctor_get(x_291, 3); +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_277); - x_306 = lean_box(0); + lean_dec_ref(x_291); + x_310 = lean_box(0); } -if (lean_is_scalar(x_306)) { - x_307 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_310)) { + x_311 = lean_alloc_ctor(0, 4, 0); } else { - x_307 = x_306; + x_311 = x_310; } -lean_ctor_set(x_307, 0, x_304); -lean_ctor_set(x_307, 1, x_305); -lean_ctor_set(x_307, 2, x_269); -if (lean_is_scalar(x_303)) { - x_308 = lean_alloc_ctor(0, 6, 0); -} else { - x_308 = x_303; -} -lean_ctor_set(x_308, 0, x_298); -lean_ctor_set(x_308, 1, x_299); -lean_ctor_set(x_308, 2, x_307); -lean_ctor_set(x_308, 3, x_300); -lean_ctor_set(x_308, 4, x_301); -lean_ctor_set(x_308, 5, x_302); -x_309 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_309, 0, x_297); -lean_ctor_set(x_309, 1, x_308); -return x_309; +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_310; lean_object* x_311; uint8_t x_312; -x_310 = lean_ctor_get(x_275, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_310, 2); -lean_inc(x_311); -x_312 = !lean_is_exclusive(x_275); -if (x_312 == 0) -{ -lean_object* x_313; uint8_t x_314; -x_313 = lean_ctor_get(x_275, 1); -lean_dec(x_313); -x_314 = !lean_is_exclusive(x_310); -if (x_314 == 0) -{ -lean_object* x_315; uint8_t x_316; -x_315 = lean_ctor_get(x_310, 2); -lean_dec(x_315); -x_316 = !lean_is_exclusive(x_311); -if (x_316 == 0) -{ -lean_object* x_317; -x_317 = lean_ctor_get(x_311, 2); -lean_dec(x_317); -lean_ctor_set(x_311, 2, x_269); -return x_275; -} -else -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_311, 0); -x_319 = lean_ctor_get(x_311, 1); -lean_inc(x_319); +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_inc(x_318); -lean_dec(x_311); -x_320 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_320, 0, x_318); -lean_ctor_set(x_320, 1, x_319); -lean_ctor_set(x_320, 2, x_269); -lean_ctor_set(x_310, 2, x_320); -return x_275; +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); } -} -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; -x_321 = lean_ctor_get(x_310, 0); -x_322 = lean_ctor_get(x_310, 1); -x_323 = lean_ctor_get(x_310, 3); -x_324 = lean_ctor_get(x_310, 4); -x_325 = lean_ctor_get(x_310, 5); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); +x_320 = lean_ctor_get(x_291, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_291, 1); lean_inc(x_321); -lean_dec(x_310); -x_326 = lean_ctor_get(x_311, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_311, 1); +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); -if (lean_is_exclusive(x_311)) { - lean_ctor_release(x_311, 0); - lean_ctor_release(x_311, 1); - lean_ctor_release(x_311, 2); - x_328 = x_311; -} else { - lean_dec_ref(x_311); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 3, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_326); -lean_ctor_set(x_329, 1, x_327); -lean_ctor_set(x_329, 2, x_269); -x_330 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_330, 0, x_321); -lean_ctor_set(x_330, 1, x_322); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_323); -lean_ctor_set(x_330, 4, x_324); -lean_ctor_set(x_330, 5, x_325); -lean_ctor_set(x_275, 1, x_330); -return x_275; -} +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_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_331 = lean_ctor_get(x_275, 0); -lean_inc(x_331); -lean_dec(x_275); -x_332 = lean_ctor_get(x_310, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_310, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_310, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_310, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_310, 5); +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); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - lean_ctor_release(x_310, 3); - lean_ctor_release(x_310, 4); - lean_ctor_release(x_310, 5); - x_337 = x_310; -} else { - lean_dec_ref(x_310); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_311, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_311, 1); -lean_inc(x_339); -if (lean_is_exclusive(x_311)) { - lean_ctor_release(x_311, 0); - lean_ctor_release(x_311, 1); - lean_ctor_release(x_311, 2); - x_340 = x_311; -} else { - lean_dec_ref(x_311); - x_340 = lean_box(0); -} -if (lean_is_scalar(x_340)) { - x_341 = lean_alloc_ctor(0, 3, 0); -} else { - x_341 = x_340; -} -lean_ctor_set(x_341, 0, x_338); -lean_ctor_set(x_341, 1, x_339); -lean_ctor_set(x_341, 2, x_269); -if (lean_is_scalar(x_337)) { - x_342 = lean_alloc_ctor(0, 6, 0); -} else { - x_342 = x_337; -} -lean_ctor_set(x_342, 0, x_332); -lean_ctor_set(x_342, 1, x_333); -lean_ctor_set(x_342, 2, x_341); -lean_ctor_set(x_342, 3, x_334); -lean_ctor_set(x_342, 4, x_335); -lean_ctor_set(x_342, 5, x_336); -x_343 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_343, 0, x_331); -lean_ctor_set(x_343, 1, x_342); -return x_343; -} +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_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_344 = lean_ctor_get(x_11, 0); -x_345 = lean_ctor_get(x_11, 1); -x_346 = lean_ctor_get(x_11, 2); -x_347 = lean_ctor_get(x_11, 3); -x_348 = lean_ctor_get(x_11, 4); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); +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); -lean_dec(x_11); -x_349 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_349, 0, x_263); -lean_ctor_set(x_349, 1, x_19); -x_350 = lean_array_push(x_346, x_349); -x_351 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_351, 0, x_344); -lean_ctor_set(x_351, 1, x_345); -lean_ctor_set(x_351, 2, x_350); -lean_ctor_set(x_351, 3, x_347); -lean_ctor_set(x_351, 4, x_348); -x_352 = 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_265, x_351, x_262); -if (lean_obj_tag(x_352) == 0) -{ -lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; -x_353 = lean_ctor_get(x_352, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_353, 2); -lean_inc(x_354); -x_355 = lean_ctor_get(x_352, 0); -lean_inc(x_355); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - x_356 = x_352; +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_352); + 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_353, 0); +x_357 = lean_ctor_get(x_328, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_353, 1); +x_358 = lean_ctor_get(x_328, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_353, 3); +x_359 = lean_ctor_get(x_328, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_353, 4); -lean_inc(x_360); -x_361 = lean_ctor_get(x_353, 5); -lean_inc(x_361); -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); - lean_ctor_release(x_353, 4); - lean_ctor_release(x_353, 5); - x_362 = x_353; +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_353); - x_362 = lean_box(0); + lean_dec_ref(x_328); + x_360 = lean_box(0); } -x_363 = lean_ctor_get(x_354, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_354, 1); -lean_inc(x_364); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - lean_ctor_release(x_354, 2); - x_365 = x_354; +if (lean_is_scalar(x_360)) { + x_361 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_354); - x_365 = lean_box(0); + x_361 = x_360; } -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 3, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_363); -lean_ctor_set(x_366, 1, x_364); -lean_ctor_set(x_366, 2, x_269); -if (lean_is_scalar(x_362)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_362; -} -lean_ctor_set(x_367, 0, x_357); -lean_ctor_set(x_367, 1, x_358); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_359); -lean_ctor_set(x_367, 4, x_360); -lean_ctor_set(x_367, 5, x_361); +lean_ctor_set(x_361, 0, x_357); +lean_ctor_set(x_361, 1, x_358); +lean_ctor_set(x_361, 2, x_283); +lean_ctor_set(x_361, 3, x_359); if (lean_is_scalar(x_356)) { - x_368 = lean_alloc_ctor(0, 2, 0); + x_362 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_356; + 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; +} } -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; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_369 = lean_ctor_get(x_352, 1); -lean_inc(x_369); -x_370 = lean_ctor_get(x_369, 2); -lean_inc(x_370); -x_371 = lean_ctor_get(x_352, 0); -lean_inc(x_371); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - x_372 = x_352; -} else { - lean_dec_ref(x_352); - x_372 = lean_box(0); -} -x_373 = lean_ctor_get(x_369, 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; +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_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) +{ +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_369, 1); +x_374 = lean_ctor_get(x_373, 2); lean_inc(x_374); -x_375 = lean_ctor_get(x_369, 3); +x_375 = lean_ctor_get(x_372, 0); lean_inc(x_375); -x_376 = lean_ctor_get(x_369, 4); -lean_inc(x_376); -x_377 = lean_ctor_get(x_369, 5); +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); -if (lean_is_exclusive(x_369)) { - lean_ctor_release(x_369, 0); - lean_ctor_release(x_369, 1); - lean_ctor_release(x_369, 2); - lean_ctor_release(x_369, 3); - lean_ctor_release(x_369, 4); - lean_ctor_release(x_369, 5); - x_378 = x_369; -} else { - lean_dec_ref(x_369); - x_378 = lean_box(0); -} -x_379 = lean_ctor_get(x_370, 0); +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_370, 1); +x_380 = lean_ctor_get(x_373, 4); lean_inc(x_380); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - lean_ctor_release(x_370, 2); - x_381 = x_370; +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_370); - x_381 = lean_box(0); + lean_dec_ref(x_373); + x_382 = lean_box(0); } -if (lean_is_scalar(x_381)) { - x_382 = lean_alloc_ctor(0, 3, 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 { - x_382 = x_381; + lean_dec_ref(x_374); + x_386 = lean_box(0); } -lean_ctor_set(x_382, 0, x_379); -lean_ctor_set(x_382, 1, x_380); -lean_ctor_set(x_382, 2, x_269); -if (lean_is_scalar(x_378)) { - x_383 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_386)) { + x_387 = lean_alloc_ctor(0, 4, 0); } else { - x_383 = x_378; + x_387 = x_386; } -lean_ctor_set(x_383, 0, x_373); -lean_ctor_set(x_383, 1, x_374); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_375); -lean_ctor_set(x_383, 4, x_376); -lean_ctor_set(x_383, 5, x_377); -if (lean_is_scalar(x_372)) { - x_384 = lean_alloc_ctor(1, 2, 0); +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_384 = x_372; -} -lean_ctor_set(x_384, 0, x_371); -lean_ctor_set(x_384, 1, x_383); -return x_384; + 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; } 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; -x_385 = lean_ctor_get(x_267, 0); -x_386 = lean_ctor_get(x_267, 1); -x_387 = lean_ctor_get(x_267, 2); -lean_inc(x_387); -lean_inc(x_386); -lean_inc(x_385); -lean_dec(x_267); -x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_389 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_389, 0, x_385); -lean_ctor_set(x_389, 1, x_386); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_262, 2, x_389); -x_390 = lean_ctor_get(x_11, 0); +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_11, 1); +x_391 = lean_ctor_get(x_390, 2); lean_inc(x_391); -x_392 = lean_ctor_get(x_11, 2); +x_392 = lean_ctor_get(x_372, 0); lean_inc(x_392); -x_393 = lean_ctor_get(x_11, 3); -lean_inc(x_393); -x_394 = lean_ctor_get(x_11, 4); +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); +} +x_394 = lean_ctor_get(x_390, 0); lean_inc(x_394); -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_395 = x_11; +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_11); - x_395 = lean_box(0); + lean_dec_ref(x_390); + x_399 = lean_box(0); } -x_396 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_396, 0, x_263); -lean_ctor_set(x_396, 1, x_19); -x_397 = lean_array_push(x_392, x_396); -if (lean_is_scalar(x_395)) { - x_398 = lean_alloc_ctor(0, 5, 0); -} else { - x_398 = x_395; -} -lean_ctor_set(x_398, 0, x_390); -lean_ctor_set(x_398, 1, x_391); -lean_ctor_set(x_398, 2, x_397); -lean_ctor_set(x_398, 3, x_393); -lean_ctor_set(x_398, 4, x_394); -x_399 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_265, x_398, x_262); -if (lean_obj_tag(x_399) == 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; lean_object* x_415; -x_400 = lean_ctor_get(x_399, 1); +x_400 = lean_ctor_get(x_391, 0); lean_inc(x_400); -x_401 = lean_ctor_get(x_400, 2); +x_401 = lean_ctor_get(x_391, 1); lean_inc(x_401); -x_402 = lean_ctor_get(x_399, 0); +x_402 = lean_ctor_get(x_391, 3); lean_inc(x_402); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - x_403 = 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); + x_403 = x_391; } else { - lean_dec_ref(x_399); + lean_dec_ref(x_391); x_403 = lean_box(0); } -x_404 = lean_ctor_get(x_400, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_400, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_400, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_400, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_400, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - lean_ctor_release(x_400, 2); - lean_ctor_release(x_400, 3); - lean_ctor_release(x_400, 4); - lean_ctor_release(x_400, 5); - x_409 = x_400; -} else { - lean_dec_ref(x_400); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_401, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_401, 1); -lean_inc(x_411); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - x_412 = x_401; -} else { - lean_dec_ref(x_401); - x_412 = lean_box(0); -} -if (lean_is_scalar(x_412)) { - x_413 = lean_alloc_ctor(0, 3, 0); -} else { - x_413 = x_412; -} -lean_ctor_set(x_413, 0, x_410); -lean_ctor_set(x_413, 1, x_411); -lean_ctor_set(x_413, 2, x_387); -if (lean_is_scalar(x_409)) { - x_414 = lean_alloc_ctor(0, 6, 0); -} else { - x_414 = x_409; -} -lean_ctor_set(x_414, 0, x_404); -lean_ctor_set(x_414, 1, x_405); -lean_ctor_set(x_414, 2, x_413); -lean_ctor_set(x_414, 3, x_406); -lean_ctor_set(x_414, 4, x_407); -lean_ctor_set(x_414, 5, x_408); if (lean_is_scalar(x_403)) { - x_415 = lean_alloc_ctor(0, 2, 0); + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_415 = x_403; + x_404 = x_403; +} +lean_ctor_set(x_404, 0, x_400); +lean_ctor_set(x_404, 1, x_401); +lean_ctor_set(x_404, 2, x_283); +lean_ctor_set(x_404, 3, x_402); +if (lean_is_scalar(x_399)) { + x_405 = lean_alloc_ctor(0, 6, 0); +} else { + x_405 = x_399; +} +lean_ctor_set(x_405, 0, x_394); +lean_ctor_set(x_405, 1, x_395); +lean_ctor_set(x_405, 2, x_404); +lean_ctor_set(x_405, 3, x_396); +lean_ctor_set(x_405, 4, x_397); +lean_ctor_set(x_405, 5, x_398); +if (lean_is_scalar(x_393)) { + x_406 = lean_alloc_ctor(1, 2, 0); +} else { + x_406 = x_393; +} +lean_ctor_set(x_406, 0, x_392); +lean_ctor_set(x_406, 1, x_405); +return x_406; +} } -lean_ctor_set(x_415, 0, x_402); -lean_ctor_set(x_415, 1, x_414); -return x_415; } else { -lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_416 = lean_ctor_get(x_399, 1); +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_416, 2); +x_417 = lean_ctor_get(x_11, 4); lean_inc(x_417); -x_418 = lean_ctor_get(x_399, 0); -lean_inc(x_418); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - x_419 = x_399; -} else { - lean_dec_ref(x_399); - x_419 = lean_box(0); -} -x_420 = lean_ctor_get(x_416, 0); -lean_inc(x_420); -x_421 = lean_ctor_get(x_416, 1); -lean_inc(x_421); -x_422 = lean_ctor_get(x_416, 3); -lean_inc(x_422); -x_423 = lean_ctor_get(x_416, 4); -lean_inc(x_423); -x_424 = lean_ctor_get(x_416, 5); -lean_inc(x_424); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - lean_ctor_release(x_416, 2); - lean_ctor_release(x_416, 3); - lean_ctor_release(x_416, 4); - lean_ctor_release(x_416, 5); - x_425 = x_416; -} else { - lean_dec_ref(x_416); - x_425 = lean_box(0); -} -x_426 = lean_ctor_get(x_417, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 1); -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); - x_428 = x_417; -} else { - lean_dec_ref(x_417); - x_428 = lean_box(0); -} -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 3, 0); -} else { - x_429 = x_428; -} -lean_ctor_set(x_429, 0, x_426); -lean_ctor_set(x_429, 1, x_427); -lean_ctor_set(x_429, 2, x_387); -if (lean_is_scalar(x_425)) { - x_430 = lean_alloc_ctor(0, 6, 0); -} else { - x_430 = x_425; -} -lean_ctor_set(x_430, 0, x_420); -lean_ctor_set(x_430, 1, x_421); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_422); -lean_ctor_set(x_430, 4, x_423); -lean_ctor_set(x_430, 5, x_424); -if (lean_is_scalar(x_419)) { - x_431 = lean_alloc_ctor(1, 2, 0); -} else { - x_431 = x_419; -} -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; -} -} -} -else -{ -lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_432 = lean_ctor_get(x_262, 2); -x_433 = lean_ctor_get(x_262, 0); -x_434 = lean_ctor_get(x_262, 1); -x_435 = lean_ctor_get(x_262, 3); -x_436 = lean_ctor_get(x_262, 4); -x_437 = lean_ctor_get(x_262, 5); -lean_inc(x_437); -lean_inc(x_436); -lean_inc(x_435); -lean_inc(x_432); -lean_inc(x_434); -lean_inc(x_433); -lean_dec(x_262); -x_438 = lean_ctor_get(x_432, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_432, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_432, 2); -lean_inc(x_440); -if (lean_is_exclusive(x_432)) { - lean_ctor_release(x_432, 0); - lean_ctor_release(x_432, 1); - lean_ctor_release(x_432, 2); - x_441 = x_432; -} else { - lean_dec_ref(x_432); - x_441 = lean_box(0); -} -x_442 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_441)) { - x_443 = lean_alloc_ctor(0, 3, 0); -} else { - x_443 = x_441; -} -lean_ctor_set(x_443, 0, x_438); -lean_ctor_set(x_443, 1, x_439); -lean_ctor_set(x_443, 2, x_442); -x_444 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_444, 0, x_433); -lean_ctor_set(x_444, 1, x_434); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_435); -lean_ctor_set(x_444, 4, x_436); -lean_ctor_set(x_444, 5, x_437); -x_445 = lean_ctor_get(x_11, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_11, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_11, 2); -lean_inc(x_447); -x_448 = lean_ctor_get(x_11, 3); -lean_inc(x_448); -x_449 = lean_ctor_get(x_11, 4); -lean_inc(x_449); 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_450 = x_11; + x_418 = x_11; } else { lean_dec_ref(x_11); - x_450 = lean_box(0); + x_418 = lean_box(0); } -x_451 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_451, 0, x_263); -lean_ctor_set(x_451, 1, x_19); -x_452 = lean_array_push(x_447, x_451); -if (lean_is_scalar(x_450)) { - x_453 = lean_alloc_ctor(0, 5, 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); } else { - x_453 = x_450; + x_421 = x_418; } -lean_ctor_set(x_453, 0, x_445); -lean_ctor_set(x_453, 1, x_446); -lean_ctor_set(x_453, 2, x_452); -lean_ctor_set(x_453, 3, x_448); -lean_ctor_set(x_453, 4, x_449); -x_454 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_265, x_453, x_444); -if (lean_obj_tag(x_454) == 0) +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_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; -x_455 = lean_ctor_get(x_454, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_455, 2); -lean_inc(x_456); -x_457 = lean_ctor_get(x_454, 0); -lean_inc(x_457); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - x_458 = x_454; +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_454); - x_458 = lean_box(0); + lean_dec_ref(x_422); + x_426 = lean_box(0); } -x_459 = lean_ctor_get(x_455, 0); -lean_inc(x_459); -x_460 = lean_ctor_get(x_455, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_455, 3); -lean_inc(x_461); -x_462 = lean_ctor_get(x_455, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_440); + x_449 = 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; +} else { + lean_dec_ref(x_441); + x_453 = lean_box(0); +} +if (lean_is_scalar(x_453)) { + x_454 = lean_alloc_ctor(0, 4, 0); +} else { + x_454 = x_453; +} +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); +} else { + x_455 = x_449; +} +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); +} else { + x_456 = x_443; +} +lean_ctor_set(x_456, 0, x_442); +lean_ctor_set(x_456, 1, x_455); +return x_456; +} +} +} +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); -x_463 = lean_ctor_get(x_455, 5); +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); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - lean_ctor_release(x_455, 2); - lean_ctor_release(x_455, 3); - lean_ctor_release(x_455, 4); - lean_ctor_release(x_455, 5); - x_464 = x_455; -} else { - lean_dec_ref(x_455); - x_464 = lean_box(0); -} -x_465 = lean_ctor_get(x_456, 0); +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_456, 1); +x_466 = lean_ctor_get(x_457, 3); lean_inc(x_466); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - lean_ctor_release(x_456, 2); - x_467 = x_456; +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; } else { - lean_dec_ref(x_456); + lean_dec_ref(x_457); x_467 = lean_box(0); } +x_468 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_467)) { - x_468 = lean_alloc_ctor(0, 3, 0); + x_469 = lean_alloc_ctor(0, 4, 0); } else { - x_468 = x_467; + x_469 = x_467; } -lean_ctor_set(x_468, 0, x_465); -lean_ctor_set(x_468, 1, x_466); -lean_ctor_set(x_468, 2, x_440); -if (lean_is_scalar(x_464)) { - x_469 = lean_alloc_ctor(0, 6, 0); -} else { - x_469 = x_464; -} -lean_ctor_set(x_469, 0, x_459); -lean_ctor_set(x_469, 1, x_460); +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_461); -lean_ctor_set(x_469, 4, x_462); -lean_ctor_set(x_469, 5, x_463); -if (lean_is_scalar(x_458)) { - x_470 = lean_alloc_ctor(0, 2, 0); -} else { - x_470 = x_458; -} -lean_ctor_set(x_470, 0, x_457); -lean_ctor_set(x_470, 1, x_469); -return x_470; -} -else -{ -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; -x_471 = lean_ctor_get(x_454, 1); +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_471, 2); +x_472 = lean_ctor_get(x_11, 1); lean_inc(x_472); -x_473 = lean_ctor_get(x_454, 0); +x_473 = lean_ctor_get(x_11, 2); lean_inc(x_473); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - x_474 = x_454; -} else { - lean_dec_ref(x_454); - x_474 = lean_box(0); -} -x_475 = lean_ctor_get(x_471, 0); +x_474 = lean_ctor_get(x_11, 3); +lean_inc(x_474); +x_475 = lean_ctor_get(x_11, 4); lean_inc(x_475); -x_476 = lean_ctor_get(x_471, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_471, 3); -lean_inc(x_477); -x_478 = lean_ctor_get(x_471, 4); -lean_inc(x_478); -x_479 = lean_ctor_get(x_471, 5); -lean_inc(x_479); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - lean_ctor_release(x_471, 2); - lean_ctor_release(x_471, 3); - lean_ctor_release(x_471, 4); - lean_ctor_release(x_471, 5); - x_480 = x_471; +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; } else { - lean_dec_ref(x_471); - x_480 = lean_box(0); + lean_dec_ref(x_11); + x_476 = lean_box(0); } -x_481 = lean_ctor_get(x_472, 0); +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); +} else { + x_479 = x_476; +} +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_472, 1); +x_482 = lean_ctor_get(x_481, 2); lean_inc(x_482); -if (lean_is_exclusive(x_472)) { - lean_ctor_release(x_472, 0); - lean_ctor_release(x_472, 1); - lean_ctor_release(x_472, 2); - x_483 = x_472; +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; } else { - lean_dec_ref(x_472); - x_483 = lean_box(0); + lean_dec_ref(x_480); + x_484 = lean_box(0); } -if (lean_is_scalar(x_483)) { - x_484 = lean_alloc_ctor(0, 3, 0); +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 { - x_484 = x_483; + lean_dec_ref(x_481); + x_490 = lean_box(0); } -lean_ctor_set(x_484, 0, x_481); -lean_ctor_set(x_484, 1, x_482); -lean_ctor_set(x_484, 2, x_440); -if (lean_is_scalar(x_480)) { - x_485 = lean_alloc_ctor(0, 6, 0); +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 { - x_485 = x_480; + lean_dec_ref(x_482); + x_494 = lean_box(0); } -lean_ctor_set(x_485, 0, x_475); -lean_ctor_set(x_485, 1, x_476); -lean_ctor_set(x_485, 2, x_484); -lean_ctor_set(x_485, 3, x_477); -lean_ctor_set(x_485, 4, x_478); -lean_ctor_set(x_485, 5, x_479); -if (lean_is_scalar(x_474)) { - x_486 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_494)) { + x_495 = lean_alloc_ctor(0, 4, 0); } else { - x_486 = x_474; + x_495 = x_494; } -lean_ctor_set(x_486, 0, x_473); -lean_ctor_set(x_486, 1, x_485); -return x_486; +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_487; +uint8_t x_515; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -15533,23 +15951,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_487 = !lean_is_exclusive(x_256); -if (x_487 == 0) +x_515 = !lean_is_exclusive(x_270); +if (x_515 == 0) { -return x_256; +return x_270; } else { -lean_object* x_488; lean_object* x_489; lean_object* x_490; -x_488 = lean_ctor_get(x_256, 0); -x_489 = lean_ctor_get(x_256, 1); -lean_inc(x_489); -lean_inc(x_488); -lean_dec(x_256); -x_490 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_490, 0, x_488); -lean_ctor_set(x_490, 1, x_489); -return x_490; +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; } } } @@ -15557,7 +15975,7 @@ return x_490; } else { -uint8_t x_491; +uint8_t x_519; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -15567,29 +15985,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_491 = !lean_is_exclusive(x_24); -if (x_491 == 0) +x_519 = !lean_is_exclusive(x_24); +if (x_519 == 0) { return x_24; } else { -lean_object* x_492; lean_object* x_493; lean_object* x_494; -x_492 = lean_ctor_get(x_24, 0); -x_493 = lean_ctor_get(x_24, 1); -lean_inc(x_493); -lean_inc(x_492); +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_dec(x_24); -x_494 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_494, 0, x_492); -lean_ctor_set(x_494, 1, x_493); -return x_494; +x_522 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_522, 0, x_520); +lean_ctor_set(x_522, 1, x_521); +return x_522; } } } else { -uint8_t x_495; +uint8_t x_523; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -15598,23 +16016,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_495 = !lean_is_exclusive(x_20); -if (x_495 == 0) +x_523 = !lean_is_exclusive(x_20); +if (x_523 == 0) { return x_20; } else { -lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_496 = lean_ctor_get(x_20, 0); -x_497 = lean_ctor_get(x_20, 1); -lean_inc(x_497); -lean_inc(x_496); +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_dec(x_20); -x_498 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_498, 0, x_496); -lean_ctor_set(x_498, 1, x_497); -return x_498; +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; } } } @@ -15781,82 +16199,89 @@ return x_42; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; +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_53 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -lean_ctor_set(x_53, 2, x_36); -lean_ctor_set(x_43, 2, x_53); +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; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_54 = lean_ctor_get(x_43, 0); -x_55 = lean_ctor_get(x_43, 1); -x_56 = lean_ctor_get(x_43, 3); -x_57 = lean_ctor_get(x_43, 4); -x_58 = lean_ctor_get(x_43, 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; +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_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_43); -x_59 = lean_ctor_get(x_44, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_44, 1); +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); - x_61 = x_44; + lean_ctor_release(x_44, 3); + x_63 = x_44; } else { lean_dec_ref(x_44); - x_61 = lean_box(0); + x_63 = lean_box(0); } -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 4, 0); } else { - x_62 = x_61; + x_64 = x_63; } -lean_ctor_set(x_62, 0, x_59); -lean_ctor_set(x_62, 1, x_60); -lean_ctor_set(x_62, 2, x_36); -x_63 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_63, 0, x_54); -lean_ctor_set(x_63, 1, x_55); -lean_ctor_set(x_63, 2, x_62); -lean_ctor_set(x_63, 3, x_56); -lean_ctor_set(x_63, 4, x_57); -lean_ctor_set(x_63, 5, x_58); -lean_ctor_set(x_42, 1, 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, 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; } } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_64 = lean_ctor_get(x_42, 0); -lean_inc(x_64); -lean_dec(x_42); -x_65 = lean_ctor_get(x_43, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_43, 1); +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); -x_67 = lean_ctor_get(x_43, 3); +lean_dec(x_42); +x_67 = lean_ctor_get(x_43, 0); lean_inc(x_67); -x_68 = lean_ctor_get(x_43, 4); +x_68 = lean_ctor_get(x_43, 1); lean_inc(x_68); -x_69 = lean_ctor_get(x_43, 5); +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); @@ -15864,1897 +16289,1996 @@ if (lean_is_exclusive(x_43)) { lean_ctor_release(x_43, 3); lean_ctor_release(x_43, 4); lean_ctor_release(x_43, 5); - x_70 = x_43; + x_72 = x_43; } else { lean_dec_ref(x_43); - x_70 = lean_box(0); + x_72 = lean_box(0); } -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_44, 1); -lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +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); - x_73 = x_44; + lean_ctor_release(x_44, 3); + x_76 = x_44; } else { lean_dec_ref(x_44); - x_73 = lean_box(0); + x_76 = lean_box(0); } -if (lean_is_scalar(x_73)) { - x_74 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 4, 0); } else { - x_74 = x_73; + x_77 = x_76; } -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_36); -if (lean_is_scalar(x_70)) { - x_75 = lean_alloc_ctor(0, 6, 0); +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_75 = x_70; + x_78 = x_72; } -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); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_64); -lean_ctor_set(x_76, 1, x_75); -return x_76; +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; } } else { -lean_object* x_77; lean_object* x_78; uint8_t x_79; -x_77 = lean_ctor_get(x_42, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_77, 2); -lean_inc(x_78); -x_79 = !lean_is_exclusive(x_42); -if (x_79 == 0) -{ -lean_object* x_80; uint8_t x_81; +lean_object* x_80; lean_object* x_81; uint8_t x_82; x_80 = lean_ctor_get(x_42, 1); -lean_dec(x_80); -x_81 = !lean_is_exclusive(x_77); -if (x_81 == 0) +lean_inc(x_80); +x_81 = lean_ctor_get(x_80, 2); +lean_inc(x_81); +x_82 = !lean_is_exclusive(x_42); +if (x_82 == 0) { -lean_object* x_82; uint8_t x_83; -x_82 = lean_ctor_get(x_77, 2); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_78); -if (x_83 == 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_84; -x_84 = lean_ctor_get(x_78, 2); -lean_dec(x_84); -lean_ctor_set(x_78, 2, x_36); +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_85; lean_object* x_86; lean_object* x_87; -x_85 = lean_ctor_get(x_78, 0); -x_86 = lean_ctor_get(x_78, 1); -lean_inc(x_86); -lean_inc(x_85); -lean_dec(x_78); -x_87 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_87, 0, x_85); -lean_ctor_set(x_87, 1, x_86); -lean_ctor_set(x_87, 2, x_36); -lean_ctor_set(x_77, 2, x_87); -return x_42; -} -} -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; -x_88 = lean_ctor_get(x_77, 0); -x_89 = lean_ctor_get(x_77, 1); -x_90 = lean_ctor_get(x_77, 3); -x_91 = lean_ctor_get(x_77, 4); -x_92 = lean_ctor_get(x_77, 5); -lean_inc(x_92); -lean_inc(x_91); +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_77); -x_93 = lean_ctor_get(x_78, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_78, 1); -lean_inc(x_94); -if (lean_is_exclusive(x_78)) { - lean_ctor_release(x_78, 0); - lean_ctor_release(x_78, 1); - lean_ctor_release(x_78, 2); - x_95 = x_78; -} else { - lean_dec_ref(x_78); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 3, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_93); -lean_ctor_set(x_96, 1, x_94); -lean_ctor_set(x_96, 2, x_36); -x_97 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_89); -lean_ctor_set(x_97, 2, x_96); -lean_ctor_set(x_97, 3, x_90); -lean_ctor_set(x_97, 4, x_91); -lean_ctor_set(x_97, 5, x_92); -lean_ctor_set(x_42, 1, x_97); +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_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_98 = lean_ctor_get(x_42, 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_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); -lean_dec(x_42); -x_99 = lean_ctor_get(x_77, 0); +x_99 = lean_ctor_get(x_81, 3); lean_inc(x_99); -x_100 = lean_ctor_get(x_77, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_77, 3); -lean_inc(x_101); -x_102 = lean_ctor_get(x_77, 4); -lean_inc(x_102); -x_103 = lean_ctor_get(x_77, 5); +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; +} else { + lean_dec_ref(x_81); + x_100 = lean_box(0); +} +if (lean_is_scalar(x_100)) { + x_101 = lean_alloc_ctor(0, 4, 0); +} else { + x_101 = x_100; +} +lean_ctor_set(x_101, 0, x_97); +lean_ctor_set(x_101, 1, x_98); +lean_ctor_set(x_101, 2, x_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); -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_104 = x_77; -} else { - lean_dec_ref(x_77); - x_104 = lean_box(0); -} -x_105 = lean_ctor_get(x_78, 0); +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_78, 1); +x_106 = lean_ctor_get(x_80, 3); lean_inc(x_106); -if (lean_is_exclusive(x_78)) { - lean_ctor_release(x_78, 0); - lean_ctor_release(x_78, 1); - lean_ctor_release(x_78, 2); - x_107 = x_78; +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; } else { - lean_dec_ref(x_78); - x_107 = lean_box(0); + lean_dec_ref(x_80); + x_109 = lean_box(0); } -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 3, 0); +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 { - x_108 = x_107; + lean_dec_ref(x_81); + x_113 = lean_box(0); } -lean_ctor_set(x_108, 0, x_105); -lean_ctor_set(x_108, 1, x_106); -lean_ctor_set(x_108, 2, x_36); -if (lean_is_scalar(x_104)) { - x_109 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_113)) { + x_114 = lean_alloc_ctor(0, 4, 0); } else { - x_109 = x_104; + x_114 = x_113; } -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); -x_110 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_110, 0, x_98); -lean_ctor_set(x_110, 1, x_109); -return x_110; +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_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_111 = lean_ctor_get(x_4, 0); -x_112 = lean_ctor_get(x_4, 1); -x_113 = lean_ctor_get(x_4, 2); -x_114 = lean_ctor_get(x_4, 3); -x_115 = lean_ctor_get(x_4, 4); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_inc(x_111); -lean_dec(x_4); -x_116 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_116, 0, x_30); -lean_ctor_set(x_116, 1, x_18); -x_117 = lean_array_push(x_113, x_116); -x_118 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_118, 0, x_111); -lean_ctor_set(x_118, 1, x_112); -lean_ctor_set(x_118, 2, x_117); -lean_ctor_set(x_118, 3, x_114); -lean_ctor_set(x_118, 4, x_115); -x_119 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_118, x_29); -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; 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_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_120, 2); +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); -x_122 = lean_ctor_get(x_119, 0); -lean_inc(x_122); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_123 = x_119; -} else { - lean_dec_ref(x_119); - x_123 = lean_box(0); -} -x_124 = lean_ctor_get(x_120, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_120, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_120, 3); +lean_inc(x_120); +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_120, 4); +x_127 = lean_ctor_get(x_126, 2); lean_inc(x_127); -x_128 = lean_ctor_get(x_120, 5); +x_128 = lean_ctor_get(x_125, 0); lean_inc(x_128); -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); - lean_ctor_release(x_120, 5); - x_129 = x_120; +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_129 = x_125; } else { - lean_dec_ref(x_120); + lean_dec_ref(x_125); x_129 = lean_box(0); } -x_130 = lean_ctor_get(x_121, 0); +x_130 = lean_ctor_get(x_126, 0); lean_inc(x_130); -x_131 = lean_ctor_get(x_121, 1); +x_131 = lean_ctor_get(x_126, 1); lean_inc(x_131); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - x_132 = x_121; +x_132 = lean_ctor_get(x_126, 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; } else { - lean_dec_ref(x_121); - x_132 = lean_box(0); + lean_dec_ref(x_126); + x_135 = lean_box(0); } -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 3, 0); -} else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_130); -lean_ctor_set(x_133, 1, x_131); -lean_ctor_set(x_133, 2, x_36); -if (lean_is_scalar(x_129)) { - x_134 = lean_alloc_ctor(0, 6, 0); -} else { - x_134 = x_129; -} -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); -if (lean_is_scalar(x_123)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_123; -} -lean_ctor_set(x_135, 0, x_122); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} -else -{ -lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_136 = lean_ctor_get(x_119, 1); +x_136 = lean_ctor_get(x_127, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_136, 2); +x_137 = lean_ctor_get(x_127, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_119, 0); +x_138 = lean_ctor_get(x_127, 3); lean_inc(x_138); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - x_139 = x_119; +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; } else { - lean_dec_ref(x_119); + lean_dec_ref(x_127); x_139 = lean_box(0); } -x_140 = lean_ctor_get(x_136, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_136, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_136, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_136, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_136, 5); -lean_inc(x_144); -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_145 = x_136; -} else { - lean_dec_ref(x_136); - x_145 = lean_box(0); -} -x_146 = lean_ctor_get(x_137, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_137, 1); -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); - x_148 = x_137; -} else { - lean_dec_ref(x_137); - x_148 = lean_box(0); -} -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 3, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_146); -lean_ctor_set(x_149, 1, x_147); -lean_ctor_set(x_149, 2, x_36); -if (lean_is_scalar(x_145)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_145; -} -lean_ctor_set(x_150, 0, x_140); -lean_ctor_set(x_150, 1, x_141); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_142); -lean_ctor_set(x_150, 4, x_143); -lean_ctor_set(x_150, 5, x_144); if (lean_is_scalar(x_139)) { - x_151 = lean_alloc_ctor(1, 2, 0); + x_140 = lean_alloc_ctor(0, 4, 0); } else { - x_151 = x_139; + x_140 = x_139; } -lean_ctor_set(x_151, 0, x_138); -lean_ctor_set(x_151, 1, x_150); -return x_151; +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); +if (lean_is_scalar(x_129)) { + x_142 = lean_alloc_ctor(0, 2, 0); +} else { + x_142 = x_129; +} +lean_ctor_set(x_142, 0, x_128); +lean_ctor_set(x_142, 1, x_141); +return x_142; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_143 = lean_ctor_get(x_125, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_143, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_125, 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); +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; +} else { + lean_dec_ref(x_143); + x_152 = 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; +} else { + lean_dec_ref(x_144); + x_156 = lean_box(0); +} +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_36); +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); +if (lean_is_scalar(x_146)) { + x_159 = lean_alloc_ctor(1, 2, 0); +} else { + x_159 = x_146; +} +lean_ctor_set(x_159, 0, x_145); +lean_ctor_set(x_159, 1, x_158); +return x_159; } } } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_152 = lean_ctor_get(x_34, 0); -x_153 = lean_ctor_get(x_34, 1); -x_154 = lean_ctor_get(x_34, 2); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); -lean_dec(x_34); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_156, 0, x_152); -lean_ctor_set(x_156, 1, x_153); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_29, 2, x_156); -x_157 = lean_ctor_get(x_4, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_4, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_4, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_4, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_4, 4); +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); 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_162 = x_4; + x_171 = x_4; } else { lean_dec_ref(x_4); - x_162 = lean_box(0); + x_171 = lean_box(0); } -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_30); -lean_ctor_set(x_163, 1, x_18); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 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); } else { - x_165 = x_162; + x_174 = x_171; } -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_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_165, x_29); -if (lean_obj_tag(x_166) == 0) +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_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_167 = lean_ctor_get(x_166, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_167, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_166, 0); -lean_inc(x_169); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_170 = x_166; -} else { - lean_dec_ref(x_166); - x_170 = lean_box(0); -} -x_171 = lean_ctor_get(x_167, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_167, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_167, 3); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 4); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 5); -lean_inc(x_175); -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_176 = x_167; -} else { - lean_dec_ref(x_167); - x_176 = lean_box(0); -} -x_177 = lean_ctor_get(x_168, 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_168, 1); +x_178 = lean_ctor_get(x_175, 0); 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); - x_179 = x_168; +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_168); + lean_dec_ref(x_175); x_179 = lean_box(0); } -if (lean_is_scalar(x_179)) { - x_180 = lean_alloc_ctor(0, 3, 0); -} else { - x_180 = x_179; -} -lean_ctor_set(x_180, 0, x_177); -lean_ctor_set(x_180, 1, x_178); -lean_ctor_set(x_180, 2, x_154); -if (lean_is_scalar(x_176)) { - x_181 = lean_alloc_ctor(0, 6, 0); -} else { - x_181 = x_176; -} -lean_ctor_set(x_181, 0, x_171); -lean_ctor_set(x_181, 1, x_172); -lean_ctor_set(x_181, 2, x_180); -lean_ctor_set(x_181, 3, x_173); -lean_ctor_set(x_181, 4, x_174); -lean_ctor_set(x_181, 5, x_175); -if (lean_is_scalar(x_170)) { - x_182 = lean_alloc_ctor(0, 2, 0); -} else { - x_182 = x_170; -} -lean_ctor_set(x_182, 0, x_169); -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; -x_183 = lean_ctor_get(x_166, 1); +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_183, 2); +x_184 = lean_ctor_get(x_176, 5); lean_inc(x_184); -x_185 = lean_ctor_get(x_166, 0); -lean_inc(x_185); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - x_186 = x_166; +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_166); - x_186 = lean_box(0); + lean_dec_ref(x_176); + x_185 = lean_box(0); } -x_187 = lean_ctor_get(x_183, 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_183, 1); +x_188 = lean_ctor_get(x_177, 3); lean_inc(x_188); -x_189 = lean_ctor_get(x_183, 3); -lean_inc(x_189); -x_190 = lean_ctor_get(x_183, 4); -lean_inc(x_190); -x_191 = lean_ctor_get(x_183, 5); -lean_inc(x_191); -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_192 = x_183; +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_183); - x_192 = lean_box(0); + lean_dec_ref(x_177); + x_189 = lean_box(0); } -x_193 = lean_ctor_get(x_184, 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; +} +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_inc(x_193); -x_194 = lean_ctor_get(x_184, 1); +x_194 = lean_ctor_get(x_193, 2); 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); - x_195 = x_184; +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; } else { - lean_dec_ref(x_184); - x_195 = lean_box(0); + lean_dec_ref(x_175); + x_196 = lean_box(0); } -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 4); +lean_inc(x_200); +x_201 = lean_ctor_get(x_193, 5); +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 { - x_196 = x_195; + lean_dec_ref(x_193); + x_202 = lean_box(0); } -lean_ctor_set(x_196, 0, x_193); -lean_ctor_set(x_196, 1, x_194); -lean_ctor_set(x_196, 2, x_154); -if (lean_is_scalar(x_192)) { - x_197 = lean_alloc_ctor(0, 6, 0); +x_203 = lean_ctor_get(x_194, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_194, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_194, 3); +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; } else { - x_197 = x_192; + lean_dec_ref(x_194); + x_206 = lean_box(0); } -lean_ctor_set(x_197, 0, x_187); -lean_ctor_set(x_197, 1, x_188); -lean_ctor_set(x_197, 2, x_196); -lean_ctor_set(x_197, 3, x_189); -lean_ctor_set(x_197, 4, x_190); -lean_ctor_set(x_197, 5, x_191); -if (lean_is_scalar(x_186)) { - x_198 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 4, 0); } else { - x_198 = x_186; + x_207 = x_206; } -lean_ctor_set(x_198, 0, x_185); -lean_ctor_set(x_198, 1, x_197); -return x_198; +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_208 = x_202; +} +lean_ctor_set(x_208, 0, x_197); +lean_ctor_set(x_208, 1, x_198); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_199); +lean_ctor_set(x_208, 4, x_200); +lean_ctor_set(x_208, 5, x_201); +if (lean_is_scalar(x_196)) { + x_209 = lean_alloc_ctor(1, 2, 0); +} else { + x_209 = x_196; +} +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; } } } 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; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; -x_199 = lean_ctor_get(x_29, 2); -x_200 = lean_ctor_get(x_29, 0); -x_201 = lean_ctor_get(x_29, 1); -x_202 = lean_ctor_get(x_29, 3); -x_203 = lean_ctor_get(x_29, 4); -x_204 = lean_ctor_get(x_29, 5); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_inc(x_199); -lean_inc(x_201); -lean_inc(x_200); -lean_dec(x_29); -x_205 = lean_ctor_get(x_199, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_199, 1); -lean_inc(x_206); -x_207 = lean_ctor_get(x_199, 2); -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); - x_208 = x_199; -} else { - lean_dec_ref(x_199); - x_208 = lean_box(0); -} -x_209 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_208)) { - x_210 = lean_alloc_ctor(0, 3, 0); -} else { - x_210 = x_208; -} -lean_ctor_set(x_210, 0, x_205); -lean_ctor_set(x_210, 1, x_206); -lean_ctor_set(x_210, 2, x_209); -x_211 = lean_alloc_ctor(0, 6, 0); -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); -x_212 = lean_ctor_get(x_4, 0); -lean_inc(x_212); -x_213 = lean_ctor_get(x_4, 1); -lean_inc(x_213); -x_214 = lean_ctor_get(x_4, 2); -lean_inc(x_214); -x_215 = lean_ctor_get(x_4, 3); +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); -x_216 = lean_ctor_get(x_4, 4); +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_217 = x_4; + x_229 = x_4; } else { lean_dec_ref(x_4); - x_217 = lean_box(0); + x_229 = lean_box(0); } -x_218 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_218, 0, x_30); -lean_ctor_set(x_218, 1, x_18); -x_219 = lean_array_push(x_214, x_218); -if (lean_is_scalar(x_217)) { - x_220 = lean_alloc_ctor(0, 5, 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_220 = x_217; + x_232 = x_229; } -lean_ctor_set(x_220, 0, x_212); -lean_ctor_set(x_220, 1, x_213); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_215); -lean_ctor_set(x_220, 4, x_216); -x_221 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_220, x_211); -if (lean_obj_tag(x_221) == 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_isClassExpensive___main___spec__6(x_1, x_2, x_32, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; -x_222 = lean_ctor_get(x_221, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_222, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_221, 0); -lean_inc(x_224); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_225 = x_221; +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_221); - x_225 = lean_box(0); + lean_dec_ref(x_233); + x_237 = lean_box(0); } -x_226 = lean_ctor_get(x_222, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_222, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_222, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_222, 4); -lean_inc(x_229); -x_230 = lean_ctor_get(x_222, 5); -lean_inc(x_230); -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_231 = x_222; +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_222); - x_231 = lean_box(0); + lean_dec_ref(x_234); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_223, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_223, 1); -lean_inc(x_233); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - lean_ctor_release(x_223, 2); - x_234 = x_223; +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_223); - x_234 = lean_box(0); + lean_dec_ref(x_235); + x_247 = lean_box(0); } -if (lean_is_scalar(x_234)) { - x_235 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_247)) { + x_248 = lean_alloc_ctor(0, 4, 0); } else { - x_235 = x_234; + x_248 = x_247; } -lean_ctor_set(x_235, 0, x_232); -lean_ctor_set(x_235, 1, x_233); -lean_ctor_set(x_235, 2, x_207); -if (lean_is_scalar(x_231)) { - x_236 = lean_alloc_ctor(0, 6, 0); +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_236 = x_231; + x_249 = x_243; } -lean_ctor_set(x_236, 0, x_226); -lean_ctor_set(x_236, 1, x_227); -lean_ctor_set(x_236, 2, x_235); -lean_ctor_set(x_236, 3, x_228); -lean_ctor_set(x_236, 4, x_229); -lean_ctor_set(x_236, 5, x_230); -if (lean_is_scalar(x_225)) { - x_237 = lean_alloc_ctor(0, 2, 0); +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_237 = x_225; + x_250 = x_237; } -lean_ctor_set(x_237, 0, x_224); -lean_ctor_set(x_237, 1, x_236); -return 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_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; -x_238 = lean_ctor_get(x_221, 1); -lean_inc(x_238); -x_239 = lean_ctor_get(x_238, 2); -lean_inc(x_239); -x_240 = lean_ctor_get(x_221, 0); -lean_inc(x_240); -if (lean_is_exclusive(x_221)) { - lean_ctor_release(x_221, 0); - lean_ctor_release(x_221, 1); - x_241 = x_221; +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_221); - x_241 = lean_box(0); + lean_dec_ref(x_233); + x_254 = 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; +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_238); - x_247 = lean_box(0); + lean_dec_ref(x_251); + x_260 = 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); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - lean_ctor_release(x_239, 2); - x_250 = x_239; +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_239); - x_250 = lean_box(0); + lean_dec_ref(x_252); + x_264 = lean_box(0); } -if (lean_is_scalar(x_250)) { - x_251 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(0, 4, 0); } else { - x_251 = x_250; + x_265 = x_264; } -lean_ctor_set(x_251, 0, x_248); -lean_ctor_set(x_251, 1, x_249); -lean_ctor_set(x_251, 2, x_207); -if (lean_is_scalar(x_247)) { - x_252 = lean_alloc_ctor(0, 6, 0); +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_252 = x_247; + x_266 = x_260; } -lean_ctor_set(x_252, 0, x_242); -lean_ctor_set(x_252, 1, x_243); -lean_ctor_set(x_252, 2, x_251); -lean_ctor_set(x_252, 3, x_244); -lean_ctor_set(x_252, 4, x_245); -lean_ctor_set(x_252, 5, x_246); -if (lean_is_scalar(x_241)) { - x_253 = lean_alloc_ctor(1, 2, 0); +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_253 = x_241; + x_267 = x_254; } -lean_ctor_set(x_253, 0, x_240); -lean_ctor_set(x_253, 1, x_252); -return x_253; +lean_ctor_set(x_267, 0, x_253); +lean_ctor_set(x_267, 1, x_266); +return x_267; } } } default: { -lean_object* x_254; lean_object* x_255; -x_254 = lean_ctor_get(x_23, 1); -lean_inc(x_254); +lean_object* x_268; lean_object* x_269; +x_268 = lean_ctor_get(x_23, 1); +lean_inc(x_268); lean_dec(x_23); lean_inc(x_4); -x_255 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_254); -if (lean_obj_tag(x_255) == 0) +x_269 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_268); +if (lean_obj_tag(x_269) == 0) { -lean_object* x_256; -x_256 = lean_ctor_get(x_255, 0); -lean_inc(x_256); -if (lean_obj_tag(x_256) == 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_257; lean_object* x_258; lean_object* x_259; +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_dec(x_18); -x_257 = lean_ctor_get(x_255, 1); -lean_inc(x_257); -lean_dec(x_255); -x_258 = lean_unsigned_to_nat(1u); -x_259 = lean_nat_add(x_3, x_258); +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); lean_dec(x_3); -x_3 = x_259; -x_5 = x_257; +x_3 = x_273; +x_5 = x_271; goto _start; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; uint8_t x_265; -x_261 = lean_ctor_get(x_255, 1); -lean_inc(x_261); -lean_dec(x_255); -x_262 = lean_ctor_get(x_256, 0); -lean_inc(x_262); -lean_dec(x_256); -x_263 = lean_unsigned_to_nat(1u); -x_264 = lean_nat_add(x_3, x_263); -lean_dec(x_3); -x_265 = !lean_is_exclusive(x_261); -if (x_265 == 0) -{ -lean_object* x_266; uint8_t x_267; -x_266 = lean_ctor_get(x_261, 2); -x_267 = !lean_is_exclusive(x_266); -if (x_267 == 0) -{ -lean_object* x_268; lean_object* x_269; uint8_t x_270; -x_268 = lean_ctor_get(x_266, 2); -x_269 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_266, 2, x_269); -x_270 = !lean_is_exclusive(x_4); -if (x_270 == 0) -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; -x_271 = lean_ctor_get(x_4, 2); -x_272 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_272, 0, x_262); -lean_ctor_set(x_272, 1, x_18); -x_273 = lean_array_push(x_271, x_272); -lean_ctor_set(x_4, 2, x_273); -x_274 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_264, x_4, x_261); -if (lean_obj_tag(x_274) == 0) -{ -lean_object* x_275; lean_object* x_276; uint8_t x_277; -x_275 = lean_ctor_get(x_274, 1); +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); -x_276 = lean_ctor_get(x_275, 2); +lean_dec(x_269); +x_276 = lean_ctor_get(x_270, 0); lean_inc(x_276); -x_277 = !lean_is_exclusive(x_274); -if (x_277 == 0) -{ -lean_object* x_278; uint8_t x_279; -x_278 = lean_ctor_get(x_274, 1); -lean_dec(x_278); +lean_dec(x_270); +x_277 = lean_unsigned_to_nat(1u); +x_278 = lean_nat_add(x_3, x_277); +lean_dec(x_3); x_279 = !lean_is_exclusive(x_275); if (x_279 == 0) { lean_object* x_280; uint8_t x_281; x_280 = lean_ctor_get(x_275, 2); -lean_dec(x_280); -x_281 = !lean_is_exclusive(x_276); +x_281 = !lean_is_exclusive(x_280); if (x_281 == 0) { -lean_object* x_282; -x_282 = lean_ctor_get(x_276, 2); -lean_dec(x_282); -lean_ctor_set(x_276, 2, x_268); -return x_274; -} -else +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_283; lean_object* x_284; lean_object* x_285; -x_283 = lean_ctor_get(x_276, 0); -x_284 = lean_ctor_get(x_276, 1); -lean_inc(x_284); -lean_inc(x_283); -lean_dec(x_276); -x_285 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_285, 0, x_283); -lean_ctor_set(x_285, 1, x_284); -lean_ctor_set(x_285, 2, x_268); -lean_ctor_set(x_275, 2, x_285); -return x_274; -} -} -else +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_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_286 = lean_ctor_get(x_275, 0); -x_287 = lean_ctor_get(x_275, 1); -x_288 = lean_ctor_get(x_275, 3); -x_289 = lean_ctor_get(x_275, 4); -x_290 = lean_ctor_get(x_275, 5); -lean_inc(x_290); +lean_object* x_289; lean_object* x_290; uint8_t x_291; +x_289 = lean_ctor_get(x_288, 1); lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_dec(x_275); -x_291 = lean_ctor_get(x_276, 0); -lean_inc(x_291); -x_292 = lean_ctor_get(x_276, 1); -lean_inc(x_292); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - x_293 = x_276; -} else { - lean_dec_ref(x_276); - x_293 = lean_box(0); -} -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 3, 0); -} else { - x_294 = x_293; -} -lean_ctor_set(x_294, 0, x_291); -lean_ctor_set(x_294, 1, x_292); -lean_ctor_set(x_294, 2, x_268); -x_295 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_295, 0, x_286); -lean_ctor_set(x_295, 1, x_287); -lean_ctor_set(x_295, 2, x_294); -lean_ctor_set(x_295, 3, x_288); -lean_ctor_set(x_295, 4, x_289); -lean_ctor_set(x_295, 5, x_290); -lean_ctor_set(x_274, 1, x_295); -return x_274; -} +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_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_296 = lean_ctor_get(x_274, 0); -lean_inc(x_296); -lean_dec(x_274); -x_297 = lean_ctor_get(x_275, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_275, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_275, 3); +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); -x_300 = lean_ctor_get(x_275, 4); -lean_inc(x_300); -x_301 = lean_ctor_get(x_275, 5); -lean_inc(x_301); -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); - lean_ctor_release(x_275, 4); - lean_ctor_release(x_275, 5); - x_302 = x_275; -} else { - lean_dec_ref(x_275); - x_302 = lean_box(0); +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; } -x_303 = lean_ctor_get(x_276, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_276, 1); +} +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); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - x_305 = x_276; +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_inc(x_307); +x_308 = lean_ctor_get(x_290, 3); +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_276); - x_305 = lean_box(0); + lean_dec_ref(x_290); + x_309 = lean_box(0); } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_309)) { + x_310 = lean_alloc_ctor(0, 4, 0); } else { - x_306 = x_305; + x_310 = x_309; } -lean_ctor_set(x_306, 0, x_303); -lean_ctor_set(x_306, 1, x_304); -lean_ctor_set(x_306, 2, x_268); -if (lean_is_scalar(x_302)) { - x_307 = lean_alloc_ctor(0, 6, 0); -} else { - x_307 = x_302; -} -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); -x_308 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_308, 0, x_296); -lean_ctor_set(x_308, 1, x_307); -return x_308; +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_309; lean_object* x_310; uint8_t x_311; -x_309 = lean_ctor_get(x_274, 1); -lean_inc(x_309); -x_310 = lean_ctor_get(x_309, 2); -lean_inc(x_310); -x_311 = !lean_is_exclusive(x_274); -if (x_311 == 0) -{ -lean_object* x_312; uint8_t x_313; -x_312 = lean_ctor_get(x_274, 1); -lean_dec(x_312); -x_313 = !lean_is_exclusive(x_309); -if (x_313 == 0) -{ -lean_object* x_314; uint8_t x_315; -x_314 = lean_ctor_get(x_309, 2); -lean_dec(x_314); -x_315 = !lean_is_exclusive(x_310); -if (x_315 == 0) -{ -lean_object* x_316; -x_316 = lean_ctor_get(x_310, 2); -lean_dec(x_316); -lean_ctor_set(x_310, 2, x_268); -return x_274; -} -else -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; -x_317 = lean_ctor_get(x_310, 0); -x_318 = lean_ctor_get(x_310, 1); -lean_inc(x_318); +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_inc(x_317); -lean_dec(x_310); -x_319 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_319, 0, x_317); -lean_ctor_set(x_319, 1, x_318); -lean_ctor_set(x_319, 2, x_268); -lean_ctor_set(x_309, 2, x_319); -return x_274; +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); } -} -else -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_320 = lean_ctor_get(x_309, 0); -x_321 = lean_ctor_get(x_309, 1); -x_322 = lean_ctor_get(x_309, 3); -x_323 = lean_ctor_get(x_309, 4); -x_324 = lean_ctor_get(x_309, 5); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); +x_319 = lean_ctor_get(x_290, 0); +lean_inc(x_319); +x_320 = lean_ctor_get(x_290, 1); lean_inc(x_320); -lean_dec(x_309); -x_325 = lean_ctor_get(x_310, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_310, 1); +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); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - x_327 = x_310; -} else { - lean_dec_ref(x_310); - x_327 = lean_box(0); -} -if (lean_is_scalar(x_327)) { - x_328 = lean_alloc_ctor(0, 3, 0); -} else { - x_328 = x_327; -} -lean_ctor_set(x_328, 0, x_325); -lean_ctor_set(x_328, 1, x_326); -lean_ctor_set(x_328, 2, x_268); -x_329 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_329, 0, x_320); -lean_ctor_set(x_329, 1, x_321); -lean_ctor_set(x_329, 2, x_328); -lean_ctor_set(x_329, 3, x_322); -lean_ctor_set(x_329, 4, x_323); -lean_ctor_set(x_329, 5, x_324); -lean_ctor_set(x_274, 1, x_329); -return x_274; -} +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_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; -x_330 = lean_ctor_get(x_274, 0); -lean_inc(x_330); -lean_dec(x_274); -x_331 = lean_ctor_get(x_309, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_309, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_309, 3); -lean_inc(x_333); -x_334 = lean_ctor_get(x_309, 4); -lean_inc(x_334); -x_335 = lean_ctor_get(x_309, 5); +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); -if (lean_is_exclusive(x_309)) { - lean_ctor_release(x_309, 0); - lean_ctor_release(x_309, 1); - lean_ctor_release(x_309, 2); - lean_ctor_release(x_309, 3); - lean_ctor_release(x_309, 4); - lean_ctor_release(x_309, 5); - x_336 = x_309; -} else { - lean_dec_ref(x_309); - x_336 = lean_box(0); -} -x_337 = lean_ctor_get(x_310, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_310, 1); -lean_inc(x_338); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - x_339 = x_310; -} else { - lean_dec_ref(x_310); - x_339 = lean_box(0); -} -if (lean_is_scalar(x_339)) { - x_340 = lean_alloc_ctor(0, 3, 0); -} else { - x_340 = x_339; -} -lean_ctor_set(x_340, 0, x_337); -lean_ctor_set(x_340, 1, x_338); -lean_ctor_set(x_340, 2, x_268); -if (lean_is_scalar(x_336)) { - x_341 = lean_alloc_ctor(0, 6, 0); -} else { - x_341 = x_336; -} -lean_ctor_set(x_341, 0, x_331); -lean_ctor_set(x_341, 1, x_332); -lean_ctor_set(x_341, 2, x_340); -lean_ctor_set(x_341, 3, x_333); -lean_ctor_set(x_341, 4, x_334); -lean_ctor_set(x_341, 5, x_335); -x_342 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_342, 0, x_330); -lean_ctor_set(x_342, 1, x_341); -return x_342; -} +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_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_343 = lean_ctor_get(x_4, 0); -x_344 = lean_ctor_get(x_4, 1); -x_345 = lean_ctor_get(x_4, 2); -x_346 = lean_ctor_get(x_4, 3); -x_347 = lean_ctor_get(x_4, 4); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); -lean_inc(x_344); +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); -lean_dec(x_4); -x_348 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_348, 0, x_262); -lean_ctor_set(x_348, 1, x_18); -x_349 = lean_array_push(x_345, x_348); -x_350 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_350, 0, x_343); -lean_ctor_set(x_350, 1, x_344); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_346); -lean_ctor_set(x_350, 4, x_347); -x_351 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_264, x_350, x_261); -if (lean_obj_tag(x_351) == 0) -{ -lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; -x_352 = lean_ctor_get(x_351, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_352, 2); -lean_inc(x_353); -x_354 = lean_ctor_get(x_351, 0); -lean_inc(x_354); -if (lean_is_exclusive(x_351)) { - lean_ctor_release(x_351, 0); - lean_ctor_release(x_351, 1); - x_355 = x_351; +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_351); + 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_352, 0); +x_356 = lean_ctor_get(x_327, 0); lean_inc(x_356); -x_357 = lean_ctor_get(x_352, 1); +x_357 = lean_ctor_get(x_327, 1); lean_inc(x_357); -x_358 = lean_ctor_get(x_352, 3); +x_358 = lean_ctor_get(x_327, 3); lean_inc(x_358); -x_359 = lean_ctor_get(x_352, 4); -lean_inc(x_359); -x_360 = lean_ctor_get(x_352, 5); -lean_inc(x_360); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - lean_ctor_release(x_352, 2); - lean_ctor_release(x_352, 3); - lean_ctor_release(x_352, 4); - lean_ctor_release(x_352, 5); - x_361 = x_352; +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_352); - x_361 = lean_box(0); + lean_dec_ref(x_327); + x_359 = lean_box(0); } -x_362 = lean_ctor_get(x_353, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_353, 1); -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); - x_364 = x_353; +if (lean_is_scalar(x_359)) { + x_360 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_353); - x_364 = lean_box(0); + x_360 = x_359; } -if (lean_is_scalar(x_364)) { - x_365 = lean_alloc_ctor(0, 3, 0); -} else { - x_365 = x_364; -} -lean_ctor_set(x_365, 0, x_362); -lean_ctor_set(x_365, 1, x_363); -lean_ctor_set(x_365, 2, x_268); -if (lean_is_scalar(x_361)) { - x_366 = lean_alloc_ctor(0, 6, 0); -} else { - x_366 = x_361; -} -lean_ctor_set(x_366, 0, x_356); -lean_ctor_set(x_366, 1, x_357); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_358); -lean_ctor_set(x_366, 4, x_359); -lean_ctor_set(x_366, 5, x_360); +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_367 = lean_alloc_ctor(0, 2, 0); + x_361 = lean_alloc_ctor(0, 6, 0); } else { - x_367 = x_355; + 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; +} } -lean_ctor_set(x_367, 0, x_354); -lean_ctor_set(x_367, 1, x_366); -return x_367; } else { -lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_368 = lean_ctor_get(x_351, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_368, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_351, 0); -lean_inc(x_370); -if (lean_is_exclusive(x_351)) { - lean_ctor_release(x_351, 0); - lean_ctor_release(x_351, 1); - x_371 = x_351; -} else { - lean_dec_ref(x_351); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_368, 0); +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_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) +{ +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_368, 1); +x_373 = lean_ctor_get(x_372, 2); lean_inc(x_373); -x_374 = lean_ctor_get(x_368, 3); +x_374 = lean_ctor_get(x_371, 0); lean_inc(x_374); -x_375 = lean_ctor_get(x_368, 4); -lean_inc(x_375); -x_376 = lean_ctor_get(x_368, 5); +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); -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); +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_369, 1); +x_379 = lean_ctor_get(x_372, 4); lean_inc(x_379); -if (lean_is_exclusive(x_369)) { - lean_ctor_release(x_369, 0); - lean_ctor_release(x_369, 1); - lean_ctor_release(x_369, 2); - x_380 = x_369; +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_369); - x_380 = lean_box(0); + lean_dec_ref(x_372); + x_381 = lean_box(0); } -if (lean_is_scalar(x_380)) { - x_381 = lean_alloc_ctor(0, 3, 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 { - x_381 = x_380; + lean_dec_ref(x_373); + x_385 = lean_box(0); } -lean_ctor_set(x_381, 0, x_378); -lean_ctor_set(x_381, 1, x_379); -lean_ctor_set(x_381, 2, x_268); -if (lean_is_scalar(x_377)) { - x_382 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_385)) { + x_386 = lean_alloc_ctor(0, 4, 0); } else { - x_382 = x_377; + x_386 = x_385; } -lean_ctor_set(x_382, 0, x_372); -lean_ctor_set(x_382, 1, x_373); -lean_ctor_set(x_382, 2, x_381); -lean_ctor_set(x_382, 3, x_374); -lean_ctor_set(x_382, 4, x_375); -lean_ctor_set(x_382, 5, x_376); -if (lean_is_scalar(x_371)) { - x_383 = lean_alloc_ctor(1, 2, 0); +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_383 = x_371; -} -lean_ctor_set(x_383, 0, x_370); -lean_ctor_set(x_383, 1, x_382); -return x_383; + 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; } 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; -x_384 = lean_ctor_get(x_266, 0); -x_385 = lean_ctor_get(x_266, 1); -x_386 = lean_ctor_get(x_266, 2); -lean_inc(x_386); -lean_inc(x_385); -lean_inc(x_384); -lean_dec(x_266); -x_387 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_388 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_388, 0, x_384); -lean_ctor_set(x_388, 1, x_385); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_261, 2, x_388); -x_389 = lean_ctor_get(x_4, 0); +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_4, 1); +x_390 = lean_ctor_get(x_389, 2); lean_inc(x_390); -x_391 = lean_ctor_get(x_4, 2); +x_391 = lean_ctor_get(x_371, 0); lean_inc(x_391); -x_392 = lean_ctor_get(x_4, 3); -lean_inc(x_392); -x_393 = lean_ctor_get(x_4, 4); +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); +} +x_393 = lean_ctor_get(x_389, 0); lean_inc(x_393); -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_394 = x_4; +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_4); - x_394 = lean_box(0); + lean_dec_ref(x_389); + x_398 = lean_box(0); } -x_395 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_395, 0, x_262); -lean_ctor_set(x_395, 1, x_18); -x_396 = lean_array_push(x_391, x_395); -if (lean_is_scalar(x_394)) { - x_397 = lean_alloc_ctor(0, 5, 0); -} else { - x_397 = x_394; -} -lean_ctor_set(x_397, 0, x_389); -lean_ctor_set(x_397, 1, x_390); -lean_ctor_set(x_397, 2, x_396); -lean_ctor_set(x_397, 3, x_392); -lean_ctor_set(x_397, 4, x_393); -x_398 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_264, x_397, x_261); -if (lean_obj_tag(x_398) == 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; lean_object* x_414; -x_399 = lean_ctor_get(x_398, 1); +x_399 = lean_ctor_get(x_390, 0); lean_inc(x_399); -x_400 = lean_ctor_get(x_399, 2); +x_400 = lean_ctor_get(x_390, 1); lean_inc(x_400); -x_401 = lean_ctor_get(x_398, 0); +x_401 = lean_ctor_get(x_390, 3); lean_inc(x_401); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - x_402 = 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); + x_402 = x_390; } else { - lean_dec_ref(x_398); + lean_dec_ref(x_390); x_402 = lean_box(0); } -x_403 = lean_ctor_get(x_399, 0); -lean_inc(x_403); -x_404 = lean_ctor_get(x_399, 1); -lean_inc(x_404); -x_405 = lean_ctor_get(x_399, 3); -lean_inc(x_405); -x_406 = lean_ctor_get(x_399, 4); -lean_inc(x_406); -x_407 = lean_ctor_get(x_399, 5); -lean_inc(x_407); -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_408 = x_399; -} else { - lean_dec_ref(x_399); - x_408 = lean_box(0); -} -x_409 = lean_ctor_get(x_400, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_400, 1); -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); - x_411 = x_400; -} else { - lean_dec_ref(x_400); - x_411 = lean_box(0); -} -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 3, 0); -} else { - x_412 = x_411; -} -lean_ctor_set(x_412, 0, x_409); -lean_ctor_set(x_412, 1, x_410); -lean_ctor_set(x_412, 2, x_386); -if (lean_is_scalar(x_408)) { - x_413 = lean_alloc_ctor(0, 6, 0); -} else { - x_413 = x_408; -} -lean_ctor_set(x_413, 0, x_403); -lean_ctor_set(x_413, 1, x_404); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_405); -lean_ctor_set(x_413, 4, x_406); -lean_ctor_set(x_413, 5, x_407); if (lean_is_scalar(x_402)) { - x_414 = lean_alloc_ctor(0, 2, 0); + x_403 = lean_alloc_ctor(0, 4, 0); } else { - x_414 = x_402; + x_403 = x_402; +} +lean_ctor_set(x_403, 0, x_399); +lean_ctor_set(x_403, 1, x_400); +lean_ctor_set(x_403, 2, x_282); +lean_ctor_set(x_403, 3, x_401); +if (lean_is_scalar(x_398)) { + x_404 = lean_alloc_ctor(0, 6, 0); +} else { + x_404 = x_398; +} +lean_ctor_set(x_404, 0, x_393); +lean_ctor_set(x_404, 1, x_394); +lean_ctor_set(x_404, 2, x_403); +lean_ctor_set(x_404, 3, x_395); +lean_ctor_set(x_404, 4, x_396); +lean_ctor_set(x_404, 5, x_397); +if (lean_is_scalar(x_392)) { + x_405 = lean_alloc_ctor(1, 2, 0); +} else { + x_405 = x_392; +} +lean_ctor_set(x_405, 0, x_391); +lean_ctor_set(x_405, 1, x_404); +return x_405; +} } -lean_ctor_set(x_414, 0, x_401); -lean_ctor_set(x_414, 1, x_413); -return x_414; } else { -lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; -x_415 = lean_ctor_get(x_398, 1); +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; +x_406 = lean_ctor_get(x_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_415, 2); +x_416 = lean_ctor_get(x_4, 4); lean_inc(x_416); -x_417 = lean_ctor_get(x_398, 0); -lean_inc(x_417); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - x_418 = x_398; -} else { - lean_dec_ref(x_398); - x_418 = lean_box(0); -} -x_419 = lean_ctor_get(x_415, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_415, 1); -lean_inc(x_420); -x_421 = lean_ctor_get(x_415, 3); -lean_inc(x_421); -x_422 = lean_ctor_get(x_415, 4); -lean_inc(x_422); -x_423 = lean_ctor_get(x_415, 5); -lean_inc(x_423); -if (lean_is_exclusive(x_415)) { - lean_ctor_release(x_415, 0); - lean_ctor_release(x_415, 1); - lean_ctor_release(x_415, 2); - lean_ctor_release(x_415, 3); - lean_ctor_release(x_415, 4); - lean_ctor_release(x_415, 5); - x_424 = x_415; -} else { - lean_dec_ref(x_415); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_416, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_416, 1); -lean_inc(x_426); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - lean_ctor_release(x_416, 2); - x_427 = x_416; -} else { - lean_dec_ref(x_416); - x_427 = lean_box(0); -} -if (lean_is_scalar(x_427)) { - x_428 = lean_alloc_ctor(0, 3, 0); -} else { - x_428 = x_427; -} -lean_ctor_set(x_428, 0, x_425); -lean_ctor_set(x_428, 1, x_426); -lean_ctor_set(x_428, 2, x_386); -if (lean_is_scalar(x_424)) { - x_429 = lean_alloc_ctor(0, 6, 0); -} else { - x_429 = x_424; -} -lean_ctor_set(x_429, 0, x_419); -lean_ctor_set(x_429, 1, x_420); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_421); -lean_ctor_set(x_429, 4, x_422); -lean_ctor_set(x_429, 5, x_423); -if (lean_is_scalar(x_418)) { - x_430 = lean_alloc_ctor(1, 2, 0); -} else { - x_430 = x_418; -} -lean_ctor_set(x_430, 0, x_417); -lean_ctor_set(x_430, 1, x_429); -return x_430; -} -} -} -else -{ -lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_431 = lean_ctor_get(x_261, 2); -x_432 = lean_ctor_get(x_261, 0); -x_433 = lean_ctor_get(x_261, 1); -x_434 = lean_ctor_get(x_261, 3); -x_435 = lean_ctor_get(x_261, 4); -x_436 = lean_ctor_get(x_261, 5); -lean_inc(x_436); -lean_inc(x_435); -lean_inc(x_434); -lean_inc(x_431); -lean_inc(x_433); -lean_inc(x_432); -lean_dec(x_261); -x_437 = lean_ctor_get(x_431, 0); -lean_inc(x_437); -x_438 = lean_ctor_get(x_431, 1); -lean_inc(x_438); -x_439 = lean_ctor_get(x_431, 2); -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); - x_440 = x_431; -} else { - lean_dec_ref(x_431); - x_440 = lean_box(0); -} -x_441 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_440)) { - x_442 = lean_alloc_ctor(0, 3, 0); -} else { - x_442 = x_440; -} -lean_ctor_set(x_442, 0, x_437); -lean_ctor_set(x_442, 1, x_438); -lean_ctor_set(x_442, 2, x_441); -x_443 = lean_alloc_ctor(0, 6, 0); -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); -x_444 = lean_ctor_get(x_4, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_4, 1); -lean_inc(x_445); -x_446 = lean_ctor_get(x_4, 2); -lean_inc(x_446); -x_447 = lean_ctor_get(x_4, 3); -lean_inc(x_447); -x_448 = lean_ctor_get(x_4, 4); -lean_inc(x_448); 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_449 = x_4; + x_417 = x_4; } else { lean_dec_ref(x_4); - x_449 = lean_box(0); + x_417 = lean_box(0); } -x_450 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_450, 0, x_262); -lean_ctor_set(x_450, 1, x_18); -x_451 = lean_array_push(x_446, x_450); -if (lean_is_scalar(x_449)) { - x_452 = lean_alloc_ctor(0, 5, 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); } else { - x_452 = x_449; + x_420 = x_417; } -lean_ctor_set(x_452, 0, x_444); -lean_ctor_set(x_452, 1, x_445); -lean_ctor_set(x_452, 2, x_451); -lean_ctor_set(x_452, 3, x_447); -lean_ctor_set(x_452, 4, x_448); -x_453 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_264, x_452, x_443); -if (lean_obj_tag(x_453) == 0) +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_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; -x_454 = lean_ctor_get(x_453, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_454, 2); -lean_inc(x_455); -x_456 = lean_ctor_get(x_453, 0); -lean_inc(x_456); -if (lean_is_exclusive(x_453)) { - lean_ctor_release(x_453, 0); - lean_ctor_release(x_453, 1); - x_457 = x_453; +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_453); - x_457 = lean_box(0); + lean_dec_ref(x_421); + x_425 = lean_box(0); } -x_458 = lean_ctor_get(x_454, 0); -lean_inc(x_458); -x_459 = lean_ctor_get(x_454, 1); -lean_inc(x_459); -x_460 = lean_ctor_get(x_454, 3); -lean_inc(x_460); -x_461 = lean_ctor_get(x_454, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_439); + x_448 = 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; +} else { + lean_dec_ref(x_440); + x_452 = lean_box(0); +} +if (lean_is_scalar(x_452)) { + x_453 = lean_alloc_ctor(0, 4, 0); +} else { + x_453 = x_452; +} +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); +} else { + x_454 = x_448; +} +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); +} else { + x_455 = x_442; +} +lean_ctor_set(x_455, 0, x_441); +lean_ctor_set(x_455, 1, x_454); +return x_455; +} +} +} +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); -x_462 = lean_ctor_get(x_454, 5); +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); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - lean_ctor_release(x_454, 2); - lean_ctor_release(x_454, 3); - lean_ctor_release(x_454, 4); - lean_ctor_release(x_454, 5); - x_463 = x_454; -} else { - lean_dec_ref(x_454); - x_463 = lean_box(0); -} -x_464 = lean_ctor_get(x_455, 0); +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_455, 1); +x_465 = lean_ctor_get(x_456, 3); lean_inc(x_465); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - lean_ctor_release(x_455, 2); - x_466 = x_455; +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; } else { - lean_dec_ref(x_455); + lean_dec_ref(x_456); x_466 = lean_box(0); } +x_467 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_466)) { - x_467 = lean_alloc_ctor(0, 3, 0); + x_468 = lean_alloc_ctor(0, 4, 0); } else { - x_467 = x_466; + x_468 = x_466; } -lean_ctor_set(x_467, 0, x_464); -lean_ctor_set(x_467, 1, x_465); -lean_ctor_set(x_467, 2, x_439); -if (lean_is_scalar(x_463)) { - x_468 = lean_alloc_ctor(0, 6, 0); -} else { - x_468 = x_463; -} -lean_ctor_set(x_468, 0, x_458); -lean_ctor_set(x_468, 1, x_459); +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_460); -lean_ctor_set(x_468, 4, x_461); -lean_ctor_set(x_468, 5, x_462); -if (lean_is_scalar(x_457)) { - x_469 = lean_alloc_ctor(0, 2, 0); -} else { - x_469 = x_457; -} -lean_ctor_set(x_469, 0, x_456); -lean_ctor_set(x_469, 1, x_468); -return x_469; -} -else -{ -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_470 = lean_ctor_get(x_453, 1); +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_470, 2); +x_471 = lean_ctor_get(x_4, 1); lean_inc(x_471); -x_472 = lean_ctor_get(x_453, 0); +x_472 = lean_ctor_get(x_4, 2); lean_inc(x_472); -if (lean_is_exclusive(x_453)) { - lean_ctor_release(x_453, 0); - lean_ctor_release(x_453, 1); - x_473 = x_453; -} else { - lean_dec_ref(x_453); - x_473 = lean_box(0); -} -x_474 = lean_ctor_get(x_470, 0); +x_473 = lean_ctor_get(x_4, 3); +lean_inc(x_473); +x_474 = lean_ctor_get(x_4, 4); lean_inc(x_474); -x_475 = lean_ctor_get(x_470, 1); -lean_inc(x_475); -x_476 = lean_ctor_get(x_470, 3); -lean_inc(x_476); -x_477 = lean_ctor_get(x_470, 4); -lean_inc(x_477); -x_478 = lean_ctor_get(x_470, 5); -lean_inc(x_478); -if (lean_is_exclusive(x_470)) { - lean_ctor_release(x_470, 0); - lean_ctor_release(x_470, 1); - lean_ctor_release(x_470, 2); - lean_ctor_release(x_470, 3); - lean_ctor_release(x_470, 4); - lean_ctor_release(x_470, 5); - x_479 = x_470; +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; } else { - lean_dec_ref(x_470); - x_479 = lean_box(0); + lean_dec_ref(x_4); + x_475 = lean_box(0); } -x_480 = lean_ctor_get(x_471, 0); +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); +} else { + x_478 = x_475; +} +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_471, 1); +x_481 = lean_ctor_get(x_480, 2); lean_inc(x_481); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - lean_ctor_release(x_471, 2); - x_482 = x_471; +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; } else { - lean_dec_ref(x_471); - x_482 = lean_box(0); + lean_dec_ref(x_479); + x_483 = lean_box(0); } -if (lean_is_scalar(x_482)) { - x_483 = lean_alloc_ctor(0, 3, 0); +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 { - x_483 = x_482; + lean_dec_ref(x_480); + x_489 = lean_box(0); } -lean_ctor_set(x_483, 0, x_480); -lean_ctor_set(x_483, 1, x_481); -lean_ctor_set(x_483, 2, x_439); -if (lean_is_scalar(x_479)) { - x_484 = lean_alloc_ctor(0, 6, 0); +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 { - x_484 = x_479; + lean_dec_ref(x_481); + x_493 = lean_box(0); } -lean_ctor_set(x_484, 0, x_474); -lean_ctor_set(x_484, 1, x_475); -lean_ctor_set(x_484, 2, x_483); -lean_ctor_set(x_484, 3, x_476); -lean_ctor_set(x_484, 4, x_477); -lean_ctor_set(x_484, 5, x_478); -if (lean_is_scalar(x_473)) { - x_485 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_493)) { + x_494 = lean_alloc_ctor(0, 4, 0); } else { - x_485 = x_473; + x_494 = x_493; } -lean_ctor_set(x_485, 0, x_472); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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_486; +uint8_t x_514; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_486 = !lean_is_exclusive(x_255); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_269); +if (x_514 == 0) { -return x_255; +return x_269; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_255, 0); -x_488 = lean_ctor_get(x_255, 1); -lean_inc(x_488); -lean_inc(x_487); -lean_dec(x_255); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } @@ -17762,54 +18286,54 @@ return x_489; } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_490 = !lean_is_exclusive(x_23); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_23); +if (x_518 == 0) { return x_23; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_23, 0); -x_492 = lean_ctor_get(x_23, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_23); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } else { -uint8_t x_494; +uint8_t x_522; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_494 = !lean_is_exclusive(x_19); -if (x_494 == 0) +x_522 = !lean_is_exclusive(x_19); +if (x_522 == 0) { return x_19; } else { -lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_495 = lean_ctor_get(x_19, 0); -x_496 = lean_ctor_get(x_19, 1); -lean_inc(x_496); -lean_inc(x_495); +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_dec(x_19); -x_497 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_497, 0, x_495); -lean_ctor_set(x_497, 1, x_496); -return x_497; +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; } } } @@ -18492,82 +19016,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -18575,1899 +19106,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -20475,58 +21105,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -20710,82 +21340,89 @@ return x_44; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; +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_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_38); -lean_ctor_set(x_45, 2, x_55); +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; } } 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; -x_56 = lean_ctor_get(x_45, 0); -x_57 = lean_ctor_get(x_45, 1); -x_58 = lean_ctor_get(x_45, 3); -x_59 = lean_ctor_get(x_45, 4); -x_60 = lean_ctor_get(x_45, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +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_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_45); -x_61 = lean_ctor_get(x_46, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_46, 1); +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); - x_63 = x_46; + lean_ctor_release(x_46, 3); + x_65 = x_46; } else { lean_dec_ref(x_46); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -lean_ctor_set(x_64, 2, x_38); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_56); -lean_ctor_set(x_65, 1, x_57); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_58); -lean_ctor_set(x_65, 4, x_59); -lean_ctor_set(x_65, 5, x_60); -lean_ctor_set(x_44, 1, 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_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; } } 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; -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -lean_dec(x_44); -x_67 = lean_ctor_get(x_45, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_45, 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; lean_object* x_80; lean_object* x_81; +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_45, 3); +lean_dec(x_44); +x_69 = lean_ctor_get(x_45, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 4); +x_70 = lean_ctor_get(x_45, 1); lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 5); +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); @@ -20793,1877 +21430,1976 @@ if (lean_is_exclusive(x_45)) { lean_ctor_release(x_45, 3); lean_ctor_release(x_45, 4); lean_ctor_release(x_45, 5); - x_72 = x_45; + x_74 = x_45; } else { lean_dec_ref(x_45); - x_72 = lean_box(0); + x_74 = lean_box(0); } -x_73 = lean_ctor_get(x_46, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_46, 1); -lean_inc(x_74); +x_75 = lean_ctor_get(x_46, 0); +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); - x_75 = x_46; + lean_ctor_release(x_46, 3); + x_78 = x_46; } else { lean_dec_ref(x_46); - x_75 = lean_box(0); + x_78 = lean_box(0); } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 4, 0); } else { - x_76 = x_75; + x_79 = x_78; } -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_38); -if (lean_is_scalar(x_72)) { - x_77 = 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_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_77 = x_72; + x_80 = x_74; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_68); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_69); -lean_ctor_set(x_77, 4, x_70); -lean_ctor_set(x_77, 5, x_71); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_66); -lean_ctor_set(x_78, 1, x_77); -return x_78; +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; } } else { -lean_object* x_79; lean_object* x_80; uint8_t x_81; -x_79 = lean_ctor_get(x_44, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 2); -lean_inc(x_80); -x_81 = !lean_is_exclusive(x_44); -if (x_81 == 0) -{ -lean_object* x_82; uint8_t x_83; +lean_object* x_82; lean_object* x_83; uint8_t x_84; x_82 = lean_ctor_get(x_44, 1); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_79); -if (x_83 == 0) +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 2); +lean_inc(x_83); +x_84 = !lean_is_exclusive(x_44); +if (x_84 == 0) { -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_79, 2); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_80); -if (x_85 == 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_86; -x_86 = lean_ctor_get(x_80, 2); -lean_dec(x_86); -lean_ctor_set(x_80, 2, x_38); +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_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_80, 0); -x_88 = lean_ctor_get(x_80, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_80); -x_89 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -lean_ctor_set(x_89, 2, x_38); -lean_ctor_set(x_79, 2, x_89); -return x_44; -} -} -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; -x_90 = lean_ctor_get(x_79, 0); -x_91 = lean_ctor_get(x_79, 1); -x_92 = lean_ctor_get(x_79, 3); -x_93 = lean_ctor_get(x_79, 4); -x_94 = lean_ctor_get(x_79, 5); -lean_inc(x_94); -lean_inc(x_93); +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_79); -x_95 = lean_ctor_get(x_80, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_80, 1); -lean_inc(x_96); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - x_97 = x_80; -} else { - lean_dec_ref(x_80); - x_97 = lean_box(0); -} -if (lean_is_scalar(x_97)) { - x_98 = lean_alloc_ctor(0, 3, 0); -} else { - x_98 = x_97; -} -lean_ctor_set(x_98, 0, x_95); -lean_ctor_set(x_98, 1, x_96); -lean_ctor_set(x_98, 2, x_38); -x_99 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_99, 0, x_90); -lean_ctor_set(x_99, 1, x_91); -lean_ctor_set(x_99, 2, x_98); -lean_ctor_set(x_99, 3, x_92); -lean_ctor_set(x_99, 4, x_93); -lean_ctor_set(x_99, 5, x_94); -lean_ctor_set(x_44, 1, x_99); +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_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_100 = lean_ctor_get(x_44, 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; +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); -lean_dec(x_44); -x_101 = lean_ctor_get(x_79, 0); +x_101 = lean_ctor_get(x_83, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_79, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_79, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_79, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_79, 5); +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; +} else { + lean_dec_ref(x_83); + x_102 = lean_box(0); +} +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 4, 0); +} else { + x_103 = x_102; +} +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); -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); - lean_ctor_release(x_79, 4); - lean_ctor_release(x_79, 5); - x_106 = x_79; -} else { - lean_dec_ref(x_79); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_80, 0); +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_80, 1); +x_108 = lean_ctor_get(x_82, 3); 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); - x_109 = x_80; +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; } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + lean_dec_ref(x_82); + x_111 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 3, 0); +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 { - x_110 = x_109; + lean_dec_ref(x_83); + x_115 = lean_box(0); } -lean_ctor_set(x_110, 0, x_107); -lean_ctor_set(x_110, 1, x_108); -lean_ctor_set(x_110, 2, x_38); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 4, 0); } else { - x_111 = x_106; + x_116 = x_115; } -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_100); -lean_ctor_set(x_112, 1, x_111); -return x_112; +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_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_12, 0); -x_114 = lean_ctor_get(x_12, 1); -x_115 = lean_ctor_get(x_12, 2); -x_116 = lean_ctor_get(x_12, 3); -x_117 = lean_ctor_get(x_12, 4); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_12); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_32); -lean_ctor_set(x_118, 1, x_20); -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__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_120, x_31); -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; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); +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); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; -} else { - lean_dec_ref(x_121); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_122, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_122); +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_122, 4); +x_129 = lean_ctor_get(x_128, 2); lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); +x_130 = lean_ctor_get(x_127, 0); 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_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + x_131 = x_127; } else { - lean_dec_ref(x_122); + lean_dec_ref(x_127); x_131 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); +x_132 = lean_ctor_get(x_128, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); +x_133 = lean_ctor_get(x_128, 1); lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - x_134 = x_123; +x_134 = lean_ctor_get(x_128, 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; } else { - lean_dec_ref(x_123); - x_134 = lean_box(0); + lean_dec_ref(x_128); + x_137 = lean_box(0); } -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 3, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_132); -lean_ctor_set(x_135, 1, x_133); -lean_ctor_set(x_135, 2, x_38); -if (lean_is_scalar(x_131)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_131; -} -lean_ctor_set(x_136, 0, x_126); -lean_ctor_set(x_136, 1, x_127); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_128); -lean_ctor_set(x_136, 4, x_129); -lean_ctor_set(x_136, 5, x_130); -if (lean_is_scalar(x_125)) { - x_137 = lean_alloc_ctor(0, 2, 0); -} else { - x_137 = x_125; -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_138 = lean_ctor_get(x_121, 1); +x_138 = lean_ctor_get(x_129, 0); lean_inc(x_138); -x_139 = lean_ctor_get(x_138, 2); +x_139 = lean_ctor_get(x_129, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 0); +x_140 = lean_ctor_get(x_129, 3); lean_inc(x_140); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_141 = x_121; +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; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_129); x_141 = lean_box(0); } -x_142 = lean_ctor_get(x_138, 0); -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; -} else { - lean_dec_ref(x_138); - x_147 = 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); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - 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, 3, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -lean_ctor_set(x_151, 2, x_38); -if (lean_is_scalar(x_147)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_147; -} -lean_ctor_set(x_152, 0, x_142); -lean_ctor_set(x_152, 1, x_143); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_144); -lean_ctor_set(x_152, 4, x_145); -lean_ctor_set(x_152, 5, x_146); if (lean_is_scalar(x_141)) { - x_153 = lean_alloc_ctor(1, 2, 0); + x_142 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_141; + x_142 = x_141; } -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; +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); +if (lean_is_scalar(x_131)) { + x_144 = lean_alloc_ctor(0, 2, 0); +} else { + x_144 = x_131; +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_145 = lean_ctor_get(x_127, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_145, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 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); +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; +} else { + lean_dec_ref(x_145); + x_154 = 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; +} else { + lean_dec_ref(x_146); + x_158 = lean_box(0); +} +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_38); +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); +if (lean_is_scalar(x_148)) { + x_161 = lean_alloc_ctor(1, 2, 0); +} else { + x_161 = x_148; +} +lean_ctor_set(x_161, 0, x_147); +lean_ctor_set(x_161, 1, x_160); +return x_161; } } } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_154 = lean_ctor_get(x_36, 0); -x_155 = lean_ctor_get(x_36, 1); -x_156 = lean_ctor_get(x_36, 2); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_dec(x_36); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_31, 2, x_158); -x_159 = lean_ctor_get(x_12, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_12, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_12, 4); +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); 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_164 = x_12; + x_173 = x_12; } else { lean_dec_ref(x_12); - x_164 = lean_box(0); + x_173 = lean_box(0); } -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_32); -lean_ctor_set(x_165, 1, x_20); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 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); } else { - x_167 = x_164; + x_176 = x_173; } -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_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_167, x_31); -if (lean_obj_tag(x_168) == 0) +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_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, 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_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_170, 1); +x_180 = lean_ctor_get(x_177, 0); lean_inc(x_180); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - lean_ctor_release(x_170, 2); - x_181 = x_170; +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_170); + lean_dec_ref(x_177); x_181 = lean_box(0); } -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 3, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_179); -lean_ctor_set(x_182, 1, x_180); -lean_ctor_set(x_182, 2, x_156); -if (lean_is_scalar(x_178)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_178; -} -lean_ctor_set(x_183, 0, x_173); -lean_ctor_set(x_183, 1, x_174); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_175); -lean_ctor_set(x_183, 4, x_176); -lean_ctor_set(x_183, 5, x_177); -if (lean_is_scalar(x_172)) { - x_184 = lean_alloc_ctor(0, 2, 0); -} else { - x_184 = x_172; -} -lean_ctor_set(x_184, 0, x_171); -lean_ctor_set(x_184, 1, x_183); -return x_184; -} -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; -x_185 = lean_ctor_get(x_168, 1); +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_185, 2); +x_186 = lean_ctor_get(x_178, 5); lean_inc(x_186); -x_187 = lean_ctor_get(x_168, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_188 = x_168; +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_168); - x_188 = lean_box(0); + lean_dec_ref(x_178); + x_187 = lean_box(0); } -x_189 = lean_ctor_get(x_185, 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_185, 1); +x_190 = lean_ctor_get(x_179, 3); 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; +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_185); - x_194 = lean_box(0); + lean_dec_ref(x_179); + x_191 = lean_box(0); } -x_195 = lean_ctor_get(x_186, 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; +} +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_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); +x_196 = lean_ctor_get(x_195, 2); 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); - x_197 = x_186; +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; } else { - lean_dec_ref(x_186); - x_197 = lean_box(0); + lean_dec_ref(x_177); + x_198 = lean_box(0); } -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_195, 5); +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 { - x_198 = x_197; + lean_dec_ref(x_195); + x_204 = lean_box(0); } -lean_ctor_set(x_198, 0, x_195); -lean_ctor_set(x_198, 1, x_196); -lean_ctor_set(x_198, 2, x_156); -if (lean_is_scalar(x_194)) { - x_199 = lean_alloc_ctor(0, 6, 0); +x_205 = lean_ctor_get(x_196, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_196, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_196, 3); +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; } else { - x_199 = x_194; + lean_dec_ref(x_196); + x_208 = lean_box(0); } -lean_ctor_set(x_199, 0, x_189); -lean_ctor_set(x_199, 1, x_190); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_191); -lean_ctor_set(x_199, 4, x_192); -lean_ctor_set(x_199, 5, x_193); -if (lean_is_scalar(x_188)) { - x_200 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 4, 0); } else { - x_200 = x_188; + x_209 = x_208; } -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +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); +} else { + x_210 = x_204; +} +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_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; } } } 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; 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_201 = lean_ctor_get(x_31, 2); -x_202 = lean_ctor_get(x_31, 0); -x_203 = lean_ctor_get(x_31, 1); -x_204 = lean_ctor_get(x_31, 3); -x_205 = lean_ctor_get(x_31, 4); -x_206 = lean_ctor_get(x_31, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_201); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_31); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 2); -lean_inc(x_209); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_210 = x_201; -} else { - lean_dec_ref(x_201); - x_210 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_210)) { - x_212 = lean_alloc_ctor(0, 3, 0); -} else { - x_212 = x_210; -} -lean_ctor_set(x_212, 0, x_207); -lean_ctor_set(x_212, 1, x_208); -lean_ctor_set(x_212, 2, x_211); -x_213 = 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); -x_214 = lean_ctor_get(x_12, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_12, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_12, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_12, 3); +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); -x_218 = lean_ctor_get(x_12, 4); +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_219 = x_12; + x_231 = x_12; } else { lean_dec_ref(x_12); - x_219 = lean_box(0); + x_231 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_32); -lean_ctor_set(x_220, 1, x_20); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { - x_222 = lean_alloc_ctor(0, 5, 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_222 = x_219; + x_234 = x_231; } -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__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_222, x_213); -if (lean_obj_tag(x_223) == 0) +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_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_224 = lean_ctor_get(x_223, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_223, 0); -lean_inc(x_226); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_227 = x_223; +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_223); - x_227 = lean_box(0); + lean_dec_ref(x_235); + x_239 = lean_box(0); } -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; +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_224); - x_233 = lean_box(0); + lean_dec_ref(x_236); + x_245 = 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); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - lean_ctor_release(x_225, 2); - x_236 = x_225; +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_225); - x_236 = lean_box(0); + lean_dec_ref(x_237); + x_249 = lean_box(0); } -if (lean_is_scalar(x_236)) { - x_237 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(0, 4, 0); } else { - x_237 = x_236; + x_250 = x_249; } -lean_ctor_set(x_237, 0, x_234); -lean_ctor_set(x_237, 1, x_235); -lean_ctor_set(x_237, 2, x_209); -if (lean_is_scalar(x_233)) { - x_238 = lean_alloc_ctor(0, 6, 0); +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_238 = x_233; + x_251 = x_245; } -lean_ctor_set(x_238, 0, x_228); -lean_ctor_set(x_238, 1, x_229); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_230); -lean_ctor_set(x_238, 4, x_231); -lean_ctor_set(x_238, 5, x_232); -if (lean_is_scalar(x_227)) { - x_239 = lean_alloc_ctor(0, 2, 0); +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_239 = x_227; + x_252 = x_239; } -lean_ctor_set(x_239, 0, x_226); -lean_ctor_set(x_239, 1, x_238); -return 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_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; -x_240 = lean_ctor_get(x_223, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_223, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_243 = x_223; +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_223); - x_243 = lean_box(0); + lean_dec_ref(x_235); + x_256 = 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; +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_240); - x_249 = lean_box(0); + lean_dec_ref(x_253); + x_262 = 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); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - lean_ctor_release(x_241, 2); - x_252 = x_241; +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_241); - x_252 = lean_box(0); + lean_dec_ref(x_254); + x_266 = lean_box(0); } -if (lean_is_scalar(x_252)) { - x_253 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_266)) { + x_267 = lean_alloc_ctor(0, 4, 0); } else { - x_253 = x_252; + x_267 = x_266; } -lean_ctor_set(x_253, 0, x_250); -lean_ctor_set(x_253, 1, x_251); -lean_ctor_set(x_253, 2, x_209); -if (lean_is_scalar(x_249)) { - x_254 = lean_alloc_ctor(0, 6, 0); +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_254 = x_249; + x_268 = x_262; } -lean_ctor_set(x_254, 0, x_244); -lean_ctor_set(x_254, 1, x_245); -lean_ctor_set(x_254, 2, x_253); -lean_ctor_set(x_254, 3, x_246); -lean_ctor_set(x_254, 4, x_247); -lean_ctor_set(x_254, 5, x_248); -if (lean_is_scalar(x_243)) { - x_255 = lean_alloc_ctor(1, 2, 0); +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_255 = x_243; + x_269 = x_256; } -lean_ctor_set(x_255, 0, x_242); -lean_ctor_set(x_255, 1, x_254); -return x_255; +lean_ctor_set(x_269, 0, x_255); +lean_ctor_set(x_269, 1, x_268); +return x_269; } } } default: { -lean_object* x_256; lean_object* x_257; -x_256 = lean_ctor_get(x_25, 1); -lean_inc(x_256); +lean_object* x_270; lean_object* x_271; +x_270 = lean_ctor_get(x_25, 1); +lean_inc(x_270); lean_dec(x_25); lean_inc(x_12); -x_257 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_256); -if (lean_obj_tag(x_257) == 0) +x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); +if (lean_obj_tag(x_271) == 0) { -lean_object* x_258; -x_258 = lean_ctor_get(x_257, 0); -lean_inc(x_258); -if (lean_obj_tag(x_258) == 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_259; lean_object* x_260; lean_object* x_261; +lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_dec(x_20); -x_259 = lean_ctor_get(x_257, 1); -lean_inc(x_259); -lean_dec(x_257); -x_260 = lean_unsigned_to_nat(1u); -x_261 = lean_nat_add(x_11, x_260); +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); lean_dec(x_11); -x_11 = x_261; -x_13 = x_259; +x_11 = x_275; +x_13 = x_273; goto _start; } else { -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; uint8_t x_267; -x_263 = lean_ctor_get(x_257, 1); -lean_inc(x_263); -lean_dec(x_257); -x_264 = lean_ctor_get(x_258, 0); -lean_inc(x_264); -lean_dec(x_258); -x_265 = lean_unsigned_to_nat(1u); -x_266 = lean_nat_add(x_11, x_265); -lean_dec(x_11); -x_267 = !lean_is_exclusive(x_263); -if (x_267 == 0) -{ -lean_object* x_268; uint8_t x_269; -x_268 = lean_ctor_get(x_263, 2); -x_269 = !lean_is_exclusive(x_268); -if (x_269 == 0) -{ -lean_object* x_270; lean_object* x_271; uint8_t x_272; -x_270 = lean_ctor_get(x_268, 2); -x_271 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_268, 2, x_271); -x_272 = !lean_is_exclusive(x_12); -if (x_272 == 0) -{ -lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_273 = lean_ctor_get(x_12, 2); -x_274 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_274, 0, x_264); -lean_ctor_set(x_274, 1, x_20); -x_275 = lean_array_push(x_273, x_274); -lean_ctor_set(x_12, 2, x_275); -x_276 = 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_266, x_12, x_263); -if (lean_obj_tag(x_276) == 0) -{ -lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_276, 1); +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); -x_278 = lean_ctor_get(x_277, 2); +lean_dec(x_271); +x_278 = lean_ctor_get(x_272, 0); lean_inc(x_278); -x_279 = !lean_is_exclusive(x_276); -if (x_279 == 0) -{ -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_276, 1); -lean_dec(x_280); +lean_dec(x_272); +x_279 = lean_unsigned_to_nat(1u); +x_280 = lean_nat_add(x_11, x_279); +lean_dec(x_11); x_281 = !lean_is_exclusive(x_277); if (x_281 == 0) { lean_object* x_282; uint8_t x_283; x_282 = lean_ctor_get(x_277, 2); -lean_dec(x_282); -x_283 = !lean_is_exclusive(x_278); +x_283 = !lean_is_exclusive(x_282); if (x_283 == 0) { -lean_object* x_284; -x_284 = lean_ctor_get(x_278, 2); -lean_dec(x_284); -lean_ctor_set(x_278, 2, x_270); -return x_276; -} -else +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_285; lean_object* x_286; lean_object* x_287; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -lean_inc(x_286); -lean_inc(x_285); -lean_dec(x_278); -x_287 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_287, 0, x_285); -lean_ctor_set(x_287, 1, x_286); -lean_ctor_set(x_287, 2, x_270); -lean_ctor_set(x_277, 2, x_287); -return x_276; -} -} -else +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_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_288 = lean_ctor_get(x_277, 0); -x_289 = lean_ctor_get(x_277, 1); -x_290 = lean_ctor_get(x_277, 3); -x_291 = lean_ctor_get(x_277, 4); -x_292 = lean_ctor_get(x_277, 5); -lean_inc(x_292); +lean_object* x_291; lean_object* x_292; uint8_t x_293; +x_291 = lean_ctor_get(x_290, 1); lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_dec(x_277); -x_293 = lean_ctor_get(x_278, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_278, 1); -lean_inc(x_294); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_295 = x_278; -} else { - lean_dec_ref(x_278); - x_295 = lean_box(0); -} -if (lean_is_scalar(x_295)) { - x_296 = lean_alloc_ctor(0, 3, 0); -} else { - x_296 = x_295; -} -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_270); -x_297 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_297, 0, x_288); -lean_ctor_set(x_297, 1, x_289); -lean_ctor_set(x_297, 2, x_296); -lean_ctor_set(x_297, 3, x_290); -lean_ctor_set(x_297, 4, x_291); -lean_ctor_set(x_297, 5, x_292); -lean_ctor_set(x_276, 1, x_297); -return x_276; -} +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_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_298 = lean_ctor_get(x_276, 0); -lean_inc(x_298); -lean_dec(x_276); -x_299 = lean_ctor_get(x_277, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_277, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_277, 3); +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); -x_302 = lean_ctor_get(x_277, 4); -lean_inc(x_302); -x_303 = lean_ctor_get(x_277, 5); -lean_inc(x_303); -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_304 = x_277; -} else { - lean_dec_ref(x_277); - x_304 = lean_box(0); +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; } -x_305 = lean_ctor_get(x_278, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_278, 1); +} +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); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_307 = x_278; +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_inc(x_309); +x_310 = lean_ctor_get(x_292, 3); +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_278); - x_307 = lean_box(0); + lean_dec_ref(x_292); + x_311 = lean_box(0); } -if (lean_is_scalar(x_307)) { - x_308 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_311)) { + x_312 = lean_alloc_ctor(0, 4, 0); } else { - x_308 = x_307; + x_312 = x_311; } -lean_ctor_set(x_308, 0, x_305); -lean_ctor_set(x_308, 1, x_306); -lean_ctor_set(x_308, 2, x_270); -if (lean_is_scalar(x_304)) { - x_309 = lean_alloc_ctor(0, 6, 0); -} else { - x_309 = x_304; -} -lean_ctor_set(x_309, 0, x_299); -lean_ctor_set(x_309, 1, x_300); -lean_ctor_set(x_309, 2, x_308); -lean_ctor_set(x_309, 3, x_301); -lean_ctor_set(x_309, 4, x_302); -lean_ctor_set(x_309, 5, x_303); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_298); -lean_ctor_set(x_310, 1, x_309); -return x_310; +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_311; lean_object* x_312; uint8_t x_313; -x_311 = lean_ctor_get(x_276, 1); -lean_inc(x_311); -x_312 = lean_ctor_get(x_311, 2); -lean_inc(x_312); -x_313 = !lean_is_exclusive(x_276); -if (x_313 == 0) -{ -lean_object* x_314; uint8_t x_315; -x_314 = lean_ctor_get(x_276, 1); -lean_dec(x_314); -x_315 = !lean_is_exclusive(x_311); -if (x_315 == 0) -{ -lean_object* x_316; uint8_t x_317; -x_316 = lean_ctor_get(x_311, 2); -lean_dec(x_316); -x_317 = !lean_is_exclusive(x_312); -if (x_317 == 0) -{ -lean_object* x_318; -x_318 = lean_ctor_get(x_312, 2); -lean_dec(x_318); -lean_ctor_set(x_312, 2, x_270); -return x_276; -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_312, 0); -x_320 = lean_ctor_get(x_312, 1); -lean_inc(x_320); +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_inc(x_319); -lean_dec(x_312); -x_321 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_321, 0, x_319); -lean_ctor_set(x_321, 1, x_320); -lean_ctor_set(x_321, 2, x_270); -lean_ctor_set(x_311, 2, x_321); -return x_276; +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); } -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_322 = lean_ctor_get(x_311, 0); -x_323 = lean_ctor_get(x_311, 1); -x_324 = lean_ctor_get(x_311, 3); -x_325 = lean_ctor_get(x_311, 4); -x_326 = lean_ctor_get(x_311, 5); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); +x_321 = lean_ctor_get(x_292, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_292, 1); lean_inc(x_322); -lean_dec(x_311); -x_327 = lean_ctor_get(x_312, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_312, 1); +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); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_329 = x_312; -} else { - lean_dec_ref(x_312); - x_329 = lean_box(0); -} -if (lean_is_scalar(x_329)) { - x_330 = lean_alloc_ctor(0, 3, 0); -} else { - x_330 = x_329; -} -lean_ctor_set(x_330, 0, x_327); -lean_ctor_set(x_330, 1, x_328); -lean_ctor_set(x_330, 2, x_270); -x_331 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_331, 0, x_322); -lean_ctor_set(x_331, 1, x_323); -lean_ctor_set(x_331, 2, x_330); -lean_ctor_set(x_331, 3, x_324); -lean_ctor_set(x_331, 4, x_325); -lean_ctor_set(x_331, 5, x_326); -lean_ctor_set(x_276, 1, x_331); -return x_276; -} +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_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_332 = lean_ctor_get(x_276, 0); -lean_inc(x_332); -lean_dec(x_276); -x_333 = lean_ctor_get(x_311, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_311, 1); -lean_inc(x_334); -x_335 = lean_ctor_get(x_311, 3); -lean_inc(x_335); -x_336 = lean_ctor_get(x_311, 4); -lean_inc(x_336); -x_337 = lean_ctor_get(x_311, 5); +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); -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); - lean_ctor_release(x_311, 5); - x_338 = x_311; -} else { - lean_dec_ref(x_311); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_312, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_312, 1); -lean_inc(x_340); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_341 = x_312; -} else { - lean_dec_ref(x_312); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 3, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_339); -lean_ctor_set(x_342, 1, x_340); -lean_ctor_set(x_342, 2, x_270); -if (lean_is_scalar(x_338)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_338; -} -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); -x_344 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_344, 0, x_332); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} +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_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; -x_345 = lean_ctor_get(x_12, 0); -x_346 = lean_ctor_get(x_12, 1); -x_347 = lean_ctor_get(x_12, 2); -x_348 = lean_ctor_get(x_12, 3); -x_349 = lean_ctor_get(x_12, 4); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); +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); -lean_dec(x_12); -x_350 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_350, 0, x_264); -lean_ctor_set(x_350, 1, x_20); -x_351 = lean_array_push(x_347, x_350); -x_352 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_352, 0, x_345); -lean_ctor_set(x_352, 1, x_346); -lean_ctor_set(x_352, 2, x_351); -lean_ctor_set(x_352, 3, x_348); -lean_ctor_set(x_352, 4, x_349); -x_353 = 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_266, x_352, x_263); -if (lean_obj_tag(x_353) == 0) -{ -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; -x_354 = lean_ctor_get(x_353, 1); -lean_inc(x_354); -x_355 = lean_ctor_get(x_354, 2); -lean_inc(x_355); -x_356 = lean_ctor_get(x_353, 0); -lean_inc(x_356); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_357 = x_353; +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_353); + 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_354, 0); +x_358 = lean_ctor_get(x_329, 0); lean_inc(x_358); -x_359 = lean_ctor_get(x_354, 1); +x_359 = lean_ctor_get(x_329, 1); lean_inc(x_359); -x_360 = lean_ctor_get(x_354, 3); +x_360 = lean_ctor_get(x_329, 3); lean_inc(x_360); -x_361 = lean_ctor_get(x_354, 4); -lean_inc(x_361); -x_362 = lean_ctor_get(x_354, 5); -lean_inc(x_362); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - lean_ctor_release(x_354, 2); - lean_ctor_release(x_354, 3); - lean_ctor_release(x_354, 4); - lean_ctor_release(x_354, 5); - x_363 = x_354; +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_354); - x_363 = lean_box(0); + lean_dec_ref(x_329); + x_361 = lean_box(0); } -x_364 = lean_ctor_get(x_355, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_355, 1); -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); - x_366 = x_355; +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_355); - x_366 = lean_box(0); + x_362 = x_361; } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 3, 0); -} else { - x_367 = x_366; -} -lean_ctor_set(x_367, 0, x_364); -lean_ctor_set(x_367, 1, x_365); -lean_ctor_set(x_367, 2, x_270); -if (lean_is_scalar(x_363)) { - x_368 = lean_alloc_ctor(0, 6, 0); -} else { - x_368 = x_363; -} -lean_ctor_set(x_368, 0, x_358); -lean_ctor_set(x_368, 1, x_359); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_360); -lean_ctor_set(x_368, 4, x_361); -lean_ctor_set(x_368, 5, x_362); +lean_ctor_set(x_362, 0, x_358); +lean_ctor_set(x_362, 1, x_359); +lean_ctor_set(x_362, 2, x_284); +lean_ctor_set(x_362, 3, x_360); if (lean_is_scalar(x_357)) { - x_369 = lean_alloc_ctor(0, 2, 0); + x_363 = lean_alloc_ctor(0, 6, 0); } else { - x_369 = x_357; + 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; +} } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; } else { -lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_370 = lean_ctor_get(x_353, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_370, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_353, 0); -lean_inc(x_372); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_373 = x_353; -} else { - lean_dec_ref(x_353); - x_373 = lean_box(0); -} -x_374 = lean_ctor_get(x_370, 0); +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_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) +{ +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_370, 1); +x_375 = lean_ctor_get(x_374, 2); lean_inc(x_375); -x_376 = lean_ctor_get(x_370, 3); +x_376 = lean_ctor_get(x_373, 0); lean_inc(x_376); -x_377 = lean_ctor_get(x_370, 4); -lean_inc(x_377); -x_378 = lean_ctor_get(x_370, 5); +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); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - lean_ctor_release(x_370, 2); - lean_ctor_release(x_370, 3); - lean_ctor_release(x_370, 4); - lean_ctor_release(x_370, 5); - x_379 = x_370; -} else { - lean_dec_ref(x_370); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_371, 0); +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_371, 1); +x_381 = lean_ctor_get(x_374, 4); lean_inc(x_381); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - lean_ctor_release(x_371, 2); - x_382 = x_371; +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_371); - x_382 = lean_box(0); + lean_dec_ref(x_374); + x_383 = lean_box(0); } -if (lean_is_scalar(x_382)) { - x_383 = lean_alloc_ctor(0, 3, 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 { - x_383 = x_382; + lean_dec_ref(x_375); + x_387 = lean_box(0); } -lean_ctor_set(x_383, 0, x_380); -lean_ctor_set(x_383, 1, x_381); -lean_ctor_set(x_383, 2, x_270); -if (lean_is_scalar(x_379)) { - x_384 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_387)) { + x_388 = lean_alloc_ctor(0, 4, 0); } else { - x_384 = x_379; + x_388 = x_387; } -lean_ctor_set(x_384, 0, x_374); -lean_ctor_set(x_384, 1, x_375); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_376); -lean_ctor_set(x_384, 4, x_377); -lean_ctor_set(x_384, 5, x_378); -if (lean_is_scalar(x_373)) { - x_385 = lean_alloc_ctor(1, 2, 0); +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_385 = x_373; -} -lean_ctor_set(x_385, 0, x_372); -lean_ctor_set(x_385, 1, x_384); -return x_385; + 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; } 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_399; lean_object* x_400; -x_386 = lean_ctor_get(x_268, 0); -x_387 = lean_ctor_get(x_268, 1); -x_388 = lean_ctor_get(x_268, 2); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_268); -x_389 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_390 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_390, 0, x_386); -lean_ctor_set(x_390, 1, x_387); -lean_ctor_set(x_390, 2, x_389); -lean_ctor_set(x_263, 2, x_390); -x_391 = lean_ctor_get(x_12, 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; 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_12, 1); +x_392 = lean_ctor_get(x_391, 2); lean_inc(x_392); -x_393 = lean_ctor_get(x_12, 2); +x_393 = lean_ctor_get(x_373, 0); lean_inc(x_393); -x_394 = lean_ctor_get(x_12, 3); -lean_inc(x_394); -x_395 = lean_ctor_get(x_12, 4); +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); +} +x_395 = lean_ctor_get(x_391, 0); lean_inc(x_395); -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_396 = x_12; +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_12); - x_396 = lean_box(0); + lean_dec_ref(x_391); + x_400 = lean_box(0); } -x_397 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_397, 0, x_264); -lean_ctor_set(x_397, 1, x_20); -x_398 = lean_array_push(x_393, x_397); -if (lean_is_scalar(x_396)) { - x_399 = lean_alloc_ctor(0, 5, 0); -} else { - x_399 = x_396; -} -lean_ctor_set(x_399, 0, x_391); -lean_ctor_set(x_399, 1, x_392); -lean_ctor_set(x_399, 2, x_398); -lean_ctor_set(x_399, 3, x_394); -lean_ctor_set(x_399, 4, x_395); -x_400 = 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_266, x_399, x_263); -if (lean_obj_tag(x_400) == 0) -{ -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_400, 1); +x_401 = lean_ctor_get(x_392, 0); lean_inc(x_401); -x_402 = lean_ctor_get(x_401, 2); +x_402 = lean_ctor_get(x_392, 1); lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); +x_403 = lean_ctor_get(x_392, 3); lean_inc(x_403); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_404 = 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); + x_404 = x_392; } else { - lean_dec_ref(x_400); + lean_dec_ref(x_392); x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_401, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 3); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 4); -lean_inc(x_408); -x_409 = lean_ctor_get(x_401, 5); -lean_inc(x_409); -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_410 = x_401; -} else { - lean_dec_ref(x_401); - x_410 = lean_box(0); -} -x_411 = lean_ctor_get(x_402, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 1); -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); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 3, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_411); -lean_ctor_set(x_414, 1, x_412); -lean_ctor_set(x_414, 2, x_388); -if (lean_is_scalar(x_410)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_410; -} -lean_ctor_set(x_415, 0, x_405); -lean_ctor_set(x_415, 1, x_406); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_407); -lean_ctor_set(x_415, 4, x_408); -lean_ctor_set(x_415, 5, x_409); if (lean_is_scalar(x_404)) { - x_416 = lean_alloc_ctor(0, 2, 0); + x_405 = lean_alloc_ctor(0, 4, 0); } else { - x_416 = x_404; + 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_284); +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_394)) { + x_407 = lean_alloc_ctor(1, 2, 0); +} else { + x_407 = x_394; +} +lean_ctor_set(x_407, 0, x_393); +lean_ctor_set(x_407, 1, x_406); +return x_407; +} } -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; } else { -lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; -x_417 = lean_ctor_get(x_400, 1); +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_417, 2); +x_418 = lean_ctor_get(x_12, 4); lean_inc(x_418); -x_419 = lean_ctor_get(x_400, 0); -lean_inc(x_419); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_420 = x_400; -} else { - lean_dec_ref(x_400); - 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); -if (lean_is_exclusive(x_418)) { - lean_ctor_release(x_418, 0); - lean_ctor_release(x_418, 1); - lean_ctor_release(x_418, 2); - x_429 = x_418; -} else { - lean_dec_ref(x_418); - x_429 = lean_box(0); -} -if (lean_is_scalar(x_429)) { - x_430 = lean_alloc_ctor(0, 3, 0); -} else { - x_430 = x_429; -} -lean_ctor_set(x_430, 0, x_427); -lean_ctor_set(x_430, 1, x_428); -lean_ctor_set(x_430, 2, x_388); -if (lean_is_scalar(x_426)) { - x_431 = lean_alloc_ctor(0, 6, 0); -} else { - x_431 = x_426; -} -lean_ctor_set(x_431, 0, x_421); -lean_ctor_set(x_431, 1, x_422); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_423); -lean_ctor_set(x_431, 4, x_424); -lean_ctor_set(x_431, 5, x_425); -if (lean_is_scalar(x_420)) { - x_432 = lean_alloc_ctor(1, 2, 0); -} else { - x_432 = x_420; -} -lean_ctor_set(x_432, 0, x_419); -lean_ctor_set(x_432, 1, x_431); -return x_432; -} -} -} -else -{ -lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; 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_433 = lean_ctor_get(x_263, 2); -x_434 = lean_ctor_get(x_263, 0); -x_435 = lean_ctor_get(x_263, 1); -x_436 = lean_ctor_get(x_263, 3); -x_437 = lean_ctor_get(x_263, 4); -x_438 = lean_ctor_get(x_263, 5); -lean_inc(x_438); -lean_inc(x_437); -lean_inc(x_436); -lean_inc(x_433); -lean_inc(x_435); -lean_inc(x_434); -lean_dec(x_263); -x_439 = lean_ctor_get(x_433, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_433, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_433, 2); -lean_inc(x_441); -if (lean_is_exclusive(x_433)) { - lean_ctor_release(x_433, 0); - lean_ctor_release(x_433, 1); - lean_ctor_release(x_433, 2); - x_442 = x_433; -} else { - lean_dec_ref(x_433); - x_442 = lean_box(0); -} -x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_442)) { - x_444 = lean_alloc_ctor(0, 3, 0); -} else { - x_444 = x_442; -} -lean_ctor_set(x_444, 0, x_439); -lean_ctor_set(x_444, 1, x_440); -lean_ctor_set(x_444, 2, x_443); -x_445 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_445, 0, x_434); -lean_ctor_set(x_445, 1, x_435); -lean_ctor_set(x_445, 2, x_444); -lean_ctor_set(x_445, 3, x_436); -lean_ctor_set(x_445, 4, x_437); -lean_ctor_set(x_445, 5, x_438); -x_446 = lean_ctor_get(x_12, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_12, 1); -lean_inc(x_447); -x_448 = lean_ctor_get(x_12, 2); -lean_inc(x_448); -x_449 = lean_ctor_get(x_12, 3); -lean_inc(x_449); -x_450 = lean_ctor_get(x_12, 4); -lean_inc(x_450); 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_451 = x_12; + x_419 = x_12; } else { lean_dec_ref(x_12); - x_451 = lean_box(0); + x_419 = lean_box(0); } -x_452 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_452, 0, x_264); -lean_ctor_set(x_452, 1, x_20); -x_453 = lean_array_push(x_448, x_452); -if (lean_is_scalar(x_451)) { - x_454 = lean_alloc_ctor(0, 5, 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); } else { - x_454 = x_451; + x_422 = x_419; } -lean_ctor_set(x_454, 0, x_446); -lean_ctor_set(x_454, 1, x_447); -lean_ctor_set(x_454, 2, x_453); -lean_ctor_set(x_454, 3, x_449); -lean_ctor_set(x_454, 4, x_450); -x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_266, x_454, x_445); -if (lean_obj_tag(x_455) == 0) +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_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_456 = lean_ctor_get(x_455, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_456, 2); -lean_inc(x_457); -x_458 = lean_ctor_get(x_455, 0); -lean_inc(x_458); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_459 = x_455; +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_455); - x_459 = lean_box(0); + lean_dec_ref(x_423); + x_427 = lean_box(0); } -x_460 = lean_ctor_get(x_456, 0); -lean_inc(x_460); -x_461 = lean_ctor_get(x_456, 1); -lean_inc(x_461); -x_462 = lean_ctor_get(x_456, 3); -lean_inc(x_462); -x_463 = lean_ctor_get(x_456, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_441); + x_450 = 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; +} else { + lean_dec_ref(x_442); + x_454 = lean_box(0); +} +if (lean_is_scalar(x_454)) { + x_455 = lean_alloc_ctor(0, 4, 0); +} else { + x_455 = x_454; +} +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); +} else { + x_456 = x_450; +} +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); +} else { + x_457 = x_444; +} +lean_ctor_set(x_457, 0, x_443); +lean_ctor_set(x_457, 1, x_456); +return x_457; +} +} +} +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); -x_464 = lean_ctor_get(x_456, 5); +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); -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); - lean_ctor_release(x_456, 4); - lean_ctor_release(x_456, 5); - x_465 = x_456; -} else { - lean_dec_ref(x_456); - x_465 = lean_box(0); -} -x_466 = lean_ctor_get(x_457, 0); +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_457, 1); +x_467 = lean_ctor_get(x_458, 3); lean_inc(x_467); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - lean_ctor_release(x_457, 2); - x_468 = x_457; +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; } else { - lean_dec_ref(x_457); + lean_dec_ref(x_458); x_468 = lean_box(0); } +x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_468)) { - x_469 = lean_alloc_ctor(0, 3, 0); + x_470 = lean_alloc_ctor(0, 4, 0); } else { - x_469 = x_468; + x_470 = x_468; } -lean_ctor_set(x_469, 0, x_466); -lean_ctor_set(x_469, 1, x_467); -lean_ctor_set(x_469, 2, x_441); -if (lean_is_scalar(x_465)) { - x_470 = lean_alloc_ctor(0, 6, 0); -} else { - x_470 = x_465; -} -lean_ctor_set(x_470, 0, x_460); -lean_ctor_set(x_470, 1, x_461); +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_462); -lean_ctor_set(x_470, 4, x_463); -lean_ctor_set(x_470, 5, x_464); -if (lean_is_scalar(x_459)) { - x_471 = lean_alloc_ctor(0, 2, 0); -} else { - x_471 = x_459; -} -lean_ctor_set(x_471, 0, x_458); -lean_ctor_set(x_471, 1, x_470); -return x_471; -} -else -{ -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; -x_472 = lean_ctor_get(x_455, 1); +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_472, 2); +x_473 = lean_ctor_get(x_12, 1); lean_inc(x_473); -x_474 = lean_ctor_get(x_455, 0); +x_474 = lean_ctor_get(x_12, 2); lean_inc(x_474); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_475 = x_455; -} else { - lean_dec_ref(x_455); - x_475 = lean_box(0); -} -x_476 = lean_ctor_get(x_472, 0); +x_475 = lean_ctor_get(x_12, 3); +lean_inc(x_475); +x_476 = lean_ctor_get(x_12, 4); 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; +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; } else { - lean_dec_ref(x_472); - x_481 = lean_box(0); + lean_dec_ref(x_12); + x_477 = lean_box(0); } -x_482 = lean_ctor_get(x_473, 0); +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); +} else { + x_480 = x_477; +} +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_473, 1); +x_483 = lean_ctor_get(x_482, 2); lean_inc(x_483); -if (lean_is_exclusive(x_473)) { - lean_ctor_release(x_473, 0); - lean_ctor_release(x_473, 1); - lean_ctor_release(x_473, 2); - x_484 = x_473; +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; } else { - lean_dec_ref(x_473); - x_484 = lean_box(0); + lean_dec_ref(x_481); + x_485 = lean_box(0); } -if (lean_is_scalar(x_484)) { - x_485 = lean_alloc_ctor(0, 3, 0); +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 { - x_485 = x_484; + lean_dec_ref(x_482); + x_491 = lean_box(0); } -lean_ctor_set(x_485, 0, x_482); -lean_ctor_set(x_485, 1, x_483); -lean_ctor_set(x_485, 2, x_441); -if (lean_is_scalar(x_481)) { - x_486 = lean_alloc_ctor(0, 6, 0); +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 { - x_486 = x_481; + lean_dec_ref(x_483); + x_495 = lean_box(0); } -lean_ctor_set(x_486, 0, x_476); -lean_ctor_set(x_486, 1, x_477); -lean_ctor_set(x_486, 2, x_485); -lean_ctor_set(x_486, 3, x_478); -lean_ctor_set(x_486, 4, x_479); -lean_ctor_set(x_486, 5, x_480); -if (lean_is_scalar(x_475)) { - x_487 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_495)) { + x_496 = lean_alloc_ctor(0, 4, 0); } else { - x_487 = x_475; + x_496 = x_495; } -lean_ctor_set(x_487, 0, x_474); -lean_ctor_set(x_487, 1, x_486); -return x_487; +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_488; +uint8_t x_516; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -22673,23 +23409,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_488 = !lean_is_exclusive(x_257); -if (x_488 == 0) +x_516 = !lean_is_exclusive(x_271); +if (x_516 == 0) { -return x_257; +return x_271; } else { -lean_object* x_489; lean_object* x_490; lean_object* x_491; -x_489 = lean_ctor_get(x_257, 0); -x_490 = lean_ctor_get(x_257, 1); -lean_inc(x_490); -lean_inc(x_489); -lean_dec(x_257); -x_491 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_491, 0, x_489); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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; } } } @@ -22697,7 +23433,7 @@ return x_491; } else { -uint8_t x_492; +uint8_t x_520; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -22708,29 +23444,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_492 = !lean_is_exclusive(x_25); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_25); +if (x_520 == 0) { return x_25; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_25, 0); -x_494 = lean_ctor_get(x_25, 1); -lean_inc(x_494); -lean_inc(x_493); +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_dec(x_25); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -22740,23 +23476,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_21); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_21); +if (x_524 == 0) { return x_21; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_21, 0); -x_498 = lean_ctor_get(x_21, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_21); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } @@ -22894,82 +23630,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -22977,1899 +23720,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -24877,58 +25719,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -25377,82 +26219,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -25460,1899 +26309,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -27360,58 +28308,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -27595,82 +28543,89 @@ return x_44; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; +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_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_38); -lean_ctor_set(x_45, 2, x_55); +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; } } 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; -x_56 = lean_ctor_get(x_45, 0); -x_57 = lean_ctor_get(x_45, 1); -x_58 = lean_ctor_get(x_45, 3); -x_59 = lean_ctor_get(x_45, 4); -x_60 = lean_ctor_get(x_45, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +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_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_45); -x_61 = lean_ctor_get(x_46, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_46, 1); +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); - x_63 = x_46; + lean_ctor_release(x_46, 3); + x_65 = x_46; } else { lean_dec_ref(x_46); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -lean_ctor_set(x_64, 2, x_38); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_56); -lean_ctor_set(x_65, 1, x_57); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_58); -lean_ctor_set(x_65, 4, x_59); -lean_ctor_set(x_65, 5, x_60); -lean_ctor_set(x_44, 1, 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_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; } } 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; -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -lean_dec(x_44); -x_67 = lean_ctor_get(x_45, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_45, 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; lean_object* x_80; lean_object* x_81; +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_45, 3); +lean_dec(x_44); +x_69 = lean_ctor_get(x_45, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 4); +x_70 = lean_ctor_get(x_45, 1); lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 5); +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); @@ -27678,1877 +28633,1976 @@ if (lean_is_exclusive(x_45)) { lean_ctor_release(x_45, 3); lean_ctor_release(x_45, 4); lean_ctor_release(x_45, 5); - x_72 = x_45; + x_74 = x_45; } else { lean_dec_ref(x_45); - x_72 = lean_box(0); + x_74 = lean_box(0); } -x_73 = lean_ctor_get(x_46, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_46, 1); -lean_inc(x_74); +x_75 = lean_ctor_get(x_46, 0); +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); - x_75 = x_46; + lean_ctor_release(x_46, 3); + x_78 = x_46; } else { lean_dec_ref(x_46); - x_75 = lean_box(0); + x_78 = lean_box(0); } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 4, 0); } else { - x_76 = x_75; + x_79 = x_78; } -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_38); -if (lean_is_scalar(x_72)) { - x_77 = 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_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_77 = x_72; + x_80 = x_74; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_68); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_69); -lean_ctor_set(x_77, 4, x_70); -lean_ctor_set(x_77, 5, x_71); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_66); -lean_ctor_set(x_78, 1, x_77); -return x_78; +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; } } else { -lean_object* x_79; lean_object* x_80; uint8_t x_81; -x_79 = lean_ctor_get(x_44, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 2); -lean_inc(x_80); -x_81 = !lean_is_exclusive(x_44); -if (x_81 == 0) -{ -lean_object* x_82; uint8_t x_83; +lean_object* x_82; lean_object* x_83; uint8_t x_84; x_82 = lean_ctor_get(x_44, 1); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_79); -if (x_83 == 0) +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 2); +lean_inc(x_83); +x_84 = !lean_is_exclusive(x_44); +if (x_84 == 0) { -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_79, 2); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_80); -if (x_85 == 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_86; -x_86 = lean_ctor_get(x_80, 2); -lean_dec(x_86); -lean_ctor_set(x_80, 2, x_38); +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_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_80, 0); -x_88 = lean_ctor_get(x_80, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_80); -x_89 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -lean_ctor_set(x_89, 2, x_38); -lean_ctor_set(x_79, 2, x_89); -return x_44; -} -} -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; -x_90 = lean_ctor_get(x_79, 0); -x_91 = lean_ctor_get(x_79, 1); -x_92 = lean_ctor_get(x_79, 3); -x_93 = lean_ctor_get(x_79, 4); -x_94 = lean_ctor_get(x_79, 5); -lean_inc(x_94); -lean_inc(x_93); +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_79); -x_95 = lean_ctor_get(x_80, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_80, 1); -lean_inc(x_96); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - x_97 = x_80; -} else { - lean_dec_ref(x_80); - x_97 = lean_box(0); -} -if (lean_is_scalar(x_97)) { - x_98 = lean_alloc_ctor(0, 3, 0); -} else { - x_98 = x_97; -} -lean_ctor_set(x_98, 0, x_95); -lean_ctor_set(x_98, 1, x_96); -lean_ctor_set(x_98, 2, x_38); -x_99 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_99, 0, x_90); -lean_ctor_set(x_99, 1, x_91); -lean_ctor_set(x_99, 2, x_98); -lean_ctor_set(x_99, 3, x_92); -lean_ctor_set(x_99, 4, x_93); -lean_ctor_set(x_99, 5, x_94); -lean_ctor_set(x_44, 1, x_99); +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_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_100 = lean_ctor_get(x_44, 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; +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); -lean_dec(x_44); -x_101 = lean_ctor_get(x_79, 0); +x_101 = lean_ctor_get(x_83, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_79, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_79, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_79, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_79, 5); +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; +} else { + lean_dec_ref(x_83); + x_102 = lean_box(0); +} +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 4, 0); +} else { + x_103 = x_102; +} +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); -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); - lean_ctor_release(x_79, 4); - lean_ctor_release(x_79, 5); - x_106 = x_79; -} else { - lean_dec_ref(x_79); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_80, 0); +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_80, 1); +x_108 = lean_ctor_get(x_82, 3); 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); - x_109 = x_80; +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; } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + lean_dec_ref(x_82); + x_111 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 3, 0); +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 { - x_110 = x_109; + lean_dec_ref(x_83); + x_115 = lean_box(0); } -lean_ctor_set(x_110, 0, x_107); -lean_ctor_set(x_110, 1, x_108); -lean_ctor_set(x_110, 2, x_38); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 4, 0); } else { - x_111 = x_106; + x_116 = x_115; } -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_100); -lean_ctor_set(x_112, 1, x_111); -return x_112; +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_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_12, 0); -x_114 = lean_ctor_get(x_12, 1); -x_115 = lean_ctor_get(x_12, 2); -x_116 = lean_ctor_get(x_12, 3); -x_117 = lean_ctor_get(x_12, 4); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_12); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_32); -lean_ctor_set(x_118, 1, x_20); -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__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_120, x_31); -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; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); +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); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; -} else { - lean_dec_ref(x_121); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_122, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_122); +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_122, 4); +x_129 = lean_ctor_get(x_128, 2); lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); +x_130 = lean_ctor_get(x_127, 0); 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_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + x_131 = x_127; } else { - lean_dec_ref(x_122); + lean_dec_ref(x_127); x_131 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); +x_132 = lean_ctor_get(x_128, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); +x_133 = lean_ctor_get(x_128, 1); lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - x_134 = x_123; +x_134 = lean_ctor_get(x_128, 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; } else { - lean_dec_ref(x_123); - x_134 = lean_box(0); + lean_dec_ref(x_128); + x_137 = lean_box(0); } -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 3, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_132); -lean_ctor_set(x_135, 1, x_133); -lean_ctor_set(x_135, 2, x_38); -if (lean_is_scalar(x_131)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_131; -} -lean_ctor_set(x_136, 0, x_126); -lean_ctor_set(x_136, 1, x_127); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_128); -lean_ctor_set(x_136, 4, x_129); -lean_ctor_set(x_136, 5, x_130); -if (lean_is_scalar(x_125)) { - x_137 = lean_alloc_ctor(0, 2, 0); -} else { - x_137 = x_125; -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_138 = lean_ctor_get(x_121, 1); +x_138 = lean_ctor_get(x_129, 0); lean_inc(x_138); -x_139 = lean_ctor_get(x_138, 2); +x_139 = lean_ctor_get(x_129, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 0); +x_140 = lean_ctor_get(x_129, 3); lean_inc(x_140); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_141 = x_121; +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; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_129); x_141 = lean_box(0); } -x_142 = lean_ctor_get(x_138, 0); -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; -} else { - lean_dec_ref(x_138); - x_147 = 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); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - 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, 3, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -lean_ctor_set(x_151, 2, x_38); -if (lean_is_scalar(x_147)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_147; -} -lean_ctor_set(x_152, 0, x_142); -lean_ctor_set(x_152, 1, x_143); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_144); -lean_ctor_set(x_152, 4, x_145); -lean_ctor_set(x_152, 5, x_146); if (lean_is_scalar(x_141)) { - x_153 = lean_alloc_ctor(1, 2, 0); + x_142 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_141; + x_142 = x_141; } -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; +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); +if (lean_is_scalar(x_131)) { + x_144 = lean_alloc_ctor(0, 2, 0); +} else { + x_144 = x_131; +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_145 = lean_ctor_get(x_127, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_145, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 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); +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; +} else { + lean_dec_ref(x_145); + x_154 = 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; +} else { + lean_dec_ref(x_146); + x_158 = lean_box(0); +} +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_38); +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); +if (lean_is_scalar(x_148)) { + x_161 = lean_alloc_ctor(1, 2, 0); +} else { + x_161 = x_148; +} +lean_ctor_set(x_161, 0, x_147); +lean_ctor_set(x_161, 1, x_160); +return x_161; } } } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_154 = lean_ctor_get(x_36, 0); -x_155 = lean_ctor_get(x_36, 1); -x_156 = lean_ctor_get(x_36, 2); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_dec(x_36); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_31, 2, x_158); -x_159 = lean_ctor_get(x_12, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_12, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_12, 4); +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); 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_164 = x_12; + x_173 = x_12; } else { lean_dec_ref(x_12); - x_164 = lean_box(0); + x_173 = lean_box(0); } -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_32); -lean_ctor_set(x_165, 1, x_20); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 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); } else { - x_167 = x_164; + x_176 = x_173; } -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_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_167, x_31); -if (lean_obj_tag(x_168) == 0) +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_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, 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_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_170, 1); +x_180 = lean_ctor_get(x_177, 0); lean_inc(x_180); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - lean_ctor_release(x_170, 2); - x_181 = x_170; +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_170); + lean_dec_ref(x_177); x_181 = lean_box(0); } -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 3, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_179); -lean_ctor_set(x_182, 1, x_180); -lean_ctor_set(x_182, 2, x_156); -if (lean_is_scalar(x_178)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_178; -} -lean_ctor_set(x_183, 0, x_173); -lean_ctor_set(x_183, 1, x_174); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_175); -lean_ctor_set(x_183, 4, x_176); -lean_ctor_set(x_183, 5, x_177); -if (lean_is_scalar(x_172)) { - x_184 = lean_alloc_ctor(0, 2, 0); -} else { - x_184 = x_172; -} -lean_ctor_set(x_184, 0, x_171); -lean_ctor_set(x_184, 1, x_183); -return x_184; -} -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; -x_185 = lean_ctor_get(x_168, 1); +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_185, 2); +x_186 = lean_ctor_get(x_178, 5); lean_inc(x_186); -x_187 = lean_ctor_get(x_168, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_188 = x_168; +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_168); - x_188 = lean_box(0); + lean_dec_ref(x_178); + x_187 = lean_box(0); } -x_189 = lean_ctor_get(x_185, 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_185, 1); +x_190 = lean_ctor_get(x_179, 3); 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; +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_185); - x_194 = lean_box(0); + lean_dec_ref(x_179); + x_191 = lean_box(0); } -x_195 = lean_ctor_get(x_186, 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; +} +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_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); +x_196 = lean_ctor_get(x_195, 2); 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); - x_197 = x_186; +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; } else { - lean_dec_ref(x_186); - x_197 = lean_box(0); + lean_dec_ref(x_177); + x_198 = lean_box(0); } -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_195, 5); +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 { - x_198 = x_197; + lean_dec_ref(x_195); + x_204 = lean_box(0); } -lean_ctor_set(x_198, 0, x_195); -lean_ctor_set(x_198, 1, x_196); -lean_ctor_set(x_198, 2, x_156); -if (lean_is_scalar(x_194)) { - x_199 = lean_alloc_ctor(0, 6, 0); +x_205 = lean_ctor_get(x_196, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_196, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_196, 3); +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; } else { - x_199 = x_194; + lean_dec_ref(x_196); + x_208 = lean_box(0); } -lean_ctor_set(x_199, 0, x_189); -lean_ctor_set(x_199, 1, x_190); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_191); -lean_ctor_set(x_199, 4, x_192); -lean_ctor_set(x_199, 5, x_193); -if (lean_is_scalar(x_188)) { - x_200 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 4, 0); } else { - x_200 = x_188; + x_209 = x_208; } -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +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); +} else { + x_210 = x_204; +} +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_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; } } } 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; 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_201 = lean_ctor_get(x_31, 2); -x_202 = lean_ctor_get(x_31, 0); -x_203 = lean_ctor_get(x_31, 1); -x_204 = lean_ctor_get(x_31, 3); -x_205 = lean_ctor_get(x_31, 4); -x_206 = lean_ctor_get(x_31, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_201); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_31); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 2); -lean_inc(x_209); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_210 = x_201; -} else { - lean_dec_ref(x_201); - x_210 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_210)) { - x_212 = lean_alloc_ctor(0, 3, 0); -} else { - x_212 = x_210; -} -lean_ctor_set(x_212, 0, x_207); -lean_ctor_set(x_212, 1, x_208); -lean_ctor_set(x_212, 2, x_211); -x_213 = 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); -x_214 = lean_ctor_get(x_12, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_12, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_12, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_12, 3); +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); -x_218 = lean_ctor_get(x_12, 4); +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_219 = x_12; + x_231 = x_12; } else { lean_dec_ref(x_12); - x_219 = lean_box(0); + x_231 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_32); -lean_ctor_set(x_220, 1, x_20); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { - x_222 = lean_alloc_ctor(0, 5, 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_222 = x_219; + x_234 = x_231; } -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__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_222, x_213); -if (lean_obj_tag(x_223) == 0) +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_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_224 = lean_ctor_get(x_223, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_223, 0); -lean_inc(x_226); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_227 = x_223; +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_223); - x_227 = lean_box(0); + lean_dec_ref(x_235); + x_239 = lean_box(0); } -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; +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_224); - x_233 = lean_box(0); + lean_dec_ref(x_236); + x_245 = 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); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - lean_ctor_release(x_225, 2); - x_236 = x_225; +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_225); - x_236 = lean_box(0); + lean_dec_ref(x_237); + x_249 = lean_box(0); } -if (lean_is_scalar(x_236)) { - x_237 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(0, 4, 0); } else { - x_237 = x_236; + x_250 = x_249; } -lean_ctor_set(x_237, 0, x_234); -lean_ctor_set(x_237, 1, x_235); -lean_ctor_set(x_237, 2, x_209); -if (lean_is_scalar(x_233)) { - x_238 = lean_alloc_ctor(0, 6, 0); +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_238 = x_233; + x_251 = x_245; } -lean_ctor_set(x_238, 0, x_228); -lean_ctor_set(x_238, 1, x_229); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_230); -lean_ctor_set(x_238, 4, x_231); -lean_ctor_set(x_238, 5, x_232); -if (lean_is_scalar(x_227)) { - x_239 = lean_alloc_ctor(0, 2, 0); +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_239 = x_227; + x_252 = x_239; } -lean_ctor_set(x_239, 0, x_226); -lean_ctor_set(x_239, 1, x_238); -return 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_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; -x_240 = lean_ctor_get(x_223, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_223, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_243 = x_223; +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_223); - x_243 = lean_box(0); + lean_dec_ref(x_235); + x_256 = 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; +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_240); - x_249 = lean_box(0); + lean_dec_ref(x_253); + x_262 = 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); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - lean_ctor_release(x_241, 2); - x_252 = x_241; +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_241); - x_252 = lean_box(0); + lean_dec_ref(x_254); + x_266 = lean_box(0); } -if (lean_is_scalar(x_252)) { - x_253 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_266)) { + x_267 = lean_alloc_ctor(0, 4, 0); } else { - x_253 = x_252; + x_267 = x_266; } -lean_ctor_set(x_253, 0, x_250); -lean_ctor_set(x_253, 1, x_251); -lean_ctor_set(x_253, 2, x_209); -if (lean_is_scalar(x_249)) { - x_254 = lean_alloc_ctor(0, 6, 0); +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_254 = x_249; + x_268 = x_262; } -lean_ctor_set(x_254, 0, x_244); -lean_ctor_set(x_254, 1, x_245); -lean_ctor_set(x_254, 2, x_253); -lean_ctor_set(x_254, 3, x_246); -lean_ctor_set(x_254, 4, x_247); -lean_ctor_set(x_254, 5, x_248); -if (lean_is_scalar(x_243)) { - x_255 = lean_alloc_ctor(1, 2, 0); +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_255 = x_243; + x_269 = x_256; } -lean_ctor_set(x_255, 0, x_242); -lean_ctor_set(x_255, 1, x_254); -return x_255; +lean_ctor_set(x_269, 0, x_255); +lean_ctor_set(x_269, 1, x_268); +return x_269; } } } default: { -lean_object* x_256; lean_object* x_257; -x_256 = lean_ctor_get(x_25, 1); -lean_inc(x_256); +lean_object* x_270; lean_object* x_271; +x_270 = lean_ctor_get(x_25, 1); +lean_inc(x_270); lean_dec(x_25); lean_inc(x_12); -x_257 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_256); -if (lean_obj_tag(x_257) == 0) +x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); +if (lean_obj_tag(x_271) == 0) { -lean_object* x_258; -x_258 = lean_ctor_get(x_257, 0); -lean_inc(x_258); -if (lean_obj_tag(x_258) == 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_259; lean_object* x_260; lean_object* x_261; +lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_dec(x_20); -x_259 = lean_ctor_get(x_257, 1); -lean_inc(x_259); -lean_dec(x_257); -x_260 = lean_unsigned_to_nat(1u); -x_261 = lean_nat_add(x_11, x_260); +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); lean_dec(x_11); -x_11 = x_261; -x_13 = x_259; +x_11 = x_275; +x_13 = x_273; goto _start; } else { -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; uint8_t x_267; -x_263 = lean_ctor_get(x_257, 1); -lean_inc(x_263); -lean_dec(x_257); -x_264 = lean_ctor_get(x_258, 0); -lean_inc(x_264); -lean_dec(x_258); -x_265 = lean_unsigned_to_nat(1u); -x_266 = lean_nat_add(x_11, x_265); -lean_dec(x_11); -x_267 = !lean_is_exclusive(x_263); -if (x_267 == 0) -{ -lean_object* x_268; uint8_t x_269; -x_268 = lean_ctor_get(x_263, 2); -x_269 = !lean_is_exclusive(x_268); -if (x_269 == 0) -{ -lean_object* x_270; lean_object* x_271; uint8_t x_272; -x_270 = lean_ctor_get(x_268, 2); -x_271 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_268, 2, x_271); -x_272 = !lean_is_exclusive(x_12); -if (x_272 == 0) -{ -lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_273 = lean_ctor_get(x_12, 2); -x_274 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_274, 0, x_264); -lean_ctor_set(x_274, 1, x_20); -x_275 = lean_array_push(x_273, x_274); -lean_ctor_set(x_12, 2, x_275); -x_276 = 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_266, x_12, x_263); -if (lean_obj_tag(x_276) == 0) -{ -lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_276, 1); +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); -x_278 = lean_ctor_get(x_277, 2); +lean_dec(x_271); +x_278 = lean_ctor_get(x_272, 0); lean_inc(x_278); -x_279 = !lean_is_exclusive(x_276); -if (x_279 == 0) -{ -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_276, 1); -lean_dec(x_280); +lean_dec(x_272); +x_279 = lean_unsigned_to_nat(1u); +x_280 = lean_nat_add(x_11, x_279); +lean_dec(x_11); x_281 = !lean_is_exclusive(x_277); if (x_281 == 0) { lean_object* x_282; uint8_t x_283; x_282 = lean_ctor_get(x_277, 2); -lean_dec(x_282); -x_283 = !lean_is_exclusive(x_278); +x_283 = !lean_is_exclusive(x_282); if (x_283 == 0) { -lean_object* x_284; -x_284 = lean_ctor_get(x_278, 2); -lean_dec(x_284); -lean_ctor_set(x_278, 2, x_270); -return x_276; -} -else +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_285; lean_object* x_286; lean_object* x_287; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -lean_inc(x_286); -lean_inc(x_285); -lean_dec(x_278); -x_287 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_287, 0, x_285); -lean_ctor_set(x_287, 1, x_286); -lean_ctor_set(x_287, 2, x_270); -lean_ctor_set(x_277, 2, x_287); -return x_276; -} -} -else +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_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_288 = lean_ctor_get(x_277, 0); -x_289 = lean_ctor_get(x_277, 1); -x_290 = lean_ctor_get(x_277, 3); -x_291 = lean_ctor_get(x_277, 4); -x_292 = lean_ctor_get(x_277, 5); -lean_inc(x_292); +lean_object* x_291; lean_object* x_292; uint8_t x_293; +x_291 = lean_ctor_get(x_290, 1); lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_dec(x_277); -x_293 = lean_ctor_get(x_278, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_278, 1); -lean_inc(x_294); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_295 = x_278; -} else { - lean_dec_ref(x_278); - x_295 = lean_box(0); -} -if (lean_is_scalar(x_295)) { - x_296 = lean_alloc_ctor(0, 3, 0); -} else { - x_296 = x_295; -} -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_270); -x_297 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_297, 0, x_288); -lean_ctor_set(x_297, 1, x_289); -lean_ctor_set(x_297, 2, x_296); -lean_ctor_set(x_297, 3, x_290); -lean_ctor_set(x_297, 4, x_291); -lean_ctor_set(x_297, 5, x_292); -lean_ctor_set(x_276, 1, x_297); -return x_276; -} +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_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_298 = lean_ctor_get(x_276, 0); -lean_inc(x_298); -lean_dec(x_276); -x_299 = lean_ctor_get(x_277, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_277, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_277, 3); +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); -x_302 = lean_ctor_get(x_277, 4); -lean_inc(x_302); -x_303 = lean_ctor_get(x_277, 5); -lean_inc(x_303); -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_304 = x_277; -} else { - lean_dec_ref(x_277); - x_304 = lean_box(0); +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; } -x_305 = lean_ctor_get(x_278, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_278, 1); +} +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); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_307 = x_278; +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_inc(x_309); +x_310 = lean_ctor_get(x_292, 3); +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_278); - x_307 = lean_box(0); + lean_dec_ref(x_292); + x_311 = lean_box(0); } -if (lean_is_scalar(x_307)) { - x_308 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_311)) { + x_312 = lean_alloc_ctor(0, 4, 0); } else { - x_308 = x_307; + x_312 = x_311; } -lean_ctor_set(x_308, 0, x_305); -lean_ctor_set(x_308, 1, x_306); -lean_ctor_set(x_308, 2, x_270); -if (lean_is_scalar(x_304)) { - x_309 = lean_alloc_ctor(0, 6, 0); -} else { - x_309 = x_304; -} -lean_ctor_set(x_309, 0, x_299); -lean_ctor_set(x_309, 1, x_300); -lean_ctor_set(x_309, 2, x_308); -lean_ctor_set(x_309, 3, x_301); -lean_ctor_set(x_309, 4, x_302); -lean_ctor_set(x_309, 5, x_303); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_298); -lean_ctor_set(x_310, 1, x_309); -return x_310; +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_311; lean_object* x_312; uint8_t x_313; -x_311 = lean_ctor_get(x_276, 1); -lean_inc(x_311); -x_312 = lean_ctor_get(x_311, 2); -lean_inc(x_312); -x_313 = !lean_is_exclusive(x_276); -if (x_313 == 0) -{ -lean_object* x_314; uint8_t x_315; -x_314 = lean_ctor_get(x_276, 1); -lean_dec(x_314); -x_315 = !lean_is_exclusive(x_311); -if (x_315 == 0) -{ -lean_object* x_316; uint8_t x_317; -x_316 = lean_ctor_get(x_311, 2); -lean_dec(x_316); -x_317 = !lean_is_exclusive(x_312); -if (x_317 == 0) -{ -lean_object* x_318; -x_318 = lean_ctor_get(x_312, 2); -lean_dec(x_318); -lean_ctor_set(x_312, 2, x_270); -return x_276; -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_312, 0); -x_320 = lean_ctor_get(x_312, 1); -lean_inc(x_320); +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_inc(x_319); -lean_dec(x_312); -x_321 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_321, 0, x_319); -lean_ctor_set(x_321, 1, x_320); -lean_ctor_set(x_321, 2, x_270); -lean_ctor_set(x_311, 2, x_321); -return x_276; +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); } -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_322 = lean_ctor_get(x_311, 0); -x_323 = lean_ctor_get(x_311, 1); -x_324 = lean_ctor_get(x_311, 3); -x_325 = lean_ctor_get(x_311, 4); -x_326 = lean_ctor_get(x_311, 5); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); +x_321 = lean_ctor_get(x_292, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_292, 1); lean_inc(x_322); -lean_dec(x_311); -x_327 = lean_ctor_get(x_312, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_312, 1); +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); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_329 = x_312; -} else { - lean_dec_ref(x_312); - x_329 = lean_box(0); -} -if (lean_is_scalar(x_329)) { - x_330 = lean_alloc_ctor(0, 3, 0); -} else { - x_330 = x_329; -} -lean_ctor_set(x_330, 0, x_327); -lean_ctor_set(x_330, 1, x_328); -lean_ctor_set(x_330, 2, x_270); -x_331 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_331, 0, x_322); -lean_ctor_set(x_331, 1, x_323); -lean_ctor_set(x_331, 2, x_330); -lean_ctor_set(x_331, 3, x_324); -lean_ctor_set(x_331, 4, x_325); -lean_ctor_set(x_331, 5, x_326); -lean_ctor_set(x_276, 1, x_331); -return x_276; -} +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_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_332 = lean_ctor_get(x_276, 0); -lean_inc(x_332); -lean_dec(x_276); -x_333 = lean_ctor_get(x_311, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_311, 1); -lean_inc(x_334); -x_335 = lean_ctor_get(x_311, 3); -lean_inc(x_335); -x_336 = lean_ctor_get(x_311, 4); -lean_inc(x_336); -x_337 = lean_ctor_get(x_311, 5); +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); -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); - lean_ctor_release(x_311, 5); - x_338 = x_311; -} else { - lean_dec_ref(x_311); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_312, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_312, 1); -lean_inc(x_340); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_341 = x_312; -} else { - lean_dec_ref(x_312); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 3, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_339); -lean_ctor_set(x_342, 1, x_340); -lean_ctor_set(x_342, 2, x_270); -if (lean_is_scalar(x_338)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_338; -} -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); -x_344 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_344, 0, x_332); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} +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_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; -x_345 = lean_ctor_get(x_12, 0); -x_346 = lean_ctor_get(x_12, 1); -x_347 = lean_ctor_get(x_12, 2); -x_348 = lean_ctor_get(x_12, 3); -x_349 = lean_ctor_get(x_12, 4); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); +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); -lean_dec(x_12); -x_350 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_350, 0, x_264); -lean_ctor_set(x_350, 1, x_20); -x_351 = lean_array_push(x_347, x_350); -x_352 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_352, 0, x_345); -lean_ctor_set(x_352, 1, x_346); -lean_ctor_set(x_352, 2, x_351); -lean_ctor_set(x_352, 3, x_348); -lean_ctor_set(x_352, 4, x_349); -x_353 = 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_266, x_352, x_263); -if (lean_obj_tag(x_353) == 0) -{ -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; -x_354 = lean_ctor_get(x_353, 1); -lean_inc(x_354); -x_355 = lean_ctor_get(x_354, 2); -lean_inc(x_355); -x_356 = lean_ctor_get(x_353, 0); -lean_inc(x_356); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_357 = x_353; +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_353); + 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_354, 0); +x_358 = lean_ctor_get(x_329, 0); lean_inc(x_358); -x_359 = lean_ctor_get(x_354, 1); +x_359 = lean_ctor_get(x_329, 1); lean_inc(x_359); -x_360 = lean_ctor_get(x_354, 3); +x_360 = lean_ctor_get(x_329, 3); lean_inc(x_360); -x_361 = lean_ctor_get(x_354, 4); -lean_inc(x_361); -x_362 = lean_ctor_get(x_354, 5); -lean_inc(x_362); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - lean_ctor_release(x_354, 2); - lean_ctor_release(x_354, 3); - lean_ctor_release(x_354, 4); - lean_ctor_release(x_354, 5); - x_363 = x_354; +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_354); - x_363 = lean_box(0); + lean_dec_ref(x_329); + x_361 = lean_box(0); } -x_364 = lean_ctor_get(x_355, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_355, 1); -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); - x_366 = x_355; +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_355); - x_366 = lean_box(0); + x_362 = x_361; } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 3, 0); -} else { - x_367 = x_366; -} -lean_ctor_set(x_367, 0, x_364); -lean_ctor_set(x_367, 1, x_365); -lean_ctor_set(x_367, 2, x_270); -if (lean_is_scalar(x_363)) { - x_368 = lean_alloc_ctor(0, 6, 0); -} else { - x_368 = x_363; -} -lean_ctor_set(x_368, 0, x_358); -lean_ctor_set(x_368, 1, x_359); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_360); -lean_ctor_set(x_368, 4, x_361); -lean_ctor_set(x_368, 5, x_362); +lean_ctor_set(x_362, 0, x_358); +lean_ctor_set(x_362, 1, x_359); +lean_ctor_set(x_362, 2, x_284); +lean_ctor_set(x_362, 3, x_360); if (lean_is_scalar(x_357)) { - x_369 = lean_alloc_ctor(0, 2, 0); + x_363 = lean_alloc_ctor(0, 6, 0); } else { - x_369 = x_357; + 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; +} } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; } else { -lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_370 = lean_ctor_get(x_353, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_370, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_353, 0); -lean_inc(x_372); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_373 = x_353; -} else { - lean_dec_ref(x_353); - x_373 = lean_box(0); -} -x_374 = lean_ctor_get(x_370, 0); +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_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) +{ +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_370, 1); +x_375 = lean_ctor_get(x_374, 2); lean_inc(x_375); -x_376 = lean_ctor_get(x_370, 3); +x_376 = lean_ctor_get(x_373, 0); lean_inc(x_376); -x_377 = lean_ctor_get(x_370, 4); -lean_inc(x_377); -x_378 = lean_ctor_get(x_370, 5); +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); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - lean_ctor_release(x_370, 2); - lean_ctor_release(x_370, 3); - lean_ctor_release(x_370, 4); - lean_ctor_release(x_370, 5); - x_379 = x_370; -} else { - lean_dec_ref(x_370); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_371, 0); +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_371, 1); +x_381 = lean_ctor_get(x_374, 4); lean_inc(x_381); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - lean_ctor_release(x_371, 2); - x_382 = x_371; +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_371); - x_382 = lean_box(0); + lean_dec_ref(x_374); + x_383 = lean_box(0); } -if (lean_is_scalar(x_382)) { - x_383 = lean_alloc_ctor(0, 3, 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 { - x_383 = x_382; + lean_dec_ref(x_375); + x_387 = lean_box(0); } -lean_ctor_set(x_383, 0, x_380); -lean_ctor_set(x_383, 1, x_381); -lean_ctor_set(x_383, 2, x_270); -if (lean_is_scalar(x_379)) { - x_384 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_387)) { + x_388 = lean_alloc_ctor(0, 4, 0); } else { - x_384 = x_379; + x_388 = x_387; } -lean_ctor_set(x_384, 0, x_374); -lean_ctor_set(x_384, 1, x_375); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_376); -lean_ctor_set(x_384, 4, x_377); -lean_ctor_set(x_384, 5, x_378); -if (lean_is_scalar(x_373)) { - x_385 = lean_alloc_ctor(1, 2, 0); +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_385 = x_373; -} -lean_ctor_set(x_385, 0, x_372); -lean_ctor_set(x_385, 1, x_384); -return x_385; + 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; } 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_399; lean_object* x_400; -x_386 = lean_ctor_get(x_268, 0); -x_387 = lean_ctor_get(x_268, 1); -x_388 = lean_ctor_get(x_268, 2); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_268); -x_389 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_390 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_390, 0, x_386); -lean_ctor_set(x_390, 1, x_387); -lean_ctor_set(x_390, 2, x_389); -lean_ctor_set(x_263, 2, x_390); -x_391 = lean_ctor_get(x_12, 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; 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_12, 1); +x_392 = lean_ctor_get(x_391, 2); lean_inc(x_392); -x_393 = lean_ctor_get(x_12, 2); +x_393 = lean_ctor_get(x_373, 0); lean_inc(x_393); -x_394 = lean_ctor_get(x_12, 3); -lean_inc(x_394); -x_395 = lean_ctor_get(x_12, 4); +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); +} +x_395 = lean_ctor_get(x_391, 0); lean_inc(x_395); -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_396 = x_12; +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_12); - x_396 = lean_box(0); + lean_dec_ref(x_391); + x_400 = lean_box(0); } -x_397 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_397, 0, x_264); -lean_ctor_set(x_397, 1, x_20); -x_398 = lean_array_push(x_393, x_397); -if (lean_is_scalar(x_396)) { - x_399 = lean_alloc_ctor(0, 5, 0); -} else { - x_399 = x_396; -} -lean_ctor_set(x_399, 0, x_391); -lean_ctor_set(x_399, 1, x_392); -lean_ctor_set(x_399, 2, x_398); -lean_ctor_set(x_399, 3, x_394); -lean_ctor_set(x_399, 4, x_395); -x_400 = 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_266, x_399, x_263); -if (lean_obj_tag(x_400) == 0) -{ -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_400, 1); +x_401 = lean_ctor_get(x_392, 0); lean_inc(x_401); -x_402 = lean_ctor_get(x_401, 2); +x_402 = lean_ctor_get(x_392, 1); lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); +x_403 = lean_ctor_get(x_392, 3); lean_inc(x_403); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_404 = 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); + x_404 = x_392; } else { - lean_dec_ref(x_400); + lean_dec_ref(x_392); x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_401, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 3); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 4); -lean_inc(x_408); -x_409 = lean_ctor_get(x_401, 5); -lean_inc(x_409); -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_410 = x_401; -} else { - lean_dec_ref(x_401); - x_410 = lean_box(0); -} -x_411 = lean_ctor_get(x_402, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 1); -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); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 3, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_411); -lean_ctor_set(x_414, 1, x_412); -lean_ctor_set(x_414, 2, x_388); -if (lean_is_scalar(x_410)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_410; -} -lean_ctor_set(x_415, 0, x_405); -lean_ctor_set(x_415, 1, x_406); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_407); -lean_ctor_set(x_415, 4, x_408); -lean_ctor_set(x_415, 5, x_409); if (lean_is_scalar(x_404)) { - x_416 = lean_alloc_ctor(0, 2, 0); + x_405 = lean_alloc_ctor(0, 4, 0); } else { - x_416 = x_404; + 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_284); +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_394)) { + x_407 = lean_alloc_ctor(1, 2, 0); +} else { + x_407 = x_394; +} +lean_ctor_set(x_407, 0, x_393); +lean_ctor_set(x_407, 1, x_406); +return x_407; +} } -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; } else { -lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; -x_417 = lean_ctor_get(x_400, 1); +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_417, 2); +x_418 = lean_ctor_get(x_12, 4); lean_inc(x_418); -x_419 = lean_ctor_get(x_400, 0); -lean_inc(x_419); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_420 = x_400; -} else { - lean_dec_ref(x_400); - 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); -if (lean_is_exclusive(x_418)) { - lean_ctor_release(x_418, 0); - lean_ctor_release(x_418, 1); - lean_ctor_release(x_418, 2); - x_429 = x_418; -} else { - lean_dec_ref(x_418); - x_429 = lean_box(0); -} -if (lean_is_scalar(x_429)) { - x_430 = lean_alloc_ctor(0, 3, 0); -} else { - x_430 = x_429; -} -lean_ctor_set(x_430, 0, x_427); -lean_ctor_set(x_430, 1, x_428); -lean_ctor_set(x_430, 2, x_388); -if (lean_is_scalar(x_426)) { - x_431 = lean_alloc_ctor(0, 6, 0); -} else { - x_431 = x_426; -} -lean_ctor_set(x_431, 0, x_421); -lean_ctor_set(x_431, 1, x_422); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_423); -lean_ctor_set(x_431, 4, x_424); -lean_ctor_set(x_431, 5, x_425); -if (lean_is_scalar(x_420)) { - x_432 = lean_alloc_ctor(1, 2, 0); -} else { - x_432 = x_420; -} -lean_ctor_set(x_432, 0, x_419); -lean_ctor_set(x_432, 1, x_431); -return x_432; -} -} -} -else -{ -lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; 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_433 = lean_ctor_get(x_263, 2); -x_434 = lean_ctor_get(x_263, 0); -x_435 = lean_ctor_get(x_263, 1); -x_436 = lean_ctor_get(x_263, 3); -x_437 = lean_ctor_get(x_263, 4); -x_438 = lean_ctor_get(x_263, 5); -lean_inc(x_438); -lean_inc(x_437); -lean_inc(x_436); -lean_inc(x_433); -lean_inc(x_435); -lean_inc(x_434); -lean_dec(x_263); -x_439 = lean_ctor_get(x_433, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_433, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_433, 2); -lean_inc(x_441); -if (lean_is_exclusive(x_433)) { - lean_ctor_release(x_433, 0); - lean_ctor_release(x_433, 1); - lean_ctor_release(x_433, 2); - x_442 = x_433; -} else { - lean_dec_ref(x_433); - x_442 = lean_box(0); -} -x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_442)) { - x_444 = lean_alloc_ctor(0, 3, 0); -} else { - x_444 = x_442; -} -lean_ctor_set(x_444, 0, x_439); -lean_ctor_set(x_444, 1, x_440); -lean_ctor_set(x_444, 2, x_443); -x_445 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_445, 0, x_434); -lean_ctor_set(x_445, 1, x_435); -lean_ctor_set(x_445, 2, x_444); -lean_ctor_set(x_445, 3, x_436); -lean_ctor_set(x_445, 4, x_437); -lean_ctor_set(x_445, 5, x_438); -x_446 = lean_ctor_get(x_12, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_12, 1); -lean_inc(x_447); -x_448 = lean_ctor_get(x_12, 2); -lean_inc(x_448); -x_449 = lean_ctor_get(x_12, 3); -lean_inc(x_449); -x_450 = lean_ctor_get(x_12, 4); -lean_inc(x_450); 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_451 = x_12; + x_419 = x_12; } else { lean_dec_ref(x_12); - x_451 = lean_box(0); + x_419 = lean_box(0); } -x_452 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_452, 0, x_264); -lean_ctor_set(x_452, 1, x_20); -x_453 = lean_array_push(x_448, x_452); -if (lean_is_scalar(x_451)) { - x_454 = lean_alloc_ctor(0, 5, 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); } else { - x_454 = x_451; + x_422 = x_419; } -lean_ctor_set(x_454, 0, x_446); -lean_ctor_set(x_454, 1, x_447); -lean_ctor_set(x_454, 2, x_453); -lean_ctor_set(x_454, 3, x_449); -lean_ctor_set(x_454, 4, x_450); -x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_266, x_454, x_445); -if (lean_obj_tag(x_455) == 0) +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_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_456 = lean_ctor_get(x_455, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_456, 2); -lean_inc(x_457); -x_458 = lean_ctor_get(x_455, 0); -lean_inc(x_458); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_459 = x_455; +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_455); - x_459 = lean_box(0); + lean_dec_ref(x_423); + x_427 = lean_box(0); } -x_460 = lean_ctor_get(x_456, 0); -lean_inc(x_460); -x_461 = lean_ctor_get(x_456, 1); -lean_inc(x_461); -x_462 = lean_ctor_get(x_456, 3); -lean_inc(x_462); -x_463 = lean_ctor_get(x_456, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_441); + x_450 = 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; +} else { + lean_dec_ref(x_442); + x_454 = lean_box(0); +} +if (lean_is_scalar(x_454)) { + x_455 = lean_alloc_ctor(0, 4, 0); +} else { + x_455 = x_454; +} +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); +} else { + x_456 = x_450; +} +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); +} else { + x_457 = x_444; +} +lean_ctor_set(x_457, 0, x_443); +lean_ctor_set(x_457, 1, x_456); +return x_457; +} +} +} +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); -x_464 = lean_ctor_get(x_456, 5); +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); -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); - lean_ctor_release(x_456, 4); - lean_ctor_release(x_456, 5); - x_465 = x_456; -} else { - lean_dec_ref(x_456); - x_465 = lean_box(0); -} -x_466 = lean_ctor_get(x_457, 0); +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_457, 1); +x_467 = lean_ctor_get(x_458, 3); lean_inc(x_467); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - lean_ctor_release(x_457, 2); - x_468 = x_457; +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; } else { - lean_dec_ref(x_457); + lean_dec_ref(x_458); x_468 = lean_box(0); } +x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_468)) { - x_469 = lean_alloc_ctor(0, 3, 0); + x_470 = lean_alloc_ctor(0, 4, 0); } else { - x_469 = x_468; + x_470 = x_468; } -lean_ctor_set(x_469, 0, x_466); -lean_ctor_set(x_469, 1, x_467); -lean_ctor_set(x_469, 2, x_441); -if (lean_is_scalar(x_465)) { - x_470 = lean_alloc_ctor(0, 6, 0); -} else { - x_470 = x_465; -} -lean_ctor_set(x_470, 0, x_460); -lean_ctor_set(x_470, 1, x_461); +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_462); -lean_ctor_set(x_470, 4, x_463); -lean_ctor_set(x_470, 5, x_464); -if (lean_is_scalar(x_459)) { - x_471 = lean_alloc_ctor(0, 2, 0); -} else { - x_471 = x_459; -} -lean_ctor_set(x_471, 0, x_458); -lean_ctor_set(x_471, 1, x_470); -return x_471; -} -else -{ -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; -x_472 = lean_ctor_get(x_455, 1); +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_472, 2); +x_473 = lean_ctor_get(x_12, 1); lean_inc(x_473); -x_474 = lean_ctor_get(x_455, 0); +x_474 = lean_ctor_get(x_12, 2); lean_inc(x_474); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_475 = x_455; -} else { - lean_dec_ref(x_455); - x_475 = lean_box(0); -} -x_476 = lean_ctor_get(x_472, 0); +x_475 = lean_ctor_get(x_12, 3); +lean_inc(x_475); +x_476 = lean_ctor_get(x_12, 4); 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; +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; } else { - lean_dec_ref(x_472); - x_481 = lean_box(0); + lean_dec_ref(x_12); + x_477 = lean_box(0); } -x_482 = lean_ctor_get(x_473, 0); +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); +} else { + x_480 = x_477; +} +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_473, 1); +x_483 = lean_ctor_get(x_482, 2); lean_inc(x_483); -if (lean_is_exclusive(x_473)) { - lean_ctor_release(x_473, 0); - lean_ctor_release(x_473, 1); - lean_ctor_release(x_473, 2); - x_484 = x_473; +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; } else { - lean_dec_ref(x_473); - x_484 = lean_box(0); + lean_dec_ref(x_481); + x_485 = lean_box(0); } -if (lean_is_scalar(x_484)) { - x_485 = lean_alloc_ctor(0, 3, 0); +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 { - x_485 = x_484; + lean_dec_ref(x_482); + x_491 = lean_box(0); } -lean_ctor_set(x_485, 0, x_482); -lean_ctor_set(x_485, 1, x_483); -lean_ctor_set(x_485, 2, x_441); -if (lean_is_scalar(x_481)) { - x_486 = lean_alloc_ctor(0, 6, 0); +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 { - x_486 = x_481; + lean_dec_ref(x_483); + x_495 = lean_box(0); } -lean_ctor_set(x_486, 0, x_476); -lean_ctor_set(x_486, 1, x_477); -lean_ctor_set(x_486, 2, x_485); -lean_ctor_set(x_486, 3, x_478); -lean_ctor_set(x_486, 4, x_479); -lean_ctor_set(x_486, 5, x_480); -if (lean_is_scalar(x_475)) { - x_487 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_495)) { + x_496 = lean_alloc_ctor(0, 4, 0); } else { - x_487 = x_475; + x_496 = x_495; } -lean_ctor_set(x_487, 0, x_474); -lean_ctor_set(x_487, 1, x_486); -return x_487; +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_488; +uint8_t x_516; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -29558,23 +30612,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_488 = !lean_is_exclusive(x_257); -if (x_488 == 0) +x_516 = !lean_is_exclusive(x_271); +if (x_516 == 0) { -return x_257; +return x_271; } else { -lean_object* x_489; lean_object* x_490; lean_object* x_491; -x_489 = lean_ctor_get(x_257, 0); -x_490 = lean_ctor_get(x_257, 1); -lean_inc(x_490); -lean_inc(x_489); -lean_dec(x_257); -x_491 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_491, 0, x_489); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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; } } } @@ -29582,7 +30636,7 @@ return x_491; } else { -uint8_t x_492; +uint8_t x_520; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -29593,29 +30647,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_492 = !lean_is_exclusive(x_25); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_25); +if (x_520 == 0) { return x_25; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_25, 0); -x_494 = lean_ctor_get(x_25, 1); -lean_inc(x_494); -lean_inc(x_493); +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_dec(x_25); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -29625,23 +30679,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_21); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_21); +if (x_524 == 0) { return x_21; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_21, 0); -x_498 = lean_ctor_get(x_21, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_21); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } @@ -29779,82 +30833,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -29862,1899 +30923,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -31762,58 +32922,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -32331,82 +33491,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -32414,1899 +33581,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -34314,58 +35580,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -34549,82 +35815,89 @@ return x_44; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; +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_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_38); -lean_ctor_set(x_45, 2, x_55); +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; } } 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; -x_56 = lean_ctor_get(x_45, 0); -x_57 = lean_ctor_get(x_45, 1); -x_58 = lean_ctor_get(x_45, 3); -x_59 = lean_ctor_get(x_45, 4); -x_60 = lean_ctor_get(x_45, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +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_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_45); -x_61 = lean_ctor_get(x_46, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_46, 1); +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); - x_63 = x_46; + lean_ctor_release(x_46, 3); + x_65 = x_46; } else { lean_dec_ref(x_46); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -lean_ctor_set(x_64, 2, x_38); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_56); -lean_ctor_set(x_65, 1, x_57); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_58); -lean_ctor_set(x_65, 4, x_59); -lean_ctor_set(x_65, 5, x_60); -lean_ctor_set(x_44, 1, 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_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; } } 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; -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -lean_dec(x_44); -x_67 = lean_ctor_get(x_45, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_45, 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; lean_object* x_80; lean_object* x_81; +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_45, 3); +lean_dec(x_44); +x_69 = lean_ctor_get(x_45, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 4); +x_70 = lean_ctor_get(x_45, 1); lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 5); +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); @@ -34632,1877 +35905,1976 @@ if (lean_is_exclusive(x_45)) { lean_ctor_release(x_45, 3); lean_ctor_release(x_45, 4); lean_ctor_release(x_45, 5); - x_72 = x_45; + x_74 = x_45; } else { lean_dec_ref(x_45); - x_72 = lean_box(0); + x_74 = lean_box(0); } -x_73 = lean_ctor_get(x_46, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_46, 1); -lean_inc(x_74); +x_75 = lean_ctor_get(x_46, 0); +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); - x_75 = x_46; + lean_ctor_release(x_46, 3); + x_78 = x_46; } else { lean_dec_ref(x_46); - x_75 = lean_box(0); + x_78 = lean_box(0); } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 4, 0); } else { - x_76 = x_75; + x_79 = x_78; } -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_38); -if (lean_is_scalar(x_72)) { - x_77 = 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_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_77 = x_72; + x_80 = x_74; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_68); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_69); -lean_ctor_set(x_77, 4, x_70); -lean_ctor_set(x_77, 5, x_71); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_66); -lean_ctor_set(x_78, 1, x_77); -return x_78; +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; } } else { -lean_object* x_79; lean_object* x_80; uint8_t x_81; -x_79 = lean_ctor_get(x_44, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 2); -lean_inc(x_80); -x_81 = !lean_is_exclusive(x_44); -if (x_81 == 0) -{ -lean_object* x_82; uint8_t x_83; +lean_object* x_82; lean_object* x_83; uint8_t x_84; x_82 = lean_ctor_get(x_44, 1); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_79); -if (x_83 == 0) +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 2); +lean_inc(x_83); +x_84 = !lean_is_exclusive(x_44); +if (x_84 == 0) { -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_79, 2); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_80); -if (x_85 == 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_86; -x_86 = lean_ctor_get(x_80, 2); -lean_dec(x_86); -lean_ctor_set(x_80, 2, x_38); +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_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_80, 0); -x_88 = lean_ctor_get(x_80, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_80); -x_89 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -lean_ctor_set(x_89, 2, x_38); -lean_ctor_set(x_79, 2, x_89); -return x_44; -} -} -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; -x_90 = lean_ctor_get(x_79, 0); -x_91 = lean_ctor_get(x_79, 1); -x_92 = lean_ctor_get(x_79, 3); -x_93 = lean_ctor_get(x_79, 4); -x_94 = lean_ctor_get(x_79, 5); -lean_inc(x_94); -lean_inc(x_93); +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_79); -x_95 = lean_ctor_get(x_80, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_80, 1); -lean_inc(x_96); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - x_97 = x_80; -} else { - lean_dec_ref(x_80); - x_97 = lean_box(0); -} -if (lean_is_scalar(x_97)) { - x_98 = lean_alloc_ctor(0, 3, 0); -} else { - x_98 = x_97; -} -lean_ctor_set(x_98, 0, x_95); -lean_ctor_set(x_98, 1, x_96); -lean_ctor_set(x_98, 2, x_38); -x_99 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_99, 0, x_90); -lean_ctor_set(x_99, 1, x_91); -lean_ctor_set(x_99, 2, x_98); -lean_ctor_set(x_99, 3, x_92); -lean_ctor_set(x_99, 4, x_93); -lean_ctor_set(x_99, 5, x_94); -lean_ctor_set(x_44, 1, x_99); +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_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_100 = lean_ctor_get(x_44, 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; +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); -lean_dec(x_44); -x_101 = lean_ctor_get(x_79, 0); +x_101 = lean_ctor_get(x_83, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_79, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_79, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_79, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_79, 5); +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; +} else { + lean_dec_ref(x_83); + x_102 = lean_box(0); +} +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 4, 0); +} else { + x_103 = x_102; +} +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); -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); - lean_ctor_release(x_79, 4); - lean_ctor_release(x_79, 5); - x_106 = x_79; -} else { - lean_dec_ref(x_79); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_80, 0); +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_80, 1); +x_108 = lean_ctor_get(x_82, 3); 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); - x_109 = x_80; +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; } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + lean_dec_ref(x_82); + x_111 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 3, 0); +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 { - x_110 = x_109; + lean_dec_ref(x_83); + x_115 = lean_box(0); } -lean_ctor_set(x_110, 0, x_107); -lean_ctor_set(x_110, 1, x_108); -lean_ctor_set(x_110, 2, x_38); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 4, 0); } else { - x_111 = x_106; + x_116 = x_115; } -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_100); -lean_ctor_set(x_112, 1, x_111); -return x_112; +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_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_12, 0); -x_114 = lean_ctor_get(x_12, 1); -x_115 = lean_ctor_get(x_12, 2); -x_116 = lean_ctor_get(x_12, 3); -x_117 = lean_ctor_get(x_12, 4); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_12); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_32); -lean_ctor_set(x_118, 1, x_20); -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__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_120, x_31); -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; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); +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); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; -} else { - lean_dec_ref(x_121); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_122, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_122); +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_122, 4); +x_129 = lean_ctor_get(x_128, 2); lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); +x_130 = lean_ctor_get(x_127, 0); 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_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + x_131 = x_127; } else { - lean_dec_ref(x_122); + lean_dec_ref(x_127); x_131 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); +x_132 = lean_ctor_get(x_128, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); +x_133 = lean_ctor_get(x_128, 1); lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - x_134 = x_123; +x_134 = lean_ctor_get(x_128, 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; } else { - lean_dec_ref(x_123); - x_134 = lean_box(0); + lean_dec_ref(x_128); + x_137 = lean_box(0); } -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 3, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_132); -lean_ctor_set(x_135, 1, x_133); -lean_ctor_set(x_135, 2, x_38); -if (lean_is_scalar(x_131)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_131; -} -lean_ctor_set(x_136, 0, x_126); -lean_ctor_set(x_136, 1, x_127); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_128); -lean_ctor_set(x_136, 4, x_129); -lean_ctor_set(x_136, 5, x_130); -if (lean_is_scalar(x_125)) { - x_137 = lean_alloc_ctor(0, 2, 0); -} else { - x_137 = x_125; -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_138 = lean_ctor_get(x_121, 1); +x_138 = lean_ctor_get(x_129, 0); lean_inc(x_138); -x_139 = lean_ctor_get(x_138, 2); +x_139 = lean_ctor_get(x_129, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 0); +x_140 = lean_ctor_get(x_129, 3); lean_inc(x_140); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_141 = x_121; +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; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_129); x_141 = lean_box(0); } -x_142 = lean_ctor_get(x_138, 0); -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; -} else { - lean_dec_ref(x_138); - x_147 = 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); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - 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, 3, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -lean_ctor_set(x_151, 2, x_38); -if (lean_is_scalar(x_147)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_147; -} -lean_ctor_set(x_152, 0, x_142); -lean_ctor_set(x_152, 1, x_143); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_144); -lean_ctor_set(x_152, 4, x_145); -lean_ctor_set(x_152, 5, x_146); if (lean_is_scalar(x_141)) { - x_153 = lean_alloc_ctor(1, 2, 0); + x_142 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_141; + x_142 = x_141; } -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; +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); +if (lean_is_scalar(x_131)) { + x_144 = lean_alloc_ctor(0, 2, 0); +} else { + x_144 = x_131; +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_145 = lean_ctor_get(x_127, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_145, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 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); +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; +} else { + lean_dec_ref(x_145); + x_154 = 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; +} else { + lean_dec_ref(x_146); + x_158 = lean_box(0); +} +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_38); +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); +if (lean_is_scalar(x_148)) { + x_161 = lean_alloc_ctor(1, 2, 0); +} else { + x_161 = x_148; +} +lean_ctor_set(x_161, 0, x_147); +lean_ctor_set(x_161, 1, x_160); +return x_161; } } } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_154 = lean_ctor_get(x_36, 0); -x_155 = lean_ctor_get(x_36, 1); -x_156 = lean_ctor_get(x_36, 2); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_dec(x_36); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_31, 2, x_158); -x_159 = lean_ctor_get(x_12, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_12, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_12, 4); +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); 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_164 = x_12; + x_173 = x_12; } else { lean_dec_ref(x_12); - x_164 = lean_box(0); + x_173 = lean_box(0); } -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_32); -lean_ctor_set(x_165, 1, x_20); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 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); } else { - x_167 = x_164; + x_176 = x_173; } -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_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_167, x_31); -if (lean_obj_tag(x_168) == 0) +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_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, 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_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_170, 1); +x_180 = lean_ctor_get(x_177, 0); lean_inc(x_180); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - lean_ctor_release(x_170, 2); - x_181 = x_170; +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_170); + lean_dec_ref(x_177); x_181 = lean_box(0); } -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 3, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_179); -lean_ctor_set(x_182, 1, x_180); -lean_ctor_set(x_182, 2, x_156); -if (lean_is_scalar(x_178)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_178; -} -lean_ctor_set(x_183, 0, x_173); -lean_ctor_set(x_183, 1, x_174); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_175); -lean_ctor_set(x_183, 4, x_176); -lean_ctor_set(x_183, 5, x_177); -if (lean_is_scalar(x_172)) { - x_184 = lean_alloc_ctor(0, 2, 0); -} else { - x_184 = x_172; -} -lean_ctor_set(x_184, 0, x_171); -lean_ctor_set(x_184, 1, x_183); -return x_184; -} -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; -x_185 = lean_ctor_get(x_168, 1); +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_185, 2); +x_186 = lean_ctor_get(x_178, 5); lean_inc(x_186); -x_187 = lean_ctor_get(x_168, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_188 = x_168; +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_168); - x_188 = lean_box(0); + lean_dec_ref(x_178); + x_187 = lean_box(0); } -x_189 = lean_ctor_get(x_185, 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_185, 1); +x_190 = lean_ctor_get(x_179, 3); 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; +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_185); - x_194 = lean_box(0); + lean_dec_ref(x_179); + x_191 = lean_box(0); } -x_195 = lean_ctor_get(x_186, 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; +} +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_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); +x_196 = lean_ctor_get(x_195, 2); 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); - x_197 = x_186; +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; } else { - lean_dec_ref(x_186); - x_197 = lean_box(0); + lean_dec_ref(x_177); + x_198 = lean_box(0); } -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_195, 5); +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 { - x_198 = x_197; + lean_dec_ref(x_195); + x_204 = lean_box(0); } -lean_ctor_set(x_198, 0, x_195); -lean_ctor_set(x_198, 1, x_196); -lean_ctor_set(x_198, 2, x_156); -if (lean_is_scalar(x_194)) { - x_199 = lean_alloc_ctor(0, 6, 0); +x_205 = lean_ctor_get(x_196, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_196, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_196, 3); +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; } else { - x_199 = x_194; + lean_dec_ref(x_196); + x_208 = lean_box(0); } -lean_ctor_set(x_199, 0, x_189); -lean_ctor_set(x_199, 1, x_190); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_191); -lean_ctor_set(x_199, 4, x_192); -lean_ctor_set(x_199, 5, x_193); -if (lean_is_scalar(x_188)) { - x_200 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 4, 0); } else { - x_200 = x_188; + x_209 = x_208; } -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +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); +} else { + x_210 = x_204; +} +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_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; } } } 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; 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_201 = lean_ctor_get(x_31, 2); -x_202 = lean_ctor_get(x_31, 0); -x_203 = lean_ctor_get(x_31, 1); -x_204 = lean_ctor_get(x_31, 3); -x_205 = lean_ctor_get(x_31, 4); -x_206 = lean_ctor_get(x_31, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_201); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_31); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 2); -lean_inc(x_209); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_210 = x_201; -} else { - lean_dec_ref(x_201); - x_210 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_210)) { - x_212 = lean_alloc_ctor(0, 3, 0); -} else { - x_212 = x_210; -} -lean_ctor_set(x_212, 0, x_207); -lean_ctor_set(x_212, 1, x_208); -lean_ctor_set(x_212, 2, x_211); -x_213 = 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); -x_214 = lean_ctor_get(x_12, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_12, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_12, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_12, 3); +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); -x_218 = lean_ctor_get(x_12, 4); +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_219 = x_12; + x_231 = x_12; } else { lean_dec_ref(x_12); - x_219 = lean_box(0); + x_231 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_32); -lean_ctor_set(x_220, 1, x_20); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { - x_222 = lean_alloc_ctor(0, 5, 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_222 = x_219; + x_234 = x_231; } -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__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_222, x_213); -if (lean_obj_tag(x_223) == 0) +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_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_224 = lean_ctor_get(x_223, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_223, 0); -lean_inc(x_226); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_227 = x_223; +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_223); - x_227 = lean_box(0); + lean_dec_ref(x_235); + x_239 = lean_box(0); } -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; +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_224); - x_233 = lean_box(0); + lean_dec_ref(x_236); + x_245 = 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); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - lean_ctor_release(x_225, 2); - x_236 = x_225; +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_225); - x_236 = lean_box(0); + lean_dec_ref(x_237); + x_249 = lean_box(0); } -if (lean_is_scalar(x_236)) { - x_237 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(0, 4, 0); } else { - x_237 = x_236; + x_250 = x_249; } -lean_ctor_set(x_237, 0, x_234); -lean_ctor_set(x_237, 1, x_235); -lean_ctor_set(x_237, 2, x_209); -if (lean_is_scalar(x_233)) { - x_238 = lean_alloc_ctor(0, 6, 0); +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_238 = x_233; + x_251 = x_245; } -lean_ctor_set(x_238, 0, x_228); -lean_ctor_set(x_238, 1, x_229); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_230); -lean_ctor_set(x_238, 4, x_231); -lean_ctor_set(x_238, 5, x_232); -if (lean_is_scalar(x_227)) { - x_239 = lean_alloc_ctor(0, 2, 0); +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_239 = x_227; + x_252 = x_239; } -lean_ctor_set(x_239, 0, x_226); -lean_ctor_set(x_239, 1, x_238); -return 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_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; -x_240 = lean_ctor_get(x_223, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); -lean_inc(x_241); -x_242 = lean_ctor_get(x_223, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_243 = x_223; +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_223); - x_243 = lean_box(0); + lean_dec_ref(x_235); + x_256 = 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; +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_240); - x_249 = lean_box(0); + lean_dec_ref(x_253); + x_262 = 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); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - lean_ctor_release(x_241, 2); - x_252 = x_241; +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_241); - x_252 = lean_box(0); + lean_dec_ref(x_254); + x_266 = lean_box(0); } -if (lean_is_scalar(x_252)) { - x_253 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_266)) { + x_267 = lean_alloc_ctor(0, 4, 0); } else { - x_253 = x_252; + x_267 = x_266; } -lean_ctor_set(x_253, 0, x_250); -lean_ctor_set(x_253, 1, x_251); -lean_ctor_set(x_253, 2, x_209); -if (lean_is_scalar(x_249)) { - x_254 = lean_alloc_ctor(0, 6, 0); +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_254 = x_249; + x_268 = x_262; } -lean_ctor_set(x_254, 0, x_244); -lean_ctor_set(x_254, 1, x_245); -lean_ctor_set(x_254, 2, x_253); -lean_ctor_set(x_254, 3, x_246); -lean_ctor_set(x_254, 4, x_247); -lean_ctor_set(x_254, 5, x_248); -if (lean_is_scalar(x_243)) { - x_255 = lean_alloc_ctor(1, 2, 0); +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_255 = x_243; + x_269 = x_256; } -lean_ctor_set(x_255, 0, x_242); -lean_ctor_set(x_255, 1, x_254); -return x_255; +lean_ctor_set(x_269, 0, x_255); +lean_ctor_set(x_269, 1, x_268); +return x_269; } } } default: { -lean_object* x_256; lean_object* x_257; -x_256 = lean_ctor_get(x_25, 1); -lean_inc(x_256); +lean_object* x_270; lean_object* x_271; +x_270 = lean_ctor_get(x_25, 1); +lean_inc(x_270); lean_dec(x_25); lean_inc(x_12); -x_257 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_256); -if (lean_obj_tag(x_257) == 0) +x_271 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_270); +if (lean_obj_tag(x_271) == 0) { -lean_object* x_258; -x_258 = lean_ctor_get(x_257, 0); -lean_inc(x_258); -if (lean_obj_tag(x_258) == 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_259; lean_object* x_260; lean_object* x_261; +lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_dec(x_20); -x_259 = lean_ctor_get(x_257, 1); -lean_inc(x_259); -lean_dec(x_257); -x_260 = lean_unsigned_to_nat(1u); -x_261 = lean_nat_add(x_11, x_260); +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); lean_dec(x_11); -x_11 = x_261; -x_13 = x_259; +x_11 = x_275; +x_13 = x_273; goto _start; } else { -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; uint8_t x_267; -x_263 = lean_ctor_get(x_257, 1); -lean_inc(x_263); -lean_dec(x_257); -x_264 = lean_ctor_get(x_258, 0); -lean_inc(x_264); -lean_dec(x_258); -x_265 = lean_unsigned_to_nat(1u); -x_266 = lean_nat_add(x_11, x_265); -lean_dec(x_11); -x_267 = !lean_is_exclusive(x_263); -if (x_267 == 0) -{ -lean_object* x_268; uint8_t x_269; -x_268 = lean_ctor_get(x_263, 2); -x_269 = !lean_is_exclusive(x_268); -if (x_269 == 0) -{ -lean_object* x_270; lean_object* x_271; uint8_t x_272; -x_270 = lean_ctor_get(x_268, 2); -x_271 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_268, 2, x_271); -x_272 = !lean_is_exclusive(x_12); -if (x_272 == 0) -{ -lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_273 = lean_ctor_get(x_12, 2); -x_274 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_274, 0, x_264); -lean_ctor_set(x_274, 1, x_20); -x_275 = lean_array_push(x_273, x_274); -lean_ctor_set(x_12, 2, x_275); -x_276 = 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_266, x_12, x_263); -if (lean_obj_tag(x_276) == 0) -{ -lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_276, 1); +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); -x_278 = lean_ctor_get(x_277, 2); +lean_dec(x_271); +x_278 = lean_ctor_get(x_272, 0); lean_inc(x_278); -x_279 = !lean_is_exclusive(x_276); -if (x_279 == 0) -{ -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_276, 1); -lean_dec(x_280); +lean_dec(x_272); +x_279 = lean_unsigned_to_nat(1u); +x_280 = lean_nat_add(x_11, x_279); +lean_dec(x_11); x_281 = !lean_is_exclusive(x_277); if (x_281 == 0) { lean_object* x_282; uint8_t x_283; x_282 = lean_ctor_get(x_277, 2); -lean_dec(x_282); -x_283 = !lean_is_exclusive(x_278); +x_283 = !lean_is_exclusive(x_282); if (x_283 == 0) { -lean_object* x_284; -x_284 = lean_ctor_get(x_278, 2); -lean_dec(x_284); -lean_ctor_set(x_278, 2, x_270); -return x_276; -} -else +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_285; lean_object* x_286; lean_object* x_287; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -lean_inc(x_286); -lean_inc(x_285); -lean_dec(x_278); -x_287 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_287, 0, x_285); -lean_ctor_set(x_287, 1, x_286); -lean_ctor_set(x_287, 2, x_270); -lean_ctor_set(x_277, 2, x_287); -return x_276; -} -} -else +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_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_288 = lean_ctor_get(x_277, 0); -x_289 = lean_ctor_get(x_277, 1); -x_290 = lean_ctor_get(x_277, 3); -x_291 = lean_ctor_get(x_277, 4); -x_292 = lean_ctor_get(x_277, 5); -lean_inc(x_292); +lean_object* x_291; lean_object* x_292; uint8_t x_293; +x_291 = lean_ctor_get(x_290, 1); lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_dec(x_277); -x_293 = lean_ctor_get(x_278, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_278, 1); -lean_inc(x_294); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_295 = x_278; -} else { - lean_dec_ref(x_278); - x_295 = lean_box(0); -} -if (lean_is_scalar(x_295)) { - x_296 = lean_alloc_ctor(0, 3, 0); -} else { - x_296 = x_295; -} -lean_ctor_set(x_296, 0, x_293); -lean_ctor_set(x_296, 1, x_294); -lean_ctor_set(x_296, 2, x_270); -x_297 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_297, 0, x_288); -lean_ctor_set(x_297, 1, x_289); -lean_ctor_set(x_297, 2, x_296); -lean_ctor_set(x_297, 3, x_290); -lean_ctor_set(x_297, 4, x_291); -lean_ctor_set(x_297, 5, x_292); -lean_ctor_set(x_276, 1, x_297); -return x_276; -} +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_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_298 = lean_ctor_get(x_276, 0); -lean_inc(x_298); -lean_dec(x_276); -x_299 = lean_ctor_get(x_277, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_277, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_277, 3); +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); -x_302 = lean_ctor_get(x_277, 4); -lean_inc(x_302); -x_303 = lean_ctor_get(x_277, 5); -lean_inc(x_303); -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_304 = x_277; -} else { - lean_dec_ref(x_277); - x_304 = lean_box(0); +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; } -x_305 = lean_ctor_get(x_278, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_278, 1); +} +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); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - x_307 = x_278; +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_inc(x_309); +x_310 = lean_ctor_get(x_292, 3); +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_278); - x_307 = lean_box(0); + lean_dec_ref(x_292); + x_311 = lean_box(0); } -if (lean_is_scalar(x_307)) { - x_308 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_311)) { + x_312 = lean_alloc_ctor(0, 4, 0); } else { - x_308 = x_307; + x_312 = x_311; } -lean_ctor_set(x_308, 0, x_305); -lean_ctor_set(x_308, 1, x_306); -lean_ctor_set(x_308, 2, x_270); -if (lean_is_scalar(x_304)) { - x_309 = lean_alloc_ctor(0, 6, 0); -} else { - x_309 = x_304; -} -lean_ctor_set(x_309, 0, x_299); -lean_ctor_set(x_309, 1, x_300); -lean_ctor_set(x_309, 2, x_308); -lean_ctor_set(x_309, 3, x_301); -lean_ctor_set(x_309, 4, x_302); -lean_ctor_set(x_309, 5, x_303); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_298); -lean_ctor_set(x_310, 1, x_309); -return x_310; +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_311; lean_object* x_312; uint8_t x_313; -x_311 = lean_ctor_get(x_276, 1); -lean_inc(x_311); -x_312 = lean_ctor_get(x_311, 2); -lean_inc(x_312); -x_313 = !lean_is_exclusive(x_276); -if (x_313 == 0) -{ -lean_object* x_314; uint8_t x_315; -x_314 = lean_ctor_get(x_276, 1); -lean_dec(x_314); -x_315 = !lean_is_exclusive(x_311); -if (x_315 == 0) -{ -lean_object* x_316; uint8_t x_317; -x_316 = lean_ctor_get(x_311, 2); -lean_dec(x_316); -x_317 = !lean_is_exclusive(x_312); -if (x_317 == 0) -{ -lean_object* x_318; -x_318 = lean_ctor_get(x_312, 2); -lean_dec(x_318); -lean_ctor_set(x_312, 2, x_270); -return x_276; -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_312, 0); -x_320 = lean_ctor_get(x_312, 1); -lean_inc(x_320); +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_inc(x_319); -lean_dec(x_312); -x_321 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_321, 0, x_319); -lean_ctor_set(x_321, 1, x_320); -lean_ctor_set(x_321, 2, x_270); -lean_ctor_set(x_311, 2, x_321); -return x_276; +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); } -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_322 = lean_ctor_get(x_311, 0); -x_323 = lean_ctor_get(x_311, 1); -x_324 = lean_ctor_get(x_311, 3); -x_325 = lean_ctor_get(x_311, 4); -x_326 = lean_ctor_get(x_311, 5); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); +x_321 = lean_ctor_get(x_292, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_292, 1); lean_inc(x_322); -lean_dec(x_311); -x_327 = lean_ctor_get(x_312, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_312, 1); +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); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_329 = x_312; -} else { - lean_dec_ref(x_312); - x_329 = lean_box(0); -} -if (lean_is_scalar(x_329)) { - x_330 = lean_alloc_ctor(0, 3, 0); -} else { - x_330 = x_329; -} -lean_ctor_set(x_330, 0, x_327); -lean_ctor_set(x_330, 1, x_328); -lean_ctor_set(x_330, 2, x_270); -x_331 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_331, 0, x_322); -lean_ctor_set(x_331, 1, x_323); -lean_ctor_set(x_331, 2, x_330); -lean_ctor_set(x_331, 3, x_324); -lean_ctor_set(x_331, 4, x_325); -lean_ctor_set(x_331, 5, x_326); -lean_ctor_set(x_276, 1, x_331); -return x_276; -} +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_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_332 = lean_ctor_get(x_276, 0); -lean_inc(x_332); -lean_dec(x_276); -x_333 = lean_ctor_get(x_311, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_311, 1); -lean_inc(x_334); -x_335 = lean_ctor_get(x_311, 3); -lean_inc(x_335); -x_336 = lean_ctor_get(x_311, 4); -lean_inc(x_336); -x_337 = lean_ctor_get(x_311, 5); +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); -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); - lean_ctor_release(x_311, 5); - x_338 = x_311; -} else { - lean_dec_ref(x_311); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_312, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_312, 1); -lean_inc(x_340); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - x_341 = x_312; -} else { - lean_dec_ref(x_312); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 3, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_339); -lean_ctor_set(x_342, 1, x_340); -lean_ctor_set(x_342, 2, x_270); -if (lean_is_scalar(x_338)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_338; -} -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); -x_344 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_344, 0, x_332); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} +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_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; -x_345 = lean_ctor_get(x_12, 0); -x_346 = lean_ctor_get(x_12, 1); -x_347 = lean_ctor_get(x_12, 2); -x_348 = lean_ctor_get(x_12, 3); -x_349 = lean_ctor_get(x_12, 4); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); +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); -lean_dec(x_12); -x_350 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_350, 0, x_264); -lean_ctor_set(x_350, 1, x_20); -x_351 = lean_array_push(x_347, x_350); -x_352 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_352, 0, x_345); -lean_ctor_set(x_352, 1, x_346); -lean_ctor_set(x_352, 2, x_351); -lean_ctor_set(x_352, 3, x_348); -lean_ctor_set(x_352, 4, x_349); -x_353 = 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_266, x_352, x_263); -if (lean_obj_tag(x_353) == 0) -{ -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; -x_354 = lean_ctor_get(x_353, 1); -lean_inc(x_354); -x_355 = lean_ctor_get(x_354, 2); -lean_inc(x_355); -x_356 = lean_ctor_get(x_353, 0); -lean_inc(x_356); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_357 = x_353; +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_353); + 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_354, 0); +x_358 = lean_ctor_get(x_329, 0); lean_inc(x_358); -x_359 = lean_ctor_get(x_354, 1); +x_359 = lean_ctor_get(x_329, 1); lean_inc(x_359); -x_360 = lean_ctor_get(x_354, 3); +x_360 = lean_ctor_get(x_329, 3); lean_inc(x_360); -x_361 = lean_ctor_get(x_354, 4); -lean_inc(x_361); -x_362 = lean_ctor_get(x_354, 5); -lean_inc(x_362); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - lean_ctor_release(x_354, 2); - lean_ctor_release(x_354, 3); - lean_ctor_release(x_354, 4); - lean_ctor_release(x_354, 5); - x_363 = x_354; +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_354); - x_363 = lean_box(0); + lean_dec_ref(x_329); + x_361 = lean_box(0); } -x_364 = lean_ctor_get(x_355, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_355, 1); -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); - x_366 = x_355; +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_355); - x_366 = lean_box(0); + x_362 = x_361; } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 3, 0); -} else { - x_367 = x_366; -} -lean_ctor_set(x_367, 0, x_364); -lean_ctor_set(x_367, 1, x_365); -lean_ctor_set(x_367, 2, x_270); -if (lean_is_scalar(x_363)) { - x_368 = lean_alloc_ctor(0, 6, 0); -} else { - x_368 = x_363; -} -lean_ctor_set(x_368, 0, x_358); -lean_ctor_set(x_368, 1, x_359); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_360); -lean_ctor_set(x_368, 4, x_361); -lean_ctor_set(x_368, 5, x_362); +lean_ctor_set(x_362, 0, x_358); +lean_ctor_set(x_362, 1, x_359); +lean_ctor_set(x_362, 2, x_284); +lean_ctor_set(x_362, 3, x_360); if (lean_is_scalar(x_357)) { - x_369 = lean_alloc_ctor(0, 2, 0); + x_363 = lean_alloc_ctor(0, 6, 0); } else { - x_369 = x_357; + 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; +} } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; } else { -lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_370 = lean_ctor_get(x_353, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_370, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_353, 0); -lean_inc(x_372); -if (lean_is_exclusive(x_353)) { - lean_ctor_release(x_353, 0); - lean_ctor_release(x_353, 1); - x_373 = x_353; -} else { - lean_dec_ref(x_353); - x_373 = lean_box(0); -} -x_374 = lean_ctor_get(x_370, 0); +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_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) +{ +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_370, 1); +x_375 = lean_ctor_get(x_374, 2); lean_inc(x_375); -x_376 = lean_ctor_get(x_370, 3); +x_376 = lean_ctor_get(x_373, 0); lean_inc(x_376); -x_377 = lean_ctor_get(x_370, 4); -lean_inc(x_377); -x_378 = lean_ctor_get(x_370, 5); +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); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - lean_ctor_release(x_370, 2); - lean_ctor_release(x_370, 3); - lean_ctor_release(x_370, 4); - lean_ctor_release(x_370, 5); - x_379 = x_370; -} else { - lean_dec_ref(x_370); - x_379 = lean_box(0); -} -x_380 = lean_ctor_get(x_371, 0); +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_371, 1); +x_381 = lean_ctor_get(x_374, 4); lean_inc(x_381); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - lean_ctor_release(x_371, 2); - x_382 = x_371; +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_371); - x_382 = lean_box(0); + lean_dec_ref(x_374); + x_383 = lean_box(0); } -if (lean_is_scalar(x_382)) { - x_383 = lean_alloc_ctor(0, 3, 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 { - x_383 = x_382; + lean_dec_ref(x_375); + x_387 = lean_box(0); } -lean_ctor_set(x_383, 0, x_380); -lean_ctor_set(x_383, 1, x_381); -lean_ctor_set(x_383, 2, x_270); -if (lean_is_scalar(x_379)) { - x_384 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_387)) { + x_388 = lean_alloc_ctor(0, 4, 0); } else { - x_384 = x_379; + x_388 = x_387; } -lean_ctor_set(x_384, 0, x_374); -lean_ctor_set(x_384, 1, x_375); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_376); -lean_ctor_set(x_384, 4, x_377); -lean_ctor_set(x_384, 5, x_378); -if (lean_is_scalar(x_373)) { - x_385 = lean_alloc_ctor(1, 2, 0); +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_385 = x_373; -} -lean_ctor_set(x_385, 0, x_372); -lean_ctor_set(x_385, 1, x_384); -return x_385; + 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; } 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_399; lean_object* x_400; -x_386 = lean_ctor_get(x_268, 0); -x_387 = lean_ctor_get(x_268, 1); -x_388 = lean_ctor_get(x_268, 2); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_268); -x_389 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_390 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_390, 0, x_386); -lean_ctor_set(x_390, 1, x_387); -lean_ctor_set(x_390, 2, x_389); -lean_ctor_set(x_263, 2, x_390); -x_391 = lean_ctor_get(x_12, 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; 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_12, 1); +x_392 = lean_ctor_get(x_391, 2); lean_inc(x_392); -x_393 = lean_ctor_get(x_12, 2); +x_393 = lean_ctor_get(x_373, 0); lean_inc(x_393); -x_394 = lean_ctor_get(x_12, 3); -lean_inc(x_394); -x_395 = lean_ctor_get(x_12, 4); +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); +} +x_395 = lean_ctor_get(x_391, 0); lean_inc(x_395); -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_396 = x_12; +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_12); - x_396 = lean_box(0); + lean_dec_ref(x_391); + x_400 = lean_box(0); } -x_397 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_397, 0, x_264); -lean_ctor_set(x_397, 1, x_20); -x_398 = lean_array_push(x_393, x_397); -if (lean_is_scalar(x_396)) { - x_399 = lean_alloc_ctor(0, 5, 0); -} else { - x_399 = x_396; -} -lean_ctor_set(x_399, 0, x_391); -lean_ctor_set(x_399, 1, x_392); -lean_ctor_set(x_399, 2, x_398); -lean_ctor_set(x_399, 3, x_394); -lean_ctor_set(x_399, 4, x_395); -x_400 = 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_266, x_399, x_263); -if (lean_obj_tag(x_400) == 0) -{ -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_400, 1); +x_401 = lean_ctor_get(x_392, 0); lean_inc(x_401); -x_402 = lean_ctor_get(x_401, 2); +x_402 = lean_ctor_get(x_392, 1); lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); +x_403 = lean_ctor_get(x_392, 3); lean_inc(x_403); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_404 = 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); + x_404 = x_392; } else { - lean_dec_ref(x_400); + lean_dec_ref(x_392); x_404 = lean_box(0); } -x_405 = lean_ctor_get(x_401, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 3); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 4); -lean_inc(x_408); -x_409 = lean_ctor_get(x_401, 5); -lean_inc(x_409); -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_410 = x_401; -} else { - lean_dec_ref(x_401); - x_410 = lean_box(0); -} -x_411 = lean_ctor_get(x_402, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 1); -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); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 3, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_411); -lean_ctor_set(x_414, 1, x_412); -lean_ctor_set(x_414, 2, x_388); -if (lean_is_scalar(x_410)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_410; -} -lean_ctor_set(x_415, 0, x_405); -lean_ctor_set(x_415, 1, x_406); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_407); -lean_ctor_set(x_415, 4, x_408); -lean_ctor_set(x_415, 5, x_409); if (lean_is_scalar(x_404)) { - x_416 = lean_alloc_ctor(0, 2, 0); + x_405 = lean_alloc_ctor(0, 4, 0); } else { - x_416 = x_404; + 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_284); +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_394)) { + x_407 = lean_alloc_ctor(1, 2, 0); +} else { + x_407 = x_394; +} +lean_ctor_set(x_407, 0, x_393); +lean_ctor_set(x_407, 1, x_406); +return x_407; +} } -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; } else { -lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; -x_417 = lean_ctor_get(x_400, 1); +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_417, 2); +x_418 = lean_ctor_get(x_12, 4); lean_inc(x_418); -x_419 = lean_ctor_get(x_400, 0); -lean_inc(x_419); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - x_420 = x_400; -} else { - lean_dec_ref(x_400); - 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); -if (lean_is_exclusive(x_418)) { - lean_ctor_release(x_418, 0); - lean_ctor_release(x_418, 1); - lean_ctor_release(x_418, 2); - x_429 = x_418; -} else { - lean_dec_ref(x_418); - x_429 = lean_box(0); -} -if (lean_is_scalar(x_429)) { - x_430 = lean_alloc_ctor(0, 3, 0); -} else { - x_430 = x_429; -} -lean_ctor_set(x_430, 0, x_427); -lean_ctor_set(x_430, 1, x_428); -lean_ctor_set(x_430, 2, x_388); -if (lean_is_scalar(x_426)) { - x_431 = lean_alloc_ctor(0, 6, 0); -} else { - x_431 = x_426; -} -lean_ctor_set(x_431, 0, x_421); -lean_ctor_set(x_431, 1, x_422); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_423); -lean_ctor_set(x_431, 4, x_424); -lean_ctor_set(x_431, 5, x_425); -if (lean_is_scalar(x_420)) { - x_432 = lean_alloc_ctor(1, 2, 0); -} else { - x_432 = x_420; -} -lean_ctor_set(x_432, 0, x_419); -lean_ctor_set(x_432, 1, x_431); -return x_432; -} -} -} -else -{ -lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; 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_433 = lean_ctor_get(x_263, 2); -x_434 = lean_ctor_get(x_263, 0); -x_435 = lean_ctor_get(x_263, 1); -x_436 = lean_ctor_get(x_263, 3); -x_437 = lean_ctor_get(x_263, 4); -x_438 = lean_ctor_get(x_263, 5); -lean_inc(x_438); -lean_inc(x_437); -lean_inc(x_436); -lean_inc(x_433); -lean_inc(x_435); -lean_inc(x_434); -lean_dec(x_263); -x_439 = lean_ctor_get(x_433, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_433, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_433, 2); -lean_inc(x_441); -if (lean_is_exclusive(x_433)) { - lean_ctor_release(x_433, 0); - lean_ctor_release(x_433, 1); - lean_ctor_release(x_433, 2); - x_442 = x_433; -} else { - lean_dec_ref(x_433); - x_442 = lean_box(0); -} -x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_442)) { - x_444 = lean_alloc_ctor(0, 3, 0); -} else { - x_444 = x_442; -} -lean_ctor_set(x_444, 0, x_439); -lean_ctor_set(x_444, 1, x_440); -lean_ctor_set(x_444, 2, x_443); -x_445 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_445, 0, x_434); -lean_ctor_set(x_445, 1, x_435); -lean_ctor_set(x_445, 2, x_444); -lean_ctor_set(x_445, 3, x_436); -lean_ctor_set(x_445, 4, x_437); -lean_ctor_set(x_445, 5, x_438); -x_446 = lean_ctor_get(x_12, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_12, 1); -lean_inc(x_447); -x_448 = lean_ctor_get(x_12, 2); -lean_inc(x_448); -x_449 = lean_ctor_get(x_12, 3); -lean_inc(x_449); -x_450 = lean_ctor_get(x_12, 4); -lean_inc(x_450); 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_451 = x_12; + x_419 = x_12; } else { lean_dec_ref(x_12); - x_451 = lean_box(0); + x_419 = lean_box(0); } -x_452 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_452, 0, x_264); -lean_ctor_set(x_452, 1, x_20); -x_453 = lean_array_push(x_448, x_452); -if (lean_is_scalar(x_451)) { - x_454 = lean_alloc_ctor(0, 5, 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); } else { - x_454 = x_451; + x_422 = x_419; } -lean_ctor_set(x_454, 0, x_446); -lean_ctor_set(x_454, 1, x_447); -lean_ctor_set(x_454, 2, x_453); -lean_ctor_set(x_454, 3, x_449); -lean_ctor_set(x_454, 4, x_450); -x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_266, x_454, x_445); -if (lean_obj_tag(x_455) == 0) +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_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_456 = lean_ctor_get(x_455, 1); -lean_inc(x_456); -x_457 = lean_ctor_get(x_456, 2); -lean_inc(x_457); -x_458 = lean_ctor_get(x_455, 0); -lean_inc(x_458); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_459 = x_455; +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_455); - x_459 = lean_box(0); + lean_dec_ref(x_423); + x_427 = lean_box(0); } -x_460 = lean_ctor_get(x_456, 0); -lean_inc(x_460); -x_461 = lean_ctor_get(x_456, 1); -lean_inc(x_461); -x_462 = lean_ctor_get(x_456, 3); -lean_inc(x_462); -x_463 = lean_ctor_get(x_456, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_441); + x_450 = 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; +} else { + lean_dec_ref(x_442); + x_454 = lean_box(0); +} +if (lean_is_scalar(x_454)) { + x_455 = lean_alloc_ctor(0, 4, 0); +} else { + x_455 = x_454; +} +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); +} else { + x_456 = x_450; +} +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); +} else { + x_457 = x_444; +} +lean_ctor_set(x_457, 0, x_443); +lean_ctor_set(x_457, 1, x_456); +return x_457; +} +} +} +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); -x_464 = lean_ctor_get(x_456, 5); +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); -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); - lean_ctor_release(x_456, 4); - lean_ctor_release(x_456, 5); - x_465 = x_456; -} else { - lean_dec_ref(x_456); - x_465 = lean_box(0); -} -x_466 = lean_ctor_get(x_457, 0); +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_457, 1); +x_467 = lean_ctor_get(x_458, 3); lean_inc(x_467); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - lean_ctor_release(x_457, 2); - x_468 = x_457; +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; } else { - lean_dec_ref(x_457); + lean_dec_ref(x_458); x_468 = lean_box(0); } +x_469 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_468)) { - x_469 = lean_alloc_ctor(0, 3, 0); + x_470 = lean_alloc_ctor(0, 4, 0); } else { - x_469 = x_468; + x_470 = x_468; } -lean_ctor_set(x_469, 0, x_466); -lean_ctor_set(x_469, 1, x_467); -lean_ctor_set(x_469, 2, x_441); -if (lean_is_scalar(x_465)) { - x_470 = lean_alloc_ctor(0, 6, 0); -} else { - x_470 = x_465; -} -lean_ctor_set(x_470, 0, x_460); -lean_ctor_set(x_470, 1, x_461); +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_462); -lean_ctor_set(x_470, 4, x_463); -lean_ctor_set(x_470, 5, x_464); -if (lean_is_scalar(x_459)) { - x_471 = lean_alloc_ctor(0, 2, 0); -} else { - x_471 = x_459; -} -lean_ctor_set(x_471, 0, x_458); -lean_ctor_set(x_471, 1, x_470); -return x_471; -} -else -{ -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; -x_472 = lean_ctor_get(x_455, 1); +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_472, 2); +x_473 = lean_ctor_get(x_12, 1); lean_inc(x_473); -x_474 = lean_ctor_get(x_455, 0); +x_474 = lean_ctor_get(x_12, 2); lean_inc(x_474); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - x_475 = x_455; -} else { - lean_dec_ref(x_455); - x_475 = lean_box(0); -} -x_476 = lean_ctor_get(x_472, 0); +x_475 = lean_ctor_get(x_12, 3); +lean_inc(x_475); +x_476 = lean_ctor_get(x_12, 4); 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; +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; } else { - lean_dec_ref(x_472); - x_481 = lean_box(0); + lean_dec_ref(x_12); + x_477 = lean_box(0); } -x_482 = lean_ctor_get(x_473, 0); +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); +} else { + x_480 = x_477; +} +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_473, 1); +x_483 = lean_ctor_get(x_482, 2); lean_inc(x_483); -if (lean_is_exclusive(x_473)) { - lean_ctor_release(x_473, 0); - lean_ctor_release(x_473, 1); - lean_ctor_release(x_473, 2); - x_484 = x_473; +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; } else { - lean_dec_ref(x_473); - x_484 = lean_box(0); + lean_dec_ref(x_481); + x_485 = lean_box(0); } -if (lean_is_scalar(x_484)) { - x_485 = lean_alloc_ctor(0, 3, 0); +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 { - x_485 = x_484; + lean_dec_ref(x_482); + x_491 = lean_box(0); } -lean_ctor_set(x_485, 0, x_482); -lean_ctor_set(x_485, 1, x_483); -lean_ctor_set(x_485, 2, x_441); -if (lean_is_scalar(x_481)) { - x_486 = lean_alloc_ctor(0, 6, 0); +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 { - x_486 = x_481; + lean_dec_ref(x_483); + x_495 = lean_box(0); } -lean_ctor_set(x_486, 0, x_476); -lean_ctor_set(x_486, 1, x_477); -lean_ctor_set(x_486, 2, x_485); -lean_ctor_set(x_486, 3, x_478); -lean_ctor_set(x_486, 4, x_479); -lean_ctor_set(x_486, 5, x_480); -if (lean_is_scalar(x_475)) { - x_487 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_495)) { + x_496 = lean_alloc_ctor(0, 4, 0); } else { - x_487 = x_475; + x_496 = x_495; } -lean_ctor_set(x_487, 0, x_474); -lean_ctor_set(x_487, 1, x_486); -return x_487; +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_488; +uint8_t x_516; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -36512,23 +37884,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_488 = !lean_is_exclusive(x_257); -if (x_488 == 0) +x_516 = !lean_is_exclusive(x_271); +if (x_516 == 0) { -return x_257; +return x_271; } else { -lean_object* x_489; lean_object* x_490; lean_object* x_491; -x_489 = lean_ctor_get(x_257, 0); -x_490 = lean_ctor_get(x_257, 1); -lean_inc(x_490); -lean_inc(x_489); -lean_dec(x_257); -x_491 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_491, 0, x_489); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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; } } } @@ -36536,7 +37908,7 @@ return x_491; } else { -uint8_t x_492; +uint8_t x_520; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -36547,29 +37919,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_492 = !lean_is_exclusive(x_25); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_25); +if (x_520 == 0) { return x_25; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_25, 0); -x_494 = lean_ctor_get(x_25, 1); -lean_inc(x_494); -lean_inc(x_493); +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_dec(x_25); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -36579,23 +37951,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_21); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_21); +if (x_524 == 0) { return x_21; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_21, 0); -x_498 = lean_ctor_get(x_21, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_21); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } @@ -36733,82 +38105,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -36816,1899 +38195,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = 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_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = 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_216, x_207); -if (lean_obj_tag(x_217) == 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__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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -38716,58 +40194,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -39549,82 +41027,89 @@ return x_38; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; +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_49 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_ctor_set(x_49, 2, x_32); -lean_ctor_set(x_39, 2, x_49); +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; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_39, 0); -x_51 = lean_ctor_get(x_39, 1); -x_52 = lean_ctor_get(x_39, 3); -x_53 = lean_ctor_get(x_39, 4); -x_54 = lean_ctor_get(x_39, 5); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +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_inc(x_52); lean_inc(x_51); -lean_inc(x_50); lean_dec(x_39); -x_55 = lean_ctor_get(x_40, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_40, 1); +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); - x_57 = x_40; + lean_ctor_release(x_40, 3); + x_59 = x_40; } else { lean_dec_ref(x_40); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 4, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_55); -lean_ctor_set(x_58, 1, x_56); -lean_ctor_set(x_58, 2, x_32); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_50); -lean_ctor_set(x_59, 1, x_51); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_52); -lean_ctor_set(x_59, 4, x_53); -lean_ctor_set(x_59, 5, x_54); -lean_ctor_set(x_38, 1, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -lean_dec(x_38); -x_61 = lean_ctor_get(x_39, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_39, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_39, 3); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_39, 4); +x_64 = lean_ctor_get(x_39, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_39, 5); +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); @@ -39632,1899 +41117,1998 @@ if (lean_is_exclusive(x_39)) { lean_ctor_release(x_39, 3); lean_ctor_release(x_39, 4); lean_ctor_release(x_39, 5); - x_66 = x_39; + x_68 = x_39; } else { lean_dec_ref(x_39); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_40, 1); -lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +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); - x_69 = x_40; + lean_ctor_release(x_40, 3); + x_72 = x_40; } else { lean_dec_ref(x_40); - x_69 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_69; + x_73 = x_72; } -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_32); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(0, 6, 0); +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_71 = x_66; + x_74 = x_68; } -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); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_60); -lean_ctor_set(x_72, 1, x_71); -return x_72; +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; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_38, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_73, 2); -lean_inc(x_74); -x_75 = !lean_is_exclusive(x_38); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; +lean_object* x_76; lean_object* x_77; uint8_t x_78; x_76 = lean_ctor_get(x_38, 1); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); -if (x_77 == 0) +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = !lean_is_exclusive(x_38); +if (x_78 == 0) { -lean_object* x_78; uint8_t x_79; -x_78 = lean_ctor_get(x_73, 2); -lean_dec(x_78); -x_79 = !lean_is_exclusive(x_74); -if (x_79 == 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_80; -x_80 = lean_ctor_get(x_74, 2); -lean_dec(x_80); -lean_ctor_set(x_74, 2, x_32); +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_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_74, 0); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_74); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -lean_ctor_set(x_83, 2, x_32); -lean_ctor_set(x_73, 2, x_83); -return x_38; -} -} -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; -x_84 = lean_ctor_get(x_73, 0); -x_85 = lean_ctor_get(x_73, 1); -x_86 = lean_ctor_get(x_73, 3); -x_87 = lean_ctor_get(x_73, 4); -x_88 = lean_ctor_get(x_73, 5); -lean_inc(x_88); -lean_inc(x_87); +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_73); -x_89 = lean_ctor_get(x_74, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_74, 1); -lean_inc(x_90); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_91 = x_74; -} else { - lean_dec_ref(x_74); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 3, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_89); -lean_ctor_set(x_92, 1, x_90); -lean_ctor_set(x_92, 2, x_32); -x_93 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_85); -lean_ctor_set(x_93, 2, x_92); -lean_ctor_set(x_93, 3, x_86); -lean_ctor_set(x_93, 4, x_87); -lean_ctor_set(x_93, 5, x_88); -lean_ctor_set(x_38, 1, x_93); +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_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_94 = lean_ctor_get(x_38, 0); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); -lean_dec(x_38); -x_95 = lean_ctor_get(x_73, 0); +x_95 = lean_ctor_get(x_77, 3); lean_inc(x_95); -x_96 = lean_ctor_get(x_73, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_73, 3); -lean_inc(x_97); -x_98 = lean_ctor_get(x_73, 4); -lean_inc(x_98); -x_99 = lean_ctor_get(x_73, 5); +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; +} else { + lean_dec_ref(x_77); + x_96 = lean_box(0); +} +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(0, 4, 0); +} else { + x_97 = x_96; +} +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); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - lean_ctor_release(x_73, 4); - lean_ctor_release(x_73, 5); - x_100 = x_73; -} else { - lean_dec_ref(x_73); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_74, 0); +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_74, 1); +x_102 = lean_ctor_get(x_76, 3); lean_inc(x_102); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - lean_ctor_release(x_74, 2); - x_103 = x_74; +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; } else { - lean_dec_ref(x_74); - x_103 = lean_box(0); + lean_dec_ref(x_76); + x_105 = lean_box(0); } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(0, 3, 0); +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 { - x_104 = x_103; + lean_dec_ref(x_77); + x_109 = lean_box(0); } -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -lean_ctor_set(x_104, 2, x_32); -if (lean_is_scalar(x_100)) { - x_105 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 4, 0); } else { - x_105 = x_100; + x_110 = x_109; } -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); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_94); -lean_ctor_set(x_106, 1, x_105); -return x_106; +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_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_26); -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_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_114, x_25); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +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); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_119 = x_115; -} else { - lean_dec_ref(x_115); - 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_116); +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_Init_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_116, 4); +x_123 = lean_ctor_get(x_122, 2); lean_inc(x_123); -x_124 = lean_ctor_get(x_116, 5); +x_124 = lean_ctor_get(x_121, 0); 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; +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; } else { - lean_dec_ref(x_116); + lean_dec_ref(x_121); x_125 = lean_box(0); } -x_126 = lean_ctor_get(x_117, 0); +x_126 = lean_ctor_get(x_122, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 1); +x_127 = lean_ctor_get(x_122, 1); lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; } else { - lean_dec_ref(x_117); - x_128 = lean_box(0); + lean_dec_ref(x_122); + x_131 = lean_box(0); } -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_32); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); -if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_119; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_132 = lean_ctor_get(x_115, 1); +x_132 = lean_ctor_get(x_123, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); +x_133 = lean_ctor_get(x_123, 1); lean_inc(x_133); -x_134 = lean_ctor_get(x_115, 0); +x_134 = lean_ctor_get(x_123, 3); lean_inc(x_134); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_135 = x_115; +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; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_123); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_132, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_132, 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; -} else { - lean_dec_ref(x_132); - x_141 = 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); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 3, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_145, 2, x_32); -if (lean_is_scalar(x_141)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_141; -} -lean_ctor_set(x_146, 0, x_136); -lean_ctor_set(x_146, 1, x_137); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_138); -lean_ctor_set(x_146, 4, x_139); -lean_ctor_set(x_146, 5, x_140); if (lean_is_scalar(x_135)) { - x_147 = lean_alloc_ctor(1, 2, 0); + x_136 = lean_alloc_ctor(0, 4, 0); } else { - x_147 = x_135; + x_136 = x_135; } -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; +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); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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_inc(x_139); +x_140 = lean_ctor_get(x_139, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 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); +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; +} else { + lean_dec_ref(x_139); + x_148 = 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; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 4, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_149); +lean_ctor_set(x_153, 1, x_150); +lean_ctor_set(x_153, 2, x_32); +lean_ctor_set(x_153, 3, x_151); +if (lean_is_scalar(x_148)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_148; +} +lean_ctor_set(x_154, 0, x_143); +lean_ctor_set(x_154, 1, x_144); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_145); +lean_ctor_set(x_154, 4, x_146); +lean_ctor_set(x_154, 5, x_147); +if (lean_is_scalar(x_142)) { + x_155 = lean_alloc_ctor(1, 2, 0); +} else { + x_155 = x_142; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_148 = lean_ctor_get(x_30, 0); -x_149 = lean_ctor_get(x_30, 1); -x_150 = lean_ctor_get(x_30, 2); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_dec(x_30); -x_151 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_152 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_25, 2, x_152); -x_153 = lean_ctor_get(x_7, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 1); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 2); -lean_inc(x_155); -x_156 = lean_ctor_get(x_7, 3); -lean_inc(x_156); -x_157 = lean_ctor_get(x_7, 4); +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); 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_158 = x_7; + x_167 = x_7; } else { lean_dec_ref(x_7); - x_158 = lean_box(0); + x_167 = lean_box(0); } -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_26); -lean_ctor_set(x_159, 1, x_14); -x_160 = lean_array_push(x_155, x_159); -if (lean_is_scalar(x_158)) { - x_161 = lean_alloc_ctor(0, 5, 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); } else { - x_161 = x_158; + x_170 = x_167; } -lean_ctor_set(x_161, 0, x_153); -lean_ctor_set(x_161, 1, x_154); -lean_ctor_set(x_161, 2, x_160); -lean_ctor_set(x_161, 3, x_156); -lean_ctor_set(x_161, 4, x_157); -x_162 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_161, x_25); -if (lean_obj_tag(x_162) == 0) +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_Init_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_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_162, 1); -lean_inc(x_163); -x_164 = lean_ctor_get(x_163, 2); -lean_inc(x_164); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_166 = x_162; -} else { - lean_dec_ref(x_162); - x_166 = lean_box(0); -} -x_167 = lean_ctor_get(x_163, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_163, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; -} else { - lean_dec_ref(x_163); - x_172 = lean_box(0); -} -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_171, 0); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); + lean_dec_ref(x_171); x_175 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 0); -} else { - x_176 = x_175; -} -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_150); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 0); -} else { - x_177 = x_172; -} -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(0, 2, 0); -} else { - x_178 = x_166; -} -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_162, 1); +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_179, 2); +x_180 = lean_ctor_get(x_172, 5); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 0); -lean_inc(x_181); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - x_182 = x_162; +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_162); - x_182 = lean_box(0); + lean_dec_ref(x_172); + x_181 = lean_box(0); } -x_183 = lean_ctor_get(x_179, 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_179, 1); +x_184 = lean_ctor_get(x_173, 3); 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; +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_179); - x_188 = lean_box(0); + lean_dec_ref(x_173); + x_185 = lean_box(0); } -x_189 = lean_ctor_get(x_180, 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; +} +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_inc(x_189); -x_190 = lean_ctor_get(x_180, 1); +x_190 = lean_ctor_get(x_189, 2); lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - x_191 = x_180; +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; } else { - lean_dec_ref(x_180); - x_191 = lean_box(0); + lean_dec_ref(x_171); + x_192 = lean_box(0); } -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_195); +x_196 = lean_ctor_get(x_189, 4); +lean_inc(x_196); +x_197 = lean_ctor_get(x_189, 5); +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 { - x_192 = x_191; + lean_dec_ref(x_189); + x_198 = lean_box(0); } -lean_ctor_set(x_192, 0, x_189); -lean_ctor_set(x_192, 1, x_190); -lean_ctor_set(x_192, 2, x_150); -if (lean_is_scalar(x_188)) { - x_193 = lean_alloc_ctor(0, 6, 0); +x_199 = lean_ctor_get(x_190, 0); +lean_inc(x_199); +x_200 = lean_ctor_get(x_190, 1); +lean_inc(x_200); +x_201 = lean_ctor_get(x_190, 3); +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; } else { - x_193 = x_188; + lean_dec_ref(x_190); + x_202 = lean_box(0); } -lean_ctor_set(x_193, 0, x_183); -lean_ctor_set(x_193, 1, x_184); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_185); -lean_ctor_set(x_193, 4, x_186); -lean_ctor_set(x_193, 5, x_187); -if (lean_is_scalar(x_182)) { - x_194 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_202)) { + x_203 = lean_alloc_ctor(0, 4, 0); } else { - x_194 = x_182; + x_203 = x_202; } -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +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); +} else { + x_204 = x_198; +} +lean_ctor_set(x_204, 0, x_193); +lean_ctor_set(x_204, 1, x_194); +lean_ctor_set(x_204, 2, x_203); +lean_ctor_set(x_204, 3, x_195); +lean_ctor_set(x_204, 4, x_196); +lean_ctor_set(x_204, 5, x_197); +if (lean_is_scalar(x_192)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_192; +} +lean_ctor_set(x_205, 0, x_191); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } 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; 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_195 = lean_ctor_get(x_25, 2); -x_196 = lean_ctor_get(x_25, 0); -x_197 = lean_ctor_get(x_25, 1); -x_198 = lean_ctor_get(x_25, 3); -x_199 = lean_ctor_get(x_25, 4); -x_200 = lean_ctor_get(x_25, 5); -lean_inc(x_200); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_195); -lean_inc(x_197); -lean_inc(x_196); -lean_dec(x_25); -x_201 = lean_ctor_get(x_195, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_195, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_195, 2); -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); - x_204 = x_195; -} else { - lean_dec_ref(x_195); - x_204 = lean_box(0); -} -x_205 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_204)) { - x_206 = lean_alloc_ctor(0, 3, 0); -} else { - x_206 = x_204; -} -lean_ctor_set(x_206, 0, x_201); -lean_ctor_set(x_206, 1, x_202); -lean_ctor_set(x_206, 2, x_205); -x_207 = 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); -x_208 = lean_ctor_get(x_7, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_7, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_7, 2); -lean_inc(x_210); -x_211 = lean_ctor_get(x_7, 3); +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); -x_212 = lean_ctor_get(x_7, 4); +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_213 = x_7; + x_225 = x_7; } else { lean_dec_ref(x_7); - x_213 = lean_box(0); + x_225 = lean_box(0); } -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_26); -lean_ctor_set(x_214, 1, x_14); -x_215 = lean_array_push(x_210, x_214); -if (lean_is_scalar(x_213)) { - x_216 = lean_alloc_ctor(0, 5, 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_216 = x_213; + x_228 = x_225; } -lean_ctor_set(x_216, 0, x_208); -lean_ctor_set(x_216, 1, x_209); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_211); -lean_ctor_set(x_216, 4, x_212); -x_217 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_28, x_216, x_207); -if (lean_obj_tag(x_217) == 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___private_Init_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_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_218 = lean_ctor_get(x_217, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_218, 2); -lean_inc(x_219); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_221 = x_217; +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_217); - x_221 = lean_box(0); + lean_dec_ref(x_229); + x_233 = lean_box(0); } -x_222 = lean_ctor_get(x_218, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_218, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_218, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_218, 4); -lean_inc(x_225); -x_226 = lean_ctor_get(x_218, 5); -lean_inc(x_226); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - lean_ctor_release(x_218, 4); - lean_ctor_release(x_218, 5); - x_227 = x_218; +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_218); - x_227 = lean_box(0); + lean_dec_ref(x_230); + x_239 = lean_box(0); } -x_228 = lean_ctor_get(x_219, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_219, 1); -lean_inc(x_229); -if (lean_is_exclusive(x_219)) { - lean_ctor_release(x_219, 0); - lean_ctor_release(x_219, 1); - lean_ctor_release(x_219, 2); - x_230 = x_219; +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_219); - x_230 = lean_box(0); + lean_dec_ref(x_231); + x_243 = lean_box(0); } -if (lean_is_scalar(x_230)) { - x_231 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_243)) { + x_244 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_230; + x_244 = x_243; } -lean_ctor_set(x_231, 0, x_228); -lean_ctor_set(x_231, 1, x_229); -lean_ctor_set(x_231, 2, x_203); -if (lean_is_scalar(x_227)) { - x_232 = lean_alloc_ctor(0, 6, 0); +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_232 = x_227; + x_245 = x_239; } -lean_ctor_set(x_232, 0, x_222); -lean_ctor_set(x_232, 1, x_223); -lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_224); -lean_ctor_set(x_232, 4, x_225); -lean_ctor_set(x_232, 5, x_226); -if (lean_is_scalar(x_221)) { - x_233 = lean_alloc_ctor(0, 2, 0); +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_233 = x_221; + x_246 = x_233; } -lean_ctor_set(x_233, 0, x_220); -lean_ctor_set(x_233, 1, x_232); -return 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_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_234 = lean_ctor_get(x_217, 1); -lean_inc(x_234); -x_235 = lean_ctor_get(x_234, 2); -lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 0); -lean_inc(x_236); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - x_237 = x_217; +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_217); - x_237 = lean_box(0); + lean_dec_ref(x_229); + x_250 = 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; +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_234); - x_243 = lean_box(0); + lean_dec_ref(x_247); + x_256 = 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); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - lean_ctor_release(x_235, 2); - x_246 = x_235; +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_235); - x_246 = lean_box(0); + lean_dec_ref(x_248); + x_260 = lean_box(0); } -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 4, 0); } else { - x_247 = x_246; + x_261 = x_260; } -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -lean_ctor_set(x_247, 2, x_203); -if (lean_is_scalar(x_243)) { - x_248 = lean_alloc_ctor(0, 6, 0); +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_248 = x_243; + x_262 = x_256; } -lean_ctor_set(x_248, 0, x_238); -lean_ctor_set(x_248, 1, x_239); -lean_ctor_set(x_248, 2, x_247); -lean_ctor_set(x_248, 3, x_240); -lean_ctor_set(x_248, 4, x_241); -lean_ctor_set(x_248, 5, x_242); -if (lean_is_scalar(x_237)) { - x_249 = lean_alloc_ctor(1, 2, 0); +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_249 = x_237; + x_263 = x_250; } -lean_ctor_set(x_249, 0, x_236); -lean_ctor_set(x_249, 1, x_248); -return x_249; +lean_ctor_set(x_263, 0, x_249); +lean_ctor_set(x_263, 1, x_262); +return x_263; } } } default: { -lean_object* x_250; lean_object* x_251; -x_250 = lean_ctor_get(x_19, 1); -lean_inc(x_250); +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_19, 1); +lean_inc(x_264); lean_dec(x_19); lean_inc(x_7); -x_251 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_250); -if (lean_obj_tag(x_251) == 0) +x_265 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_264); +if (lean_obj_tag(x_265) == 0) { -lean_object* x_252; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -if (lean_obj_tag(x_252) == 0) +lean_object* x_266; +x_266 = lean_ctor_get(x_265, 0); +lean_inc(x_266); +if (lean_obj_tag(x_266) == 0) { -lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_dec(x_14); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -x_254 = lean_unsigned_to_nat(1u); -x_255 = lean_nat_add(x_6, x_254); +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); lean_dec(x_6); -x_6 = x_255; -x_8 = x_253; +x_6 = x_269; +x_8 = x_267; goto _start; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; uint8_t x_261; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_ctor_get(x_252, 0); -lean_inc(x_258); -lean_dec(x_252); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_6, x_259); -lean_dec(x_6); -x_261 = !lean_is_exclusive(x_257); -if (x_261 == 0) -{ -lean_object* x_262; uint8_t x_263; -x_262 = lean_ctor_get(x_257, 2); -x_263 = !lean_is_exclusive(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_264 = lean_ctor_get(x_262, 2); -x_265 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_262, 2, x_265); -x_266 = !lean_is_exclusive(x_7); -if (x_266 == 0) -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_267 = lean_ctor_get(x_7, 2); -x_268 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_268, 0, x_258); -lean_ctor_set(x_268, 1, x_14); -x_269 = lean_array_push(x_267, x_268); -lean_ctor_set(x_7, 2, x_269); -x_270 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_7, x_257); -if (lean_obj_tag(x_270) == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_270, 1); +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); -x_272 = lean_ctor_get(x_271, 2); +lean_dec(x_265); +x_272 = lean_ctor_get(x_266, 0); lean_inc(x_272); -x_273 = !lean_is_exclusive(x_270); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_270, 1); -lean_dec(x_274); +lean_dec(x_266); +x_273 = lean_unsigned_to_nat(1u); +x_274 = lean_nat_add(x_6, x_273); +lean_dec(x_6); x_275 = !lean_is_exclusive(x_271); if (x_275 == 0) { lean_object* x_276; uint8_t x_277; x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_272); +x_277 = !lean_is_exclusive(x_276); if (x_277 == 0) { -lean_object* x_278; -x_278 = lean_ctor_get(x_272, 2); -lean_dec(x_278); -lean_ctor_set(x_272, 2, x_264); -return x_270; -} -else +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_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -lean_inc(x_280); -lean_inc(x_279); -lean_dec(x_272); -x_281 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_281, 0, x_279); -lean_ctor_set(x_281, 1, x_280); -lean_ctor_set(x_281, 2, x_264); -lean_ctor_set(x_271, 2, x_281); -return x_270; -} -} -else +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_Init_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_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_282 = lean_ctor_get(x_271, 0); -x_283 = lean_ctor_get(x_271, 1); -x_284 = lean_ctor_get(x_271, 3); -x_285 = lean_ctor_get(x_271, 4); -x_286 = lean_ctor_get(x_271, 5); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_284, 1); lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_dec(x_271); -x_287 = lean_ctor_get(x_272, 0); -lean_inc(x_287); -x_288 = lean_ctor_get(x_272, 1); -lean_inc(x_288); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_289 = x_272; -} else { - lean_dec_ref(x_272); - x_289 = lean_box(0); -} -if (lean_is_scalar(x_289)) { - x_290 = lean_alloc_ctor(0, 3, 0); -} else { - x_290 = x_289; -} -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_264); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_282); -lean_ctor_set(x_291, 1, x_283); -lean_ctor_set(x_291, 2, x_290); -lean_ctor_set(x_291, 3, x_284); -lean_ctor_set(x_291, 4, x_285); -lean_ctor_set(x_291, 5, x_286); -lean_ctor_set(x_270, 1, x_291); -return x_270; -} +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_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_270, 0); -lean_inc(x_292); -lean_dec(x_270); -x_293 = lean_ctor_get(x_271, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_271, 3); +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); -x_296 = lean_ctor_get(x_271, 4); -lean_inc(x_296); -x_297 = lean_ctor_get(x_271, 5); -lean_inc(x_297); -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_298 = x_271; -} else { - lean_dec_ref(x_271); - x_298 = lean_box(0); +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; } -x_299 = lean_ctor_get(x_272, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_272, 1); +} +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); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - x_301 = x_272; +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_inc(x_303); +x_304 = lean_ctor_get(x_286, 3); +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_272); - x_301 = lean_box(0); + lean_dec_ref(x_286); + x_305 = lean_box(0); } -if (lean_is_scalar(x_301)) { - x_302 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 4, 0); } else { - x_302 = x_301; + x_306 = x_305; } -lean_ctor_set(x_302, 0, x_299); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_264); -if (lean_is_scalar(x_298)) { - x_303 = lean_alloc_ctor(0, 6, 0); -} else { - x_303 = x_298; -} -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); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_292); -lean_ctor_set(x_304, 1, x_303); -return x_304; +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_305; lean_object* x_306; uint8_t x_307; -x_305 = lean_ctor_get(x_270, 1); -lean_inc(x_305); -x_306 = lean_ctor_get(x_305, 2); -lean_inc(x_306); -x_307 = !lean_is_exclusive(x_270); -if (x_307 == 0) -{ -lean_object* x_308; uint8_t x_309; -x_308 = lean_ctor_get(x_270, 1); -lean_dec(x_308); -x_309 = !lean_is_exclusive(x_305); -if (x_309 == 0) -{ -lean_object* x_310; uint8_t x_311; -x_310 = lean_ctor_get(x_305, 2); -lean_dec(x_310); -x_311 = !lean_is_exclusive(x_306); -if (x_311 == 0) -{ -lean_object* x_312; -x_312 = lean_ctor_get(x_306, 2); -lean_dec(x_312); -lean_ctor_set(x_306, 2, x_264); -return x_270; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_306, 0); -x_314 = lean_ctor_get(x_306, 1); -lean_inc(x_314); +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_inc(x_313); -lean_dec(x_306); -x_315 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_315, 0, x_313); -lean_ctor_set(x_315, 1, x_314); -lean_ctor_set(x_315, 2, x_264); -lean_ctor_set(x_305, 2, x_315); -return x_270; +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); } -} -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; -x_316 = lean_ctor_get(x_305, 0); -x_317 = lean_ctor_get(x_305, 1); -x_318 = lean_ctor_get(x_305, 3); -x_319 = lean_ctor_get(x_305, 4); -x_320 = lean_ctor_get(x_305, 5); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +x_315 = lean_ctor_get(x_286, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_286, 1); lean_inc(x_316); -lean_dec(x_305); -x_321 = lean_ctor_get(x_306, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_306, 1); +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); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_323 = x_306; -} else { - lean_dec_ref(x_306); - x_323 = lean_box(0); -} -if (lean_is_scalar(x_323)) { - x_324 = lean_alloc_ctor(0, 3, 0); -} else { - x_324 = x_323; -} -lean_ctor_set(x_324, 0, x_321); -lean_ctor_set(x_324, 1, x_322); -lean_ctor_set(x_324, 2, x_264); -x_325 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_325, 0, x_316); -lean_ctor_set(x_325, 1, x_317); -lean_ctor_set(x_325, 2, x_324); -lean_ctor_set(x_325, 3, x_318); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_270, 1, x_325); -return x_270; -} +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_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_326 = lean_ctor_get(x_270, 0); -lean_inc(x_326); -lean_dec(x_270); -x_327 = lean_ctor_get(x_305, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_305, 1); -lean_inc(x_328); -x_329 = lean_ctor_get(x_305, 3); -lean_inc(x_329); -x_330 = lean_ctor_get(x_305, 4); -lean_inc(x_330); -x_331 = lean_ctor_get(x_305, 5); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - lean_ctor_release(x_305, 3); - lean_ctor_release(x_305, 4); - lean_ctor_release(x_305, 5); - x_332 = x_305; -} else { - lean_dec_ref(x_305); - x_332 = lean_box(0); -} -x_333 = lean_ctor_get(x_306, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_306, 1); -lean_inc(x_334); -if (lean_is_exclusive(x_306)) { - lean_ctor_release(x_306, 0); - lean_ctor_release(x_306, 1); - lean_ctor_release(x_306, 2); - x_335 = x_306; -} else { - lean_dec_ref(x_306); - x_335 = lean_box(0); -} -if (lean_is_scalar(x_335)) { - x_336 = lean_alloc_ctor(0, 3, 0); -} else { - x_336 = x_335; -} -lean_ctor_set(x_336, 0, x_333); -lean_ctor_set(x_336, 1, x_334); -lean_ctor_set(x_336, 2, x_264); -if (lean_is_scalar(x_332)) { - x_337 = lean_alloc_ctor(0, 6, 0); -} else { - x_337 = x_332; -} -lean_ctor_set(x_337, 0, x_327); -lean_ctor_set(x_337, 1, x_328); -lean_ctor_set(x_337, 2, x_336); -lean_ctor_set(x_337, 3, x_329); -lean_ctor_set(x_337, 4, x_330); -lean_ctor_set(x_337, 5, x_331); -x_338 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_338, 0, x_326); -lean_ctor_set(x_338, 1, x_337); -return x_338; -} +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_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; -x_339 = lean_ctor_get(x_7, 0); -x_340 = lean_ctor_get(x_7, 1); -x_341 = lean_ctor_get(x_7, 2); -x_342 = lean_ctor_get(x_7, 3); -x_343 = lean_ctor_get(x_7, 4); -lean_inc(x_343); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); +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); -lean_dec(x_7); -x_344 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_344, 0, x_258); -lean_ctor_set(x_344, 1, x_14); -x_345 = lean_array_push(x_341, x_344); -x_346 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_346, 0, x_339); -lean_ctor_set(x_346, 1, x_340); -lean_ctor_set(x_346, 2, x_345); -lean_ctor_set(x_346, 3, x_342); -lean_ctor_set(x_346, 4, x_343); -x_347 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_346, x_257); -if (lean_obj_tag(x_347) == 0) -{ -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_348 = lean_ctor_get(x_347, 1); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_347, 0); -lean_inc(x_350); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_351 = x_347; +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_347); + 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_348, 0); +x_352 = lean_ctor_get(x_323, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_348, 1); +x_353 = lean_ctor_get(x_323, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_348, 3); +x_354 = lean_ctor_get(x_323, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_348, 4); -lean_inc(x_355); -x_356 = lean_ctor_get(x_348, 5); -lean_inc(x_356); -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_357 = x_348; +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_348); - x_357 = lean_box(0); + lean_dec_ref(x_323); + x_355 = lean_box(0); } -x_358 = lean_ctor_get(x_349, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_349, 1); -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); - x_360 = x_349; +if (lean_is_scalar(x_355)) { + x_356 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_349); - x_360 = lean_box(0); + x_356 = x_355; } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 3, 0); -} else { - x_361 = x_360; -} -lean_ctor_set(x_361, 0, x_358); -lean_ctor_set(x_361, 1, x_359); -lean_ctor_set(x_361, 2, x_264); -if (lean_is_scalar(x_357)) { - x_362 = lean_alloc_ctor(0, 6, 0); -} else { - x_362 = x_357; -} -lean_ctor_set(x_362, 0, x_352); -lean_ctor_set(x_362, 1, x_353); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_354); -lean_ctor_set(x_362, 4, x_355); -lean_ctor_set(x_362, 5, x_356); +lean_ctor_set(x_356, 0, x_352); +lean_ctor_set(x_356, 1, x_353); +lean_ctor_set(x_356, 2, x_278); +lean_ctor_set(x_356, 3, x_354); if (lean_is_scalar(x_351)) { - x_363 = lean_alloc_ctor(0, 2, 0); + x_357 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_351; + 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; +} } -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; 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_364 = lean_ctor_get(x_347, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_364, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_347, 0); -lean_inc(x_366); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - x_367 = x_347; -} else { - lean_dec_ref(x_347); - x_367 = lean_box(0); -} -x_368 = lean_ctor_get(x_364, 0); +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_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_Init_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) +{ +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_364, 1); +x_369 = lean_ctor_get(x_368, 2); lean_inc(x_369); -x_370 = lean_ctor_get(x_364, 3); +x_370 = lean_ctor_get(x_367, 0); lean_inc(x_370); -x_371 = lean_ctor_get(x_364, 4); -lean_inc(x_371); -x_372 = lean_ctor_get(x_364, 5); +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); -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); +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_365, 1); +x_375 = lean_ctor_get(x_368, 4); lean_inc(x_375); -if (lean_is_exclusive(x_365)) { - lean_ctor_release(x_365, 0); - lean_ctor_release(x_365, 1); - lean_ctor_release(x_365, 2); - x_376 = x_365; +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_365); - x_376 = lean_box(0); + lean_dec_ref(x_368); + x_377 = lean_box(0); } -if (lean_is_scalar(x_376)) { - x_377 = lean_alloc_ctor(0, 3, 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 { - x_377 = x_376; + lean_dec_ref(x_369); + x_381 = lean_box(0); } -lean_ctor_set(x_377, 0, x_374); -lean_ctor_set(x_377, 1, x_375); -lean_ctor_set(x_377, 2, x_264); -if (lean_is_scalar(x_373)) { - x_378 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 4, 0); } else { - x_378 = x_373; + x_382 = x_381; } -lean_ctor_set(x_378, 0, x_368); -lean_ctor_set(x_378, 1, x_369); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_370); -lean_ctor_set(x_378, 4, x_371); -lean_ctor_set(x_378, 5, x_372); -if (lean_is_scalar(x_367)) { - x_379 = lean_alloc_ctor(1, 2, 0); +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_379 = x_367; -} -lean_ctor_set(x_379, 0, x_366); -lean_ctor_set(x_379, 1, x_378); -return x_379; + 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; } 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_393; lean_object* x_394; -x_380 = lean_ctor_get(x_262, 0); -x_381 = lean_ctor_get(x_262, 1); -x_382 = lean_ctor_get(x_262, 2); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_262); -x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_384 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_384, 0, x_380); -lean_ctor_set(x_384, 1, x_381); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_257, 2, x_384); -x_385 = lean_ctor_get(x_7, 0); +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_7, 1); +x_386 = lean_ctor_get(x_385, 2); lean_inc(x_386); -x_387 = lean_ctor_get(x_7, 2); +x_387 = lean_ctor_get(x_367, 0); lean_inc(x_387); -x_388 = lean_ctor_get(x_7, 3); -lean_inc(x_388); -x_389 = lean_ctor_get(x_7, 4); +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); +} +x_389 = lean_ctor_get(x_385, 0); lean_inc(x_389); -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_390 = x_7; +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_7); - x_390 = lean_box(0); + lean_dec_ref(x_385); + x_394 = lean_box(0); } -x_391 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_391, 0, x_258); -lean_ctor_set(x_391, 1, x_14); -x_392 = lean_array_push(x_387, x_391); -if (lean_is_scalar(x_390)) { - x_393 = lean_alloc_ctor(0, 5, 0); -} else { - x_393 = x_390; -} -lean_ctor_set(x_393, 0, x_385); -lean_ctor_set(x_393, 1, x_386); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_388); -lean_ctor_set(x_393, 4, x_389); -x_394 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_393, x_257); -if (lean_obj_tag(x_394) == 0) -{ -lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_395 = lean_ctor_get(x_394, 1); +x_395 = lean_ctor_get(x_386, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_395, 2); +x_396 = lean_ctor_get(x_386, 1); lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); +x_397 = lean_ctor_get(x_386, 3); lean_inc(x_397); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_398 = x_394; +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; } else { - lean_dec_ref(x_394); + lean_dec_ref(x_386); x_398 = lean_box(0); } -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); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 3, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -lean_ctor_set(x_408, 2, x_382); -if (lean_is_scalar(x_404)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_404; -} -lean_ctor_set(x_409, 0, x_399); -lean_ctor_set(x_409, 1, x_400); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_401); -lean_ctor_set(x_409, 4, x_402); -lean_ctor_set(x_409, 5, x_403); if (lean_is_scalar(x_398)) { - x_410 = lean_alloc_ctor(0, 2, 0); + x_399 = lean_alloc_ctor(0, 4, 0); } else { - x_410 = x_398; + x_399 = x_398; +} +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); +} else { + x_400 = x_394; +} +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); +} else { + x_401 = x_388; +} +lean_ctor_set(x_401, 0, x_387); +lean_ctor_set(x_401, 1, x_400); +return x_401; +} } -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; } else { -lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_411 = lean_ctor_get(x_394, 1); +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_411, 2); +x_412 = lean_ctor_get(x_7, 4); lean_inc(x_412); -x_413 = lean_ctor_get(x_394, 0); -lean_inc(x_413); -if (lean_is_exclusive(x_394)) { - lean_ctor_release(x_394, 0); - lean_ctor_release(x_394, 1); - x_414 = x_394; -} else { - lean_dec_ref(x_394); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_411, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_411, 1); -lean_inc(x_416); -x_417 = lean_ctor_get(x_411, 3); -lean_inc(x_417); -x_418 = lean_ctor_get(x_411, 4); -lean_inc(x_418); -x_419 = lean_ctor_get(x_411, 5); -lean_inc(x_419); -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_420 = x_411; -} else { - lean_dec_ref(x_411); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_412, 0); -lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 1); -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); - x_423 = x_412; -} else { - lean_dec_ref(x_412); - x_423 = lean_box(0); -} -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 3, 0); -} else { - x_424 = x_423; -} -lean_ctor_set(x_424, 0, x_421); -lean_ctor_set(x_424, 1, x_422); -lean_ctor_set(x_424, 2, x_382); -if (lean_is_scalar(x_420)) { - x_425 = lean_alloc_ctor(0, 6, 0); -} else { - x_425 = x_420; -} -lean_ctor_set(x_425, 0, x_415); -lean_ctor_set(x_425, 1, x_416); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_417); -lean_ctor_set(x_425, 4, x_418); -lean_ctor_set(x_425, 5, x_419); -if (lean_is_scalar(x_414)) { - x_426 = lean_alloc_ctor(1, 2, 0); -} else { - x_426 = x_414; -} -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; -} -} -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_427 = lean_ctor_get(x_257, 2); -x_428 = lean_ctor_get(x_257, 0); -x_429 = lean_ctor_get(x_257, 1); -x_430 = lean_ctor_get(x_257, 3); -x_431 = lean_ctor_get(x_257, 4); -x_432 = lean_ctor_get(x_257, 5); -lean_inc(x_432); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_427); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_257); -x_433 = lean_ctor_get(x_427, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_427, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_427, 2); -lean_inc(x_435); -if (lean_is_exclusive(x_427)) { - lean_ctor_release(x_427, 0); - lean_ctor_release(x_427, 1); - lean_ctor_release(x_427, 2); - x_436 = x_427; -} else { - lean_dec_ref(x_427); - x_436 = lean_box(0); -} -x_437 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_436)) { - x_438 = lean_alloc_ctor(0, 3, 0); -} else { - x_438 = x_436; -} -lean_ctor_set(x_438, 0, x_433); -lean_ctor_set(x_438, 1, x_434); -lean_ctor_set(x_438, 2, x_437); -x_439 = lean_alloc_ctor(0, 6, 0); -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); -x_440 = lean_ctor_get(x_7, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_7, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_7, 2); -lean_inc(x_442); -x_443 = lean_ctor_get(x_7, 3); -lean_inc(x_443); -x_444 = lean_ctor_get(x_7, 4); -lean_inc(x_444); 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_445 = x_7; + x_413 = x_7; } else { lean_dec_ref(x_7); - x_445 = lean_box(0); + x_413 = lean_box(0); } -x_446 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_446, 0, x_258); -lean_ctor_set(x_446, 1, x_14); -x_447 = lean_array_push(x_442, x_446); -if (lean_is_scalar(x_445)) { - x_448 = lean_alloc_ctor(0, 5, 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); } else { - x_448 = x_445; + x_416 = x_413; } -lean_ctor_set(x_448, 0, x_440); -lean_ctor_set(x_448, 1, x_441); -lean_ctor_set(x_448, 2, x_447); -lean_ctor_set(x_448, 3, x_443); -lean_ctor_set(x_448, 4, x_444); -x_449 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_260, x_448, x_439); -if (lean_obj_tag(x_449) == 0) +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_Init_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_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; -x_450 = lean_ctor_get(x_449, 1); -lean_inc(x_450); -x_451 = lean_ctor_get(x_450, 2); -lean_inc(x_451); -x_452 = lean_ctor_get(x_449, 0); -lean_inc(x_452); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_453 = x_449; +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_449); - x_453 = lean_box(0); + lean_dec_ref(x_417); + x_421 = lean_box(0); } -x_454 = lean_ctor_get(x_450, 0); -lean_inc(x_454); -x_455 = lean_ctor_get(x_450, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_450, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_450, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_435); + x_444 = 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; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 4, 0); +} else { + x_449 = x_448; +} +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); +} else { + x_450 = x_444; +} +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); +} else { + x_451 = x_438; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; +} +} +} +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); -x_458 = lean_ctor_get(x_450, 5); +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); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - lean_ctor_release(x_450, 3); - lean_ctor_release(x_450, 4); - lean_ctor_release(x_450, 5); - x_459 = x_450; -} else { - lean_dec_ref(x_450); - x_459 = lean_box(0); -} -x_460 = lean_ctor_get(x_451, 0); +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_451, 1); +x_461 = lean_ctor_get(x_452, 3); lean_inc(x_461); -if (lean_is_exclusive(x_451)) { - lean_ctor_release(x_451, 0); - lean_ctor_release(x_451, 1); - lean_ctor_release(x_451, 2); - x_462 = x_451; +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; } else { - lean_dec_ref(x_451); + lean_dec_ref(x_452); x_462 = lean_box(0); } +x_463 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_462)) { - x_463 = lean_alloc_ctor(0, 3, 0); + x_464 = lean_alloc_ctor(0, 4, 0); } else { - x_463 = x_462; + x_464 = x_462; } -lean_ctor_set(x_463, 0, x_460); -lean_ctor_set(x_463, 1, x_461); -lean_ctor_set(x_463, 2, x_435); -if (lean_is_scalar(x_459)) { - x_464 = lean_alloc_ctor(0, 6, 0); -} else { - x_464 = x_459; -} -lean_ctor_set(x_464, 0, x_454); -lean_ctor_set(x_464, 1, x_455); +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_456); -lean_ctor_set(x_464, 4, x_457); -lean_ctor_set(x_464, 5, x_458); -if (lean_is_scalar(x_453)) { - x_465 = lean_alloc_ctor(0, 2, 0); -} else { - x_465 = x_453; -} -lean_ctor_set(x_465, 0, x_452); -lean_ctor_set(x_465, 1, x_464); -return x_465; -} -else -{ -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_466 = lean_ctor_get(x_449, 1); +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_466, 2); +x_467 = lean_ctor_get(x_7, 1); lean_inc(x_467); -x_468 = lean_ctor_get(x_449, 0); +x_468 = lean_ctor_get(x_7, 2); lean_inc(x_468); -if (lean_is_exclusive(x_449)) { - lean_ctor_release(x_449, 0); - lean_ctor_release(x_449, 1); - x_469 = x_449; -} else { - lean_dec_ref(x_449); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_466, 0); +x_469 = lean_ctor_get(x_7, 3); +lean_inc(x_469); +x_470 = lean_ctor_get(x_7, 4); lean_inc(x_470); -x_471 = lean_ctor_get(x_466, 1); -lean_inc(x_471); -x_472 = lean_ctor_get(x_466, 3); -lean_inc(x_472); -x_473 = lean_ctor_get(x_466, 4); -lean_inc(x_473); -x_474 = lean_ctor_get(x_466, 5); -lean_inc(x_474); -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); - lean_ctor_release(x_466, 5); - x_475 = x_466; +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; } else { - lean_dec_ref(x_466); - x_475 = lean_box(0); + lean_dec_ref(x_7); + x_471 = lean_box(0); } -x_476 = lean_ctor_get(x_467, 0); +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); +} else { + x_474 = x_471; +} +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_Init_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_467, 1); +x_477 = lean_ctor_get(x_476, 2); lean_inc(x_477); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - lean_ctor_release(x_467, 2); - x_478 = x_467; +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; } else { - lean_dec_ref(x_467); - x_478 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -if (lean_is_scalar(x_478)) { - x_479 = lean_alloc_ctor(0, 3, 0); +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 { - x_479 = x_478; + lean_dec_ref(x_476); + x_485 = lean_box(0); } -lean_ctor_set(x_479, 0, x_476); -lean_ctor_set(x_479, 1, x_477); -lean_ctor_set(x_479, 2, x_435); -if (lean_is_scalar(x_475)) { - x_480 = lean_alloc_ctor(0, 6, 0); +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 { - x_480 = x_475; + lean_dec_ref(x_477); + x_489 = lean_box(0); } -lean_ctor_set(x_480, 0, x_470); -lean_ctor_set(x_480, 1, x_471); -lean_ctor_set(x_480, 2, x_479); -lean_ctor_set(x_480, 3, x_472); -lean_ctor_set(x_480, 4, x_473); -lean_ctor_set(x_480, 5, x_474); -if (lean_is_scalar(x_469)) { - x_481 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_489)) { + x_490 = lean_alloc_ctor(0, 4, 0); } else { - x_481 = x_469; + x_490 = x_489; } -lean_ctor_set(x_481, 0, x_468); -lean_ctor_set(x_481, 1, x_480); -return x_481; +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_482; +uint8_t x_510; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_482 = !lean_is_exclusive(x_251); -if (x_482 == 0) +x_510 = !lean_is_exclusive(x_265); +if (x_510 == 0) { -return x_251; +return x_265; } else { -lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_483 = lean_ctor_get(x_251, 0); -x_484 = lean_ctor_get(x_251, 1); -lean_inc(x_484); -lean_inc(x_483); -lean_dec(x_251); -x_485 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_485, 0, x_483); -lean_ctor_set(x_485, 1, x_484); -return x_485; +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; } } } @@ -41532,58 +43116,58 @@ return x_485; } else { -uint8_t x_486; +uint8_t x_514; 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_486 = !lean_is_exclusive(x_19); -if (x_486 == 0) +x_514 = !lean_is_exclusive(x_19); +if (x_514 == 0) { return x_19; } else { -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_19, 0); -x_488 = lean_ctor_get(x_19, 1); -lean_inc(x_488); -lean_inc(x_487); +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_dec(x_19); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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; } } } else { -uint8_t x_490; +uint8_t x_518; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_15); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_15); +if (x_518 == 0) { return x_15; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_15, 0); -x_492 = lean_ctor_get(x_15, 1); -lean_inc(x_492); -lean_inc(x_491); +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_dec(x_15); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -43032,82 +44616,89 @@ return x_22; } else { -lean_object* x_31; lean_object* x_32; lean_object* x_33; +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_33 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_33, 0, x_31); -lean_ctor_set(x_33, 1, x_32); -lean_ctor_set(x_33, 2, x_16); -lean_ctor_set(x_23, 2, x_33); +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; } } else { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_34 = lean_ctor_get(x_23, 0); -x_35 = lean_ctor_get(x_23, 1); -x_36 = lean_ctor_get(x_23, 3); -x_37 = lean_ctor_get(x_23, 4); -x_38 = lean_ctor_get(x_23, 5); +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_inc(x_36); lean_inc(x_35); -lean_inc(x_34); lean_dec(x_23); -x_39 = lean_ctor_get(x_24, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_24, 1); +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); - x_41 = x_24; + lean_ctor_release(x_24, 3); + x_43 = x_24; } else { lean_dec_ref(x_24); - x_41 = lean_box(0); + x_43 = lean_box(0); } -if (lean_is_scalar(x_41)) { - x_42 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_43)) { + x_44 = lean_alloc_ctor(0, 4, 0); } else { - x_42 = x_41; + x_44 = x_43; } -lean_ctor_set(x_42, 0, x_39); -lean_ctor_set(x_42, 1, x_40); -lean_ctor_set(x_42, 2, x_16); -x_43 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_43, 0, x_34); -lean_ctor_set(x_43, 1, x_35); -lean_ctor_set(x_43, 2, x_42); -lean_ctor_set(x_43, 3, x_36); -lean_ctor_set(x_43, 4, x_37); -lean_ctor_set(x_43, 5, x_38); -lean_ctor_set(x_22, 1, x_43); +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; } } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_44 = lean_ctor_get(x_22, 0); -lean_inc(x_44); -lean_dec(x_22); -x_45 = lean_ctor_get(x_23, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_23, 1); +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; 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); -x_47 = lean_ctor_get(x_23, 3); +lean_dec(x_22); +x_47 = lean_ctor_get(x_23, 0); lean_inc(x_47); -x_48 = lean_ctor_get(x_23, 4); +x_48 = lean_ctor_get(x_23, 1); lean_inc(x_48); -x_49 = lean_ctor_get(x_23, 5); +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); @@ -43115,877 +44706,923 @@ if (lean_is_exclusive(x_23)) { lean_ctor_release(x_23, 3); lean_ctor_release(x_23, 4); lean_ctor_release(x_23, 5); - x_50 = x_23; + x_52 = x_23; } else { lean_dec_ref(x_23); - x_50 = lean_box(0); + x_52 = lean_box(0); } -x_51 = lean_ctor_get(x_24, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_24, 1); -lean_inc(x_52); +x_53 = lean_ctor_get(x_24, 0); +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); - x_53 = x_24; + lean_ctor_release(x_24, 3); + x_56 = x_24; } else { lean_dec_ref(x_24); - x_53 = lean_box(0); + x_56 = lean_box(0); } -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 4, 0); } else { - x_54 = x_53; + x_57 = x_56; } -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_16); -if (lean_is_scalar(x_50)) { - x_55 = lean_alloc_ctor(0, 6, 0); +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_55 = x_50; + x_58 = x_52; } -lean_ctor_set(x_55, 0, x_45); -lean_ctor_set(x_55, 1, x_46); -lean_ctor_set(x_55, 2, x_54); -lean_ctor_set(x_55, 3, x_47); -lean_ctor_set(x_55, 4, x_48); -lean_ctor_set(x_55, 5, x_49); -x_56 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_56, 0, x_44); -lean_ctor_set(x_56, 1, x_55); -return x_56; +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; } } else { -lean_object* x_57; lean_object* x_58; uint8_t x_59; -x_57 = lean_ctor_get(x_22, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_57, 2); -lean_inc(x_58); -x_59 = !lean_is_exclusive(x_22); -if (x_59 == 0) -{ -lean_object* x_60; uint8_t x_61; +lean_object* x_60; lean_object* x_61; uint8_t x_62; x_60 = lean_ctor_get(x_22, 1); -lean_dec(x_60); -x_61 = !lean_is_exclusive(x_57); -if (x_61 == 0) +lean_inc(x_60); +x_61 = lean_ctor_get(x_60, 2); +lean_inc(x_61); +x_62 = !lean_is_exclusive(x_22); +if (x_62 == 0) { -lean_object* x_62; uint8_t x_63; -x_62 = lean_ctor_get(x_57, 2); -lean_dec(x_62); -x_63 = !lean_is_exclusive(x_58); -if (x_63 == 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_64; -x_64 = lean_ctor_get(x_58, 2); -lean_dec(x_64); -lean_ctor_set(x_58, 2, x_16); +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_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_58, 0); -x_66 = lean_ctor_get(x_58, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_58); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_65); -lean_ctor_set(x_67, 1, x_66); -lean_ctor_set(x_67, 2, x_16); -lean_ctor_set(x_57, 2, x_67); -return x_22; -} -} -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; -x_68 = lean_ctor_get(x_57, 0); -x_69 = lean_ctor_get(x_57, 1); -x_70 = lean_ctor_get(x_57, 3); -x_71 = lean_ctor_get(x_57, 4); -x_72 = lean_ctor_get(x_57, 5); -lean_inc(x_72); -lean_inc(x_71); +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_57); -x_73 = lean_ctor_get(x_58, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_58, 1); -lean_inc(x_74); -if (lean_is_exclusive(x_58)) { - lean_ctor_release(x_58, 0); - lean_ctor_release(x_58, 1); - lean_ctor_release(x_58, 2); - x_75 = x_58; -} else { - lean_dec_ref(x_58); - x_75 = lean_box(0); -} -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 3, 0); -} else { - x_76 = x_75; -} -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_16); -x_77 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_77, 0, x_68); -lean_ctor_set(x_77, 1, x_69); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_70); -lean_ctor_set(x_77, 4, x_71); -lean_ctor_set(x_77, 5, x_72); -lean_ctor_set(x_22, 1, x_77); +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_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_78 = lean_ctor_get(x_22, 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; 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); -lean_dec(x_22); -x_79 = lean_ctor_get(x_57, 0); +x_79 = lean_ctor_get(x_61, 3); lean_inc(x_79); -x_80 = lean_ctor_get(x_57, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_57, 3); -lean_inc(x_81); -x_82 = lean_ctor_get(x_57, 4); -lean_inc(x_82); -x_83 = lean_ctor_get(x_57, 5); +if (lean_is_exclusive(x_61)) { + lean_ctor_release(x_61, 0); + lean_ctor_release(x_61, 1); + lean_ctor_release(x_61, 2); + lean_ctor_release(x_61, 3); + x_80 = x_61; +} else { + lean_dec_ref(x_61); + 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_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); -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_84 = x_57; -} else { - lean_dec_ref(x_57); - x_84 = lean_box(0); -} -x_85 = lean_ctor_get(x_58, 0); +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_58, 1); +x_86 = lean_ctor_get(x_60, 3); 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); - x_87 = x_58; +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; } else { - lean_dec_ref(x_58); - x_87 = lean_box(0); + lean_dec_ref(x_60); + x_89 = lean_box(0); } -if (lean_is_scalar(x_87)) { - x_88 = lean_alloc_ctor(0, 3, 0); +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 { - x_88 = x_87; + lean_dec_ref(x_61); + x_93 = lean_box(0); } -lean_ctor_set(x_88, 0, x_85); -lean_ctor_set(x_88, 1, x_86); -lean_ctor_set(x_88, 2, x_16); -if (lean_is_scalar(x_84)) { - x_89 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_93)) { + x_94 = lean_alloc_ctor(0, 4, 0); } else { - x_89 = x_84; + x_94 = x_93; } -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); -x_90 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_90, 0, x_78); -lean_ctor_set(x_90, 1, x_89); -return x_90; +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_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_91 = lean_ctor_get(x_4, 0); -x_92 = lean_ctor_get(x_4, 1); -x_93 = lean_ctor_get(x_4, 2); -x_94 = lean_ctor_get(x_4, 3); -x_95 = lean_ctor_get(x_4, 4); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_inc(x_91); +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_inc(x_99); +lean_inc(x_98); +lean_inc(x_97); lean_dec(x_4); lean_inc(x_1); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_12); -lean_ctor_set(x_96, 1, x_1); -x_97 = lean_array_push(x_93, x_96); -x_98 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_98, 0, x_91); -lean_ctor_set(x_98, 1, x_92); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_94); -lean_ctor_set(x_98, 4, x_95); -x_99 = lean_apply_3(x_3, x_1, x_98, x_10); -if (lean_obj_tag(x_99) == 0) +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_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_100 = lean_ctor_get(x_99, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_100, 2); -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; -} else { - lean_dec_ref(x_99); - x_103 = lean_box(0); -} -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_100, 3); +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_100, 4); +x_107 = lean_ctor_get(x_106, 2); lean_inc(x_107); -x_108 = lean_ctor_get(x_100, 5); +x_108 = lean_ctor_get(x_105, 0); lean_inc(x_108); -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); - lean_ctor_release(x_100, 5); - x_109 = x_100; +if (lean_is_exclusive(x_105)) { + lean_ctor_release(x_105, 0); + lean_ctor_release(x_105, 1); + x_109 = x_105; } else { - lean_dec_ref(x_100); + lean_dec_ref(x_105); x_109 = lean_box(0); } -x_110 = lean_ctor_get(x_101, 0); +x_110 = lean_ctor_get(x_106, 0); lean_inc(x_110); -x_111 = lean_ctor_get(x_101, 1); +x_111 = lean_ctor_get(x_106, 1); lean_inc(x_111); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - lean_ctor_release(x_101, 2); - x_112 = x_101; +x_112 = lean_ctor_get(x_106, 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; } else { - lean_dec_ref(x_101); - x_112 = lean_box(0); + lean_dec_ref(x_106); + x_115 = lean_box(0); } -if (lean_is_scalar(x_112)) { - x_113 = lean_alloc_ctor(0, 3, 0); -} else { - x_113 = x_112; -} -lean_ctor_set(x_113, 0, x_110); -lean_ctor_set(x_113, 1, x_111); -lean_ctor_set(x_113, 2, x_16); -if (lean_is_scalar(x_109)) { - x_114 = lean_alloc_ctor(0, 6, 0); -} else { - x_114 = x_109; -} -lean_ctor_set(x_114, 0, x_104); -lean_ctor_set(x_114, 1, x_105); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_106); -lean_ctor_set(x_114, 4, x_107); -lean_ctor_set(x_114, 5, x_108); -if (lean_is_scalar(x_103)) { - x_115 = lean_alloc_ctor(0, 2, 0); -} else { - x_115 = x_103; -} -lean_ctor_set(x_115, 0, x_102); -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; -x_116 = lean_ctor_get(x_99, 1); +x_116 = lean_ctor_get(x_107, 0); lean_inc(x_116); -x_117 = lean_ctor_get(x_116, 2); +x_117 = lean_ctor_get(x_107, 1); lean_inc(x_117); -x_118 = lean_ctor_get(x_99, 0); +x_118 = lean_ctor_get(x_107, 3); lean_inc(x_118); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - x_119 = x_99; +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; } else { - lean_dec_ref(x_99); + lean_dec_ref(x_107); 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); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - x_128 = x_117; -} else { - lean_dec_ref(x_117); - x_128 = lean_box(0); -} -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 3, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_126); -lean_ctor_set(x_129, 1, x_127); -lean_ctor_set(x_129, 2, x_16); -if (lean_is_scalar(x_125)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_125; -} -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); if (lean_is_scalar(x_119)) { - x_131 = lean_alloc_ctor(1, 2, 0); + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_131 = x_119; + x_120 = x_119; } -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; +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); +if (lean_is_scalar(x_109)) { + x_122 = lean_alloc_ctor(0, 2, 0); +} else { + x_122 = x_109; +} +lean_ctor_set(x_122, 0, x_108); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +x_123 = lean_ctor_get(x_105, 1); +lean_inc(x_123); +x_124 = lean_ctor_get(x_123, 2); +lean_inc(x_124); +x_125 = lean_ctor_get(x_105, 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); +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; +} else { + lean_dec_ref(x_123); + x_132 = 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; +} else { + lean_dec_ref(x_124); + 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_16); +lean_ctor_set(x_137, 3, x_135); +if (lean_is_scalar(x_132)) { + x_138 = lean_alloc_ctor(0, 6, 0); +} else { + x_138 = x_132; +} +lean_ctor_set(x_138, 0, x_127); +lean_ctor_set(x_138, 1, x_128); +lean_ctor_set(x_138, 2, x_137); +lean_ctor_set(x_138, 3, x_129); +lean_ctor_set(x_138, 4, x_130); +lean_ctor_set(x_138, 5, x_131); +if (lean_is_scalar(x_126)) { + x_139 = lean_alloc_ctor(1, 2, 0); +} else { + x_139 = x_126; +} +lean_ctor_set(x_139, 0, x_125); +lean_ctor_set(x_139, 1, x_138); +return x_139; } } } else { -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_132 = lean_ctor_get(x_11, 0); -x_133 = lean_ctor_get(x_11, 1); -x_134 = lean_ctor_get(x_11, 2); -lean_inc(x_134); -lean_inc(x_133); -lean_inc(x_132); -lean_dec(x_11); -x_135 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_136 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_10, 2, x_136); -x_137 = lean_ctor_get(x_4, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_4, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_4, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_4, 3); -lean_inc(x_140); -x_141 = lean_ctor_get(x_4, 4); +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; 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_142 = x_4; + x_151 = x_4; } else { lean_dec_ref(x_4); - x_142 = lean_box(0); + x_151 = lean_box(0); } lean_inc(x_1); -x_143 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_143, 0, x_12); -lean_ctor_set(x_143, 1, x_1); -x_144 = lean_array_push(x_139, x_143); -if (lean_is_scalar(x_142)) { - x_145 = lean_alloc_ctor(0, 5, 0); +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_145 = x_142; + x_154 = x_151; } -lean_ctor_set(x_145, 0, x_137); -lean_ctor_set(x_145, 1, x_138); -lean_ctor_set(x_145, 2, x_144); -lean_ctor_set(x_145, 3, x_140); -lean_ctor_set(x_145, 4, x_141); -x_146 = lean_apply_3(x_3, x_1, x_145, x_10); -if (lean_obj_tag(x_146) == 0) +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_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_147 = lean_ctor_get(x_146, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_147, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_146, 0); -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); -} -x_151 = lean_ctor_get(x_147, 0); -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; -} else { - lean_dec_ref(x_147); - x_156 = lean_box(0); -} -x_157 = lean_ctor_get(x_148, 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_148, 1); +x_158 = lean_ctor_get(x_155, 0); lean_inc(x_158); -if (lean_is_exclusive(x_148)) { - lean_ctor_release(x_148, 0); - lean_ctor_release(x_148, 1); - lean_ctor_release(x_148, 2); - x_159 = x_148; +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_148); + lean_dec_ref(x_155); x_159 = lean_box(0); } -if (lean_is_scalar(x_159)) { - x_160 = lean_alloc_ctor(0, 3, 0); -} else { - x_160 = x_159; -} -lean_ctor_set(x_160, 0, x_157); -lean_ctor_set(x_160, 1, x_158); -lean_ctor_set(x_160, 2, x_134); -if (lean_is_scalar(x_156)) { - x_161 = lean_alloc_ctor(0, 6, 0); -} else { - x_161 = x_156; -} -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); -if (lean_is_scalar(x_150)) { - x_162 = lean_alloc_ctor(0, 2, 0); -} else { - x_162 = x_150; -} -lean_ctor_set(x_162, 0, x_149); -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_146, 1); +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_163, 2); +x_164 = lean_ctor_get(x_156, 5); lean_inc(x_164); -x_165 = lean_ctor_get(x_146, 0); -lean_inc(x_165); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - lean_ctor_release(x_146, 1); - x_166 = x_146; +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_146); - x_166 = lean_box(0); + lean_dec_ref(x_156); + x_165 = lean_box(0); } -x_167 = lean_ctor_get(x_163, 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_163, 1); +x_168 = lean_ctor_get(x_157, 3); lean_inc(x_168); -x_169 = lean_ctor_get(x_163, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 4); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - lean_ctor_release(x_163, 4); - lean_ctor_release(x_163, 5); - x_172 = x_163; +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_163); - x_172 = lean_box(0); + lean_dec_ref(x_157); + x_169 = lean_box(0); } -x_173 = lean_ctor_get(x_164, 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_164, 1); +x_174 = lean_ctor_get(x_173, 2); lean_inc(x_174); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - x_175 = x_164; +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_164); - x_175 = lean_box(0); + lean_dec_ref(x_155); + x_176 = lean_box(0); } -if (lean_is_scalar(x_175)) { - x_176 = lean_alloc_ctor(0, 3, 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 { - x_176 = x_175; + lean_dec_ref(x_173); + x_182 = lean_box(0); } -lean_ctor_set(x_176, 0, x_173); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_134); -if (lean_is_scalar(x_172)) { - x_177 = lean_alloc_ctor(0, 6, 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 { - x_177 = x_172; + lean_dec_ref(x_174); + x_186 = lean_box(0); } -lean_ctor_set(x_177, 0, x_167); -lean_ctor_set(x_177, 1, x_168); -lean_ctor_set(x_177, 2, x_176); -lean_ctor_set(x_177, 3, x_169); -lean_ctor_set(x_177, 4, x_170); -lean_ctor_set(x_177, 5, x_171); -if (lean_is_scalar(x_166)) { - x_178 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_186)) { + x_187 = lean_alloc_ctor(0, 4, 0); } else { - x_178 = x_166; + x_187 = x_186; } -lean_ctor_set(x_178, 0, x_165); -lean_ctor_set(x_178, 1, x_177); -return x_178; +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_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; lean_object* x_199; lean_object* x_200; -x_179 = lean_ctor_get(x_10, 0); -x_180 = lean_ctor_get(x_10, 1); -x_181 = lean_ctor_get(x_10, 3); -x_182 = lean_ctor_get(x_10, 4); -x_183 = lean_ctor_get(x_10, 5); -lean_inc(x_183); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_179); +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_dec(x_10); -x_184 = lean_ctor_get(x_11, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_11, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_11, 2); -lean_inc(x_186); +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); +lean_inc(x_197); +x_198 = lean_ctor_get(x_11, 3); +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); - x_187 = x_11; + lean_ctor_release(x_11, 3); + x_199 = x_11; } else { lean_dec_ref(x_11); - x_187 = lean_box(0); + x_199 = lean_box(0); } -x_188 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_189 = lean_alloc_ctor(0, 3, 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_189 = x_187; + x_201 = x_199; } -lean_ctor_set(x_189, 0, x_184); -lean_ctor_set(x_189, 1, x_185); -lean_ctor_set(x_189, 2, x_188); -x_190 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_190, 0, x_179); -lean_ctor_set(x_190, 1, x_180); -lean_ctor_set(x_190, 2, x_189); -lean_ctor_set(x_190, 3, x_181); -lean_ctor_set(x_190, 4, x_182); -lean_ctor_set(x_190, 5, x_183); -x_191 = lean_ctor_get(x_4, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_4, 1); -lean_inc(x_192); -x_193 = lean_ctor_get(x_4, 2); -lean_inc(x_193); -x_194 = lean_ctor_get(x_4, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_4, 4); -lean_inc(x_195); +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); 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_196 = x_4; + x_208 = x_4; } else { lean_dec_ref(x_4); - x_196 = lean_box(0); + x_208 = lean_box(0); } lean_inc(x_1); -x_197 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_197, 0, x_12); -lean_ctor_set(x_197, 1, x_1); -x_198 = lean_array_push(x_193, x_197); -if (lean_is_scalar(x_196)) { - x_199 = lean_alloc_ctor(0, 5, 0); +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); } else { - x_199 = x_196; + x_211 = x_208; } -lean_ctor_set(x_199, 0, x_191); -lean_ctor_set(x_199, 1, x_192); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_194); -lean_ctor_set(x_199, 4, x_195); -x_200 = lean_apply_3(x_3, x_1, x_199, x_190); -if (lean_obj_tag(x_200) == 0) +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_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; -x_201 = lean_ctor_get(x_200, 1); -lean_inc(x_201); -x_202 = lean_ctor_get(x_201, 2); -lean_inc(x_202); -x_203 = lean_ctor_get(x_200, 0); -lean_inc(x_203); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - x_204 = x_200; +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_200); - x_204 = lean_box(0); + lean_dec_ref(x_212); + x_216 = lean_box(0); } -x_205 = lean_ctor_get(x_201, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_201, 1); -lean_inc(x_206); -x_207 = lean_ctor_get(x_201, 3); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 4); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 5); -lean_inc(x_209); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - lean_ctor_release(x_201, 4); - lean_ctor_release(x_201, 5); - x_210 = x_201; -} else { - lean_dec_ref(x_201); - x_210 = lean_box(0); -} -x_211 = lean_ctor_get(x_202, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_202, 1); -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); - 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, 3, 0); -} else { - x_214 = x_213; -} -lean_ctor_set(x_214, 0, x_211); -lean_ctor_set(x_214, 1, x_212); -lean_ctor_set(x_214, 2, x_186); -if (lean_is_scalar(x_210)) { - x_215 = lean_alloc_ctor(0, 6, 0); -} else { - x_215 = x_210; -} -lean_ctor_set(x_215, 0, x_205); -lean_ctor_set(x_215, 1, x_206); -lean_ctor_set(x_215, 2, x_214); -lean_ctor_set(x_215, 3, x_207); -lean_ctor_set(x_215, 4, x_208); -lean_ctor_set(x_215, 5, x_209); -if (lean_is_scalar(x_204)) { - x_216 = lean_alloc_ctor(0, 2, 0); -} else { - x_216 = x_204; -} -lean_ctor_set(x_216, 0, x_203); -lean_ctor_set(x_216, 1, x_215); -return x_216; -} -else -{ -lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_217 = lean_ctor_get(x_200, 1); +x_217 = lean_ctor_get(x_213, 0); lean_inc(x_217); -x_218 = lean_ctor_get(x_217, 2); +x_218 = lean_ctor_get(x_213, 1); lean_inc(x_218); -x_219 = lean_ctor_get(x_200, 0); +x_219 = lean_ctor_get(x_213, 3); lean_inc(x_219); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - x_220 = x_200; -} else { - lean_dec_ref(x_200); - x_220 = lean_box(0); -} -x_221 = lean_ctor_get(x_217, 0); +x_220 = lean_ctor_get(x_213, 4); +lean_inc(x_220); +x_221 = lean_ctor_get(x_213, 5); lean_inc(x_221); -x_222 = lean_ctor_get(x_217, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_217, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_217, 4); -lean_inc(x_224); -x_225 = lean_ctor_get(x_217, 5); -lean_inc(x_225); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - lean_ctor_release(x_217, 2); - lean_ctor_release(x_217, 3); - lean_ctor_release(x_217, 4); - lean_ctor_release(x_217, 5); - x_226 = x_217; +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_217); + 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); } -x_227 = lean_ctor_get(x_218, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_218, 1); -lean_inc(x_228); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - x_229 = x_218; -} else { - lean_dec_ref(x_218); - x_229 = lean_box(0); -} -if (lean_is_scalar(x_229)) { - x_230 = lean_alloc_ctor(0, 3, 0); -} else { - x_230 = x_229; -} -lean_ctor_set(x_230, 0, x_227); -lean_ctor_set(x_230, 1, x_228); -lean_ctor_set(x_230, 2, x_186); if (lean_is_scalar(x_226)) { - x_231 = lean_alloc_ctor(0, 6, 0); + x_227 = lean_alloc_ctor(0, 4, 0); } else { - x_231 = x_226; + x_227 = x_226; } -lean_ctor_set(x_231, 0, x_221); -lean_ctor_set(x_231, 1, x_222); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_223); -lean_ctor_set(x_231, 4, x_224); -lean_ctor_set(x_231, 5, x_225); -if (lean_is_scalar(x_220)) { - x_232 = lean_alloc_ctor(1, 2, 0); +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_232 = x_220; + x_228 = x_222; } -lean_ctor_set(x_232, 0, x_219); -lean_ctor_set(x_232, 1, x_231); -return x_232; +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; +} +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); +} +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_197); +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(1, 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 { -uint8_t x_233; +uint8_t x_247; lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_233 = !lean_is_exclusive(x_6); -if (x_233 == 0) +x_247 = !lean_is_exclusive(x_6); +if (x_247 == 0) { return x_6; } else { -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_6, 0); -x_235 = lean_ctor_get(x_6, 1); -lean_inc(x_235); -lean_inc(x_234); +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_dec(x_6); -x_236 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_236, 0, x_234); -lean_ctor_set(x_236, 1, x_235); -return x_236; +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; } } } @@ -44115,82 +45752,89 @@ return x_33; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; +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_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -lean_ctor_set(x_44, 2, x_28); -lean_ctor_set(x_34, 2, x_44); +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; } } 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_34, 0); -x_46 = lean_ctor_get(x_34, 1); -x_47 = lean_ctor_get(x_34, 3); -x_48 = lean_ctor_get(x_34, 4); -x_49 = lean_ctor_get(x_34, 5); +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_inc(x_48); lean_inc(x_47); lean_inc(x_46); -lean_inc(x_45); lean_dec(x_34); -x_50 = lean_ctor_get(x_35, 0); -lean_inc(x_50); -x_51 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 0); 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); - x_52 = x_35; + lean_ctor_release(x_35, 3); + x_54 = x_35; } else { lean_dec_ref(x_35); - x_52 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - x_53 = x_52; + x_55 = x_54; } -lean_ctor_set(x_53, 0, x_50); -lean_ctor_set(x_53, 1, x_51); -lean_ctor_set(x_53, 2, x_28); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_45); -lean_ctor_set(x_54, 1, x_46); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_47); -lean_ctor_set(x_54, 4, x_48); -lean_ctor_set(x_54, 5, x_49); -lean_ctor_set(x_33, 1, 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_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; } } 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; -x_55 = lean_ctor_get(x_33, 0); -lean_inc(x_55); -lean_dec(x_33); -x_56 = lean_ctor_get(x_34, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_34, 1); +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_inc(x_57); -x_58 = lean_ctor_get(x_34, 3); +lean_dec(x_33); +x_58 = lean_ctor_get(x_34, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_34, 4); +x_59 = lean_ctor_get(x_34, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_34, 5); +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); @@ -44198,619 +45842,657 @@ if (lean_is_exclusive(x_34)) { lean_ctor_release(x_34, 3); lean_ctor_release(x_34, 4); lean_ctor_release(x_34, 5); - x_61 = x_34; + x_63 = x_34; } else { lean_dec_ref(x_34); - x_61 = lean_box(0); + x_63 = lean_box(0); } -x_62 = lean_ctor_get(x_35, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_35, 1); -lean_inc(x_63); +x_64 = lean_ctor_get(x_35, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_35, 1); +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); - x_64 = x_35; + lean_ctor_release(x_35, 3); + x_67 = x_35; } else { lean_dec_ref(x_35); - x_64 = lean_box(0); + x_67 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 4, 0); } else { - x_65 = x_64; + x_68 = x_67; } -lean_ctor_set(x_65, 0, x_62); -lean_ctor_set(x_65, 1, x_63); -lean_ctor_set(x_65, 2, x_28); -if (lean_is_scalar(x_61)) { - x_66 = lean_alloc_ctor(0, 6, 0); +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_66 = x_61; + x_69 = x_63; } -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); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_55); -lean_ctor_set(x_67, 1, x_66); -return x_67; +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; } } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_68 = lean_ctor_get(x_33, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_68, 2); -lean_inc(x_69); -x_70 = !lean_is_exclusive(x_33); -if (x_70 == 0) -{ -lean_object* x_71; uint8_t x_72; +lean_object* x_71; lean_object* x_72; uint8_t x_73; x_71 = lean_ctor_get(x_33, 1); -lean_dec(x_71); -x_72 = !lean_is_exclusive(x_68); -if (x_72 == 0) +lean_inc(x_71); +x_72 = lean_ctor_get(x_71, 2); +lean_inc(x_72); +x_73 = !lean_is_exclusive(x_33); +if (x_73 == 0) { -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_68, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_69); -if (x_74 == 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_75; -x_75 = lean_ctor_get(x_69, 2); -lean_dec(x_75); -lean_ctor_set(x_69, 2, x_28); +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_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_69, 0); -x_77 = lean_ctor_get(x_69, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_69); -x_78 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -lean_ctor_set(x_78, 2, x_28); -lean_ctor_set(x_68, 2, x_78); -return x_33; -} -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_79 = lean_ctor_get(x_68, 0); -x_80 = lean_ctor_get(x_68, 1); -x_81 = lean_ctor_get(x_68, 3); -x_82 = lean_ctor_get(x_68, 4); -x_83 = lean_ctor_get(x_68, 5); -lean_inc(x_83); -lean_inc(x_82); +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_68); -x_84 = lean_ctor_get(x_69, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_69, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - x_86 = x_69; -} else { - lean_dec_ref(x_69); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 3, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_28); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_79); -lean_ctor_set(x_88, 1, x_80); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_81); -lean_ctor_set(x_88, 4, x_82); -lean_ctor_set(x_88, 5, x_83); -lean_ctor_set(x_33, 1, x_88); +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_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_89 = lean_ctor_get(x_33, 0); +lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_83 = lean_ctor_get(x_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); -lean_dec(x_33); -x_90 = lean_ctor_get(x_68, 0); +x_90 = lean_ctor_get(x_72, 3); lean_inc(x_90); -x_91 = lean_ctor_get(x_68, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_68, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_68, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_68, 5); +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; +} else { + lean_dec_ref(x_72); + x_91 = lean_box(0); +} +if (lean_is_scalar(x_91)) { + x_92 = lean_alloc_ctor(0, 4, 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_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); -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_95 = x_68; -} else { - lean_dec_ref(x_68); - x_95 = lean_box(0); -} -x_96 = lean_ctor_get(x_69, 0); +lean_dec(x_33); +x_95 = lean_ctor_get(x_71, 0); +lean_inc(x_95); +x_96 = lean_ctor_get(x_71, 1); lean_inc(x_96); -x_97 = lean_ctor_get(x_69, 1); +x_97 = lean_ctor_get(x_71, 3); lean_inc(x_97); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - x_98 = x_69; +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_69); - x_98 = lean_box(0); + lean_dec_ref(x_71); + x_100 = lean_box(0); } -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 3, 0); -} else { - x_99 = x_98; -} -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -lean_ctor_set(x_99, 2, x_28); -if (lean_is_scalar(x_95)) { - x_100 = lean_alloc_ctor(0, 6, 0); -} else { - x_100 = x_95; -} -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); -x_101 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_101, 0, x_89); -lean_ctor_set(x_101, 1, x_100); -return x_101; -} -} -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_102 = lean_ctor_get(x_23, 0); -x_103 = lean_ctor_get(x_23, 1); -x_104 = lean_ctor_get(x_23, 2); -lean_inc(x_104); -lean_inc(x_103); +x_101 = lean_ctor_get(x_72, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_72, 1); lean_inc(x_102); -lean_dec(x_23); -x_105 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_106 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_106, 0, x_102); -lean_ctor_set(x_106, 1, x_103); +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_22, 2, x_106); -lean_inc(x_17); -x_107 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_107, 0, x_24); -lean_ctor_set(x_107, 1, x_17); -x_108 = lean_array_push(x_13, x_107); -x_109 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_109, 0, x_11); -lean_ctor_set(x_109, 1, x_16); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_14); -lean_ctor_set(x_109, 4, x_15); -x_110 = lean_apply_3(x_4, x_17, x_109, x_22); -if (lean_obj_tag(x_110) == 0) +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_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_111 = lean_ctor_get(x_110, 1); +lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; 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); -x_112 = lean_ctor_get(x_111, 2); -lean_inc(x_112); -x_113 = lean_ctor_get(x_110, 0); -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_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_111, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_111, 4); +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_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_111, 5); +x_119 = lean_ctor_get(x_118, 2); lean_inc(x_119); -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_120 = x_111; +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_111); - x_120 = lean_box(0); + lean_dec_ref(x_117); + x_121 = lean_box(0); } -x_121 = lean_ctor_get(x_112, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_112, 1); +x_122 = lean_ctor_get(x_118, 0); lean_inc(x_122); -if (lean_is_exclusive(x_112)) { - lean_ctor_release(x_112, 0); - lean_ctor_release(x_112, 1); - lean_ctor_release(x_112, 2); - x_123 = x_112; +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_112); - x_123 = lean_box(0); + lean_dec_ref(x_118); + x_127 = lean_box(0); } -if (lean_is_scalar(x_123)) { - x_124 = lean_alloc_ctor(0, 3, 0); -} else { - x_124 = x_123; -} -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_122); -lean_ctor_set(x_124, 2, x_104); -if (lean_is_scalar(x_120)) { - x_125 = lean_alloc_ctor(0, 6, 0); -} else { - x_125 = x_120; -} -lean_ctor_set(x_125, 0, x_115); -lean_ctor_set(x_125, 1, x_116); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_117); -lean_ctor_set(x_125, 4, x_118); -lean_ctor_set(x_125, 5, x_119); -if (lean_is_scalar(x_114)) { - x_126 = lean_alloc_ctor(0, 2, 0); -} else { - x_126 = x_114; -} -lean_ctor_set(x_126, 0, x_113); -lean_ctor_set(x_126, 1, x_125); -return x_126; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; -x_127 = lean_ctor_get(x_110, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 2); +x_128 = lean_ctor_get(x_119, 0); lean_inc(x_128); -x_129 = lean_ctor_get(x_110, 0); +x_129 = lean_ctor_get(x_119, 1); lean_inc(x_129); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_130 = x_110; +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_110); - x_130 = lean_box(0); + lean_dec_ref(x_119); + x_131 = lean_box(0); } -x_131 = lean_ctor_get(x_127, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 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); +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); +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_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_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; -} else { - lean_dec_ref(x_127); - x_136 = lean_box(0); -} -x_137 = lean_ctor_get(x_128, 0); +x_136 = lean_ctor_get(x_135, 2); +lean_inc(x_136); +x_137 = lean_ctor_get(x_117, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 1); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - x_139 = x_128; +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_128); - x_139 = lean_box(0); + lean_dec_ref(x_117); + x_138 = lean_box(0); } -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 3, 0); +x_139 = lean_ctor_get(x_135, 0); +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 { - x_140 = x_139; + lean_dec_ref(x_135); + x_144 = lean_box(0); } -lean_ctor_set(x_140, 0, x_137); -lean_ctor_set(x_140, 1, x_138); -lean_ctor_set(x_140, 2, x_104); -if (lean_is_scalar(x_136)) { - x_141 = lean_alloc_ctor(0, 6, 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; } else { - x_141 = x_136; + lean_dec_ref(x_136); + x_148 = lean_box(0); } -lean_ctor_set(x_141, 0, x_131); -lean_ctor_set(x_141, 1, x_132); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_133); -lean_ctor_set(x_141, 4, x_134); -lean_ctor_set(x_141, 5, x_135); -if (lean_is_scalar(x_130)) { - x_142 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 4, 0); } else { - x_142 = x_130; + x_149 = x_148; } -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; +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_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_143 = lean_ctor_get(x_22, 0); -x_144 = lean_ctor_get(x_22, 1); -x_145 = lean_ctor_get(x_22, 3); -x_146 = lean_ctor_get(x_22, 4); -x_147 = lean_ctor_get(x_22, 5); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); +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_dec(x_22); -x_148 = lean_ctor_get(x_23, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_23, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_23, 2); -lean_inc(x_150); +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); - x_151 = x_23; + lean_ctor_release(x_23, 3); + x_161 = x_23; } else { lean_dec_ref(x_23); - x_151 = lean_box(0); + x_161 = lean_box(0); } -x_152 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_151)) { - x_153 = lean_alloc_ctor(0, 3, 0); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_161)) { + x_163 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_151; + x_163 = x_161; } -lean_ctor_set(x_153, 0, x_148); -lean_ctor_set(x_153, 1, x_149); -lean_ctor_set(x_153, 2, x_152); -x_154 = 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); +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_inc(x_17); -x_155 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_155, 0, x_24); -lean_ctor_set(x_155, 1, x_17); -x_156 = lean_array_push(x_13, x_155); -x_157 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_157, 0, x_11); -lean_ctor_set(x_157, 1, x_16); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_14); -lean_ctor_set(x_157, 4, x_15); -x_158 = lean_apply_3(x_4, x_17, x_157, x_154); -if (lean_obj_tag(x_158) == 0) +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) { -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; -x_159 = lean_ctor_get(x_158, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_159, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_158, 0); -lean_inc(x_161); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_162 = x_158; -} else { - lean_dec_ref(x_158); - x_162 = lean_box(0); -} -x_163 = lean_ctor_get(x_159, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_159, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_159, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_159, 5); -lean_inc(x_167); -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); - lean_ctor_release(x_159, 5); - x_168 = x_159; -} else { - lean_dec_ref(x_159); - x_168 = lean_box(0); -} -x_169 = lean_ctor_get(x_160, 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_160, 1); +x_170 = lean_ctor_get(x_169, 2); 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); - x_171 = x_160; +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_160); - x_171 = lean_box(0); + lean_dec_ref(x_168); + x_172 = lean_box(0); } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 3, 0); -} else { - x_172 = x_171; -} -lean_ctor_set(x_172, 0, x_169); -lean_ctor_set(x_172, 1, x_170); -lean_ctor_set(x_172, 2, x_150); -if (lean_is_scalar(x_168)) { - x_173 = lean_alloc_ctor(0, 6, 0); -} else { - x_173 = x_168; -} -lean_ctor_set(x_173, 0, x_163); -lean_ctor_set(x_173, 1, x_164); -lean_ctor_set(x_173, 2, x_172); -lean_ctor_set(x_173, 3, x_165); -lean_ctor_set(x_173, 4, x_166); -lean_ctor_set(x_173, 5, x_167); -if (lean_is_scalar(x_162)) { - x_174 = lean_alloc_ctor(0, 2, 0); -} else { - x_174 = x_162; -} -lean_ctor_set(x_174, 0, x_161); -lean_ctor_set(x_174, 1, x_173); -return x_174; -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -x_175 = lean_ctor_get(x_158, 1); +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_175, 2); +x_176 = lean_ctor_get(x_169, 4); lean_inc(x_176); -x_177 = lean_ctor_get(x_158, 0); +x_177 = lean_ctor_get(x_169, 5); lean_inc(x_177); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_178 = x_158; +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_158); + lean_dec_ref(x_169); x_178 = lean_box(0); } -x_179 = lean_ctor_get(x_175, 0); +x_179 = lean_ctor_get(x_170, 0); lean_inc(x_179); -x_180 = lean_ctor_get(x_175, 1); +x_180 = lean_ctor_get(x_170, 1); lean_inc(x_180); -x_181 = lean_ctor_get(x_175, 3); +x_181 = lean_ctor_get(x_170, 3); lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 4); -lean_inc(x_182); -x_183 = lean_ctor_get(x_175, 5); -lean_inc(x_183); -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_184 = x_175; +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_175); - x_184 = lean_box(0); + lean_dec_ref(x_170); + x_182 = lean_box(0); } -x_185 = lean_ctor_get(x_176, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_176, 1); -lean_inc(x_186); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - lean_ctor_release(x_176, 2); - x_187 = x_176; +if (lean_is_scalar(x_182)) { + x_183 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_176); - x_187 = lean_box(0); + x_183 = x_182; } -if (lean_is_scalar(x_187)) { - x_188 = lean_alloc_ctor(0, 3, 0); -} else { - x_188 = x_187; -} -lean_ctor_set(x_188, 0, x_185); -lean_ctor_set(x_188, 1, x_186); -lean_ctor_set(x_188, 2, x_150); -if (lean_is_scalar(x_184)) { - x_189 = lean_alloc_ctor(0, 6, 0); -} else { - x_189 = x_184; -} -lean_ctor_set(x_189, 0, x_179); -lean_ctor_set(x_189, 1, x_180); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_181); -lean_ctor_set(x_189, 4, x_182); -lean_ctor_set(x_189, 5, x_183); +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_190 = lean_alloc_ctor(1, 2, 0); + x_184 = lean_alloc_ctor(0, 6, 0); } else { - x_190 = x_178; + x_184 = x_178; } -lean_ctor_set(x_190, 0, x_177); -lean_ctor_set(x_190, 1, x_189); -return x_190; +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_inc(x_191); +x_192 = lean_ctor_get(x_186, 3); +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_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_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; +} else { + lean_dec_ref(x_187); + x_199 = lean_box(0); +} +if (lean_is_scalar(x_199)) { + x_200 = lean_alloc_ctor(0, 4, 0); +} else { + x_200 = x_199; +} +lean_ctor_set(x_200, 0, x_196); +lean_ctor_set(x_200, 1, x_197); +lean_ctor_set(x_200, 2, x_159); +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_189)) { + x_202 = lean_alloc_ctor(1, 2, 0); +} else { + x_202 = x_189; +} +lean_ctor_set(x_202, 0, x_188); +lean_ctor_set(x_202, 1, x_201); +return x_202; } } } } else { -uint8_t x_191; +uint8_t x_203; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -44819,350 +46501,362 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_191 = !lean_is_exclusive(x_18); -if (x_191 == 0) +x_203 = !lean_is_exclusive(x_18); +if (x_203 == 0) { return x_18; } else { -lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_192 = lean_ctor_get(x_18, 0); -x_193 = lean_ctor_get(x_18, 1); -lean_inc(x_193); -lean_inc(x_192); +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_dec(x_18); -x_194 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_194, 0, x_192); -lean_ctor_set(x_194, 1, x_193); -return x_194; +x_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; } } } 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; -x_195 = lean_ctor_get(x_5, 0); -x_196 = lean_ctor_get(x_5, 1); -x_197 = lean_ctor_get(x_5, 2); -x_198 = lean_ctor_get(x_5, 3); -x_199 = lean_ctor_get(x_5, 4); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_196); -lean_inc(x_195); +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_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_200 = lean_local_ctx_mk_local_decl(x_196, x_8, x_1, x_2, x_3); -x_201 = l_Lean_mkFVar(x_8); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_200); -lean_inc(x_195); -x_202 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_202, 0, x_195); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_197); -lean_ctor_set(x_202, 3, x_198); -lean_ctor_set(x_202, 4, x_199); -lean_inc(x_202); -x_203 = l_Lean_Meta_isClass(x_2, x_202, x_9); -if (lean_obj_tag(x_203) == 0) -{ -lean_object* x_204; -x_204 = lean_ctor_get(x_203, 0); -lean_inc(x_204); -if (lean_obj_tag(x_204) == 0) -{ -lean_object* x_205; lean_object* x_206; -lean_dec(x_200); -lean_dec(x_199); -lean_dec(x_198); -lean_dec(x_197); -lean_dec(x_195); -x_205 = lean_ctor_get(x_203, 1); -lean_inc(x_205); -lean_dec(x_203); -x_206 = lean_apply_3(x_4, x_201, x_202, x_205); -return x_206; -} -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; 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_dec(x_202); -x_207 = lean_ctor_get(x_203, 1); -lean_inc(x_207); -lean_dec(x_203); -x_208 = lean_ctor_get(x_207, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_204, 0); -lean_inc(x_209); -lean_dec(x_204); -x_210 = lean_ctor_get(x_207, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_207, 1); +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_212 = lean_ctor_get(x_207, 3); +lean_inc(x_210); +lean_inc(x_209); lean_inc(x_212); -x_213 = lean_ctor_get(x_207, 4); -lean_inc(x_213); -x_214 = lean_ctor_get(x_207, 5); +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); -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_215 = x_207; -} else { - lean_dec_ref(x_207); - x_215 = lean_box(0); -} -x_216 = lean_ctor_get(x_208, 0); +x_215 = l_Lean_Meta_isClass(x_2, x_214, x_9); +if (lean_obj_tag(x_215) == 0) +{ +lean_object* x_216; +x_216 = lean_ctor_get(x_215, 0); lean_inc(x_216); -x_217 = lean_ctor_get(x_208, 1); +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_dec(x_209); +lean_dec(x_207); +x_217 = lean_ctor_get(x_215, 1); lean_inc(x_217); -x_218 = lean_ctor_get(x_208, 2); -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); - x_219 = x_208; -} else { - lean_dec_ref(x_208); - x_219 = lean_box(0); +lean_dec(x_215); +x_218 = lean_apply_3(x_4, x_213, x_214, x_217); +return x_218; } -x_220 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_219)) { - x_221 = lean_alloc_ctor(0, 3, 0); -} else { - x_221 = x_219; -} -lean_ctor_set(x_221, 0, x_216); -lean_ctor_set(x_221, 1, x_217); -lean_ctor_set(x_221, 2, x_220); -if (lean_is_scalar(x_215)) { - x_222 = lean_alloc_ctor(0, 6, 0); -} else { - x_222 = x_215; -} -lean_ctor_set(x_222, 0, x_210); -lean_ctor_set(x_222, 1, x_211); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_212); -lean_ctor_set(x_222, 4, x_213); -lean_ctor_set(x_222, 5, x_214); -lean_inc(x_201); -x_223 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_223, 0, x_209); -lean_ctor_set(x_223, 1, x_201); -x_224 = lean_array_push(x_197, x_223); -x_225 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_225, 0, x_195); -lean_ctor_set(x_225, 1, x_200); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_198); -lean_ctor_set(x_225, 4, x_199); -x_226 = lean_apply_3(x_4, x_201, x_225, x_222); -if (lean_obj_tag(x_226) == 0) +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; -x_227 = lean_ctor_get(x_226, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_227, 2); +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; +} else { + lean_dec_ref(x_219); + x_227 = lean_box(0); +} +x_228 = lean_ctor_get(x_220, 0); lean_inc(x_228); -x_229 = lean_ctor_get(x_226, 0); +x_229 = lean_ctor_get(x_220, 1); lean_inc(x_229); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - x_230 = x_226; -} else { - lean_dec_ref(x_226); - x_230 = lean_box(0); -} -x_231 = lean_ctor_get(x_227, 0); +x_230 = lean_ctor_get(x_220, 2); +lean_inc(x_230); +x_231 = lean_ctor_get(x_220, 3); lean_inc(x_231); -x_232 = lean_ctor_get(x_227, 1); -lean_inc(x_232); -x_233 = lean_ctor_get(x_227, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_227, 4); -lean_inc(x_234); -x_235 = lean_ctor_get(x_227, 5); -lean_inc(x_235); -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_236 = 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); + x_232 = x_220; } else { - lean_dec_ref(x_227); - x_236 = lean_box(0); + lean_dec_ref(x_220); + x_232 = lean_box(0); } -x_237 = lean_ctor_get(x_228, 0); -lean_inc(x_237); -x_238 = lean_ctor_get(x_228, 1); -lean_inc(x_238); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - lean_ctor_release(x_228, 2); - x_239 = x_228; +x_233 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_232)) { + x_234 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_228); - x_239 = lean_box(0); + x_234 = x_232; } -if (lean_is_scalar(x_239)) { - x_240 = lean_alloc_ctor(0, 3, 0); +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); +if (lean_is_scalar(x_227)) { + x_235 = lean_alloc_ctor(0, 6, 0); } else { - x_240 = x_239; + x_235 = x_227; } -lean_ctor_set(x_240, 0, x_237); -lean_ctor_set(x_240, 1, x_238); -lean_ctor_set(x_240, 2, x_218); -if (lean_is_scalar(x_236)) { - x_241 = lean_alloc_ctor(0, 6, 0); -} else { - x_241 = x_236; -} -lean_ctor_set(x_241, 0, x_231); -lean_ctor_set(x_241, 1, x_232); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_233); -lean_ctor_set(x_241, 4, x_234); -lean_ctor_set(x_241, 5, x_235); -if (lean_is_scalar(x_230)) { - x_242 = lean_alloc_ctor(0, 2, 0); -} else { - x_242 = x_230; -} -lean_ctor_set(x_242, 0, x_229); -lean_ctor_set(x_242, 1, x_241); -return x_242; -} -else +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_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; -x_243 = lean_ctor_get(x_226, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_243, 2); +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_226, 0); +x_245 = lean_ctor_get(x_240, 1); lean_inc(x_245); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - x_246 = x_226; -} else { - lean_dec_ref(x_226); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_243, 0); +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_243, 1); +x_248 = lean_ctor_get(x_240, 5); lean_inc(x_248); -x_249 = lean_ctor_get(x_243, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_243, 4); +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_243, 5); +x_251 = lean_ctor_get(x_241, 1); 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; +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_243); - x_252 = lean_box(0); + lean_dec_ref(x_241); + x_253 = 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); -if (lean_is_exclusive(x_244)) { - lean_ctor_release(x_244, 0); - lean_ctor_release(x_244, 1); - lean_ctor_release(x_244, 2); - x_255 = x_244; +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_244); - x_255 = lean_box(0); + x_254 = x_253; } -if (lean_is_scalar(x_255)) { - x_256 = lean_alloc_ctor(0, 3, 0); +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_256 = x_255; + x_255 = x_249; } -lean_ctor_set(x_256, 0, x_253); -lean_ctor_set(x_256, 1, x_254); -lean_ctor_set(x_256, 2, x_218); -if (lean_is_scalar(x_252)) { - x_257 = lean_alloc_ctor(0, 6, 0); +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_257 = x_252; + x_256 = x_243; } -lean_ctor_set(x_257, 0, x_247); -lean_ctor_set(x_257, 1, x_248); -lean_ctor_set(x_257, 2, x_256); -lean_ctor_set(x_257, 3, x_249); -lean_ctor_set(x_257, 4, x_250); -lean_ctor_set(x_257, 5, x_251); -if (lean_is_scalar(x_246)) { - x_258 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_256, 0, x_242); +lean_ctor_set(x_256, 1, x_255); +return x_256; +} +else +{ +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; 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 { - x_258 = x_246; + lean_dec_ref(x_239); + x_260 = lean_box(0); } -lean_ctor_set(x_258, 0, x_245); -lean_ctor_set(x_258, 1, x_257); -return x_258; +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_230); +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 { -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; -lean_dec(x_202); -lean_dec(x_201); -lean_dec(x_200); -lean_dec(x_199); -lean_dec(x_198); -lean_dec(x_197); -lean_dec(x_195); +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_207); lean_dec(x_4); -x_259 = lean_ctor_get(x_203, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_203, 1); -lean_inc(x_260); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - x_261 = x_203; +x_274 = lean_ctor_get(x_215, 0); +lean_inc(x_274); +x_275 = lean_ctor_get(x_215, 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; } else { - lean_dec_ref(x_203); - x_261 = lean_box(0); + lean_dec_ref(x_215); + x_276 = lean_box(0); } -if (lean_is_scalar(x_261)) { - x_262 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(1, 2, 0); } else { - x_262 = x_261; + x_277 = x_276; } -lean_ctor_set(x_262, 0, x_259); -lean_ctor_set(x_262, 1, x_260); -return x_262; +lean_ctor_set(x_277, 0, x_274); +lean_ctor_set(x_277, 1, x_275); +return x_277; } } } @@ -45319,82 +47013,89 @@ return x_33; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; +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_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -lean_ctor_set(x_44, 2, x_28); -lean_ctor_set(x_34, 2, x_44); +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; } } 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_34, 0); -x_46 = lean_ctor_get(x_34, 1); -x_47 = lean_ctor_get(x_34, 3); -x_48 = lean_ctor_get(x_34, 4); -x_49 = lean_ctor_get(x_34, 5); +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_inc(x_48); lean_inc(x_47); lean_inc(x_46); -lean_inc(x_45); lean_dec(x_34); -x_50 = lean_ctor_get(x_35, 0); -lean_inc(x_50); -x_51 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 0); 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); - x_52 = x_35; + lean_ctor_release(x_35, 3); + x_54 = x_35; } else { lean_dec_ref(x_35); - x_52 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - x_53 = x_52; + x_55 = x_54; } -lean_ctor_set(x_53, 0, x_50); -lean_ctor_set(x_53, 1, x_51); -lean_ctor_set(x_53, 2, x_28); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_45); -lean_ctor_set(x_54, 1, x_46); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_47); -lean_ctor_set(x_54, 4, x_48); -lean_ctor_set(x_54, 5, x_49); -lean_ctor_set(x_33, 1, 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_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; } } 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; -x_55 = lean_ctor_get(x_33, 0); -lean_inc(x_55); -lean_dec(x_33); -x_56 = lean_ctor_get(x_34, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_34, 1); +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_inc(x_57); -x_58 = lean_ctor_get(x_34, 3); +lean_dec(x_33); +x_58 = lean_ctor_get(x_34, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_34, 4); +x_59 = lean_ctor_get(x_34, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_34, 5); +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); @@ -45402,619 +47103,657 @@ if (lean_is_exclusive(x_34)) { lean_ctor_release(x_34, 3); lean_ctor_release(x_34, 4); lean_ctor_release(x_34, 5); - x_61 = x_34; + x_63 = x_34; } else { lean_dec_ref(x_34); - x_61 = lean_box(0); + x_63 = lean_box(0); } -x_62 = lean_ctor_get(x_35, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_35, 1); -lean_inc(x_63); +x_64 = lean_ctor_get(x_35, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_35, 1); +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); - x_64 = x_35; + lean_ctor_release(x_35, 3); + x_67 = x_35; } else { lean_dec_ref(x_35); - x_64 = lean_box(0); + x_67 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 4, 0); } else { - x_65 = x_64; + x_68 = x_67; } -lean_ctor_set(x_65, 0, x_62); -lean_ctor_set(x_65, 1, x_63); -lean_ctor_set(x_65, 2, x_28); -if (lean_is_scalar(x_61)) { - x_66 = lean_alloc_ctor(0, 6, 0); +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_66 = x_61; + x_69 = x_63; } -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); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_55); -lean_ctor_set(x_67, 1, x_66); -return x_67; +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; } } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_68 = lean_ctor_get(x_33, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_68, 2); -lean_inc(x_69); -x_70 = !lean_is_exclusive(x_33); -if (x_70 == 0) -{ -lean_object* x_71; uint8_t x_72; +lean_object* x_71; lean_object* x_72; uint8_t x_73; x_71 = lean_ctor_get(x_33, 1); -lean_dec(x_71); -x_72 = !lean_is_exclusive(x_68); -if (x_72 == 0) +lean_inc(x_71); +x_72 = lean_ctor_get(x_71, 2); +lean_inc(x_72); +x_73 = !lean_is_exclusive(x_33); +if (x_73 == 0) { -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_68, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_69); -if (x_74 == 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_75; -x_75 = lean_ctor_get(x_69, 2); -lean_dec(x_75); -lean_ctor_set(x_69, 2, x_28); +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_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_69, 0); -x_77 = lean_ctor_get(x_69, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_69); -x_78 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -lean_ctor_set(x_78, 2, x_28); -lean_ctor_set(x_68, 2, x_78); -return x_33; -} -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_79 = lean_ctor_get(x_68, 0); -x_80 = lean_ctor_get(x_68, 1); -x_81 = lean_ctor_get(x_68, 3); -x_82 = lean_ctor_get(x_68, 4); -x_83 = lean_ctor_get(x_68, 5); -lean_inc(x_83); -lean_inc(x_82); +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_68); -x_84 = lean_ctor_get(x_69, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_69, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - x_86 = x_69; -} else { - lean_dec_ref(x_69); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 3, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -lean_ctor_set(x_87, 2, x_28); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_79); -lean_ctor_set(x_88, 1, x_80); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_81); -lean_ctor_set(x_88, 4, x_82); -lean_ctor_set(x_88, 5, x_83); -lean_ctor_set(x_33, 1, x_88); +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_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_89 = lean_ctor_get(x_33, 0); +lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_83 = lean_ctor_get(x_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); -lean_dec(x_33); -x_90 = lean_ctor_get(x_68, 0); +x_90 = lean_ctor_get(x_72, 3); lean_inc(x_90); -x_91 = lean_ctor_get(x_68, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_68, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_68, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_68, 5); +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; +} else { + lean_dec_ref(x_72); + x_91 = lean_box(0); +} +if (lean_is_scalar(x_91)) { + x_92 = lean_alloc_ctor(0, 4, 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_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); -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_95 = x_68; -} else { - lean_dec_ref(x_68); - x_95 = lean_box(0); -} -x_96 = lean_ctor_get(x_69, 0); +lean_dec(x_33); +x_95 = lean_ctor_get(x_71, 0); +lean_inc(x_95); +x_96 = lean_ctor_get(x_71, 1); lean_inc(x_96); -x_97 = lean_ctor_get(x_69, 1); +x_97 = lean_ctor_get(x_71, 3); lean_inc(x_97); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - x_98 = x_69; +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_69); - x_98 = lean_box(0); + lean_dec_ref(x_71); + x_100 = lean_box(0); } -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 3, 0); -} else { - x_99 = x_98; -} -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -lean_ctor_set(x_99, 2, x_28); -if (lean_is_scalar(x_95)) { - x_100 = lean_alloc_ctor(0, 6, 0); -} else { - x_100 = x_95; -} -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); -x_101 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_101, 0, x_89); -lean_ctor_set(x_101, 1, x_100); -return x_101; -} -} -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_102 = lean_ctor_get(x_23, 0); -x_103 = lean_ctor_get(x_23, 1); -x_104 = lean_ctor_get(x_23, 2); -lean_inc(x_104); -lean_inc(x_103); +x_101 = lean_ctor_get(x_72, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_72, 1); lean_inc(x_102); -lean_dec(x_23); -x_105 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_106 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_106, 0, x_102); -lean_ctor_set(x_106, 1, x_103); +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_22, 2, x_106); -lean_inc(x_17); -x_107 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_107, 0, x_24); -lean_ctor_set(x_107, 1, x_17); -x_108 = lean_array_push(x_13, x_107); -x_109 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_109, 0, x_11); -lean_ctor_set(x_109, 1, x_16); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_14); -lean_ctor_set(x_109, 4, x_15); -x_110 = lean_apply_3(x_4, x_17, x_109, x_22); -if (lean_obj_tag(x_110) == 0) +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_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_111 = lean_ctor_get(x_110, 1); +lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; 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); -x_112 = lean_ctor_get(x_111, 2); -lean_inc(x_112); -x_113 = lean_ctor_get(x_110, 0); -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_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_111, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_111, 4); +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_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_111, 5); +x_119 = lean_ctor_get(x_118, 2); lean_inc(x_119); -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_120 = x_111; +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_111); - x_120 = lean_box(0); + lean_dec_ref(x_117); + x_121 = lean_box(0); } -x_121 = lean_ctor_get(x_112, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_112, 1); +x_122 = lean_ctor_get(x_118, 0); lean_inc(x_122); -if (lean_is_exclusive(x_112)) { - lean_ctor_release(x_112, 0); - lean_ctor_release(x_112, 1); - lean_ctor_release(x_112, 2); - x_123 = x_112; +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_112); - x_123 = lean_box(0); + lean_dec_ref(x_118); + x_127 = lean_box(0); } -if (lean_is_scalar(x_123)) { - x_124 = lean_alloc_ctor(0, 3, 0); -} else { - x_124 = x_123; -} -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_122); -lean_ctor_set(x_124, 2, x_104); -if (lean_is_scalar(x_120)) { - x_125 = lean_alloc_ctor(0, 6, 0); -} else { - x_125 = x_120; -} -lean_ctor_set(x_125, 0, x_115); -lean_ctor_set(x_125, 1, x_116); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_117); -lean_ctor_set(x_125, 4, x_118); -lean_ctor_set(x_125, 5, x_119); -if (lean_is_scalar(x_114)) { - x_126 = lean_alloc_ctor(0, 2, 0); -} else { - x_126 = x_114; -} -lean_ctor_set(x_126, 0, x_113); -lean_ctor_set(x_126, 1, x_125); -return x_126; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; -x_127 = lean_ctor_get(x_110, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 2); +x_128 = lean_ctor_get(x_119, 0); lean_inc(x_128); -x_129 = lean_ctor_get(x_110, 0); +x_129 = lean_ctor_get(x_119, 1); lean_inc(x_129); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_130 = x_110; +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_110); - x_130 = lean_box(0); + lean_dec_ref(x_119); + x_131 = lean_box(0); } -x_131 = lean_ctor_get(x_127, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 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); +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); +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_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_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; -} else { - lean_dec_ref(x_127); - x_136 = lean_box(0); -} -x_137 = lean_ctor_get(x_128, 0); +x_136 = lean_ctor_get(x_135, 2); +lean_inc(x_136); +x_137 = lean_ctor_get(x_117, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 1); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - x_139 = x_128; +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_128); - x_139 = lean_box(0); + lean_dec_ref(x_117); + x_138 = lean_box(0); } -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 3, 0); +x_139 = lean_ctor_get(x_135, 0); +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 { - x_140 = x_139; + lean_dec_ref(x_135); + x_144 = lean_box(0); } -lean_ctor_set(x_140, 0, x_137); -lean_ctor_set(x_140, 1, x_138); -lean_ctor_set(x_140, 2, x_104); -if (lean_is_scalar(x_136)) { - x_141 = lean_alloc_ctor(0, 6, 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; } else { - x_141 = x_136; + lean_dec_ref(x_136); + x_148 = lean_box(0); } -lean_ctor_set(x_141, 0, x_131); -lean_ctor_set(x_141, 1, x_132); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_133); -lean_ctor_set(x_141, 4, x_134); -lean_ctor_set(x_141, 5, x_135); -if (lean_is_scalar(x_130)) { - x_142 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 4, 0); } else { - x_142 = x_130; + x_149 = x_148; } -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; +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_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_143 = lean_ctor_get(x_22, 0); -x_144 = lean_ctor_get(x_22, 1); -x_145 = lean_ctor_get(x_22, 3); -x_146 = lean_ctor_get(x_22, 4); -x_147 = lean_ctor_get(x_22, 5); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); +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_dec(x_22); -x_148 = lean_ctor_get(x_23, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_23, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_23, 2); -lean_inc(x_150); +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); - x_151 = x_23; + lean_ctor_release(x_23, 3); + x_161 = x_23; } else { lean_dec_ref(x_23); - x_151 = lean_box(0); + x_161 = lean_box(0); } -x_152 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_151)) { - x_153 = lean_alloc_ctor(0, 3, 0); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_161)) { + x_163 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_151; + x_163 = x_161; } -lean_ctor_set(x_153, 0, x_148); -lean_ctor_set(x_153, 1, x_149); -lean_ctor_set(x_153, 2, x_152); -x_154 = 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); +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_inc(x_17); -x_155 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_155, 0, x_24); -lean_ctor_set(x_155, 1, x_17); -x_156 = lean_array_push(x_13, x_155); -x_157 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_157, 0, x_11); -lean_ctor_set(x_157, 1, x_16); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_14); -lean_ctor_set(x_157, 4, x_15); -x_158 = lean_apply_3(x_4, x_17, x_157, x_154); -if (lean_obj_tag(x_158) == 0) +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) { -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; -x_159 = lean_ctor_get(x_158, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_159, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_158, 0); -lean_inc(x_161); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_162 = x_158; -} else { - lean_dec_ref(x_158); - x_162 = lean_box(0); -} -x_163 = lean_ctor_get(x_159, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_159, 3); -lean_inc(x_165); -x_166 = lean_ctor_get(x_159, 4); -lean_inc(x_166); -x_167 = lean_ctor_get(x_159, 5); -lean_inc(x_167); -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); - lean_ctor_release(x_159, 5); - x_168 = x_159; -} else { - lean_dec_ref(x_159); - x_168 = lean_box(0); -} -x_169 = lean_ctor_get(x_160, 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_160, 1); +x_170 = lean_ctor_get(x_169, 2); 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); - x_171 = x_160; +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_160); - x_171 = lean_box(0); + lean_dec_ref(x_168); + x_172 = lean_box(0); } -if (lean_is_scalar(x_171)) { - x_172 = lean_alloc_ctor(0, 3, 0); -} else { - x_172 = x_171; -} -lean_ctor_set(x_172, 0, x_169); -lean_ctor_set(x_172, 1, x_170); -lean_ctor_set(x_172, 2, x_150); -if (lean_is_scalar(x_168)) { - x_173 = lean_alloc_ctor(0, 6, 0); -} else { - x_173 = x_168; -} -lean_ctor_set(x_173, 0, x_163); -lean_ctor_set(x_173, 1, x_164); -lean_ctor_set(x_173, 2, x_172); -lean_ctor_set(x_173, 3, x_165); -lean_ctor_set(x_173, 4, x_166); -lean_ctor_set(x_173, 5, x_167); -if (lean_is_scalar(x_162)) { - x_174 = lean_alloc_ctor(0, 2, 0); -} else { - x_174 = x_162; -} -lean_ctor_set(x_174, 0, x_161); -lean_ctor_set(x_174, 1, x_173); -return x_174; -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -x_175 = lean_ctor_get(x_158, 1); +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_175, 2); +x_176 = lean_ctor_get(x_169, 4); lean_inc(x_176); -x_177 = lean_ctor_get(x_158, 0); +x_177 = lean_ctor_get(x_169, 5); lean_inc(x_177); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - x_178 = x_158; +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_158); + lean_dec_ref(x_169); x_178 = lean_box(0); } -x_179 = lean_ctor_get(x_175, 0); +x_179 = lean_ctor_get(x_170, 0); lean_inc(x_179); -x_180 = lean_ctor_get(x_175, 1); +x_180 = lean_ctor_get(x_170, 1); lean_inc(x_180); -x_181 = lean_ctor_get(x_175, 3); +x_181 = lean_ctor_get(x_170, 3); lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 4); -lean_inc(x_182); -x_183 = lean_ctor_get(x_175, 5); -lean_inc(x_183); -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_184 = x_175; +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_175); - x_184 = lean_box(0); + lean_dec_ref(x_170); + x_182 = lean_box(0); } -x_185 = lean_ctor_get(x_176, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_176, 1); -lean_inc(x_186); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - lean_ctor_release(x_176, 2); - x_187 = x_176; +if (lean_is_scalar(x_182)) { + x_183 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_176); - x_187 = lean_box(0); + x_183 = x_182; } -if (lean_is_scalar(x_187)) { - x_188 = lean_alloc_ctor(0, 3, 0); -} else { - x_188 = x_187; -} -lean_ctor_set(x_188, 0, x_185); -lean_ctor_set(x_188, 1, x_186); -lean_ctor_set(x_188, 2, x_150); -if (lean_is_scalar(x_184)) { - x_189 = lean_alloc_ctor(0, 6, 0); -} else { - x_189 = x_184; -} -lean_ctor_set(x_189, 0, x_179); -lean_ctor_set(x_189, 1, x_180); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_181); -lean_ctor_set(x_189, 4, x_182); -lean_ctor_set(x_189, 5, x_183); +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_190 = lean_alloc_ctor(1, 2, 0); + x_184 = lean_alloc_ctor(0, 6, 0); } else { - x_190 = x_178; + x_184 = x_178; } -lean_ctor_set(x_190, 0, x_177); -lean_ctor_set(x_190, 1, x_189); -return x_190; +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_inc(x_191); +x_192 = lean_ctor_get(x_186, 3); +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_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_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; +} else { + lean_dec_ref(x_187); + x_199 = lean_box(0); +} +if (lean_is_scalar(x_199)) { + x_200 = lean_alloc_ctor(0, 4, 0); +} else { + x_200 = x_199; +} +lean_ctor_set(x_200, 0, x_196); +lean_ctor_set(x_200, 1, x_197); +lean_ctor_set(x_200, 2, x_159); +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_189)) { + x_202 = lean_alloc_ctor(1, 2, 0); +} else { + x_202 = x_189; +} +lean_ctor_set(x_202, 0, x_188); +lean_ctor_set(x_202, 1, x_201); +return x_202; } } } } else { -uint8_t x_191; +uint8_t x_203; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -46023,350 +47762,362 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_191 = !lean_is_exclusive(x_18); -if (x_191 == 0) +x_203 = !lean_is_exclusive(x_18); +if (x_203 == 0) { return x_18; } else { -lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_192 = lean_ctor_get(x_18, 0); -x_193 = lean_ctor_get(x_18, 1); -lean_inc(x_193); -lean_inc(x_192); +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_dec(x_18); -x_194 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_194, 0, x_192); -lean_ctor_set(x_194, 1, x_193); -return x_194; +x_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; } } } 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; -x_195 = lean_ctor_get(x_5, 0); -x_196 = lean_ctor_get(x_5, 1); -x_197 = lean_ctor_get(x_5, 2); -x_198 = lean_ctor_get(x_5, 3); -x_199 = lean_ctor_get(x_5, 4); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_196); -lean_inc(x_195); +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_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_200 = lean_local_ctx_mk_let_decl(x_196, x_8, x_1, x_2, x_3); -x_201 = l_Lean_mkFVar(x_8); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_200); -lean_inc(x_195); -x_202 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_202, 0, x_195); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_197); -lean_ctor_set(x_202, 3, x_198); -lean_ctor_set(x_202, 4, x_199); -lean_inc(x_202); -x_203 = l_Lean_Meta_isClass(x_2, x_202, x_9); -if (lean_obj_tag(x_203) == 0) -{ -lean_object* x_204; -x_204 = lean_ctor_get(x_203, 0); -lean_inc(x_204); -if (lean_obj_tag(x_204) == 0) -{ -lean_object* x_205; lean_object* x_206; -lean_dec(x_200); -lean_dec(x_199); -lean_dec(x_198); -lean_dec(x_197); -lean_dec(x_195); -x_205 = lean_ctor_get(x_203, 1); -lean_inc(x_205); -lean_dec(x_203); -x_206 = lean_apply_3(x_4, x_201, x_202, x_205); -return x_206; -} -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; 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_dec(x_202); -x_207 = lean_ctor_get(x_203, 1); -lean_inc(x_207); -lean_dec(x_203); -x_208 = lean_ctor_get(x_207, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_204, 0); -lean_inc(x_209); -lean_dec(x_204); -x_210 = lean_ctor_get(x_207, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_207, 1); +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_212 = lean_ctor_get(x_207, 3); +lean_inc(x_210); +lean_inc(x_209); lean_inc(x_212); -x_213 = lean_ctor_get(x_207, 4); -lean_inc(x_213); -x_214 = lean_ctor_get(x_207, 5); +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); -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_215 = x_207; -} else { - lean_dec_ref(x_207); - x_215 = lean_box(0); -} -x_216 = lean_ctor_get(x_208, 0); +x_215 = l_Lean_Meta_isClass(x_2, x_214, x_9); +if (lean_obj_tag(x_215) == 0) +{ +lean_object* x_216; +x_216 = lean_ctor_get(x_215, 0); lean_inc(x_216); -x_217 = lean_ctor_get(x_208, 1); +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_dec(x_209); +lean_dec(x_207); +x_217 = lean_ctor_get(x_215, 1); lean_inc(x_217); -x_218 = lean_ctor_get(x_208, 2); -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); - x_219 = x_208; -} else { - lean_dec_ref(x_208); - x_219 = lean_box(0); +lean_dec(x_215); +x_218 = lean_apply_3(x_4, x_213, x_214, x_217); +return x_218; } -x_220 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_219)) { - x_221 = lean_alloc_ctor(0, 3, 0); -} else { - x_221 = x_219; -} -lean_ctor_set(x_221, 0, x_216); -lean_ctor_set(x_221, 1, x_217); -lean_ctor_set(x_221, 2, x_220); -if (lean_is_scalar(x_215)) { - x_222 = lean_alloc_ctor(0, 6, 0); -} else { - x_222 = x_215; -} -lean_ctor_set(x_222, 0, x_210); -lean_ctor_set(x_222, 1, x_211); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_212); -lean_ctor_set(x_222, 4, x_213); -lean_ctor_set(x_222, 5, x_214); -lean_inc(x_201); -x_223 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_223, 0, x_209); -lean_ctor_set(x_223, 1, x_201); -x_224 = lean_array_push(x_197, x_223); -x_225 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_225, 0, x_195); -lean_ctor_set(x_225, 1, x_200); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_198); -lean_ctor_set(x_225, 4, x_199); -x_226 = lean_apply_3(x_4, x_201, x_225, x_222); -if (lean_obj_tag(x_226) == 0) +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; -x_227 = lean_ctor_get(x_226, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_227, 2); +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; +} else { + lean_dec_ref(x_219); + x_227 = lean_box(0); +} +x_228 = lean_ctor_get(x_220, 0); lean_inc(x_228); -x_229 = lean_ctor_get(x_226, 0); +x_229 = lean_ctor_get(x_220, 1); lean_inc(x_229); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - x_230 = x_226; -} else { - lean_dec_ref(x_226); - x_230 = lean_box(0); -} -x_231 = lean_ctor_get(x_227, 0); +x_230 = lean_ctor_get(x_220, 2); +lean_inc(x_230); +x_231 = lean_ctor_get(x_220, 3); lean_inc(x_231); -x_232 = lean_ctor_get(x_227, 1); -lean_inc(x_232); -x_233 = lean_ctor_get(x_227, 3); -lean_inc(x_233); -x_234 = lean_ctor_get(x_227, 4); -lean_inc(x_234); -x_235 = lean_ctor_get(x_227, 5); -lean_inc(x_235); -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_236 = 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); + x_232 = x_220; } else { - lean_dec_ref(x_227); - x_236 = lean_box(0); + lean_dec_ref(x_220); + x_232 = lean_box(0); } -x_237 = lean_ctor_get(x_228, 0); -lean_inc(x_237); -x_238 = lean_ctor_get(x_228, 1); -lean_inc(x_238); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - lean_ctor_release(x_228, 2); - x_239 = x_228; +x_233 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_232)) { + x_234 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_228); - x_239 = lean_box(0); + x_234 = x_232; } -if (lean_is_scalar(x_239)) { - x_240 = lean_alloc_ctor(0, 3, 0); +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); +if (lean_is_scalar(x_227)) { + x_235 = lean_alloc_ctor(0, 6, 0); } else { - x_240 = x_239; + x_235 = x_227; } -lean_ctor_set(x_240, 0, x_237); -lean_ctor_set(x_240, 1, x_238); -lean_ctor_set(x_240, 2, x_218); -if (lean_is_scalar(x_236)) { - x_241 = lean_alloc_ctor(0, 6, 0); -} else { - x_241 = x_236; -} -lean_ctor_set(x_241, 0, x_231); -lean_ctor_set(x_241, 1, x_232); -lean_ctor_set(x_241, 2, x_240); -lean_ctor_set(x_241, 3, x_233); -lean_ctor_set(x_241, 4, x_234); -lean_ctor_set(x_241, 5, x_235); -if (lean_is_scalar(x_230)) { - x_242 = lean_alloc_ctor(0, 2, 0); -} else { - x_242 = x_230; -} -lean_ctor_set(x_242, 0, x_229); -lean_ctor_set(x_242, 1, x_241); -return x_242; -} -else +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_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; -x_243 = lean_ctor_get(x_226, 1); -lean_inc(x_243); -x_244 = lean_ctor_get(x_243, 2); +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_226, 0); +x_245 = lean_ctor_get(x_240, 1); lean_inc(x_245); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - x_246 = x_226; -} else { - lean_dec_ref(x_226); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_243, 0); +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_243, 1); +x_248 = lean_ctor_get(x_240, 5); lean_inc(x_248); -x_249 = lean_ctor_get(x_243, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_243, 4); +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_243, 5); +x_251 = lean_ctor_get(x_241, 1); 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; +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_243); - x_252 = lean_box(0); + lean_dec_ref(x_241); + x_253 = 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); -if (lean_is_exclusive(x_244)) { - lean_ctor_release(x_244, 0); - lean_ctor_release(x_244, 1); - lean_ctor_release(x_244, 2); - x_255 = x_244; +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_244); - x_255 = lean_box(0); + x_254 = x_253; } -if (lean_is_scalar(x_255)) { - x_256 = lean_alloc_ctor(0, 3, 0); +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_256 = x_255; + x_255 = x_249; } -lean_ctor_set(x_256, 0, x_253); -lean_ctor_set(x_256, 1, x_254); -lean_ctor_set(x_256, 2, x_218); -if (lean_is_scalar(x_252)) { - x_257 = lean_alloc_ctor(0, 6, 0); +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_257 = x_252; + x_256 = x_243; } -lean_ctor_set(x_257, 0, x_247); -lean_ctor_set(x_257, 1, x_248); -lean_ctor_set(x_257, 2, x_256); -lean_ctor_set(x_257, 3, x_249); -lean_ctor_set(x_257, 4, x_250); -lean_ctor_set(x_257, 5, x_251); -if (lean_is_scalar(x_246)) { - x_258 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_256, 0, x_242); +lean_ctor_set(x_256, 1, x_255); +return x_256; +} +else +{ +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; 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 { - x_258 = x_246; + lean_dec_ref(x_239); + x_260 = lean_box(0); } -lean_ctor_set(x_258, 0, x_245); -lean_ctor_set(x_258, 1, x_257); -return x_258; +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_230); +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 { -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; -lean_dec(x_202); -lean_dec(x_201); -lean_dec(x_200); -lean_dec(x_199); -lean_dec(x_198); -lean_dec(x_197); -lean_dec(x_195); +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_207); lean_dec(x_4); -x_259 = lean_ctor_get(x_203, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_203, 1); -lean_inc(x_260); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - x_261 = x_203; +x_274 = lean_ctor_get(x_215, 0); +lean_inc(x_274); +x_275 = lean_ctor_get(x_215, 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; } else { - lean_dec_ref(x_203); - x_261 = lean_box(0); + lean_dec_ref(x_215); + x_276 = lean_box(0); } -if (lean_is_scalar(x_261)) { - x_262 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(1, 2, 0); } else { - x_262 = x_261; + x_277 = x_276; } -lean_ctor_set(x_262, 0, x_259); -lean_ctor_set(x_262, 1, x_260); -return x_262; +lean_ctor_set(x_277, 0, x_274); +lean_ctor_set(x_277, 1, x_275); +return x_277; } } } @@ -46789,33 +48540,33 @@ lean_ctor_set(x_13, 3, x_8); lean_ctor_set(x_13, 4, x_9); if (x_12 == 0) { -lean_object* x_174; +lean_object* x_186; lean_dec(x_2); -x_174 = lean_box(0); -x_14 = x_174; -goto block_173; +x_186 = lean_box(0); +x_14 = x_186; +goto block_185; } else { -lean_object* x_175; uint8_t x_176; -x_175 = lean_unsigned_to_nat(0u); -x_176 = l_Array_isEqvAux___main___at_Lean_Meta_withLocalContext___spec__1(x_2, x_4, lean_box(0), x_2, x_7, x_175); +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_dec(x_2); -if (x_176 == 0) +if (x_188 == 0) { -lean_object* x_177; -x_177 = lean_box(0); -x_14 = x_177; -goto block_173; +lean_object* x_189; +x_189 = lean_box(0); +x_14 = x_189; +goto block_185; } else { -lean_object* x_178; -x_178 = lean_apply_2(x_3, x_13, x_5); -return x_178; +lean_object* x_190; +x_190 = lean_apply_2(x_3, x_13, x_5); +return x_190; } } -block_173: +block_185: { uint8_t x_15; lean_dec(x_14); @@ -46862,82 +48613,89 @@ return x_20; } else { -lean_object* x_29; lean_object* x_30; lean_object* x_31; +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_inc(x_30); lean_inc(x_29); lean_dec(x_22); -x_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -lean_ctor_set(x_31, 2, x_18); -lean_ctor_set(x_21, 2, x_31); +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; } } 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; -x_32 = lean_ctor_get(x_21, 0); -x_33 = lean_ctor_get(x_21, 1); -x_34 = lean_ctor_get(x_21, 3); -x_35 = lean_ctor_get(x_21, 4); -x_36 = 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; +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_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); -lean_inc(x_32); lean_dec(x_21); -x_37 = lean_ctor_get(x_22, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_22, 1); +x_38 = lean_ctor_get(x_22, 0); lean_inc(x_38); +x_39 = lean_ctor_get(x_22, 1); +lean_inc(x_39); +x_40 = lean_ctor_get(x_22, 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); - x_39 = x_22; + lean_ctor_release(x_22, 3); + x_41 = x_22; } else { lean_dec_ref(x_22); - x_39 = lean_box(0); + x_41 = lean_box(0); } -if (lean_is_scalar(x_39)) { - x_40 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_41)) { + x_42 = lean_alloc_ctor(0, 4, 0); } else { - x_40 = x_39; + x_42 = x_41; } -lean_ctor_set(x_40, 0, x_37); -lean_ctor_set(x_40, 1, x_38); -lean_ctor_set(x_40, 2, x_18); -x_41 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_41, 0, x_32); -lean_ctor_set(x_41, 1, x_33); -lean_ctor_set(x_41, 2, x_40); -lean_ctor_set(x_41, 3, x_34); -lean_ctor_set(x_41, 4, x_35); -lean_ctor_set(x_41, 5, x_36); -lean_ctor_set(x_20, 1, 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_18); +lean_ctor_set(x_42, 3, x_40); +x_43 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_43, 0, x_33); +lean_ctor_set(x_43, 1, x_34); +lean_ctor_set(x_43, 2, x_42); +lean_ctor_set(x_43, 3, x_35); +lean_ctor_set(x_43, 4, x_36); +lean_ctor_set(x_43, 5, x_37); +lean_ctor_set(x_20, 1, x_43); return x_20; } } 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; -x_42 = lean_ctor_get(x_20, 0); -lean_inc(x_42); -lean_dec(x_20); -x_43 = lean_ctor_get(x_21, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_21, 1); +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_44 = lean_ctor_get(x_20, 0); lean_inc(x_44); -x_45 = lean_ctor_get(x_21, 3); +lean_dec(x_20); +x_45 = lean_ctor_get(x_21, 0); lean_inc(x_45); -x_46 = lean_ctor_get(x_21, 4); +x_46 = lean_ctor_get(x_21, 1); lean_inc(x_46); -x_47 = lean_ctor_get(x_21, 5); +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); @@ -46945,592 +48703,630 @@ if (lean_is_exclusive(x_21)) { lean_ctor_release(x_21, 3); lean_ctor_release(x_21, 4); lean_ctor_release(x_21, 5); - x_48 = x_21; + x_50 = x_21; } else { lean_dec_ref(x_21); - x_48 = lean_box(0); + x_50 = lean_box(0); } -x_49 = lean_ctor_get(x_22, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_22, 1); -lean_inc(x_50); +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); +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); - x_51 = x_22; + lean_ctor_release(x_22, 3); + x_54 = x_22; } else { lean_dec_ref(x_22); - x_51 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_51)) { - x_52 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - x_52 = x_51; + x_55 = x_54; } -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_18); -if (lean_is_scalar(x_48)) { - x_53 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_55, 0, x_51); +lean_ctor_set(x_55, 1, x_52); +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_53 = x_48; + x_56 = x_50; } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_44); -lean_ctor_set(x_53, 2, x_52); -lean_ctor_set(x_53, 3, x_45); -lean_ctor_set(x_53, 4, x_46); -lean_ctor_set(x_53, 5, x_47); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_42); -lean_ctor_set(x_54, 1, x_53); -return x_54; +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; } } else { -lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_55 = lean_ctor_get(x_20, 1); -lean_inc(x_55); -x_56 = lean_ctor_get(x_55, 2); -lean_inc(x_56); -x_57 = !lean_is_exclusive(x_20); -if (x_57 == 0) -{ -lean_object* x_58; uint8_t x_59; +lean_object* x_58; lean_object* x_59; uint8_t x_60; x_58 = lean_ctor_get(x_20, 1); -lean_dec(x_58); -x_59 = !lean_is_exclusive(x_55); -if (x_59 == 0) +lean_inc(x_58); +x_59 = lean_ctor_get(x_58, 2); +lean_inc(x_59); +x_60 = !lean_is_exclusive(x_20); +if (x_60 == 0) { -lean_object* x_60; uint8_t x_61; -x_60 = lean_ctor_get(x_55, 2); -lean_dec(x_60); -x_61 = !lean_is_exclusive(x_56); -if (x_61 == 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_62; -x_62 = lean_ctor_get(x_56, 2); -lean_dec(x_62); -lean_ctor_set(x_56, 2, x_18); +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_63; lean_object* x_64; lean_object* x_65; -x_63 = lean_ctor_get(x_56, 0); -x_64 = lean_ctor_get(x_56, 1); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_56); -x_65 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_65, 0, x_63); -lean_ctor_set(x_65, 1, x_64); -lean_ctor_set(x_65, 2, x_18); -lean_ctor_set(x_55, 2, x_65); -return x_20; -} -} -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; -x_66 = lean_ctor_get(x_55, 0); -x_67 = lean_ctor_get(x_55, 1); -x_68 = lean_ctor_get(x_55, 3); -x_69 = lean_ctor_get(x_55, 4); -x_70 = lean_ctor_get(x_55, 5); -lean_inc(x_70); -lean_inc(x_69); +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_55); -x_71 = lean_ctor_get(x_56, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_56, 1); -lean_inc(x_72); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - x_73 = x_56; -} else { - lean_dec_ref(x_56); - x_73 = lean_box(0); -} -if (lean_is_scalar(x_73)) { - x_74 = lean_alloc_ctor(0, 3, 0); -} else { - x_74 = x_73; -} -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_18); -x_75 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_75, 0, x_66); -lean_ctor_set(x_75, 1, x_67); -lean_ctor_set(x_75, 2, x_74); -lean_ctor_set(x_75, 3, x_68); -lean_ctor_set(x_75, 4, x_69); -lean_ctor_set(x_75, 5, x_70); -lean_ctor_set(x_20, 1, x_75); +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_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_76 = lean_ctor_get(x_20, 0); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_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); -lean_dec(x_20); -x_77 = lean_ctor_get(x_55, 0); +x_77 = lean_ctor_get(x_59, 3); lean_inc(x_77); -x_78 = lean_ctor_get(x_55, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_55, 3); -lean_inc(x_79); -x_80 = lean_ctor_get(x_55, 4); -lean_inc(x_80); -x_81 = lean_ctor_get(x_55, 5); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + lean_ctor_release(x_59, 2); + lean_ctor_release(x_59, 3); + 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); -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_82 = x_55; -} else { - lean_dec_ref(x_55); - x_82 = lean_box(0); -} -x_83 = lean_ctor_get(x_56, 0); +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_56, 1); +x_84 = lean_ctor_get(x_58, 3); lean_inc(x_84); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - x_85 = x_56; +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; } else { - lean_dec_ref(x_56); - x_85 = lean_box(0); + lean_dec_ref(x_58); + x_87 = lean_box(0); } -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(0, 3, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_83); -lean_ctor_set(x_86, 1, x_84); -lean_ctor_set(x_86, 2, x_18); -if (lean_is_scalar(x_82)) { - x_87 = lean_alloc_ctor(0, 6, 0); -} else { - x_87 = x_82; -} -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); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_76); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_89 = lean_ctor_get(x_16, 0); -x_90 = lean_ctor_get(x_16, 1); -x_91 = lean_ctor_get(x_16, 2); -lean_inc(x_91); -lean_inc(x_90); +x_88 = lean_ctor_get(x_59, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_59, 1); lean_inc(x_89); -lean_dec(x_16); -x_92 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_89); -lean_ctor_set(x_93, 1, x_90); +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; +} else { + lean_dec_ref(x_59); + x_91 = lean_box(0); +} +if (lean_is_scalar(x_91)) { + x_92 = lean_alloc_ctor(0, 4, 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_5, 2, x_93); -x_94 = lean_apply_2(x_3, x_13, x_5); -if (lean_obj_tag(x_94) == 0) +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; +} +} +} +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; -x_95 = lean_ctor_get(x_94, 1); -lean_inc(x_95); -x_96 = lean_ctor_get(x_95, 2); -lean_inc(x_96); -x_97 = lean_ctor_get(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_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); -if (lean_is_exclusive(x_94)) { - lean_ctor_release(x_94, 0); - lean_ctor_release(x_94, 1); - x_98 = x_94; -} else { - lean_dec_ref(x_94); - x_98 = lean_box(0); -} -x_99 = lean_ctor_get(x_95, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_95, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_95, 3); -lean_inc(x_101); -x_102 = lean_ctor_get(x_95, 4); +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_inc(x_102); -x_103 = lean_ctor_get(x_95, 5); +x_103 = lean_ctor_get(x_102, 2); lean_inc(x_103); -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_104 = x_95; +x_104 = lean_ctor_get(x_101, 0); +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; } else { - lean_dec_ref(x_95); - x_104 = lean_box(0); + lean_dec_ref(x_101); + x_105 = lean_box(0); } -x_105 = lean_ctor_get(x_96, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_96, 1); +x_106 = lean_ctor_get(x_102, 0); lean_inc(x_106); -if (lean_is_exclusive(x_96)) { - lean_ctor_release(x_96, 0); - lean_ctor_release(x_96, 1); - lean_ctor_release(x_96, 2); - x_107 = x_96; +x_107 = lean_ctor_get(x_102, 1); +lean_inc(x_107); +x_108 = lean_ctor_get(x_102, 3); +lean_inc(x_108); +x_109 = lean_ctor_get(x_102, 4); +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; } else { - lean_dec_ref(x_96); - x_107 = lean_box(0); + lean_dec_ref(x_102); + x_111 = lean_box(0); } -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 3, 0); -} else { - x_108 = x_107; -} -lean_ctor_set(x_108, 0, x_105); -lean_ctor_set(x_108, 1, x_106); -lean_ctor_set(x_108, 2, x_91); -if (lean_is_scalar(x_104)) { - x_109 = lean_alloc_ctor(0, 6, 0); -} else { - x_109 = x_104; -} -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); -if (lean_is_scalar(x_98)) { - x_110 = lean_alloc_ctor(0, 2, 0); -} else { - x_110 = x_98; -} -lean_ctor_set(x_110, 0, x_97); -lean_ctor_set(x_110, 1, x_109); -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; -x_111 = lean_ctor_get(x_94, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_111, 2); +x_112 = lean_ctor_get(x_103, 0); lean_inc(x_112); -x_113 = lean_ctor_get(x_94, 0); +x_113 = lean_ctor_get(x_103, 1); lean_inc(x_113); -if (lean_is_exclusive(x_94)) { - lean_ctor_release(x_94, 0); - lean_ctor_release(x_94, 1); - x_114 = x_94; +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; } else { - lean_dec_ref(x_94); - x_114 = lean_box(0); + lean_dec_ref(x_103); + x_115 = lean_box(0); } -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_111, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_111, 4); -lean_inc(x_118); -x_119 = lean_ctor_get(x_111, 5); +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_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); -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_120 = x_111; -} else { - lean_dec_ref(x_111); - x_120 = lean_box(0); -} -x_121 = lean_ctor_get(x_112, 0); +x_120 = lean_ctor_get(x_119, 2); +lean_inc(x_120); +x_121 = lean_ctor_get(x_101, 0); lean_inc(x_121); -x_122 = lean_ctor_get(x_112, 1); -lean_inc(x_122); -if (lean_is_exclusive(x_112)) { - lean_ctor_release(x_112, 0); - lean_ctor_release(x_112, 1); - lean_ctor_release(x_112, 2); - x_123 = x_112; +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_112); - x_123 = lean_box(0); + lean_dec_ref(x_101); + x_122 = lean_box(0); } -if (lean_is_scalar(x_123)) { - x_124 = lean_alloc_ctor(0, 3, 0); -} else { - x_124 = x_123; -} -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_122); -lean_ctor_set(x_124, 2, x_91); -if (lean_is_scalar(x_120)) { - x_125 = lean_alloc_ctor(0, 6, 0); -} else { - x_125 = x_120; -} -lean_ctor_set(x_125, 0, x_115); -lean_ctor_set(x_125, 1, x_116); -lean_ctor_set(x_125, 2, x_124); -lean_ctor_set(x_125, 3, x_117); -lean_ctor_set(x_125, 4, x_118); -lean_ctor_set(x_125, 5, x_119); -if (lean_is_scalar(x_114)) { - x_126 = lean_alloc_ctor(1, 2, 0); -} else { - x_126 = x_114; -} -lean_ctor_set(x_126, 0, x_113); -lean_ctor_set(x_126, 1, x_125); -return x_126; -} -} -} -else -{ -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_127 = lean_ctor_get(x_5, 2); -x_128 = lean_ctor_get(x_5, 0); -x_129 = lean_ctor_get(x_5, 1); -x_130 = lean_ctor_get(x_5, 3); -x_131 = lean_ctor_get(x_5, 4); -x_132 = lean_ctor_get(x_5, 5); -lean_inc(x_132); -lean_inc(x_131); -lean_inc(x_130); +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_inc(x_129); -lean_inc(x_128); -lean_dec(x_5); -x_133 = lean_ctor_get(x_127, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_127, 2); -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); - x_136 = x_127; +x_130 = lean_ctor_get(x_120, 1); +lean_inc(x_130); +x_131 = lean_ctor_get(x_120, 3); +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; } else { - lean_dec_ref(x_127); - x_136 = lean_box(0); + lean_dec_ref(x_120); + x_132 = lean_box(0); } -x_137 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_136)) { - x_138 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_132)) { + x_133 = lean_alloc_ctor(0, 4, 0); } else { - x_138 = x_136; + x_133 = x_132; } -lean_ctor_set(x_138, 0, x_133); -lean_ctor_set(x_138, 1, x_134); -lean_ctor_set(x_138, 2, x_137); -x_139 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_139, 0, x_128); -lean_ctor_set(x_139, 1, x_129); -lean_ctor_set(x_139, 2, x_138); -lean_ctor_set(x_139, 3, x_130); -lean_ctor_set(x_139, 4, x_131); -lean_ctor_set(x_139, 5, x_132); -x_140 = lean_apply_2(x_3, x_13, x_139); -if (lean_obj_tag(x_140) == 0) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; -x_141 = lean_ctor_get(x_140, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_141, 2); -lean_inc(x_142); -x_143 = lean_ctor_get(x_140, 0); -lean_inc(x_143); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_144 = x_140; +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 { - lean_dec_ref(x_140); - x_144 = lean_box(0); + x_134 = x_128; } -x_145 = lean_ctor_get(x_141, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_141, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_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; +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 { - lean_dec_ref(x_141); - x_150 = lean_box(0); + x_135 = x_122; } -x_151 = lean_ctor_get(x_142, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_142, 1); -lean_inc(x_152); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - x_153 = x_142; -} else { - lean_dec_ref(x_142); - x_153 = lean_box(0); +lean_ctor_set(x_135, 0, x_121); +lean_ctor_set(x_135, 1, x_134); +return x_135; } -if (lean_is_scalar(x_153)) { - x_154 = lean_alloc_ctor(0, 3, 0); -} else { - x_154 = x_153; } -lean_ctor_set(x_154, 0, x_151); -lean_ctor_set(x_154, 1, x_152); -lean_ctor_set(x_154, 2, x_135); -if (lean_is_scalar(x_150)) { - x_155 = lean_alloc_ctor(0, 6, 0); -} else { - x_155 = x_150; -} -lean_ctor_set(x_155, 0, x_145); -lean_ctor_set(x_155, 1, x_146); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_147); -lean_ctor_set(x_155, 4, x_148); -lean_ctor_set(x_155, 5, x_149); -if (lean_is_scalar(x_144)) { - x_156 = lean_alloc_ctor(0, 2, 0); -} else { - x_156 = x_144; -} -lean_ctor_set(x_156, 0, x_143); -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; -x_157 = lean_ctor_get(x_140, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_157, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_140, 0); -lean_inc(x_159); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_160 = x_140; +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_inc(x_137); +lean_dec(x_5); +x_142 = lean_ctor_get(x_136, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_136, 1); +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; } else { - lean_dec_ref(x_140); + lean_dec_ref(x_136); + x_146 = 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); +} else { + x_148 = x_146; +} +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) +{ +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_inc(x_152); +x_153 = lean_ctor_get(x_150, 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_inc(x_155); +x_156 = lean_ctor_get(x_151, 1); +lean_inc(x_156); +x_157 = lean_ctor_get(x_151, 3); +lean_inc(x_157); +x_158 = lean_ctor_get(x_151, 4); +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; +} else { + lean_dec_ref(x_151); x_160 = lean_box(0); } -x_161 = lean_ctor_get(x_157, 0); +x_161 = lean_ctor_get(x_152, 0); lean_inc(x_161); -x_162 = lean_ctor_get(x_157, 1); +x_162 = lean_ctor_get(x_152, 1); lean_inc(x_162); -x_163 = lean_ctor_get(x_157, 3); +x_163 = lean_ctor_get(x_152, 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; +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; } else { - lean_dec_ref(x_157); - x_166 = lean_box(0); + lean_dec_ref(x_152); + x_164 = 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); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - lean_ctor_release(x_158, 2); - x_169 = x_158; +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_158); - x_169 = lean_box(0); + x_165 = x_164; } -if (lean_is_scalar(x_169)) { - x_170 = lean_alloc_ctor(0, 3, 0); -} else { - x_170 = x_169; -} -lean_ctor_set(x_170, 0, x_167); -lean_ctor_set(x_170, 1, x_168); -lean_ctor_set(x_170, 2, x_135); -if (lean_is_scalar(x_166)) { - x_171 = lean_alloc_ctor(0, 6, 0); -} else { - x_171 = x_166; -} -lean_ctor_set(x_171, 0, x_161); -lean_ctor_set(x_171, 1, x_162); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_163); -lean_ctor_set(x_171, 4, x_164); -lean_ctor_set(x_171, 5, x_165); +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_172 = lean_alloc_ctor(1, 2, 0); + x_166 = lean_alloc_ctor(0, 6, 0); } else { - x_172 = x_160; + x_166 = x_160; } -lean_ctor_set(x_172, 0, x_159); -lean_ctor_set(x_172, 1, x_171); -return x_172; +lean_ctor_set(x_166, 0, x_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_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; } } } @@ -47986,14 +49782,63 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } +lean_object* _init_l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("debug"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__2; +x_2 = l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} lean_object* l___private_Init_Lean_Meta_Basic_10__regTraceClasses(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; x_2 = l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__2; x_3 = l_Lean_registerTraceClass(x_2, x_1); +if (lean_obj_tag(x_3) == 0) +{ +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_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4; +x_6 = l_Lean_registerTraceClass(x_5, x_4); +return x_6; +} +else +{ +uint8_t x_7; +x_7 = !lean_is_exclusive(x_3); +if (x_7 == 0) +{ return x_3; } +else +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_3, 0); +x_9 = lean_ctor_get(x_3, 1); +lean_inc(x_9); +lean_inc(x_8); +lean_dec(x_3); +x_10 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_10, 0, x_8); +lean_ctor_set(x_10, 1, x_9); +return x_10; +} +} +} } lean_object* _init_l_PersistentHashMap_empty___at_Lean_Meta_run___spec__1___closed__1() { _start: @@ -48069,10 +49914,11 @@ lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; x_1 = l_PersistentHashMap_empty___at_Lean_Meta_run___spec__1; x_2 = l_Lean_Meta_run___rarg___closed__4; x_3 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_4 = lean_alloc_ctor(0, 3, 0); +x_4 = lean_alloc_ctor(0, 4, 0); lean_ctor_set(x_4, 0, x_1); lean_ctor_set(x_4, 1, x_2); lean_ctor_set(x_4, 2, x_3); +lean_ctor_set(x_4, 3, x_1); return x_4; } } @@ -48398,6 +50244,10 @@ l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__1 = _init_l___pri lean_mark_persistent(l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__1); l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__2 = _init_l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__2(); lean_mark_persistent(l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__2); +l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3 = _init_l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__3); +l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4 = _init_l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Meta_Basic_10__regTraceClasses___closed__4); res = l___private_Init_Lean_Meta_Basic_10__regTraceClasses(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); diff --git a/stage0/stdlib/Init/Lean/Meta/ExprDefEq.c b/stage0/stdlib/Init/Lean/Meta/ExprDefEq.c index 04bef81c0a..e7c1a1858d 100644 --- a/stage0/stdlib/Init/Lean/Meta/ExprDefEq.c +++ b/stage0/stdlib/Init/Lean/Meta/ExprDefEq.c @@ -3708,82 +3708,89 @@ return x_44; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; +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_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_38); -lean_ctor_set(x_45, 2, x_55); +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; } } 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; -x_56 = lean_ctor_get(x_45, 0); -x_57 = lean_ctor_get(x_45, 1); -x_58 = lean_ctor_get(x_45, 3); -x_59 = lean_ctor_get(x_45, 4); -x_60 = lean_ctor_get(x_45, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +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_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_45); -x_61 = lean_ctor_get(x_46, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_46, 1); +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); - x_63 = x_46; + lean_ctor_release(x_46, 3); + x_65 = x_46; } else { lean_dec_ref(x_46); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 4, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -lean_ctor_set(x_64, 2, x_38); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_56); -lean_ctor_set(x_65, 1, x_57); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_58); -lean_ctor_set(x_65, 4, x_59); -lean_ctor_set(x_65, 5, x_60); -lean_ctor_set(x_44, 1, 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_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; } } 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; -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -lean_dec(x_44); -x_67 = lean_ctor_get(x_45, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_45, 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; lean_object* x_80; lean_object* x_81; +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_45, 3); +lean_dec(x_44); +x_69 = lean_ctor_get(x_45, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_45, 4); +x_70 = lean_ctor_get(x_45, 1); lean_inc(x_70); -x_71 = lean_ctor_get(x_45, 5); +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); @@ -3791,933 +3798,979 @@ if (lean_is_exclusive(x_45)) { lean_ctor_release(x_45, 3); lean_ctor_release(x_45, 4); lean_ctor_release(x_45, 5); - x_72 = x_45; + x_74 = x_45; } else { lean_dec_ref(x_45); - x_72 = lean_box(0); + x_74 = lean_box(0); } -x_73 = lean_ctor_get(x_46, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_46, 1); -lean_inc(x_74); +x_75 = lean_ctor_get(x_46, 0); +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); - x_75 = x_46; + lean_ctor_release(x_46, 3); + x_78 = x_46; } else { lean_dec_ref(x_46); - x_75 = lean_box(0); + x_78 = lean_box(0); } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 4, 0); } else { - x_76 = x_75; + x_79 = x_78; } -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_38); -if (lean_is_scalar(x_72)) { - x_77 = 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_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_77 = x_72; + x_80 = x_74; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_68); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_69); -lean_ctor_set(x_77, 4, x_70); -lean_ctor_set(x_77, 5, x_71); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_66); -lean_ctor_set(x_78, 1, x_77); -return x_78; +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; } } else { -lean_object* x_79; lean_object* x_80; uint8_t x_81; -x_79 = lean_ctor_get(x_44, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 2); -lean_inc(x_80); -x_81 = !lean_is_exclusive(x_44); -if (x_81 == 0) -{ -lean_object* x_82; uint8_t x_83; +lean_object* x_82; lean_object* x_83; uint8_t x_84; x_82 = lean_ctor_get(x_44, 1); -lean_dec(x_82); -x_83 = !lean_is_exclusive(x_79); -if (x_83 == 0) +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 2); +lean_inc(x_83); +x_84 = !lean_is_exclusive(x_44); +if (x_84 == 0) { -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_79, 2); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_80); -if (x_85 == 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_86; -x_86 = lean_ctor_get(x_80, 2); -lean_dec(x_86); -lean_ctor_set(x_80, 2, x_38); +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_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_80, 0); -x_88 = lean_ctor_get(x_80, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_80); -x_89 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -lean_ctor_set(x_89, 2, x_38); -lean_ctor_set(x_79, 2, x_89); -return x_44; -} -} -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; -x_90 = lean_ctor_get(x_79, 0); -x_91 = lean_ctor_get(x_79, 1); -x_92 = lean_ctor_get(x_79, 3); -x_93 = lean_ctor_get(x_79, 4); -x_94 = lean_ctor_get(x_79, 5); -lean_inc(x_94); -lean_inc(x_93); +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_79); -x_95 = lean_ctor_get(x_80, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_80, 1); -lean_inc(x_96); -if (lean_is_exclusive(x_80)) { - lean_ctor_release(x_80, 0); - lean_ctor_release(x_80, 1); - lean_ctor_release(x_80, 2); - x_97 = x_80; -} else { - lean_dec_ref(x_80); - x_97 = lean_box(0); -} -if (lean_is_scalar(x_97)) { - x_98 = lean_alloc_ctor(0, 3, 0); -} else { - x_98 = x_97; -} -lean_ctor_set(x_98, 0, x_95); -lean_ctor_set(x_98, 1, x_96); -lean_ctor_set(x_98, 2, x_38); -x_99 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_99, 0, x_90); -lean_ctor_set(x_99, 1, x_91); -lean_ctor_set(x_99, 2, x_98); -lean_ctor_set(x_99, 3, x_92); -lean_ctor_set(x_99, 4, x_93); -lean_ctor_set(x_99, 5, x_94); -lean_ctor_set(x_44, 1, x_99); +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_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_100 = lean_ctor_get(x_44, 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; +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); -lean_dec(x_44); -x_101 = lean_ctor_get(x_79, 0); +x_101 = lean_ctor_get(x_83, 3); lean_inc(x_101); -x_102 = lean_ctor_get(x_79, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_79, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_79, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_79, 5); +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; +} else { + lean_dec_ref(x_83); + x_102 = lean_box(0); +} +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 4, 0); +} else { + x_103 = x_102; +} +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); -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); - lean_ctor_release(x_79, 4); - lean_ctor_release(x_79, 5); - x_106 = x_79; -} else { - lean_dec_ref(x_79); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_80, 0); +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_80, 1); +x_108 = lean_ctor_get(x_82, 3); 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); - x_109 = x_80; +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; } else { - lean_dec_ref(x_80); - x_109 = lean_box(0); + lean_dec_ref(x_82); + x_111 = lean_box(0); } -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 3, 0); +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 { - x_110 = x_109; + lean_dec_ref(x_83); + x_115 = lean_box(0); } -lean_ctor_set(x_110, 0, x_107); -lean_ctor_set(x_110, 1, x_108); -lean_ctor_set(x_110, 2, x_38); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 4, 0); } else { - x_111 = x_106; + x_116 = x_115; } -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); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_100); -lean_ctor_set(x_112, 1, x_111); -return x_112; +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_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_5, 0); -x_114 = lean_ctor_get(x_5, 1); -x_115 = lean_ctor_get(x_5, 2); -x_116 = lean_ctor_get(x_5, 3); -x_117 = lean_ctor_get(x_5, 4); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_5); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_32); -lean_ctor_set(x_118, 1, x_10); -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_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_120, x_31); -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; -x_122 = lean_ctor_get(x_121, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_122, 2); +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); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_125 = x_121; -} else { - lean_dec_ref(x_121); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_122, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_122); +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_122, 4); +x_129 = lean_ctor_get(x_128, 2); lean_inc(x_129); -x_130 = lean_ctor_get(x_122, 5); +x_130 = lean_ctor_get(x_127, 0); 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_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + x_131 = x_127; } else { - lean_dec_ref(x_122); + lean_dec_ref(x_127); x_131 = lean_box(0); } -x_132 = lean_ctor_get(x_123, 0); +x_132 = lean_ctor_get(x_128, 0); lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 1); +x_133 = lean_ctor_get(x_128, 1); lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - x_134 = x_123; +x_134 = lean_ctor_get(x_128, 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; } else { - lean_dec_ref(x_123); - x_134 = lean_box(0); + lean_dec_ref(x_128); + x_137 = lean_box(0); } -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 3, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_132); -lean_ctor_set(x_135, 1, x_133); -lean_ctor_set(x_135, 2, x_38); -if (lean_is_scalar(x_131)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_131; -} -lean_ctor_set(x_136, 0, x_126); -lean_ctor_set(x_136, 1, x_127); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_128); -lean_ctor_set(x_136, 4, x_129); -lean_ctor_set(x_136, 5, x_130); -if (lean_is_scalar(x_125)) { - x_137 = lean_alloc_ctor(0, 2, 0); -} else { - x_137 = x_125; -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_138 = lean_ctor_get(x_121, 1); +x_138 = lean_ctor_get(x_129, 0); lean_inc(x_138); -x_139 = lean_ctor_get(x_138, 2); +x_139 = lean_ctor_get(x_129, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 0); +x_140 = lean_ctor_get(x_129, 3); lean_inc(x_140); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_141 = x_121; +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; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_129); x_141 = lean_box(0); } -x_142 = lean_ctor_get(x_138, 0); -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; -} else { - lean_dec_ref(x_138); - x_147 = 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); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - 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, 3, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -lean_ctor_set(x_151, 2, x_38); -if (lean_is_scalar(x_147)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_147; -} -lean_ctor_set(x_152, 0, x_142); -lean_ctor_set(x_152, 1, x_143); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_144); -lean_ctor_set(x_152, 4, x_145); -lean_ctor_set(x_152, 5, x_146); if (lean_is_scalar(x_141)) { - x_153 = lean_alloc_ctor(1, 2, 0); + x_142 = lean_alloc_ctor(0, 4, 0); } else { - x_153 = x_141; + x_142 = x_141; } -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; +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); +if (lean_is_scalar(x_131)) { + x_144 = lean_alloc_ctor(0, 2, 0); +} else { + x_144 = x_131; +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_145 = lean_ctor_get(x_127, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_145, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 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); +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; +} else { + lean_dec_ref(x_145); + x_154 = 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; +} else { + lean_dec_ref(x_146); + x_158 = lean_box(0); +} +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_38); +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); +if (lean_is_scalar(x_148)) { + x_161 = lean_alloc_ctor(1, 2, 0); +} else { + x_161 = x_148; +} +lean_ctor_set(x_161, 0, x_147); +lean_ctor_set(x_161, 1, x_160); +return x_161; } } } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_154 = lean_ctor_get(x_36, 0); -x_155 = lean_ctor_get(x_36, 1); -x_156 = lean_ctor_get(x_36, 2); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_dec(x_36); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_31, 2, x_158); -x_159 = lean_ctor_get(x_5, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_5, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_5, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_5, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_5, 4); +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); 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_164 = x_5; + x_173 = x_5; } else { lean_dec_ref(x_5); - x_164 = lean_box(0); + x_173 = lean_box(0); } -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_32); -lean_ctor_set(x_165, 1, x_10); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 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); } else { - x_167 = x_164; + x_176 = x_173; } -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_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_167, x_31); -if (lean_obj_tag(x_168) == 0) +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_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, 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_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_170, 1); +x_180 = lean_ctor_get(x_177, 0); lean_inc(x_180); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - lean_ctor_release(x_170, 2); - x_181 = x_170; +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_170); + lean_dec_ref(x_177); x_181 = lean_box(0); } -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 3, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_179); -lean_ctor_set(x_182, 1, x_180); -lean_ctor_set(x_182, 2, x_156); -if (lean_is_scalar(x_178)) { - x_183 = lean_alloc_ctor(0, 6, 0); -} else { - x_183 = x_178; -} -lean_ctor_set(x_183, 0, x_173); -lean_ctor_set(x_183, 1, x_174); -lean_ctor_set(x_183, 2, x_182); -lean_ctor_set(x_183, 3, x_175); -lean_ctor_set(x_183, 4, x_176); -lean_ctor_set(x_183, 5, x_177); -if (lean_is_scalar(x_172)) { - x_184 = lean_alloc_ctor(0, 2, 0); -} else { - x_184 = x_172; -} -lean_ctor_set(x_184, 0, x_171); -lean_ctor_set(x_184, 1, x_183); -return x_184; -} -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; -x_185 = lean_ctor_get(x_168, 1); +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_185, 2); +x_186 = lean_ctor_get(x_178, 5); lean_inc(x_186); -x_187 = lean_ctor_get(x_168, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - x_188 = x_168; +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_168); - x_188 = lean_box(0); + lean_dec_ref(x_178); + x_187 = lean_box(0); } -x_189 = lean_ctor_get(x_185, 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_185, 1); +x_190 = lean_ctor_get(x_179, 3); 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; +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_185); - x_194 = lean_box(0); + lean_dec_ref(x_179); + x_191 = lean_box(0); } -x_195 = lean_ctor_get(x_186, 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; +} +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_inc(x_195); -x_196 = lean_ctor_get(x_186, 1); +x_196 = lean_ctor_get(x_195, 2); 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); - x_197 = x_186; +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; } else { - lean_dec_ref(x_186); - x_197 = lean_box(0); + lean_dec_ref(x_177); + x_198 = lean_box(0); } -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 4); +lean_inc(x_202); +x_203 = lean_ctor_get(x_195, 5); +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 { - x_198 = x_197; + lean_dec_ref(x_195); + x_204 = lean_box(0); } -lean_ctor_set(x_198, 0, x_195); -lean_ctor_set(x_198, 1, x_196); -lean_ctor_set(x_198, 2, x_156); -if (lean_is_scalar(x_194)) { - x_199 = lean_alloc_ctor(0, 6, 0); +x_205 = lean_ctor_get(x_196, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_196, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_196, 3); +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; } else { - x_199 = x_194; + lean_dec_ref(x_196); + x_208 = lean_box(0); } -lean_ctor_set(x_199, 0, x_189); -lean_ctor_set(x_199, 1, x_190); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_191); -lean_ctor_set(x_199, 4, x_192); -lean_ctor_set(x_199, 5, x_193); -if (lean_is_scalar(x_188)) { - x_200 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 4, 0); } else { - x_200 = x_188; + x_209 = x_208; } -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +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); +} else { + x_210 = x_204; +} +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_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; } } } 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; 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_201 = lean_ctor_get(x_31, 2); -x_202 = lean_ctor_get(x_31, 0); -x_203 = lean_ctor_get(x_31, 1); -x_204 = lean_ctor_get(x_31, 3); -x_205 = lean_ctor_get(x_31, 4); -x_206 = lean_ctor_get(x_31, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_201); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_31); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 2); -lean_inc(x_209); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_210 = x_201; -} else { - lean_dec_ref(x_201); - x_210 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_210)) { - x_212 = lean_alloc_ctor(0, 3, 0); -} else { - x_212 = x_210; -} -lean_ctor_set(x_212, 0, x_207); -lean_ctor_set(x_212, 1, x_208); -lean_ctor_set(x_212, 2, x_211); -x_213 = 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); -x_214 = lean_ctor_get(x_5, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_5, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_5, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_5, 3); +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); -x_218 = lean_ctor_get(x_5, 4); +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_219 = x_5; + x_231 = x_5; } else { lean_dec_ref(x_5); - x_219 = lean_box(0); + x_231 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_32); -lean_ctor_set(x_220, 1, x_10); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { - x_222 = lean_alloc_ctor(0, 5, 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_222 = x_219; + x_234 = x_231; } -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_isDefEqBindingDomain___main(x_1, x_2, x_34, x_4, x_222, x_213); -if (lean_obj_tag(x_223) == 0) +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_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_224 = lean_ctor_get(x_223, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -x_226 = lean_ctor_get(x_223, 0); -lean_inc(x_226); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_227 = x_223; +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_223); - x_227 = lean_box(0); + lean_dec_ref(x_235); + x_239 = lean_box(0); } -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; -} else { - lean_dec_ref(x_224); - x_233 = 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); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - lean_ctor_release(x_225, 2); - x_236 = x_225; -} else { - lean_dec_ref(x_225); - x_236 = lean_box(0); -} -if (lean_is_scalar(x_236)) { - x_237 = lean_alloc_ctor(0, 3, 0); -} else { - x_237 = x_236; -} -lean_ctor_set(x_237, 0, x_234); -lean_ctor_set(x_237, 1, x_235); -lean_ctor_set(x_237, 2, x_209); -if (lean_is_scalar(x_233)) { - x_238 = lean_alloc_ctor(0, 6, 0); -} else { - x_238 = x_233; -} -lean_ctor_set(x_238, 0, x_228); -lean_ctor_set(x_238, 1, x_229); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_230); -lean_ctor_set(x_238, 4, x_231); -lean_ctor_set(x_238, 5, x_232); -if (lean_is_scalar(x_227)) { - x_239 = lean_alloc_ctor(0, 2, 0); -} else { - x_239 = x_227; -} -lean_ctor_set(x_239, 0, x_226); -lean_ctor_set(x_239, 1, x_238); -return x_239; -} -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; 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; -x_240 = lean_ctor_get(x_223, 1); +x_240 = lean_ctor_get(x_236, 0); lean_inc(x_240); -x_241 = lean_ctor_get(x_240, 2); +x_241 = lean_ctor_get(x_236, 1); lean_inc(x_241); -x_242 = lean_ctor_get(x_223, 0); +x_242 = lean_ctor_get(x_236, 3); lean_inc(x_242); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - x_243 = x_223; -} else { - lean_dec_ref(x_223); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_240, 0); +x_243 = lean_ctor_get(x_236, 4); +lean_inc(x_243); +x_244 = lean_ctor_get(x_236, 5); lean_inc(x_244); -x_245 = lean_ctor_get(x_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; +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_240); + 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); } -x_250 = lean_ctor_get(x_241, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 1); -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); - x_252 = x_241; -} else { - lean_dec_ref(x_241); - x_252 = lean_box(0); -} -if (lean_is_scalar(x_252)) { - x_253 = lean_alloc_ctor(0, 3, 0); -} else { - x_253 = x_252; -} -lean_ctor_set(x_253, 0, x_250); -lean_ctor_set(x_253, 1, x_251); -lean_ctor_set(x_253, 2, x_209); if (lean_is_scalar(x_249)) { - x_254 = lean_alloc_ctor(0, 6, 0); + x_250 = lean_alloc_ctor(0, 4, 0); } else { - x_254 = x_249; + x_250 = x_249; } -lean_ctor_set(x_254, 0, x_244); -lean_ctor_set(x_254, 1, x_245); -lean_ctor_set(x_254, 2, x_253); -lean_ctor_set(x_254, 3, x_246); -lean_ctor_set(x_254, 4, x_247); -lean_ctor_set(x_254, 5, x_248); -if (lean_is_scalar(x_243)) { - x_255 = lean_alloc_ctor(1, 2, 0); +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_255 = x_243; + x_251 = x_245; } -lean_ctor_set(x_255, 0, x_242); -lean_ctor_set(x_255, 1, x_254); -return x_255; +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_256; +uint8_t x_270; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_256 = !lean_is_exclusive(x_25); -if (x_256 == 0) +x_270 = !lean_is_exclusive(x_25); +if (x_270 == 0) { return x_25; } else { -lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_257 = lean_ctor_get(x_25, 0); -x_258 = lean_ctor_get(x_25, 1); -lean_inc(x_258); -lean_inc(x_257); +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_dec(x_25); -x_259 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_259, 0, x_257); -lean_ctor_set(x_259, 1, x_258); -return x_259; +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; } } } } else { -uint8_t x_260; +uint8_t x_274; lean_dec(x_14); lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_260 = !lean_is_exclusive(x_17); -if (x_260 == 0) +x_274 = !lean_is_exclusive(x_17); +if (x_274 == 0) { return x_17; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; -x_261 = lean_ctor_get(x_17, 0); -x_262 = lean_ctor_get(x_17, 1); -lean_inc(x_262); -lean_inc(x_261); +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_dec(x_17); -x_263 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_263, 0, x_261); -lean_ctor_set(x_263, 1, x_262); -return x_263; +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; } } } else { -uint8_t x_264; +uint8_t x_278; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_264 = !lean_is_exclusive(x_11); -if (x_264 == 0) +x_278 = !lean_is_exclusive(x_11); +if (x_278 == 0) { return x_11; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; -x_265 = lean_ctor_get(x_11, 0); -x_266 = lean_ctor_get(x_11, 1); -lean_inc(x_266); -lean_inc(x_265); +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_dec(x_11); -x_267 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_267, 0, x_265); -lean_ctor_set(x_267, 1, x_266); -return x_267; +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; } } } @@ -4916,82 +4969,89 @@ return x_48; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_59 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -lean_ctor_set(x_59, 2, x_42); -lean_ctor_set(x_49, 2, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_49, 0); -x_61 = lean_ctor_get(x_49, 1); -x_62 = lean_ctor_get(x_49, 3); -x_63 = lean_ctor_get(x_49, 4); -x_64 = lean_ctor_get(x_49, 5); +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_inc(x_62); lean_inc(x_61); -lean_inc(x_60); lean_dec(x_49); -x_65 = lean_ctor_get(x_50, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_50, 1); +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); - x_67 = x_50; + lean_ctor_release(x_50, 3); + x_69 = x_50; } else { lean_dec_ref(x_50); - x_67 = lean_box(0); + x_69 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_70 = x_69; } -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_42); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_60); -lean_ctor_set(x_69, 1, x_61); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_62); -lean_ctor_set(x_69, 4, x_63); -lean_ctor_set(x_69, 5, x_64); -lean_ctor_set(x_48, 1, x_69); +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; } } 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; -x_70 = lean_ctor_get(x_48, 0); -lean_inc(x_70); -lean_dec(x_48); -x_71 = lean_ctor_get(x_49, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_49, 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; lean_object* x_84; lean_object* x_85; +x_72 = lean_ctor_get(x_48, 0); lean_inc(x_72); -x_73 = lean_ctor_get(x_49, 3); +lean_dec(x_48); +x_73 = lean_ctor_get(x_49, 0); lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 4); +x_74 = lean_ctor_get(x_49, 1); lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 5); +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); @@ -4999,930 +5059,976 @@ if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 3); lean_ctor_release(x_49, 4); lean_ctor_release(x_49, 5); - x_76 = x_49; + x_78 = x_49; } else { lean_dec_ref(x_49); - x_76 = lean_box(0); + x_78 = lean_box(0); } -x_77 = lean_ctor_get(x_50, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_50, 1); -lean_inc(x_78); +x_79 = lean_ctor_get(x_50, 0); +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); - x_79 = x_50; + lean_ctor_release(x_50, 3); + x_82 = x_50; } else { lean_dec_ref(x_50); - x_79 = lean_box(0); + x_82 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_83 = x_82; } -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_42); -if (lean_is_scalar(x_76)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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_81 = x_76; + x_84 = x_78; } -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); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_70); -lean_ctor_set(x_82, 1, x_81); -return x_82; +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; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_48, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_48); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; +lean_object* x_86; lean_object* x_87; uint8_t x_88; x_86 = lean_ctor_get(x_48, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = !lean_is_exclusive(x_48); +if (x_88 == 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_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_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_42); +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_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -lean_ctor_set(x_93, 2, x_42); -lean_ctor_set(x_83, 2, x_93); -return x_48; -} -} -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; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -x_97 = lean_ctor_get(x_83, 4); -x_98 = lean_ctor_get(x_83, 5); -lean_inc(x_98); -lean_inc(x_97); +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_83); -x_99 = lean_ctor_get(x_84, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_84, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_101 = x_84; -} else { - lean_dec_ref(x_84); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 3, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_102, 2, x_42); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_94); -lean_ctor_set(x_103, 1, x_95); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_97); -lean_ctor_set(x_103, 5, x_98); -lean_ctor_set(x_48, 1, x_103); +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_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_104 = lean_ctor_get(x_48, 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; +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); -lean_dec(x_48); -x_105 = lean_ctor_get(x_83, 0); +x_105 = lean_ctor_get(x_87, 3); lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_83, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 5); +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; +} else { + lean_dec_ref(x_87); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 4, 0); +} else { + x_107 = x_106; +} +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); -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_110 = x_83; -} else { - lean_dec_ref(x_83); - x_110 = lean_box(0); -} -x_111 = lean_ctor_get(x_84, 0); +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_84, 1); +x_112 = lean_ctor_get(x_86, 3); 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); - x_113 = x_84; +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; } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + lean_dec_ref(x_86); + x_115 = lean_box(0); } -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 3, 0); +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 { - x_114 = x_113; + lean_dec_ref(x_87); + x_119 = lean_box(0); } -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_42); -if (lean_is_scalar(x_110)) { - x_115 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_115 = x_110; + x_120 = x_119; } -lean_ctor_set(x_115, 0, x_105); -lean_ctor_set(x_115, 1, x_106); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_107); -lean_ctor_set(x_115, 4, x_108); -lean_ctor_set(x_115, 5, x_109); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_104); -lean_ctor_set(x_116, 1, x_115); -return x_116; +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_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_7, 0); -x_118 = lean_ctor_get(x_7, 1); -x_119 = lean_ctor_get(x_7, 2); -x_120 = lean_ctor_get(x_7, 3); -x_121 = lean_ctor_get(x_7, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_7); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_36); -lean_ctor_set(x_122, 1, x_14); -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_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_38, x_124, x_35); -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; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); +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); -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; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_126, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +lean_inc(x_126); +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_Init_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_126, 4); +x_133 = lean_ctor_get(x_132, 2); lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); +x_134 = lean_ctor_get(x_131, 0); 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_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; } else { - lean_dec_ref(x_126); + lean_dec_ref(x_131); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); +x_136 = lean_ctor_get(x_132, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); +x_137 = lean_ctor_get(x_132, 1); lean_inc(x_137); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - x_138 = x_127; +x_138 = lean_ctor_get(x_132, 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; } else { - lean_dec_ref(x_127); - x_138 = lean_box(0); + lean_dec_ref(x_132); + x_141 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_42); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -if (lean_is_scalar(x_129)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_129; -} -lean_ctor_set(x_141, 0, x_128); -lean_ctor_set(x_141, 1, x_140); -return x_141; -} -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; -x_142 = lean_ctor_get(x_125, 1); +x_142 = lean_ctor_get(x_133, 0); lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); +x_143 = lean_ctor_get(x_133, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 0); +x_144 = lean_ctor_get(x_133, 3); lean_inc(x_144); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_145 = x_125; +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; } else { - lean_dec_ref(x_125); + lean_dec_ref(x_133); x_145 = lean_box(0); } -x_146 = lean_ctor_get(x_142, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 3); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 4); -lean_inc(x_149); -x_150 = lean_ctor_get(x_142, 5); -lean_inc(x_150); -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_151 = x_142; -} else { - lean_dec_ref(x_142); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_143, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 3, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -lean_ctor_set(x_155, 2, x_42); -if (lean_is_scalar(x_151)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_151; -} -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); if (lean_is_scalar(x_145)) { - x_157 = lean_alloc_ctor(1, 2, 0); + x_146 = lean_alloc_ctor(0, 4, 0); } else { - x_157 = x_145; + x_146 = x_145; } -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; +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); +if (lean_is_scalar(x_135)) { + x_148 = lean_alloc_ctor(0, 2, 0); +} else { + x_148 = x_135; +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_149, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_131, 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); +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_42); +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(1, 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_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_40, 0); -x_159 = lean_ctor_get(x_40, 1); -x_160 = lean_ctor_get(x_40, 2); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_40); -x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_162 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_162, 0, x_158); -lean_ctor_set(x_162, 1, x_159); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_35, 2, x_162); -x_163 = lean_ctor_get(x_7, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 2); -lean_inc(x_165); -x_166 = lean_ctor_get(x_7, 3); -lean_inc(x_166); -x_167 = lean_ctor_get(x_7, 4); +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); 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_168 = x_7; + x_177 = x_7; } else { lean_dec_ref(x_7); - x_168 = lean_box(0); + x_177 = lean_box(0); } -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_36); -lean_ctor_set(x_169, 1, x_14); -x_170 = lean_array_push(x_165, x_169); -if (lean_is_scalar(x_168)) { - x_171 = lean_alloc_ctor(0, 5, 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); } else { - x_171 = x_168; + x_180 = x_177; } -lean_ctor_set(x_171, 0, x_163); -lean_ctor_set(x_171, 1, x_164); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_166); -lean_ctor_set(x_171, 4, x_167); -x_172 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_38, x_171, x_35); -if (lean_obj_tag(x_172) == 0) +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_Init_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_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_173 = lean_ctor_get(x_172, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_176 = x_172; -} else { - lean_dec_ref(x_172); - 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_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_174, 1); +x_184 = lean_ctor_get(x_181, 0); lean_inc(x_184); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - x_185 = x_174; +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_174); + lean_dec_ref(x_181); x_185 = lean_box(0); } -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 3, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -lean_ctor_set(x_186, 2, x_160); -if (lean_is_scalar(x_182)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_182; -} -lean_ctor_set(x_187, 0, x_177); -lean_ctor_set(x_187, 1, x_178); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_179); -lean_ctor_set(x_187, 4, x_180); -lean_ctor_set(x_187, 5, x_181); -if (lean_is_scalar(x_176)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_176; -} -lean_ctor_set(x_188, 0, x_175); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -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; -x_189 = lean_ctor_get(x_172, 1); +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_189, 2); +x_190 = lean_ctor_get(x_182, 5); lean_inc(x_190); -x_191 = lean_ctor_get(x_172, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_192 = x_172; +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_172); - x_192 = lean_box(0); + lean_dec_ref(x_182); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 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_189, 1); +x_194 = lean_ctor_get(x_183, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); -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; +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_189); - x_198 = lean_box(0); + lean_dec_ref(x_183); + x_195 = lean_box(0); } -x_199 = lean_ctor_get(x_190, 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; +} +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_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_199, 2); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - x_201 = x_190; +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; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_181); + x_202 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_205); +x_206 = lean_ctor_get(x_199, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_199, 5); +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 { - x_202 = x_201; + lean_dec_ref(x_199); + x_208 = lean_box(0); } -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_160); -if (lean_is_scalar(x_198)) { - x_203 = lean_alloc_ctor(0, 6, 0); +x_209 = lean_ctor_get(x_200, 0); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 3); +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; } else { - x_203 = x_198; + lean_dec_ref(x_200); + x_212 = lean_box(0); } -lean_ctor_set(x_203, 0, x_193); -lean_ctor_set(x_203, 1, x_194); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_195); -lean_ctor_set(x_203, 4, x_196); -lean_ctor_set(x_203, 5, x_197); -if (lean_is_scalar(x_192)) { - x_204 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); } else { - x_204 = x_192; + x_213 = x_212; } -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +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); +} 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_202)) { + x_215 = lean_alloc_ctor(1, 2, 0); +} else { + x_215 = x_202; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } 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; -x_205 = lean_ctor_get(x_35, 2); -x_206 = lean_ctor_get(x_35, 0); -x_207 = lean_ctor_get(x_35, 1); -x_208 = lean_ctor_get(x_35, 3); -x_209 = lean_ctor_get(x_35, 4); -x_210 = lean_ctor_get(x_35, 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_35); -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); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - x_214 = x_205; -} else { - lean_dec_ref(x_205); - x_214 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 3, 0); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_211); -lean_ctor_set(x_216, 1, x_212); -lean_ctor_set(x_216, 2, x_215); -x_217 = lean_alloc_ctor(0, 6, 0); -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); -x_218 = lean_ctor_get(x_7, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_7, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_7, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_7, 3); +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); -x_222 = lean_ctor_get(x_7, 4); +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_223 = x_7; + x_235 = x_7; } else { lean_dec_ref(x_7); - x_223 = lean_box(0); + x_235 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_36); -lean_ctor_set(x_224, 1, x_14); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { - x_226 = lean_alloc_ctor(0, 5, 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_226 = x_223; + x_238 = x_235; } -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_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_38, x_226, x_217); -if (lean_obj_tag(x_227) == 0) +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_Init_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_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_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_227, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_231 = x_227; +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_227); - x_231 = lean_box(0); + lean_dec_ref(x_239); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_228, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); -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); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - x_240 = x_229; -} else { - lean_dec_ref(x_229); - x_240 = lean_box(0); -} -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 3, 0); -} else { - x_241 = x_240; -} -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_213); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); -} else { - x_242 = x_237; -} -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 2, 0); -} else { - x_243 = x_231; -} -lean_ctor_set(x_243, 0, x_230); -lean_ctor_set(x_243, 1, x_242); -return x_243; -} -else -{ -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_244 = lean_ctor_get(x_227, 1); +x_244 = lean_ctor_get(x_240, 0); lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 2); +x_245 = lean_ctor_get(x_240, 1); lean_inc(x_245); -x_246 = lean_ctor_get(x_227, 0); +x_246 = lean_ctor_get(x_240, 3); lean_inc(x_246); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_247 = x_227; -} else { - lean_dec_ref(x_227); - x_247 = lean_box(0); -} -x_248 = lean_ctor_get(x_244, 0); +x_247 = lean_ctor_get(x_240, 4); +lean_inc(x_247); +x_248 = lean_ctor_get(x_240, 5); lean_inc(x_248); -x_249 = lean_ctor_get(x_244, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_244, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_244, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 5); -lean_inc(x_252); -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_253 = x_244; +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_244); + 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); } -x_254 = lean_ctor_get(x_245, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 1); -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); - 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, 3, 0); -} else { - x_257 = x_256; -} -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_213); if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); + x_254 = lean_alloc_ctor(0, 4, 0); } else { - x_258 = x_253; + x_254 = x_253; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(1, 2, 0); +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_259 = x_247; + x_255 = x_249; } -lean_ctor_set(x_259, 0, x_246); -lean_ctor_set(x_259, 1, x_258); -return x_259; +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_260; +uint8_t x_274; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_260 = !lean_is_exclusive(x_29); -if (x_260 == 0) +x_274 = !lean_is_exclusive(x_29); +if (x_274 == 0) { return x_29; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; -x_261 = lean_ctor_get(x_29, 0); -x_262 = lean_ctor_get(x_29, 1); -lean_inc(x_262); -lean_inc(x_261); +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_dec(x_29); -x_263 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_263, 0, x_261); -lean_ctor_set(x_263, 1, x_262); -return x_263; +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; } } } } else { -uint8_t x_264; +uint8_t x_278; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_264 = !lean_is_exclusive(x_21); -if (x_264 == 0) +x_278 = !lean_is_exclusive(x_21); +if (x_278 == 0) { return x_21; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; -x_265 = lean_ctor_get(x_21, 0); -x_266 = lean_ctor_get(x_21, 1); -lean_inc(x_266); -lean_inc(x_265); +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_dec(x_21); -x_267 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_267, 0, x_265); -lean_ctor_set(x_267, 1, x_266); -return x_267; +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; } } } else { -uint8_t x_268; +uint8_t x_282; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_268 = !lean_is_exclusive(x_15); -if (x_268 == 0) +x_282 = !lean_is_exclusive(x_15); +if (x_282 == 0) { return x_15; } else { -lean_object* x_269; lean_object* x_270; lean_object* x_271; -x_269 = lean_ctor_get(x_15, 0); -x_270 = lean_ctor_get(x_15, 1); -lean_inc(x_270); -lean_inc(x_269); +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_dec(x_15); -x_271 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_271, 0, x_269); -lean_ctor_set(x_271, 1, x_270); -return x_271; +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; } } } @@ -10724,82 +10830,89 @@ return x_48; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_59 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -lean_ctor_set(x_59, 2, x_42); -lean_ctor_set(x_49, 2, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_49, 0); -x_61 = lean_ctor_get(x_49, 1); -x_62 = lean_ctor_get(x_49, 3); -x_63 = lean_ctor_get(x_49, 4); -x_64 = lean_ctor_get(x_49, 5); +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_inc(x_62); lean_inc(x_61); -lean_inc(x_60); lean_dec(x_49); -x_65 = lean_ctor_get(x_50, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_50, 1); +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); - x_67 = x_50; + lean_ctor_release(x_50, 3); + x_69 = x_50; } else { lean_dec_ref(x_50); - x_67 = lean_box(0); + x_69 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_70 = x_69; } -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_42); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_60); -lean_ctor_set(x_69, 1, x_61); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_62); -lean_ctor_set(x_69, 4, x_63); -lean_ctor_set(x_69, 5, x_64); -lean_ctor_set(x_48, 1, x_69); +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; } } 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; -x_70 = lean_ctor_get(x_48, 0); -lean_inc(x_70); -lean_dec(x_48); -x_71 = lean_ctor_get(x_49, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_49, 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; lean_object* x_84; lean_object* x_85; +x_72 = lean_ctor_get(x_48, 0); lean_inc(x_72); -x_73 = lean_ctor_get(x_49, 3); +lean_dec(x_48); +x_73 = lean_ctor_get(x_49, 0); lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 4); +x_74 = lean_ctor_get(x_49, 1); lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 5); +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); @@ -10807,1900 +10920,1999 @@ if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 3); lean_ctor_release(x_49, 4); lean_ctor_release(x_49, 5); - x_76 = x_49; + x_78 = x_49; } else { lean_dec_ref(x_49); - x_76 = lean_box(0); + x_78 = lean_box(0); } -x_77 = lean_ctor_get(x_50, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_50, 1); -lean_inc(x_78); +x_79 = lean_ctor_get(x_50, 0); +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); - x_79 = x_50; + lean_ctor_release(x_50, 3); + x_82 = x_50; } else { lean_dec_ref(x_50); - x_79 = lean_box(0); + x_82 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_83 = x_82; } -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_42); -if (lean_is_scalar(x_76)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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_81 = x_76; + x_84 = x_78; } -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); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_70); -lean_ctor_set(x_82, 1, x_81); -return x_82; +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; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_48, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_48); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; +lean_object* x_86; lean_object* x_87; uint8_t x_88; x_86 = lean_ctor_get(x_48, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = !lean_is_exclusive(x_48); +if (x_88 == 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_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_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_42); +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_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -lean_ctor_set(x_93, 2, x_42); -lean_ctor_set(x_83, 2, x_93); -return x_48; -} -} -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; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -x_97 = lean_ctor_get(x_83, 4); -x_98 = lean_ctor_get(x_83, 5); -lean_inc(x_98); -lean_inc(x_97); +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_83); -x_99 = lean_ctor_get(x_84, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_84, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_101 = x_84; -} else { - lean_dec_ref(x_84); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 3, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_102, 2, x_42); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_94); -lean_ctor_set(x_103, 1, x_95); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_97); -lean_ctor_set(x_103, 5, x_98); -lean_ctor_set(x_48, 1, x_103); +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_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_104 = lean_ctor_get(x_48, 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; +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); -lean_dec(x_48); -x_105 = lean_ctor_get(x_83, 0); +x_105 = lean_ctor_get(x_87, 3); lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_83, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 5); +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; +} else { + lean_dec_ref(x_87); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 4, 0); +} else { + x_107 = x_106; +} +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); -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_110 = x_83; -} else { - lean_dec_ref(x_83); - x_110 = lean_box(0); -} -x_111 = lean_ctor_get(x_84, 0); +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_84, 1); +x_112 = lean_ctor_get(x_86, 3); 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); - x_113 = x_84; +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; } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + lean_dec_ref(x_86); + x_115 = lean_box(0); } -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 3, 0); +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 { - x_114 = x_113; + lean_dec_ref(x_87); + x_119 = lean_box(0); } -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_42); -if (lean_is_scalar(x_110)) { - x_115 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_115 = x_110; + x_120 = x_119; } -lean_ctor_set(x_115, 0, x_105); -lean_ctor_set(x_115, 1, x_106); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_107); -lean_ctor_set(x_115, 4, x_108); -lean_ctor_set(x_115, 5, x_109); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_104); -lean_ctor_set(x_116, 1, x_115); -return x_116; +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_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_8, 0); -x_118 = lean_ctor_get(x_8, 1); -x_119 = lean_ctor_get(x_8, 2); -x_120 = lean_ctor_get(x_8, 3); -x_121 = lean_ctor_get(x_8, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_8); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_36); -lean_ctor_set(x_122, 1, x_24); -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_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_124, x_35); -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; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); +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); -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; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_126, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +lean_inc(x_126); +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_126, 4); +x_133 = lean_ctor_get(x_132, 2); lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); +x_134 = lean_ctor_get(x_131, 0); 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_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; } else { - lean_dec_ref(x_126); + lean_dec_ref(x_131); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); +x_136 = lean_ctor_get(x_132, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); +x_137 = lean_ctor_get(x_132, 1); lean_inc(x_137); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - x_138 = x_127; +x_138 = lean_ctor_get(x_132, 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; } else { - lean_dec_ref(x_127); - x_138 = lean_box(0); + lean_dec_ref(x_132); + x_141 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_42); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -if (lean_is_scalar(x_129)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_129; -} -lean_ctor_set(x_141, 0, x_128); -lean_ctor_set(x_141, 1, x_140); -return x_141; -} -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; -x_142 = lean_ctor_get(x_125, 1); +x_142 = lean_ctor_get(x_133, 0); lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); +x_143 = lean_ctor_get(x_133, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 0); +x_144 = lean_ctor_get(x_133, 3); lean_inc(x_144); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_145 = x_125; +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; } else { - lean_dec_ref(x_125); + lean_dec_ref(x_133); x_145 = lean_box(0); } -x_146 = lean_ctor_get(x_142, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 3); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 4); -lean_inc(x_149); -x_150 = lean_ctor_get(x_142, 5); -lean_inc(x_150); -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_151 = x_142; -} else { - lean_dec_ref(x_142); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_143, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 3, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -lean_ctor_set(x_155, 2, x_42); -if (lean_is_scalar(x_151)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_151; -} -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); if (lean_is_scalar(x_145)) { - x_157 = lean_alloc_ctor(1, 2, 0); + x_146 = lean_alloc_ctor(0, 4, 0); } else { - x_157 = x_145; + x_146 = x_145; } -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; +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); +if (lean_is_scalar(x_135)) { + x_148 = lean_alloc_ctor(0, 2, 0); +} else { + x_148 = x_135; +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_149, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_131, 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); +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_42); +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(1, 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_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_40, 0); -x_159 = lean_ctor_get(x_40, 1); -x_160 = lean_ctor_get(x_40, 2); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_40); -x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_162 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_162, 0, x_158); -lean_ctor_set(x_162, 1, x_159); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_35, 2, x_162); -x_163 = lean_ctor_get(x_8, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 2); -lean_inc(x_165); -x_166 = lean_ctor_get(x_8, 3); -lean_inc(x_166); -x_167 = lean_ctor_get(x_8, 4); +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); 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_168 = x_8; + x_177 = x_8; } else { lean_dec_ref(x_8); - x_168 = lean_box(0); + x_177 = lean_box(0); } -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_36); -lean_ctor_set(x_169, 1, x_24); -x_170 = lean_array_push(x_165, x_169); -if (lean_is_scalar(x_168)) { - x_171 = lean_alloc_ctor(0, 5, 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); } else { - x_171 = x_168; + x_180 = x_177; } -lean_ctor_set(x_171, 0, x_163); -lean_ctor_set(x_171, 1, x_164); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_166); -lean_ctor_set(x_171, 4, x_167); -x_172 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_171, x_35); -if (lean_obj_tag(x_172) == 0) +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_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_173 = lean_ctor_get(x_172, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_176 = x_172; -} else { - lean_dec_ref(x_172); - 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_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_174, 1); +x_184 = lean_ctor_get(x_181, 0); lean_inc(x_184); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - x_185 = x_174; +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_174); + lean_dec_ref(x_181); x_185 = lean_box(0); } -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 3, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -lean_ctor_set(x_186, 2, x_160); -if (lean_is_scalar(x_182)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_182; -} -lean_ctor_set(x_187, 0, x_177); -lean_ctor_set(x_187, 1, x_178); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_179); -lean_ctor_set(x_187, 4, x_180); -lean_ctor_set(x_187, 5, x_181); -if (lean_is_scalar(x_176)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_176; -} -lean_ctor_set(x_188, 0, x_175); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -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; -x_189 = lean_ctor_get(x_172, 1); +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_189, 2); +x_190 = lean_ctor_get(x_182, 5); lean_inc(x_190); -x_191 = lean_ctor_get(x_172, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_192 = x_172; +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_172); - x_192 = lean_box(0); + lean_dec_ref(x_182); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 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_189, 1); +x_194 = lean_ctor_get(x_183, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); -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; +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_189); - x_198 = lean_box(0); + lean_dec_ref(x_183); + x_195 = lean_box(0); } -x_199 = lean_ctor_get(x_190, 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; +} +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_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_199, 2); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - x_201 = x_190; +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; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_181); + x_202 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_205); +x_206 = lean_ctor_get(x_199, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_199, 5); +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 { - x_202 = x_201; + lean_dec_ref(x_199); + x_208 = lean_box(0); } -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_160); -if (lean_is_scalar(x_198)) { - x_203 = lean_alloc_ctor(0, 6, 0); +x_209 = lean_ctor_get(x_200, 0); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 3); +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; } else { - x_203 = x_198; + lean_dec_ref(x_200); + x_212 = lean_box(0); } -lean_ctor_set(x_203, 0, x_193); -lean_ctor_set(x_203, 1, x_194); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_195); -lean_ctor_set(x_203, 4, x_196); -lean_ctor_set(x_203, 5, x_197); -if (lean_is_scalar(x_192)) { - x_204 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); } else { - x_204 = x_192; + x_213 = x_212; } -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +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); +} 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_202)) { + x_215 = lean_alloc_ctor(1, 2, 0); +} else { + x_215 = x_202; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } 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; -x_205 = lean_ctor_get(x_35, 2); -x_206 = lean_ctor_get(x_35, 0); -x_207 = lean_ctor_get(x_35, 1); -x_208 = lean_ctor_get(x_35, 3); -x_209 = lean_ctor_get(x_35, 4); -x_210 = lean_ctor_get(x_35, 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_35); -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); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - x_214 = x_205; -} else { - lean_dec_ref(x_205); - x_214 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 3, 0); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_211); -lean_ctor_set(x_216, 1, x_212); -lean_ctor_set(x_216, 2, x_215); -x_217 = lean_alloc_ctor(0, 6, 0); -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); -x_218 = lean_ctor_get(x_8, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_8, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_8, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_8, 3); +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); -x_222 = lean_ctor_get(x_8, 4); +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_223 = x_8; + x_235 = x_8; } else { lean_dec_ref(x_8); - x_223 = lean_box(0); + x_235 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_36); -lean_ctor_set(x_224, 1, x_24); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { - x_226 = lean_alloc_ctor(0, 5, 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_226 = x_223; + x_238 = x_235; } -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_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_226, x_217); -if (lean_obj_tag(x_227) == 0) +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_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_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_227, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_231 = x_227; +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_227); - x_231 = lean_box(0); + lean_dec_ref(x_239); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_228, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); -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; +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_228); - x_237 = lean_box(0); + lean_dec_ref(x_240); + x_249 = 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); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - x_240 = x_229; +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_229); - x_240 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - x_241 = x_240; + x_254 = x_253; } -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_213); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); +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_242 = x_237; + x_255 = x_249; } -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 2, 0); +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_243 = x_231; + x_256 = x_243; } -lean_ctor_set(x_243, 0, x_230); -lean_ctor_set(x_243, 1, x_242); -return 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_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_244 = lean_ctor_get(x_227, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 2); -lean_inc(x_245); -x_246 = lean_ctor_get(x_227, 0); -lean_inc(x_246); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_247 = x_227; +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_227); - x_247 = lean_box(0); + lean_dec_ref(x_239); + x_260 = lean_box(0); } -x_248 = lean_ctor_get(x_244, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_244, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_244, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_244, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 5); -lean_inc(x_252); -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_253 = x_244; +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_244); - x_253 = lean_box(0); + lean_dec_ref(x_257); + x_266 = lean_box(0); } -x_254 = lean_ctor_get(x_245, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 1); -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); - x_256 = x_245; +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_245); - x_256 = lean_box(0); + lean_dec_ref(x_258); + x_270 = lean_box(0); } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 4, 0); } else { - x_257 = x_256; + x_271 = x_270; } -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_213); -if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); +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_258 = x_253; + x_272 = x_266; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_261); +lean_ctor_set(x_272, 1, x_262); +lean_ctor_set(x_272, 2, x_271); +lean_ctor_set(x_272, 3, x_263); +lean_ctor_set(x_272, 4, x_264); +lean_ctor_set(x_272, 5, x_265); +if (lean_is_scalar(x_260)) { + x_273 = lean_alloc_ctor(1, 2, 0); } else { - x_259 = x_247; + x_273 = x_260; } -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; } } } default: { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_29, 1); -lean_inc(x_260); +lean_object* x_274; lean_object* x_275; +x_274 = lean_ctor_get(x_29, 1); +lean_inc(x_274); lean_dec(x_29); lean_inc(x_8); -x_261 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_260); -if (lean_obj_tag(x_261) == 0) +x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); +if (lean_obj_tag(x_275) == 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_276; +x_276 = lean_ctor_get(x_275, 0); +lean_inc(x_276); +if (lean_obj_tag(x_276) == 0) { -lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_dec(x_24); -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_7, x_264); +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); lean_dec(x_7); -x_7 = x_265; -x_9 = x_263; +x_7 = x_279; +x_9 = x_277; 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_7, x_269); -lean_dec(x_7); -x_271 = !lean_is_exclusive(x_267); -if (x_271 == 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_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_8); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_8, 2); -x_278 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_24); -x_279 = lean_array_push(x_277, x_278); -lean_ctor_set(x_8, 2, x_279); -x_280 = 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_270, x_8, x_267); -if (lean_obj_tag(x_280) == 0) -{ -lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_281 = lean_ctor_get(x_280, 1); +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); -x_282 = lean_ctor_get(x_281, 2); +lean_dec(x_275); +x_282 = lean_ctor_get(x_276, 0); 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); +lean_dec(x_276); +x_283 = lean_unsigned_to_nat(1u); +x_284 = lean_nat_add(x_7, x_283); +lean_dec(x_7); 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); +x_287 = !lean_is_exclusive(x_286); 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_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_289; lean_object* x_290; lean_object* x_291; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_282); -x_291 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_291, 0, x_289); -lean_ctor_set(x_291, 1, x_290); -lean_ctor_set(x_291, 2, x_274); -lean_ctor_set(x_281, 2, x_291); -return x_280; -} -} -else +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_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_292 = lean_ctor_get(x_281, 0); -x_293 = lean_ctor_get(x_281, 1); -x_294 = lean_ctor_get(x_281, 3); -x_295 = lean_ctor_get(x_281, 4); -x_296 = lean_ctor_get(x_281, 5); -lean_inc(x_296); +lean_object* x_295; lean_object* x_296; uint8_t x_297; +x_295 = lean_ctor_get(x_294, 1); lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_281); -x_297 = lean_ctor_get(x_282, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_282, 1); -lean_inc(x_298); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_299 = x_282; -} else { - lean_dec_ref(x_282); - x_299 = lean_box(0); -} -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 3, 0); -} else { - x_300 = x_299; -} -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_274); -x_301 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_301, 0, x_292); -lean_ctor_set(x_301, 1, x_293); -lean_ctor_set(x_301, 2, x_300); -lean_ctor_set(x_301, 3, x_294); -lean_ctor_set(x_301, 4, x_295); -lean_ctor_set(x_301, 5, x_296); -lean_ctor_set(x_280, 1, x_301); -return x_280; -} +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_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_302 = lean_ctor_get(x_280, 0); -lean_inc(x_302); -lean_dec(x_280); -x_303 = lean_ctor_get(x_281, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_281, 1); -lean_inc(x_304); -x_305 = lean_ctor_get(x_281, 3); +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); -x_306 = lean_ctor_get(x_281, 4); -lean_inc(x_306); -x_307 = lean_ctor_get(x_281, 5); -lean_inc(x_307); -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_308 = x_281; -} else { - lean_dec_ref(x_281); - x_308 = lean_box(0); +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; } -x_309 = lean_ctor_get(x_282, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_282, 1); +} +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); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_311 = x_282; +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_inc(x_313); +x_314 = lean_ctor_get(x_296, 3); +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_282); - x_311 = lean_box(0); + lean_dec_ref(x_296); + x_315 = lean_box(0); } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_315)) { + x_316 = lean_alloc_ctor(0, 4, 0); } else { - x_312 = x_311; + x_316 = x_315; } -lean_ctor_set(x_312, 0, x_309); -lean_ctor_set(x_312, 1, x_310); -lean_ctor_set(x_312, 2, x_274); -if (lean_is_scalar(x_308)) { - x_313 = lean_alloc_ctor(0, 6, 0); -} else { - x_313 = x_308; -} -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); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_302); -lean_ctor_set(x_314, 1, x_313); -return x_314; +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_315; lean_object* x_316; uint8_t x_317; -x_315 = lean_ctor_get(x_280, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_315, 2); -lean_inc(x_316); -x_317 = !lean_is_exclusive(x_280); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_280, 1); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_315); -if (x_319 == 0) -{ -lean_object* x_320; uint8_t x_321; -x_320 = lean_ctor_get(x_315, 2); -lean_dec(x_320); -x_321 = !lean_is_exclusive(x_316); -if (x_321 == 0) -{ -lean_object* x_322; -x_322 = lean_ctor_get(x_316, 2); -lean_dec(x_322); -lean_ctor_set(x_316, 2, x_274); -return x_280; -} -else -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_323 = lean_ctor_get(x_316, 0); -x_324 = lean_ctor_get(x_316, 1); -lean_inc(x_324); +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_inc(x_323); -lean_dec(x_316); -x_325 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_325, 0, x_323); -lean_ctor_set(x_325, 1, x_324); -lean_ctor_set(x_325, 2, x_274); -lean_ctor_set(x_315, 2, x_325); -return x_280; +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); } -} -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; -x_326 = lean_ctor_get(x_315, 0); -x_327 = lean_ctor_get(x_315, 1); -x_328 = lean_ctor_get(x_315, 3); -x_329 = lean_ctor_get(x_315, 4); -x_330 = lean_ctor_get(x_315, 5); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_inc(x_327); +x_325 = lean_ctor_get(x_296, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_296, 1); lean_inc(x_326); -lean_dec(x_315); -x_331 = lean_ctor_get(x_316, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_316, 1); +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); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_333 = x_316; -} else { - lean_dec_ref(x_316); - x_333 = lean_box(0); -} -if (lean_is_scalar(x_333)) { - x_334 = lean_alloc_ctor(0, 3, 0); -} else { - x_334 = x_333; -} -lean_ctor_set(x_334, 0, x_331); -lean_ctor_set(x_334, 1, x_332); -lean_ctor_set(x_334, 2, x_274); -x_335 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_335, 0, x_326); -lean_ctor_set(x_335, 1, x_327); -lean_ctor_set(x_335, 2, x_334); -lean_ctor_set(x_335, 3, x_328); -lean_ctor_set(x_335, 4, x_329); -lean_ctor_set(x_335, 5, x_330); -lean_ctor_set(x_280, 1, x_335); -return x_280; -} +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_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_336 = lean_ctor_get(x_280, 0); -lean_inc(x_336); -lean_dec(x_280); -x_337 = lean_ctor_get(x_315, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_315, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_315, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_315, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_315, 5); +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); -if (lean_is_exclusive(x_315)) { - lean_ctor_release(x_315, 0); - lean_ctor_release(x_315, 1); - lean_ctor_release(x_315, 2); - lean_ctor_release(x_315, 3); - lean_ctor_release(x_315, 4); - lean_ctor_release(x_315, 5); - x_342 = x_315; -} else { - lean_dec_ref(x_315); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_316, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_316, 1); -lean_inc(x_344); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_345 = x_316; -} else { - lean_dec_ref(x_316); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 3, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_274); -if (lean_is_scalar(x_342)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_342; -} -lean_ctor_set(x_347, 0, x_337); -lean_ctor_set(x_347, 1, x_338); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_339); -lean_ctor_set(x_347, 4, x_340); -lean_ctor_set(x_347, 5, x_341); -x_348 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_348, 0, x_336); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} +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_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_349 = lean_ctor_get(x_8, 0); -x_350 = lean_ctor_get(x_8, 1); -x_351 = lean_ctor_get(x_8, 2); -x_352 = lean_ctor_get(x_8, 3); -x_353 = lean_ctor_get(x_8, 4); -lean_inc(x_353); -lean_inc(x_352); -lean_inc(x_351); -lean_inc(x_350); +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); -lean_dec(x_8); -x_354 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_354, 0, x_268); -lean_ctor_set(x_354, 1, x_24); -x_355 = lean_array_push(x_351, x_354); -x_356 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_356, 0, x_349); -lean_ctor_set(x_356, 1, x_350); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_352); -lean_ctor_set(x_356, 4, x_353); -x_357 = 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_270, x_356, x_267); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; -x_358 = lean_ctor_get(x_357, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_358, 2); -lean_inc(x_359); -x_360 = lean_ctor_get(x_357, 0); -lean_inc(x_360); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_361 = x_357; +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_357); + 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_358, 0); +x_362 = lean_ctor_get(x_333, 0); lean_inc(x_362); -x_363 = lean_ctor_get(x_358, 1); +x_363 = lean_ctor_get(x_333, 1); lean_inc(x_363); -x_364 = lean_ctor_get(x_358, 3); +x_364 = lean_ctor_get(x_333, 3); lean_inc(x_364); -x_365 = lean_ctor_get(x_358, 4); -lean_inc(x_365); -x_366 = lean_ctor_get(x_358, 5); -lean_inc(x_366); -if (lean_is_exclusive(x_358)) { - lean_ctor_release(x_358, 0); - lean_ctor_release(x_358, 1); - lean_ctor_release(x_358, 2); - lean_ctor_release(x_358, 3); - lean_ctor_release(x_358, 4); - lean_ctor_release(x_358, 5); - x_367 = x_358; +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_358); - x_367 = lean_box(0); + lean_dec_ref(x_333); + x_365 = lean_box(0); } -x_368 = lean_ctor_get(x_359, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_359, 1); -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); - x_370 = x_359; +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_359); - x_370 = lean_box(0); + x_366 = x_365; } -if (lean_is_scalar(x_370)) { - x_371 = lean_alloc_ctor(0, 3, 0); -} else { - x_371 = x_370; -} -lean_ctor_set(x_371, 0, x_368); -lean_ctor_set(x_371, 1, x_369); -lean_ctor_set(x_371, 2, x_274); -if (lean_is_scalar(x_367)) { - x_372 = lean_alloc_ctor(0, 6, 0); -} else { - x_372 = x_367; -} -lean_ctor_set(x_372, 0, x_362); -lean_ctor_set(x_372, 1, x_363); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_364); -lean_ctor_set(x_372, 4, x_365); -lean_ctor_set(x_372, 5, x_366); +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_373 = lean_alloc_ctor(0, 2, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_373 = x_361; + 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; +} } -lean_ctor_set(x_373, 0, x_360); -lean_ctor_set(x_373, 1, x_372); -return x_373; } else { -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_374 = lean_ctor_get(x_357, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_357, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_377 = x_357; -} else { - lean_dec_ref(x_357); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); +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_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) +{ +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_374, 1); +x_379 = lean_ctor_get(x_378, 2); lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); +x_380 = lean_ctor_get(x_377, 0); lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); +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); -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); +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_375, 1); +x_385 = lean_ctor_get(x_378, 4); lean_inc(x_385); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - lean_ctor_release(x_375, 2); - x_386 = x_375; +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_375); - x_386 = lean_box(0); + lean_dec_ref(x_378); + x_387 = lean_box(0); } -if (lean_is_scalar(x_386)) { - x_387 = lean_alloc_ctor(0, 3, 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 { - x_387 = x_386; + lean_dec_ref(x_379); + x_391 = lean_box(0); } -lean_ctor_set(x_387, 0, x_384); -lean_ctor_set(x_387, 1, x_385); -lean_ctor_set(x_387, 2, x_274); -if (lean_is_scalar(x_383)) { - x_388 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_391)) { + x_392 = lean_alloc_ctor(0, 4, 0); } else { - x_388 = x_383; + x_392 = x_391; } -lean_ctor_set(x_388, 0, x_378); -lean_ctor_set(x_388, 1, x_379); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_380); -lean_ctor_set(x_388, 4, x_381); -lean_ctor_set(x_388, 5, x_382); -if (lean_is_scalar(x_377)) { - x_389 = lean_alloc_ctor(1, 2, 0); +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_389 = x_377; -} -lean_ctor_set(x_389, 0, x_376); -lean_ctor_set(x_389, 1, x_388); -return x_389; + 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; } 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; -x_390 = lean_ctor_get(x_272, 0); -x_391 = lean_ctor_get(x_272, 1); -x_392 = lean_ctor_get(x_272, 2); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_272); -x_393 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_394 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_394, 0, x_390); -lean_ctor_set(x_394, 1, x_391); -lean_ctor_set(x_394, 2, x_393); -lean_ctor_set(x_267, 2, x_394); -x_395 = lean_ctor_get(x_8, 0); +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; 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_8, 1); +x_396 = lean_ctor_get(x_395, 2); lean_inc(x_396); -x_397 = lean_ctor_get(x_8, 2); +x_397 = lean_ctor_get(x_377, 0); lean_inc(x_397); -x_398 = lean_ctor_get(x_8, 3); -lean_inc(x_398); -x_399 = lean_ctor_get(x_8, 4); +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); +} +x_399 = lean_ctor_get(x_395, 0); lean_inc(x_399); -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_400 = x_8; +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_8); - x_400 = lean_box(0); + lean_dec_ref(x_395); + x_404 = lean_box(0); } -x_401 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_401, 0, x_268); -lean_ctor_set(x_401, 1, x_24); -x_402 = lean_array_push(x_397, x_401); -if (lean_is_scalar(x_400)) { - x_403 = lean_alloc_ctor(0, 5, 0); -} else { - x_403 = x_400; -} -lean_ctor_set(x_403, 0, x_395); -lean_ctor_set(x_403, 1, x_396); -lean_ctor_set(x_403, 2, x_402); -lean_ctor_set(x_403, 3, x_398); -lean_ctor_set(x_403, 4, x_399); -x_404 = 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_270, x_403, x_267); -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_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; -x_405 = lean_ctor_get(x_404, 1); +x_405 = lean_ctor_get(x_396, 0); lean_inc(x_405); -x_406 = lean_ctor_get(x_405, 2); +x_406 = lean_ctor_get(x_396, 1); lean_inc(x_406); -x_407 = lean_ctor_get(x_404, 0); +x_407 = lean_ctor_get(x_396, 3); lean_inc(x_407); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_408 = x_404; +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; } else { - lean_dec_ref(x_404); + lean_dec_ref(x_396); x_408 = lean_box(0); } -x_409 = lean_ctor_get(x_405, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_405, 1); -lean_inc(x_410); -x_411 = lean_ctor_get(x_405, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_405, 4); -lean_inc(x_412); -x_413 = lean_ctor_get(x_405, 5); -lean_inc(x_413); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - lean_ctor_release(x_405, 4); - lean_ctor_release(x_405, 5); - x_414 = x_405; -} else { - lean_dec_ref(x_405); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_406, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_406, 1); -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); - x_417 = x_406; -} else { - lean_dec_ref(x_406); - x_417 = lean_box(0); -} -if (lean_is_scalar(x_417)) { - x_418 = lean_alloc_ctor(0, 3, 0); -} else { - x_418 = x_417; -} -lean_ctor_set(x_418, 0, x_415); -lean_ctor_set(x_418, 1, x_416); -lean_ctor_set(x_418, 2, x_392); -if (lean_is_scalar(x_414)) { - x_419 = lean_alloc_ctor(0, 6, 0); -} else { - x_419 = x_414; -} -lean_ctor_set(x_419, 0, x_409); -lean_ctor_set(x_419, 1, x_410); -lean_ctor_set(x_419, 2, x_418); -lean_ctor_set(x_419, 3, x_411); -lean_ctor_set(x_419, 4, x_412); -lean_ctor_set(x_419, 5, x_413); if (lean_is_scalar(x_408)) { - x_420 = lean_alloc_ctor(0, 2, 0); + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_420 = x_408; + x_409 = x_408; +} +lean_ctor_set(x_409, 0, x_405); +lean_ctor_set(x_409, 1, x_406); +lean_ctor_set(x_409, 2, x_288); +lean_ctor_set(x_409, 3, x_407); +if (lean_is_scalar(x_404)) { + x_410 = lean_alloc_ctor(0, 6, 0); +} else { + x_410 = x_404; +} +lean_ctor_set(x_410, 0, x_399); +lean_ctor_set(x_410, 1, x_400); +lean_ctor_set(x_410, 2, x_409); +lean_ctor_set(x_410, 3, x_401); +lean_ctor_set(x_410, 4, x_402); +lean_ctor_set(x_410, 5, x_403); +if (lean_is_scalar(x_398)) { + x_411 = lean_alloc_ctor(1, 2, 0); +} else { + x_411 = x_398; +} +lean_ctor_set(x_411, 0, x_397); +lean_ctor_set(x_411, 1, x_410); +return x_411; +} } -lean_ctor_set(x_420, 0, x_407); -lean_ctor_set(x_420, 1, x_419); -return x_420; } else { -lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_421 = lean_ctor_get(x_404, 1); +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_421, 2); +x_422 = lean_ctor_get(x_8, 4); lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 0); -lean_inc(x_423); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_424 = x_404; -} else { - lean_dec_ref(x_404); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_421, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_421, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_421, 3); -lean_inc(x_427); -x_428 = lean_ctor_get(x_421, 4); -lean_inc(x_428); -x_429 = lean_ctor_get(x_421, 5); -lean_inc(x_429); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - lean_ctor_release(x_421, 2); - lean_ctor_release(x_421, 3); - lean_ctor_release(x_421, 4); - lean_ctor_release(x_421, 5); - x_430 = x_421; -} else { - lean_dec_ref(x_421); - x_430 = lean_box(0); -} -x_431 = lean_ctor_get(x_422, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_422, 1); -lean_inc(x_432); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - lean_ctor_release(x_422, 2); - x_433 = x_422; -} else { - lean_dec_ref(x_422); - x_433 = lean_box(0); -} -if (lean_is_scalar(x_433)) { - x_434 = lean_alloc_ctor(0, 3, 0); -} else { - x_434 = x_433; -} -lean_ctor_set(x_434, 0, x_431); -lean_ctor_set(x_434, 1, x_432); -lean_ctor_set(x_434, 2, x_392); -if (lean_is_scalar(x_430)) { - x_435 = lean_alloc_ctor(0, 6, 0); -} else { - x_435 = x_430; -} -lean_ctor_set(x_435, 0, x_425); -lean_ctor_set(x_435, 1, x_426); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_427); -lean_ctor_set(x_435, 4, x_428); -lean_ctor_set(x_435, 5, x_429); -if (lean_is_scalar(x_424)) { - x_436 = lean_alloc_ctor(1, 2, 0); -} else { - x_436 = x_424; -} -lean_ctor_set(x_436, 0, x_423); -lean_ctor_set(x_436, 1, x_435); -return x_436; -} -} -} -else -{ -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; 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_437 = lean_ctor_get(x_267, 2); -x_438 = lean_ctor_get(x_267, 0); -x_439 = lean_ctor_get(x_267, 1); -x_440 = lean_ctor_get(x_267, 3); -x_441 = lean_ctor_get(x_267, 4); -x_442 = lean_ctor_get(x_267, 5); -lean_inc(x_442); -lean_inc(x_441); -lean_inc(x_440); -lean_inc(x_437); -lean_inc(x_439); -lean_inc(x_438); -lean_dec(x_267); -x_443 = lean_ctor_get(x_437, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_437, 1); -lean_inc(x_444); -x_445 = lean_ctor_get(x_437, 2); -lean_inc(x_445); -if (lean_is_exclusive(x_437)) { - lean_ctor_release(x_437, 0); - lean_ctor_release(x_437, 1); - lean_ctor_release(x_437, 2); - x_446 = x_437; -} else { - lean_dec_ref(x_437); - x_446 = lean_box(0); -} -x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_446)) { - x_448 = lean_alloc_ctor(0, 3, 0); -} else { - x_448 = x_446; -} -lean_ctor_set(x_448, 0, x_443); -lean_ctor_set(x_448, 1, x_444); -lean_ctor_set(x_448, 2, x_447); -x_449 = lean_alloc_ctor(0, 6, 0); -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); -x_450 = lean_ctor_get(x_8, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_8, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_8, 2); -lean_inc(x_452); -x_453 = lean_ctor_get(x_8, 3); -lean_inc(x_453); -x_454 = lean_ctor_get(x_8, 4); -lean_inc(x_454); 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_455 = x_8; + x_423 = x_8; } else { lean_dec_ref(x_8); - x_455 = lean_box(0); + x_423 = lean_box(0); } -x_456 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_456, 0, x_268); -lean_ctor_set(x_456, 1, x_24); -x_457 = lean_array_push(x_452, x_456); -if (lean_is_scalar(x_455)) { - x_458 = lean_alloc_ctor(0, 5, 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); } else { - x_458 = x_455; + x_426 = x_423; } -lean_ctor_set(x_458, 0, x_450); -lean_ctor_set(x_458, 1, x_451); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_453); -lean_ctor_set(x_458, 4, x_454); -x_459 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_458, x_449); -if (lean_obj_tag(x_459) == 0) +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_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_460 = lean_ctor_get(x_459, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_460, 2); -lean_inc(x_461); -x_462 = lean_ctor_get(x_459, 0); -lean_inc(x_462); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_463 = x_459; +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_459); - x_463 = lean_box(0); + lean_dec_ref(x_427); + x_431 = lean_box(0); } -x_464 = lean_ctor_get(x_460, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_460, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_460, 3); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_445); + x_454 = 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; +} else { + lean_dec_ref(x_446); + x_458 = lean_box(0); +} +if (lean_is_scalar(x_458)) { + x_459 = lean_alloc_ctor(0, 4, 0); +} else { + x_459 = x_458; +} +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); +} else { + x_460 = x_454; +} +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); +} else { + x_461 = x_448; +} +lean_ctor_set(x_461, 0, x_447); +lean_ctor_set(x_461, 1, x_460); +return x_461; +} +} +} +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); -x_468 = lean_ctor_get(x_460, 5); +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); -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); - lean_ctor_release(x_460, 4); - lean_ctor_release(x_460, 5); - x_469 = x_460; -} else { - lean_dec_ref(x_460); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_461, 0); +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_461, 1); +x_471 = lean_ctor_get(x_462, 3); lean_inc(x_471); -if (lean_is_exclusive(x_461)) { - lean_ctor_release(x_461, 0); - lean_ctor_release(x_461, 1); - lean_ctor_release(x_461, 2); - x_472 = x_461; +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; } else { - lean_dec_ref(x_461); + lean_dec_ref(x_462); x_472 = lean_box(0); } +x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_472)) { - x_473 = lean_alloc_ctor(0, 3, 0); + x_474 = lean_alloc_ctor(0, 4, 0); } else { - x_473 = x_472; + x_474 = x_472; } -lean_ctor_set(x_473, 0, x_470); -lean_ctor_set(x_473, 1, x_471); -lean_ctor_set(x_473, 2, x_445); -if (lean_is_scalar(x_469)) { - x_474 = lean_alloc_ctor(0, 6, 0); -} else { - x_474 = x_469; -} -lean_ctor_set(x_474, 0, x_464); -lean_ctor_set(x_474, 1, x_465); +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_466); -lean_ctor_set(x_474, 4, x_467); -lean_ctor_set(x_474, 5, x_468); -if (lean_is_scalar(x_463)) { - x_475 = lean_alloc_ctor(0, 2, 0); -} else { - x_475 = x_463; -} -lean_ctor_set(x_475, 0, x_462); -lean_ctor_set(x_475, 1, x_474); -return x_475; -} -else -{ -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_476 = lean_ctor_get(x_459, 1); +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_476, 2); +x_477 = lean_ctor_get(x_8, 1); lean_inc(x_477); -x_478 = lean_ctor_get(x_459, 0); +x_478 = lean_ctor_get(x_8, 2); lean_inc(x_478); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_479 = x_459; -} else { - lean_dec_ref(x_459); - x_479 = lean_box(0); -} -x_480 = lean_ctor_get(x_476, 0); +x_479 = lean_ctor_get(x_8, 3); +lean_inc(x_479); +x_480 = lean_ctor_get(x_8, 4); 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; +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; } else { - lean_dec_ref(x_476); - x_485 = lean_box(0); + lean_dec_ref(x_8); + x_481 = lean_box(0); } -x_486 = lean_ctor_get(x_477, 0); +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); +} else { + x_484 = x_481; +} +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_477, 1); +x_487 = lean_ctor_get(x_486, 2); lean_inc(x_487); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - x_488 = x_477; +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; } else { - lean_dec_ref(x_477); - x_488 = lean_box(0); + lean_dec_ref(x_485); + x_489 = lean_box(0); } -if (lean_is_scalar(x_488)) { - x_489 = lean_alloc_ctor(0, 3, 0); +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 { - x_489 = x_488; + lean_dec_ref(x_486); + x_495 = lean_box(0); } -lean_ctor_set(x_489, 0, x_486); -lean_ctor_set(x_489, 1, x_487); -lean_ctor_set(x_489, 2, x_445); -if (lean_is_scalar(x_485)) { - x_490 = lean_alloc_ctor(0, 6, 0); +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 { - x_490 = x_485; + lean_dec_ref(x_487); + x_499 = lean_box(0); } -lean_ctor_set(x_490, 0, x_480); -lean_ctor_set(x_490, 1, x_481); -lean_ctor_set(x_490, 2, x_489); -lean_ctor_set(x_490, 3, x_482); -lean_ctor_set(x_490, 4, x_483); -lean_ctor_set(x_490, 5, x_484); -if (lean_is_scalar(x_479)) { - x_491 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_499)) { + x_500 = lean_alloc_ctor(0, 4, 0); } else { - x_491 = x_479; + x_500 = x_499; } -lean_ctor_set(x_491, 0, x_478); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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_492; +uint8_t x_520; 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_492 = !lean_is_exclusive(x_261); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_275); +if (x_520 == 0) { -return x_261; +return x_275; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_261, 0); -x_494 = lean_ctor_get(x_261, 1); -lean_inc(x_494); -lean_inc(x_493); -lean_dec(x_261); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } @@ -12708,7 +12920,7 @@ return x_495; } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -12716,52 +12928,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_29); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_29); +if (x_524 == 0) { return x_29; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_29, 0); -x_498 = lean_ctor_get(x_29, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_29); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } else { -uint8_t x_500; +uint8_t x_528; 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_500 = !lean_is_exclusive(x_25); -if (x_500 == 0) +x_528 = !lean_is_exclusive(x_25); +if (x_528 == 0) { return x_25; } else { -lean_object* x_501; lean_object* x_502; lean_object* x_503; -x_501 = lean_ctor_get(x_25, 0); -x_502 = lean_ctor_get(x_25, 1); -lean_inc(x_502); -lean_inc(x_501); +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_dec(x_25); -x_503 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_503, 0, x_501); -lean_ctor_set(x_503, 1, x_502); -return x_503; +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; } } } @@ -12994,82 +13206,89 @@ return x_46; } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; +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_57 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -lean_ctor_set(x_57, 2, x_40); -lean_ctor_set(x_47, 2, x_57); +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; } } 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; -x_58 = lean_ctor_get(x_47, 0); -x_59 = lean_ctor_get(x_47, 1); -x_60 = lean_ctor_get(x_47, 3); -x_61 = lean_ctor_get(x_47, 4); -x_62 = lean_ctor_get(x_47, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +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_inc(x_58); lean_dec(x_47); -x_63 = lean_ctor_get(x_48, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_48, 1); +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); - x_65 = x_48; + lean_ctor_release(x_48, 3); + x_67 = x_48; } else { lean_dec_ref(x_48); - x_65 = lean_box(0); + x_67 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_68 = x_67; } -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_40); -x_67 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_67, 0, x_58); -lean_ctor_set(x_67, 1, x_59); -lean_ctor_set(x_67, 2, x_66); -lean_ctor_set(x_67, 3, x_60); -lean_ctor_set(x_67, 4, x_61); -lean_ctor_set(x_67, 5, x_62); -lean_ctor_set(x_46, 1, 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_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; } } 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; -x_68 = lean_ctor_get(x_46, 0); -lean_inc(x_68); -lean_dec(x_46); -x_69 = lean_ctor_get(x_47, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_47, 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; lean_object* x_82; lean_object* x_83; +x_70 = lean_ctor_get(x_46, 0); lean_inc(x_70); -x_71 = lean_ctor_get(x_47, 3); +lean_dec(x_46); +x_71 = lean_ctor_get(x_47, 0); lean_inc(x_71); -x_72 = lean_ctor_get(x_47, 4); +x_72 = lean_ctor_get(x_47, 1); lean_inc(x_72); -x_73 = lean_ctor_get(x_47, 5); +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); @@ -13077,1877 +13296,1976 @@ if (lean_is_exclusive(x_47)) { lean_ctor_release(x_47, 3); lean_ctor_release(x_47, 4); lean_ctor_release(x_47, 5); - x_74 = x_47; + x_76 = x_47; } else { lean_dec_ref(x_47); - x_74 = lean_box(0); + x_76 = lean_box(0); } -x_75 = lean_ctor_get(x_48, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_48, 1); -lean_inc(x_76); +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); - x_77 = x_48; + lean_ctor_release(x_48, 3); + x_80 = x_48; } else { lean_dec_ref(x_48); - x_77 = lean_box(0); + x_80 = lean_box(0); } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_78 = x_77; + x_81 = x_80; } -lean_ctor_set(x_78, 0, x_75); -lean_ctor_set(x_78, 1, x_76); -lean_ctor_set(x_78, 2, x_40); -if (lean_is_scalar(x_74)) { - x_79 = lean_alloc_ctor(0, 6, 0); +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_79 = x_74; + x_82 = x_76; } -lean_ctor_set(x_79, 0, x_69); -lean_ctor_set(x_79, 1, x_70); -lean_ctor_set(x_79, 2, x_78); -lean_ctor_set(x_79, 3, x_71); -lean_ctor_set(x_79, 4, x_72); -lean_ctor_set(x_79, 5, x_73); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_68); -lean_ctor_set(x_80, 1, x_79); -return x_80; +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; } } else { -lean_object* x_81; lean_object* x_82; uint8_t x_83; -x_81 = lean_ctor_get(x_46, 1); -lean_inc(x_81); -x_82 = lean_ctor_get(x_81, 2); -lean_inc(x_82); -x_83 = !lean_is_exclusive(x_46); -if (x_83 == 0) -{ -lean_object* x_84; uint8_t x_85; +lean_object* x_84; lean_object* x_85; uint8_t x_86; x_84 = lean_ctor_get(x_46, 1); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_81); -if (x_85 == 0) +lean_inc(x_84); +x_85 = lean_ctor_get(x_84, 2); +lean_inc(x_85); +x_86 = !lean_is_exclusive(x_46); +if (x_86 == 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_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_88; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -lean_ctor_set(x_82, 2, x_40); +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_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_82, 0); -x_90 = lean_ctor_get(x_82, 1); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_82); -x_91 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_91, 0, x_89); -lean_ctor_set(x_91, 1, x_90); -lean_ctor_set(x_91, 2, x_40); -lean_ctor_set(x_81, 2, x_91); -return x_46; -} -} -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; -x_92 = lean_ctor_get(x_81, 0); -x_93 = lean_ctor_get(x_81, 1); -x_94 = lean_ctor_get(x_81, 3); -x_95 = lean_ctor_get(x_81, 4); -x_96 = lean_ctor_get(x_81, 5); -lean_inc(x_96); -lean_inc(x_95); +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_81); -x_97 = lean_ctor_get(x_82, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_82, 1); -lean_inc(x_98); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - x_99 = x_82; -} else { - lean_dec_ref(x_82); - x_99 = lean_box(0); -} -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 3, 0); -} else { - x_100 = x_99; -} -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -lean_ctor_set(x_100, 2, x_40); -x_101 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_101, 0, x_92); -lean_ctor_set(x_101, 1, x_93); -lean_ctor_set(x_101, 2, x_100); -lean_ctor_set(x_101, 3, x_94); -lean_ctor_set(x_101, 4, x_95); -lean_ctor_set(x_101, 5, x_96); -lean_ctor_set(x_46, 1, x_101); +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_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_102 = lean_ctor_get(x_46, 0); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_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); -lean_dec(x_46); -x_103 = lean_ctor_get(x_81, 0); +x_103 = lean_ctor_get(x_85, 3); lean_inc(x_103); -x_104 = lean_ctor_get(x_81, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_81, 3); -lean_inc(x_105); -x_106 = lean_ctor_get(x_81, 4); -lean_inc(x_106); -x_107 = lean_ctor_get(x_81, 5); +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; +} else { + lean_dec_ref(x_85); + 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_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); -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_108 = x_81; -} else { - lean_dec_ref(x_81); - x_108 = lean_box(0); -} -x_109 = lean_ctor_get(x_82, 0); +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_82, 1); +x_110 = lean_ctor_get(x_84, 3); 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); - x_111 = x_82; +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; } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + lean_dec_ref(x_84); + x_113 = lean_box(0); } -if (lean_is_scalar(x_111)) { - x_112 = lean_alloc_ctor(0, 3, 0); +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 { - x_112 = x_111; + lean_dec_ref(x_85); + x_117 = lean_box(0); } -lean_ctor_set(x_112, 0, x_109); -lean_ctor_set(x_112, 1, x_110); -lean_ctor_set(x_112, 2, x_40); -if (lean_is_scalar(x_108)) { - x_113 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_117)) { + x_118 = lean_alloc_ctor(0, 4, 0); } else { - x_113 = x_108; + x_118 = x_117; } -lean_ctor_set(x_113, 0, x_103); -lean_ctor_set(x_113, 1, x_104); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_105); -lean_ctor_set(x_113, 4, x_106); -lean_ctor_set(x_113, 5, x_107); -x_114 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_114, 0, x_102); -lean_ctor_set(x_114, 1, x_113); -return x_114; +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_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_115 = lean_ctor_get(x_13, 0); -x_116 = lean_ctor_get(x_13, 1); -x_117 = lean_ctor_get(x_13, 2); -x_118 = lean_ctor_get(x_13, 3); -x_119 = lean_ctor_get(x_13, 4); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_13); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_34); -lean_ctor_set(x_120, 1, x_22); -x_121 = lean_array_push(x_117, x_120); -x_122 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_122, 0, x_115); -lean_ctor_set(x_122, 1, x_116); -lean_ctor_set(x_122, 2, x_121); -lean_ctor_set(x_122, 3, x_118); -lean_ctor_set(x_122, 4, x_119); -x_123 = 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_122, x_33); -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_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_124, 2); +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); -x_126 = lean_ctor_get(x_123, 0); -lean_inc(x_126); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - x_127 = x_123; -} else { - lean_dec_ref(x_123); - x_127 = lean_box(0); -} -x_128 = lean_ctor_get(x_124, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_124, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_124, 3); +lean_inc(x_124); +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_124, 4); +x_131 = lean_ctor_get(x_130, 2); lean_inc(x_131); -x_132 = lean_ctor_get(x_124, 5); +x_132 = lean_ctor_get(x_129, 0); lean_inc(x_132); -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_133 = x_124; +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + x_133 = x_129; } else { - lean_dec_ref(x_124); + lean_dec_ref(x_129); x_133 = lean_box(0); } -x_134 = lean_ctor_get(x_125, 0); +x_134 = lean_ctor_get(x_130, 0); lean_inc(x_134); -x_135 = lean_ctor_get(x_125, 1); +x_135 = lean_ctor_get(x_130, 1); lean_inc(x_135); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - x_136 = x_125; +x_136 = lean_ctor_get(x_130, 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; } else { - lean_dec_ref(x_125); - x_136 = lean_box(0); + lean_dec_ref(x_130); + x_139 = lean_box(0); } -if (lean_is_scalar(x_136)) { - x_137 = lean_alloc_ctor(0, 3, 0); -} else { - x_137 = x_136; -} -lean_ctor_set(x_137, 0, x_134); -lean_ctor_set(x_137, 1, x_135); -lean_ctor_set(x_137, 2, x_40); -if (lean_is_scalar(x_133)) { - x_138 = lean_alloc_ctor(0, 6, 0); -} else { - x_138 = x_133; -} -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); -if (lean_is_scalar(x_127)) { - x_139 = lean_alloc_ctor(0, 2, 0); -} else { - x_139 = x_127; -} -lean_ctor_set(x_139, 0, x_126); -lean_ctor_set(x_139, 1, x_138); -return x_139; -} -else -{ -lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_140 = lean_ctor_get(x_123, 1); +x_140 = lean_ctor_get(x_131, 0); lean_inc(x_140); -x_141 = lean_ctor_get(x_140, 2); +x_141 = lean_ctor_get(x_131, 1); lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 0); +x_142 = lean_ctor_get(x_131, 3); lean_inc(x_142); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - x_143 = x_123; +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; } else { - lean_dec_ref(x_123); + lean_dec_ref(x_131); x_143 = lean_box(0); } -x_144 = lean_ctor_get(x_140, 0); -lean_inc(x_144); -x_145 = lean_ctor_get(x_140, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_140, 3); -lean_inc(x_146); -x_147 = lean_ctor_get(x_140, 4); -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; -} else { - lean_dec_ref(x_140); - x_149 = lean_box(0); -} -x_150 = lean_ctor_get(x_141, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_141, 1); -lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - x_152 = x_141; -} else { - lean_dec_ref(x_141); - x_152 = lean_box(0); -} -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 3, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_150); -lean_ctor_set(x_153, 1, x_151); -lean_ctor_set(x_153, 2, x_40); -if (lean_is_scalar(x_149)) { - x_154 = lean_alloc_ctor(0, 6, 0); -} else { - x_154 = x_149; -} -lean_ctor_set(x_154, 0, x_144); -lean_ctor_set(x_154, 1, x_145); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_146); -lean_ctor_set(x_154, 4, x_147); -lean_ctor_set(x_154, 5, x_148); if (lean_is_scalar(x_143)) { - x_155 = lean_alloc_ctor(1, 2, 0); + x_144 = lean_alloc_ctor(0, 4, 0); } else { - x_155 = x_143; + x_144 = x_143; } -lean_ctor_set(x_155, 0, x_142); -lean_ctor_set(x_155, 1, x_154); -return x_155; +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); +if (lean_is_scalar(x_133)) { + x_146 = lean_alloc_ctor(0, 2, 0); +} else { + x_146 = x_133; +} +lean_ctor_set(x_146, 0, x_132); +lean_ctor_set(x_146, 1, x_145); +return x_146; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; +x_147 = lean_ctor_get(x_129, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_147, 2); +lean_inc(x_148); +x_149 = lean_ctor_get(x_129, 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); +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; +} else { + lean_dec_ref(x_147); + x_156 = 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; +} else { + lean_dec_ref(x_148); + 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_40); +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(1, 2, 0); +} else { + x_163 = x_150; +} +lean_ctor_set(x_163, 0, x_149); +lean_ctor_set(x_163, 1, x_162); +return x_163; } } } 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; -x_156 = lean_ctor_get(x_38, 0); -x_157 = lean_ctor_get(x_38, 1); -x_158 = lean_ctor_get(x_38, 2); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_38); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_160, 0, x_156); -lean_ctor_set(x_160, 1, x_157); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_33, 2, x_160); -x_161 = lean_ctor_get(x_13, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_13, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_13, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_13, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_13, 4); +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); 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_166 = x_13; + x_175 = x_13; } else { lean_dec_ref(x_13); - x_166 = lean_box(0); + x_175 = lean_box(0); } -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_34); -lean_ctor_set(x_167, 1, x_22); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 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); } else { - x_169 = x_166; + x_178 = x_175; } -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__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_169, x_33); -if (lean_obj_tag(x_170) == 0) +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_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_171 = lean_ctor_get(x_170, 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_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_172, 1); +x_182 = lean_ctor_get(x_179, 0); lean_inc(x_182); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - lean_ctor_release(x_172, 2); - x_183 = x_172; +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_172); + lean_dec_ref(x_179); x_183 = lean_box(0); } -if (lean_is_scalar(x_183)) { - x_184 = lean_alloc_ctor(0, 3, 0); -} else { - x_184 = x_183; -} -lean_ctor_set(x_184, 0, x_181); -lean_ctor_set(x_184, 1, x_182); -lean_ctor_set(x_184, 2, x_158); -if (lean_is_scalar(x_180)) { - x_185 = lean_alloc_ctor(0, 6, 0); -} else { - x_185 = x_180; -} -lean_ctor_set(x_185, 0, x_175); -lean_ctor_set(x_185, 1, x_176); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_177); -lean_ctor_set(x_185, 4, x_178); -lean_ctor_set(x_185, 5, x_179); -if (lean_is_scalar(x_174)) { - x_186 = lean_alloc_ctor(0, 2, 0); -} else { - x_186 = x_174; -} -lean_ctor_set(x_186, 0, x_173); -lean_ctor_set(x_186, 1, x_185); -return x_186; -} -else -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_187 = lean_ctor_get(x_170, 1); +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_187, 2); +x_188 = lean_ctor_get(x_180, 5); lean_inc(x_188); -x_189 = lean_ctor_get(x_170, 0); -lean_inc(x_189); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_190 = x_170; +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_170); - x_190 = lean_box(0); + lean_dec_ref(x_180); + x_189 = lean_box(0); } -x_191 = lean_ctor_get(x_187, 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_187, 1); +x_192 = lean_ctor_get(x_181, 3); 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); -x_195 = lean_ctor_get(x_187, 5); -lean_inc(x_195); -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_196 = x_187; +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_187); - x_196 = lean_box(0); + lean_dec_ref(x_181); + x_193 = lean_box(0); } -x_197 = lean_ctor_get(x_188, 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; +} +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_inc(x_197); -x_198 = lean_ctor_get(x_188, 1); +x_198 = lean_ctor_get(x_197, 2); lean_inc(x_198); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - x_199 = x_188; +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; } else { - lean_dec_ref(x_188); - x_199 = lean_box(0); + lean_dec_ref(x_179); + x_200 = lean_box(0); } -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 4); +lean_inc(x_204); +x_205 = lean_ctor_get(x_197, 5); +lean_inc(x_205); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_206 = x_197; } else { - x_200 = x_199; + lean_dec_ref(x_197); + x_206 = lean_box(0); } -lean_ctor_set(x_200, 0, x_197); -lean_ctor_set(x_200, 1, x_198); -lean_ctor_set(x_200, 2, x_158); -if (lean_is_scalar(x_196)) { - x_201 = lean_alloc_ctor(0, 6, 0); +x_207 = lean_ctor_get(x_198, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_198, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_198, 3); +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; } else { - x_201 = x_196; + lean_dec_ref(x_198); + x_210 = lean_box(0); } -lean_ctor_set(x_201, 0, x_191); -lean_ctor_set(x_201, 1, x_192); -lean_ctor_set(x_201, 2, x_200); -lean_ctor_set(x_201, 3, x_193); -lean_ctor_set(x_201, 4, x_194); -lean_ctor_set(x_201, 5, x_195); -if (lean_is_scalar(x_190)) { - x_202 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 4, 0); } else { - x_202 = x_190; + x_211 = x_210; } -lean_ctor_set(x_202, 0, x_189); -lean_ctor_set(x_202, 1, x_201); -return x_202; +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); +} else { + x_212 = x_206; +} +lean_ctor_set(x_212, 0, x_201); +lean_ctor_set(x_212, 1, x_202); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_203); +lean_ctor_set(x_212, 4, x_204); +lean_ctor_set(x_212, 5, x_205); +if (lean_is_scalar(x_200)) { + x_213 = lean_alloc_ctor(1, 2, 0); +} else { + x_213 = x_200; +} +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; } } } else { -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; 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_203 = lean_ctor_get(x_33, 2); -x_204 = lean_ctor_get(x_33, 0); -x_205 = lean_ctor_get(x_33, 1); -x_206 = lean_ctor_get(x_33, 3); -x_207 = lean_ctor_get(x_33, 4); -x_208 = lean_ctor_get(x_33, 5); -lean_inc(x_208); -lean_inc(x_207); -lean_inc(x_206); -lean_inc(x_203); -lean_inc(x_205); -lean_inc(x_204); -lean_dec(x_33); -x_209 = lean_ctor_get(x_203, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_203, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_203, 2); -lean_inc(x_211); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - x_212 = x_203; -} else { - lean_dec_ref(x_203); - 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, 3, 0); -} else { - x_214 = x_212; -} -lean_ctor_set(x_214, 0, x_209); -lean_ctor_set(x_214, 1, x_210); -lean_ctor_set(x_214, 2, x_213); -x_215 = 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); -x_216 = lean_ctor_get(x_13, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_13, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_13, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_13, 3); +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); -x_220 = lean_ctor_get(x_13, 4); +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_221 = x_13; + x_233 = x_13; } else { lean_dec_ref(x_13); - x_221 = lean_box(0); + x_233 = lean_box(0); } -x_222 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_222, 0, x_34); -lean_ctor_set(x_222, 1, x_22); -x_223 = lean_array_push(x_218, x_222); -if (lean_is_scalar(x_221)) { - x_224 = lean_alloc_ctor(0, 5, 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_224 = x_221; + x_236 = x_233; } -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___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_224, x_215); -if (lean_obj_tag(x_225) == 0) +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_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; -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; +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_225); - x_229 = lean_box(0); + lean_dec_ref(x_237); + x_241 = 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; +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_226); - x_235 = lean_box(0); + lean_dec_ref(x_238); + x_247 = 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); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - lean_ctor_release(x_227, 2); - x_238 = x_227; +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_227); - x_238 = lean_box(0); + lean_dec_ref(x_239); + x_251 = lean_box(0); } -if (lean_is_scalar(x_238)) { - x_239 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_251)) { + x_252 = lean_alloc_ctor(0, 4, 0); } else { - x_239 = x_238; + x_252 = x_251; } -lean_ctor_set(x_239, 0, x_236); -lean_ctor_set(x_239, 1, x_237); -lean_ctor_set(x_239, 2, x_211); -if (lean_is_scalar(x_235)) { - x_240 = lean_alloc_ctor(0, 6, 0); +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_240 = x_235; + x_253 = x_247; } -lean_ctor_set(x_240, 0, x_230); -lean_ctor_set(x_240, 1, x_231); -lean_ctor_set(x_240, 2, x_239); -lean_ctor_set(x_240, 3, x_232); -lean_ctor_set(x_240, 4, x_233); -lean_ctor_set(x_240, 5, x_234); -if (lean_is_scalar(x_229)) { - x_241 = lean_alloc_ctor(0, 2, 0); +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_241 = x_229; + x_254 = x_241; } -lean_ctor_set(x_241, 0, x_228); -lean_ctor_set(x_241, 1, x_240); -return 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_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; -x_242 = lean_ctor_get(x_225, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_242, 2); -lean_inc(x_243); -x_244 = lean_ctor_get(x_225, 0); -lean_inc(x_244); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_245 = x_225; +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_225); - x_245 = lean_box(0); + lean_dec_ref(x_237); + x_258 = lean_box(0); } -x_246 = lean_ctor_get(x_242, 0); -lean_inc(x_246); -x_247 = lean_ctor_get(x_242, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_242, 3); -lean_inc(x_248); -x_249 = lean_ctor_get(x_242, 4); -lean_inc(x_249); -x_250 = lean_ctor_get(x_242, 5); -lean_inc(x_250); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - lean_ctor_release(x_242, 2); - lean_ctor_release(x_242, 3); - lean_ctor_release(x_242, 4); - lean_ctor_release(x_242, 5); - x_251 = x_242; +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_242); - x_251 = lean_box(0); + lean_dec_ref(x_255); + x_264 = lean_box(0); } -x_252 = lean_ctor_get(x_243, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_243, 1); -lean_inc(x_253); -if (lean_is_exclusive(x_243)) { - lean_ctor_release(x_243, 0); - lean_ctor_release(x_243, 1); - lean_ctor_release(x_243, 2); - x_254 = x_243; +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_243); - x_254 = lean_box(0); + lean_dec_ref(x_256); + x_268 = lean_box(0); } -if (lean_is_scalar(x_254)) { - x_255 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_255 = x_254; + x_269 = x_268; } -lean_ctor_set(x_255, 0, x_252); -lean_ctor_set(x_255, 1, x_253); -lean_ctor_set(x_255, 2, x_211); -if (lean_is_scalar(x_251)) { - x_256 = lean_alloc_ctor(0, 6, 0); +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_256 = x_251; + x_270 = x_264; } -lean_ctor_set(x_256, 0, x_246); -lean_ctor_set(x_256, 1, x_247); -lean_ctor_set(x_256, 2, x_255); -lean_ctor_set(x_256, 3, x_248); -lean_ctor_set(x_256, 4, x_249); -lean_ctor_set(x_256, 5, x_250); -if (lean_is_scalar(x_245)) { - x_257 = lean_alloc_ctor(1, 2, 0); +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_257 = x_245; + x_271 = x_258; } -lean_ctor_set(x_257, 0, x_244); -lean_ctor_set(x_257, 1, x_256); -return x_257; +lean_ctor_set(x_271, 0, x_257); +lean_ctor_set(x_271, 1, x_270); +return x_271; } } } default: { -lean_object* x_258; lean_object* x_259; -x_258 = lean_ctor_get(x_27, 1); -lean_inc(x_258); +lean_object* x_272; lean_object* x_273; +x_272 = lean_ctor_get(x_27, 1); +lean_inc(x_272); lean_dec(x_27); lean_inc(x_13); -x_259 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_258); -if (lean_obj_tag(x_259) == 0) +x_273 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_272); +if (lean_obj_tag(x_273) == 0) { -lean_object* x_260; -x_260 = lean_ctor_get(x_259, 0); -lean_inc(x_260); -if (lean_obj_tag(x_260) == 0) +lean_object* x_274; +x_274 = lean_ctor_get(x_273, 0); +lean_inc(x_274); +if (lean_obj_tag(x_274) == 0) { -lean_object* x_261; lean_object* x_262; lean_object* x_263; +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_dec(x_22); -x_261 = lean_ctor_get(x_259, 1); -lean_inc(x_261); -lean_dec(x_259); -x_262 = lean_unsigned_to_nat(1u); -x_263 = lean_nat_add(x_12, x_262); +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); lean_dec(x_12); -x_12 = x_263; -x_14 = x_261; +x_12 = x_277; +x_14 = x_275; goto _start; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; uint8_t x_269; -x_265 = lean_ctor_get(x_259, 1); -lean_inc(x_265); -lean_dec(x_259); -x_266 = lean_ctor_get(x_260, 0); -lean_inc(x_266); -lean_dec(x_260); -x_267 = lean_unsigned_to_nat(1u); -x_268 = lean_nat_add(x_12, x_267); -lean_dec(x_12); -x_269 = !lean_is_exclusive(x_265); -if (x_269 == 0) -{ -lean_object* x_270; uint8_t x_271; -x_270 = lean_ctor_get(x_265, 2); -x_271 = !lean_is_exclusive(x_270); -if (x_271 == 0) -{ -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_270, 2); -x_273 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_270, 2, x_273); -x_274 = !lean_is_exclusive(x_13); -if (x_274 == 0) -{ -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; -x_275 = lean_ctor_get(x_13, 2); -x_276 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_22); -x_277 = lean_array_push(x_275, x_276); -lean_ctor_set(x_13, 2, x_277); -x_278 = 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_268, x_13, x_265); -if (lean_obj_tag(x_278) == 0) -{ -lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_279 = lean_ctor_get(x_278, 1); +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); -x_280 = lean_ctor_get(x_279, 2); +lean_dec(x_273); +x_280 = lean_ctor_get(x_274, 0); lean_inc(x_280); -x_281 = !lean_is_exclusive(x_278); -if (x_281 == 0) -{ -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_278, 1); -lean_dec(x_282); +lean_dec(x_274); +x_281 = lean_unsigned_to_nat(1u); +x_282 = lean_nat_add(x_12, x_281); +lean_dec(x_12); x_283 = !lean_is_exclusive(x_279); if (x_283 == 0) { lean_object* x_284; uint8_t x_285; x_284 = lean_ctor_get(x_279, 2); -lean_dec(x_284); -x_285 = !lean_is_exclusive(x_280); +x_285 = !lean_is_exclusive(x_284); if (x_285 == 0) { -lean_object* x_286; -x_286 = lean_ctor_get(x_280, 2); -lean_dec(x_286); -lean_ctor_set(x_280, 2, x_272); -return x_278; -} -else +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_287; lean_object* x_288; lean_object* x_289; -x_287 = lean_ctor_get(x_280, 0); -x_288 = lean_ctor_get(x_280, 1); -lean_inc(x_288); -lean_inc(x_287); -lean_dec(x_280); -x_289 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_289, 0, x_287); -lean_ctor_set(x_289, 1, x_288); -lean_ctor_set(x_289, 2, x_272); -lean_ctor_set(x_279, 2, x_289); -return x_278; -} -} -else +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_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_290 = lean_ctor_get(x_279, 0); -x_291 = lean_ctor_get(x_279, 1); -x_292 = lean_ctor_get(x_279, 3); -x_293 = lean_ctor_get(x_279, 4); -x_294 = lean_ctor_get(x_279, 5); -lean_inc(x_294); +lean_object* x_293; lean_object* x_294; uint8_t x_295; +x_293 = lean_ctor_get(x_292, 1); lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); -lean_dec(x_279); -x_295 = lean_ctor_get(x_280, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_280, 1); -lean_inc(x_296); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - x_297 = x_280; -} else { - lean_dec_ref(x_280); - x_297 = lean_box(0); -} -if (lean_is_scalar(x_297)) { - x_298 = lean_alloc_ctor(0, 3, 0); -} else { - x_298 = x_297; -} -lean_ctor_set(x_298, 0, x_295); -lean_ctor_set(x_298, 1, x_296); -lean_ctor_set(x_298, 2, x_272); -x_299 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_299, 0, x_290); -lean_ctor_set(x_299, 1, x_291); -lean_ctor_set(x_299, 2, x_298); -lean_ctor_set(x_299, 3, x_292); -lean_ctor_set(x_299, 4, x_293); -lean_ctor_set(x_299, 5, x_294); -lean_ctor_set(x_278, 1, x_299); -return x_278; -} +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_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; -x_300 = lean_ctor_get(x_278, 0); -lean_inc(x_300); -lean_dec(x_278); -x_301 = lean_ctor_get(x_279, 0); -lean_inc(x_301); -x_302 = lean_ctor_get(x_279, 1); -lean_inc(x_302); -x_303 = lean_ctor_get(x_279, 3); +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); -x_304 = lean_ctor_get(x_279, 4); -lean_inc(x_304); -x_305 = lean_ctor_get(x_279, 5); -lean_inc(x_305); -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); - lean_ctor_release(x_279, 4); - lean_ctor_release(x_279, 5); - x_306 = x_279; -} else { - lean_dec_ref(x_279); - x_306 = lean_box(0); +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; } -x_307 = lean_ctor_get(x_280, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_280, 1); +} +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); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - x_309 = x_280; +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_inc(x_311); +x_312 = lean_ctor_get(x_294, 3); +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_280); - x_309 = lean_box(0); + lean_dec_ref(x_294); + x_313 = lean_box(0); } -if (lean_is_scalar(x_309)) { - x_310 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_313)) { + x_314 = lean_alloc_ctor(0, 4, 0); } else { - x_310 = x_309; + x_314 = x_313; } -lean_ctor_set(x_310, 0, x_307); -lean_ctor_set(x_310, 1, x_308); -lean_ctor_set(x_310, 2, x_272); -if (lean_is_scalar(x_306)) { - x_311 = lean_alloc_ctor(0, 6, 0); -} else { - x_311 = x_306; -} -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); -x_312 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_312, 0, x_300); -lean_ctor_set(x_312, 1, x_311); -return x_312; +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_313; lean_object* x_314; uint8_t x_315; -x_313 = lean_ctor_get(x_278, 1); -lean_inc(x_313); -x_314 = lean_ctor_get(x_313, 2); -lean_inc(x_314); -x_315 = !lean_is_exclusive(x_278); -if (x_315 == 0) -{ -lean_object* x_316; uint8_t x_317; -x_316 = lean_ctor_get(x_278, 1); -lean_dec(x_316); -x_317 = !lean_is_exclusive(x_313); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_313, 2); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_314); -if (x_319 == 0) -{ -lean_object* x_320; -x_320 = lean_ctor_get(x_314, 2); -lean_dec(x_320); -lean_ctor_set(x_314, 2, x_272); -return x_278; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_314, 0); -x_322 = lean_ctor_get(x_314, 1); -lean_inc(x_322); +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_inc(x_321); -lean_dec(x_314); -x_323 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_323, 0, x_321); -lean_ctor_set(x_323, 1, x_322); -lean_ctor_set(x_323, 2, x_272); -lean_ctor_set(x_313, 2, x_323); -return x_278; +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); } -} -else -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_324 = lean_ctor_get(x_313, 0); -x_325 = lean_ctor_get(x_313, 1); -x_326 = lean_ctor_get(x_313, 3); -x_327 = lean_ctor_get(x_313, 4); -x_328 = lean_ctor_get(x_313, 5); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); +x_323 = lean_ctor_get(x_294, 0); +lean_inc(x_323); +x_324 = lean_ctor_get(x_294, 1); lean_inc(x_324); -lean_dec(x_313); -x_329 = lean_ctor_get(x_314, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_314, 1); +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); -if (lean_is_exclusive(x_314)) { - lean_ctor_release(x_314, 0); - lean_ctor_release(x_314, 1); - lean_ctor_release(x_314, 2); - x_331 = x_314; -} else { - lean_dec_ref(x_314); - x_331 = lean_box(0); -} -if (lean_is_scalar(x_331)) { - x_332 = lean_alloc_ctor(0, 3, 0); -} else { - x_332 = x_331; -} -lean_ctor_set(x_332, 0, x_329); -lean_ctor_set(x_332, 1, x_330); -lean_ctor_set(x_332, 2, x_272); -x_333 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_333, 0, x_324); -lean_ctor_set(x_333, 1, x_325); -lean_ctor_set(x_333, 2, x_332); -lean_ctor_set(x_333, 3, x_326); -lean_ctor_set(x_333, 4, x_327); -lean_ctor_set(x_333, 5, x_328); -lean_ctor_set(x_278, 1, x_333); -return x_278; -} +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_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_334 = lean_ctor_get(x_278, 0); -lean_inc(x_334); -lean_dec(x_278); -x_335 = lean_ctor_get(x_313, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_313, 1); -lean_inc(x_336); -x_337 = lean_ctor_get(x_313, 3); -lean_inc(x_337); -x_338 = lean_ctor_get(x_313, 4); -lean_inc(x_338); -x_339 = lean_ctor_get(x_313, 5); +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); -if (lean_is_exclusive(x_313)) { - lean_ctor_release(x_313, 0); - lean_ctor_release(x_313, 1); - lean_ctor_release(x_313, 2); - lean_ctor_release(x_313, 3); - lean_ctor_release(x_313, 4); - lean_ctor_release(x_313, 5); - x_340 = x_313; -} else { - lean_dec_ref(x_313); - x_340 = lean_box(0); -} -x_341 = lean_ctor_get(x_314, 0); -lean_inc(x_341); -x_342 = lean_ctor_get(x_314, 1); -lean_inc(x_342); -if (lean_is_exclusive(x_314)) { - lean_ctor_release(x_314, 0); - lean_ctor_release(x_314, 1); - lean_ctor_release(x_314, 2); - x_343 = x_314; -} else { - lean_dec_ref(x_314); - x_343 = lean_box(0); -} -if (lean_is_scalar(x_343)) { - x_344 = lean_alloc_ctor(0, 3, 0); -} else { - x_344 = x_343; -} -lean_ctor_set(x_344, 0, x_341); -lean_ctor_set(x_344, 1, x_342); -lean_ctor_set(x_344, 2, x_272); -if (lean_is_scalar(x_340)) { - x_345 = lean_alloc_ctor(0, 6, 0); -} else { - x_345 = x_340; -} -lean_ctor_set(x_345, 0, x_335); -lean_ctor_set(x_345, 1, x_336); -lean_ctor_set(x_345, 2, x_344); -lean_ctor_set(x_345, 3, x_337); -lean_ctor_set(x_345, 4, x_338); -lean_ctor_set(x_345, 5, x_339); -x_346 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_346, 0, x_334); -lean_ctor_set(x_346, 1, x_345); -return x_346; -} +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_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_347 = lean_ctor_get(x_13, 0); -x_348 = lean_ctor_get(x_13, 1); -x_349 = lean_ctor_get(x_13, 2); -x_350 = lean_ctor_get(x_13, 3); -x_351 = lean_ctor_get(x_13, 4); -lean_inc(x_351); -lean_inc(x_350); -lean_inc(x_349); -lean_inc(x_348); +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); -lean_dec(x_13); -x_352 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_352, 0, x_266); -lean_ctor_set(x_352, 1, x_22); -x_353 = lean_array_push(x_349, x_352); -x_354 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_354, 0, x_347); -lean_ctor_set(x_354, 1, x_348); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_350); -lean_ctor_set(x_354, 4, x_351); -x_355 = 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_268, x_354, x_265); -if (lean_obj_tag(x_355) == 0) -{ -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; -x_356 = lean_ctor_get(x_355, 1); -lean_inc(x_356); -x_357 = lean_ctor_get(x_356, 2); -lean_inc(x_357); -x_358 = lean_ctor_get(x_355, 0); -lean_inc(x_358); -if (lean_is_exclusive(x_355)) { - lean_ctor_release(x_355, 0); - lean_ctor_release(x_355, 1); - x_359 = x_355; +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_355); + 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_356, 0); +x_360 = lean_ctor_get(x_331, 0); lean_inc(x_360); -x_361 = lean_ctor_get(x_356, 1); +x_361 = lean_ctor_get(x_331, 1); lean_inc(x_361); -x_362 = lean_ctor_get(x_356, 3); +x_362 = lean_ctor_get(x_331, 3); lean_inc(x_362); -x_363 = lean_ctor_get(x_356, 4); -lean_inc(x_363); -x_364 = lean_ctor_get(x_356, 5); -lean_inc(x_364); -if (lean_is_exclusive(x_356)) { - lean_ctor_release(x_356, 0); - lean_ctor_release(x_356, 1); - lean_ctor_release(x_356, 2); - lean_ctor_release(x_356, 3); - lean_ctor_release(x_356, 4); - lean_ctor_release(x_356, 5); - x_365 = x_356; +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_356); - x_365 = lean_box(0); + lean_dec_ref(x_331); + x_363 = lean_box(0); } -x_366 = lean_ctor_get(x_357, 0); -lean_inc(x_366); -x_367 = lean_ctor_get(x_357, 1); -lean_inc(x_367); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - lean_ctor_release(x_357, 2); - x_368 = x_357; +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_357); - x_368 = lean_box(0); + x_364 = x_363; } -if (lean_is_scalar(x_368)) { - x_369 = lean_alloc_ctor(0, 3, 0); -} else { - x_369 = x_368; -} -lean_ctor_set(x_369, 0, x_366); -lean_ctor_set(x_369, 1, x_367); -lean_ctor_set(x_369, 2, x_272); -if (lean_is_scalar(x_365)) { - x_370 = lean_alloc_ctor(0, 6, 0); -} else { - x_370 = x_365; -} -lean_ctor_set(x_370, 0, x_360); -lean_ctor_set(x_370, 1, x_361); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_362); -lean_ctor_set(x_370, 4, x_363); -lean_ctor_set(x_370, 5, x_364); +lean_ctor_set(x_364, 0, x_360); +lean_ctor_set(x_364, 1, x_361); +lean_ctor_set(x_364, 2, x_286); +lean_ctor_set(x_364, 3, x_362); if (lean_is_scalar(x_359)) { - x_371 = lean_alloc_ctor(0, 2, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_371 = x_359; + 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; +} } -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; 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; -x_372 = lean_ctor_get(x_355, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_372, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_355, 0); -lean_inc(x_374); -if (lean_is_exclusive(x_355)) { - lean_ctor_release(x_355, 0); - lean_ctor_release(x_355, 1); - x_375 = x_355; -} else { - lean_dec_ref(x_355); - x_375 = lean_box(0); -} -x_376 = lean_ctor_get(x_372, 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; +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_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) +{ +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_372, 1); +x_377 = lean_ctor_get(x_376, 2); lean_inc(x_377); -x_378 = lean_ctor_get(x_372, 3); +x_378 = lean_ctor_get(x_375, 0); lean_inc(x_378); -x_379 = lean_ctor_get(x_372, 4); -lean_inc(x_379); -x_380 = lean_ctor_get(x_372, 5); +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); -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); +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_373, 1); +x_383 = lean_ctor_get(x_376, 4); lean_inc(x_383); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - x_384 = x_373; +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_373); - x_384 = lean_box(0); + lean_dec_ref(x_376); + x_385 = lean_box(0); } -if (lean_is_scalar(x_384)) { - x_385 = lean_alloc_ctor(0, 3, 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 { - x_385 = x_384; + lean_dec_ref(x_377); + x_389 = lean_box(0); } -lean_ctor_set(x_385, 0, x_382); -lean_ctor_set(x_385, 1, x_383); -lean_ctor_set(x_385, 2, x_272); -if (lean_is_scalar(x_381)) { - x_386 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_389)) { + x_390 = lean_alloc_ctor(0, 4, 0); } else { - x_386 = x_381; + x_390 = x_389; } -lean_ctor_set(x_386, 0, x_376); -lean_ctor_set(x_386, 1, x_377); -lean_ctor_set(x_386, 2, x_385); -lean_ctor_set(x_386, 3, x_378); -lean_ctor_set(x_386, 4, x_379); -lean_ctor_set(x_386, 5, x_380); -if (lean_is_scalar(x_375)) { - x_387 = lean_alloc_ctor(1, 2, 0); +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_387 = x_375; -} -lean_ctor_set(x_387, 0, x_374); -lean_ctor_set(x_387, 1, x_386); -return x_387; + 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; } else { -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_270, 0); -x_389 = lean_ctor_get(x_270, 1); -x_390 = lean_ctor_get(x_270, 2); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_dec(x_270); -x_391 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_392 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_391); -lean_ctor_set(x_265, 2, x_392); -x_393 = lean_ctor_get(x_13, 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; 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_13, 1); +x_394 = lean_ctor_get(x_393, 2); lean_inc(x_394); -x_395 = lean_ctor_get(x_13, 2); +x_395 = lean_ctor_get(x_375, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_13, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_13, 4); +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); +} +x_397 = lean_ctor_get(x_393, 0); lean_inc(x_397); -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_398 = x_13; +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_13); - x_398 = lean_box(0); + lean_dec_ref(x_393); + x_402 = lean_box(0); } -x_399 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_399, 0, x_266); -lean_ctor_set(x_399, 1, x_22); -x_400 = lean_array_push(x_395, x_399); -if (lean_is_scalar(x_398)) { - x_401 = lean_alloc_ctor(0, 5, 0); -} else { - x_401 = x_398; -} -lean_ctor_set(x_401, 0, x_393); -lean_ctor_set(x_401, 1, x_394); -lean_ctor_set(x_401, 2, x_400); -lean_ctor_set(x_401, 3, x_396); -lean_ctor_set(x_401, 4, x_397); -x_402 = l_Lean_Meta_withNewLocalInstances___main___at_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_268, x_401, x_265); -if (lean_obj_tag(x_402) == 0) -{ -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; lean_object* x_418; -x_403 = lean_ctor_get(x_402, 1); +x_403 = lean_ctor_get(x_394, 0); lean_inc(x_403); -x_404 = lean_ctor_get(x_403, 2); +x_404 = lean_ctor_get(x_394, 1); lean_inc(x_404); -x_405 = lean_ctor_get(x_402, 0); +x_405 = lean_ctor_get(x_394, 3); lean_inc(x_405); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - x_406 = x_402; +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; } else { - lean_dec_ref(x_402); + lean_dec_ref(x_394); x_406 = lean_box(0); } -x_407 = lean_ctor_get(x_403, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_403, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_403, 3); -lean_inc(x_409); -x_410 = lean_ctor_get(x_403, 4); -lean_inc(x_410); -x_411 = lean_ctor_get(x_403, 5); -lean_inc(x_411); -if (lean_is_exclusive(x_403)) { - lean_ctor_release(x_403, 0); - lean_ctor_release(x_403, 1); - lean_ctor_release(x_403, 2); - lean_ctor_release(x_403, 3); - lean_ctor_release(x_403, 4); - lean_ctor_release(x_403, 5); - x_412 = x_403; -} else { - lean_dec_ref(x_403); - x_412 = lean_box(0); -} -x_413 = lean_ctor_get(x_404, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_404, 1); -lean_inc(x_414); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - x_415 = x_404; -} else { - lean_dec_ref(x_404); - x_415 = lean_box(0); -} -if (lean_is_scalar(x_415)) { - x_416 = lean_alloc_ctor(0, 3, 0); -} else { - x_416 = x_415; -} -lean_ctor_set(x_416, 0, x_413); -lean_ctor_set(x_416, 1, x_414); -lean_ctor_set(x_416, 2, x_390); -if (lean_is_scalar(x_412)) { - x_417 = lean_alloc_ctor(0, 6, 0); -} else { - x_417 = x_412; -} -lean_ctor_set(x_417, 0, x_407); -lean_ctor_set(x_417, 1, x_408); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_409); -lean_ctor_set(x_417, 4, x_410); -lean_ctor_set(x_417, 5, x_411); if (lean_is_scalar(x_406)) { - x_418 = lean_alloc_ctor(0, 2, 0); + x_407 = lean_alloc_ctor(0, 4, 0); } else { - x_418 = x_406; + x_407 = x_406; +} +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); +} else { + x_408 = x_402; +} +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); +} else { + x_409 = x_396; +} +lean_ctor_set(x_409, 0, x_395); +lean_ctor_set(x_409, 1, x_408); +return x_409; +} } -lean_ctor_set(x_418, 0, x_405); -lean_ctor_set(x_418, 1, x_417); -return x_418; } else { -lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_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_419 = lean_ctor_get(x_402, 1); +lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; +x_410 = lean_ctor_get(x_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_419, 2); +x_420 = lean_ctor_get(x_13, 4); lean_inc(x_420); -x_421 = lean_ctor_get(x_402, 0); -lean_inc(x_421); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - x_422 = x_402; -} else { - lean_dec_ref(x_402); - x_422 = lean_box(0); -} -x_423 = lean_ctor_get(x_419, 0); -lean_inc(x_423); -x_424 = lean_ctor_get(x_419, 1); -lean_inc(x_424); -x_425 = lean_ctor_get(x_419, 3); -lean_inc(x_425); -x_426 = lean_ctor_get(x_419, 4); -lean_inc(x_426); -x_427 = lean_ctor_get(x_419, 5); -lean_inc(x_427); -if (lean_is_exclusive(x_419)) { - lean_ctor_release(x_419, 0); - lean_ctor_release(x_419, 1); - lean_ctor_release(x_419, 2); - lean_ctor_release(x_419, 3); - lean_ctor_release(x_419, 4); - lean_ctor_release(x_419, 5); - x_428 = x_419; -} else { - lean_dec_ref(x_419); - x_428 = lean_box(0); -} -x_429 = lean_ctor_get(x_420, 0); -lean_inc(x_429); -x_430 = lean_ctor_get(x_420, 1); -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); - x_431 = x_420; -} else { - lean_dec_ref(x_420); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 3, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_429); -lean_ctor_set(x_432, 1, x_430); -lean_ctor_set(x_432, 2, x_390); -if (lean_is_scalar(x_428)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_428; -} -lean_ctor_set(x_433, 0, x_423); -lean_ctor_set(x_433, 1, x_424); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_425); -lean_ctor_set(x_433, 4, x_426); -lean_ctor_set(x_433, 5, x_427); -if (lean_is_scalar(x_422)) { - x_434 = lean_alloc_ctor(1, 2, 0); -} else { - x_434 = x_422; -} -lean_ctor_set(x_434, 0, x_421); -lean_ctor_set(x_434, 1, x_433); -return x_434; -} -} -} -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; 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_435 = lean_ctor_get(x_265, 2); -x_436 = lean_ctor_get(x_265, 0); -x_437 = lean_ctor_get(x_265, 1); -x_438 = lean_ctor_get(x_265, 3); -x_439 = lean_ctor_get(x_265, 4); -x_440 = lean_ctor_get(x_265, 5); -lean_inc(x_440); -lean_inc(x_439); -lean_inc(x_438); -lean_inc(x_435); -lean_inc(x_437); -lean_inc(x_436); -lean_dec(x_265); -x_441 = lean_ctor_get(x_435, 0); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 2); -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); - x_444 = x_435; -} else { - lean_dec_ref(x_435); - x_444 = lean_box(0); -} -x_445 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_444)) { - x_446 = lean_alloc_ctor(0, 3, 0); -} else { - x_446 = x_444; -} -lean_ctor_set(x_446, 0, x_441); -lean_ctor_set(x_446, 1, x_442); -lean_ctor_set(x_446, 2, x_445); -x_447 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_447, 0, x_436); -lean_ctor_set(x_447, 1, x_437); -lean_ctor_set(x_447, 2, x_446); -lean_ctor_set(x_447, 3, x_438); -lean_ctor_set(x_447, 4, x_439); -lean_ctor_set(x_447, 5, x_440); -x_448 = lean_ctor_get(x_13, 0); -lean_inc(x_448); -x_449 = lean_ctor_get(x_13, 1); -lean_inc(x_449); -x_450 = lean_ctor_get(x_13, 2); -lean_inc(x_450); -x_451 = lean_ctor_get(x_13, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_13, 4); -lean_inc(x_452); 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_453 = x_13; + x_421 = x_13; } else { lean_dec_ref(x_13); - x_453 = lean_box(0); + x_421 = lean_box(0); } -x_454 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_454, 0, x_266); -lean_ctor_set(x_454, 1, x_22); -x_455 = lean_array_push(x_450, x_454); -if (lean_is_scalar(x_453)) { - x_456 = lean_alloc_ctor(0, 5, 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); } else { - x_456 = x_453; + x_424 = x_421; } -lean_ctor_set(x_456, 0, x_448); -lean_ctor_set(x_456, 1, x_449); -lean_ctor_set(x_456, 2, x_455); -lean_ctor_set(x_456, 3, x_451); -lean_ctor_set(x_456, 4, x_452); -x_457 = 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_268, x_456, x_447); -if (lean_obj_tag(x_457) == 0) +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_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; -x_458 = lean_ctor_get(x_457, 1); -lean_inc(x_458); -x_459 = lean_ctor_get(x_458, 2); -lean_inc(x_459); -x_460 = lean_ctor_get(x_457, 0); -lean_inc(x_460); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - x_461 = x_457; +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_457); - x_461 = lean_box(0); + lean_dec_ref(x_425); + x_429 = lean_box(0); } -x_462 = lean_ctor_get(x_458, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_458, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_458, 3); -lean_inc(x_464); -x_465 = lean_ctor_get(x_458, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_443); + x_452 = 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; +} else { + lean_dec_ref(x_444); + x_456 = lean_box(0); +} +if (lean_is_scalar(x_456)) { + x_457 = lean_alloc_ctor(0, 4, 0); +} else { + x_457 = x_456; +} +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); +} else { + x_458 = x_452; +} +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); +} else { + x_459 = x_446; +} +lean_ctor_set(x_459, 0, x_445); +lean_ctor_set(x_459, 1, x_458); +return x_459; +} +} +} +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); -x_466 = lean_ctor_get(x_458, 5); +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); -if (lean_is_exclusive(x_458)) { - lean_ctor_release(x_458, 0); - lean_ctor_release(x_458, 1); - lean_ctor_release(x_458, 2); - lean_ctor_release(x_458, 3); - lean_ctor_release(x_458, 4); - lean_ctor_release(x_458, 5); - x_467 = x_458; -} else { - lean_dec_ref(x_458); - x_467 = lean_box(0); -} -x_468 = lean_ctor_get(x_459, 0); +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_459, 1); +x_469 = lean_ctor_get(x_460, 3); lean_inc(x_469); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - lean_ctor_release(x_459, 2); - x_470 = x_459; +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; } else { - lean_dec_ref(x_459); + lean_dec_ref(x_460); x_470 = lean_box(0); } +x_471 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_470)) { - x_471 = lean_alloc_ctor(0, 3, 0); + x_472 = lean_alloc_ctor(0, 4, 0); } else { - x_471 = x_470; + x_472 = x_470; } -lean_ctor_set(x_471, 0, x_468); -lean_ctor_set(x_471, 1, x_469); -lean_ctor_set(x_471, 2, x_443); -if (lean_is_scalar(x_467)) { - x_472 = lean_alloc_ctor(0, 6, 0); -} else { - x_472 = x_467; -} -lean_ctor_set(x_472, 0, x_462); -lean_ctor_set(x_472, 1, x_463); +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_464); -lean_ctor_set(x_472, 4, x_465); -lean_ctor_set(x_472, 5, x_466); -if (lean_is_scalar(x_461)) { - x_473 = lean_alloc_ctor(0, 2, 0); -} else { - x_473 = x_461; -} -lean_ctor_set(x_473, 0, x_460); -lean_ctor_set(x_473, 1, x_472); -return x_473; -} -else -{ -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; lean_object* x_489; -x_474 = lean_ctor_get(x_457, 1); +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_474, 2); +x_475 = lean_ctor_get(x_13, 1); lean_inc(x_475); -x_476 = lean_ctor_get(x_457, 0); +x_476 = lean_ctor_get(x_13, 2); lean_inc(x_476); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - x_477 = x_457; -} else { - lean_dec_ref(x_457); - x_477 = lean_box(0); -} -x_478 = lean_ctor_get(x_474, 0); +x_477 = lean_ctor_get(x_13, 3); +lean_inc(x_477); +x_478 = lean_ctor_get(x_13, 4); lean_inc(x_478); -x_479 = lean_ctor_get(x_474, 1); -lean_inc(x_479); -x_480 = lean_ctor_get(x_474, 3); -lean_inc(x_480); -x_481 = lean_ctor_get(x_474, 4); -lean_inc(x_481); -x_482 = lean_ctor_get(x_474, 5); -lean_inc(x_482); -if (lean_is_exclusive(x_474)) { - lean_ctor_release(x_474, 0); - lean_ctor_release(x_474, 1); - lean_ctor_release(x_474, 2); - lean_ctor_release(x_474, 3); - lean_ctor_release(x_474, 4); - lean_ctor_release(x_474, 5); - x_483 = x_474; +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; } else { - lean_dec_ref(x_474); - x_483 = lean_box(0); + lean_dec_ref(x_13); + x_479 = lean_box(0); } -x_484 = lean_ctor_get(x_475, 0); +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); +} else { + x_482 = x_479; +} +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_475, 1); +x_485 = lean_ctor_get(x_484, 2); lean_inc(x_485); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - lean_ctor_release(x_475, 2); - x_486 = x_475; +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; } else { - lean_dec_ref(x_475); - x_486 = lean_box(0); + lean_dec_ref(x_483); + x_487 = lean_box(0); } -if (lean_is_scalar(x_486)) { - x_487 = lean_alloc_ctor(0, 3, 0); +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 { - x_487 = x_486; + lean_dec_ref(x_484); + x_493 = lean_box(0); } -lean_ctor_set(x_487, 0, x_484); -lean_ctor_set(x_487, 1, x_485); -lean_ctor_set(x_487, 2, x_443); -if (lean_is_scalar(x_483)) { - x_488 = lean_alloc_ctor(0, 6, 0); +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 { - x_488 = x_483; + lean_dec_ref(x_485); + x_497 = lean_box(0); } -lean_ctor_set(x_488, 0, x_478); -lean_ctor_set(x_488, 1, x_479); -lean_ctor_set(x_488, 2, x_487); -lean_ctor_set(x_488, 3, x_480); -lean_ctor_set(x_488, 4, x_481); -lean_ctor_set(x_488, 5, x_482); -if (lean_is_scalar(x_477)) { - x_489 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_497)) { + x_498 = lean_alloc_ctor(0, 4, 0); } else { - x_489 = x_477; + x_498 = x_497; } -lean_ctor_set(x_489, 0, x_476); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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_490; +uint8_t x_518; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -14958,23 +15276,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_259); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_273); +if (x_518 == 0) { -return x_259; +return x_273; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_259, 0); -x_492 = lean_ctor_get(x_259, 1); -lean_inc(x_492); -lean_inc(x_491); -lean_dec(x_259); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -14982,7 +15300,7 @@ return x_493; } else { -uint8_t x_494; +uint8_t x_522; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -14994,29 +15312,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_494 = !lean_is_exclusive(x_27); -if (x_494 == 0) +x_522 = !lean_is_exclusive(x_27); +if (x_522 == 0) { return x_27; } else { -lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_495 = lean_ctor_get(x_27, 0); -x_496 = lean_ctor_get(x_27, 1); -lean_inc(x_496); -lean_inc(x_495); +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_dec(x_27); -x_497 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_497, 0, x_495); -lean_ctor_set(x_497, 1, x_496); -return x_497; +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; } } } else { -uint8_t x_498; +uint8_t x_526; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -15027,23 +15345,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_498 = !lean_is_exclusive(x_23); -if (x_498 == 0) +x_526 = !lean_is_exclusive(x_23); +if (x_526 == 0) { return x_23; } else { -lean_object* x_499; lean_object* x_500; lean_object* x_501; -x_499 = lean_ctor_get(x_23, 0); -x_500 = lean_ctor_get(x_23, 1); -lean_inc(x_500); -lean_inc(x_499); +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_dec(x_23); -x_501 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_501, 0, x_499); -lean_ctor_set(x_501, 1, x_500); -return x_501; +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; } } } @@ -15223,82 +15541,89 @@ return x_48; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_59 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -lean_ctor_set(x_59, 2, x_42); -lean_ctor_set(x_49, 2, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_49, 0); -x_61 = lean_ctor_get(x_49, 1); -x_62 = lean_ctor_get(x_49, 3); -x_63 = lean_ctor_get(x_49, 4); -x_64 = lean_ctor_get(x_49, 5); +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_inc(x_62); lean_inc(x_61); -lean_inc(x_60); lean_dec(x_49); -x_65 = lean_ctor_get(x_50, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_50, 1); +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); - x_67 = x_50; + lean_ctor_release(x_50, 3); + x_69 = x_50; } else { lean_dec_ref(x_50); - x_67 = lean_box(0); + x_69 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_70 = x_69; } -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_42); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_60); -lean_ctor_set(x_69, 1, x_61); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_62); -lean_ctor_set(x_69, 4, x_63); -lean_ctor_set(x_69, 5, x_64); -lean_ctor_set(x_48, 1, x_69); +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; } } 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; -x_70 = lean_ctor_get(x_48, 0); -lean_inc(x_70); -lean_dec(x_48); -x_71 = lean_ctor_get(x_49, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_49, 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; lean_object* x_84; lean_object* x_85; +x_72 = lean_ctor_get(x_48, 0); lean_inc(x_72); -x_73 = lean_ctor_get(x_49, 3); +lean_dec(x_48); +x_73 = lean_ctor_get(x_49, 0); lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 4); +x_74 = lean_ctor_get(x_49, 1); lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 5); +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); @@ -15306,1900 +15631,1999 @@ if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 3); lean_ctor_release(x_49, 4); lean_ctor_release(x_49, 5); - x_76 = x_49; + x_78 = x_49; } else { lean_dec_ref(x_49); - x_76 = lean_box(0); + x_78 = lean_box(0); } -x_77 = lean_ctor_get(x_50, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_50, 1); -lean_inc(x_78); +x_79 = lean_ctor_get(x_50, 0); +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); - x_79 = x_50; + lean_ctor_release(x_50, 3); + x_82 = x_50; } else { lean_dec_ref(x_50); - x_79 = lean_box(0); + x_82 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_83 = x_82; } -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_42); -if (lean_is_scalar(x_76)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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_81 = x_76; + x_84 = x_78; } -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); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_70); -lean_ctor_set(x_82, 1, x_81); -return x_82; +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; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_48, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_48); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; +lean_object* x_86; lean_object* x_87; uint8_t x_88; x_86 = lean_ctor_get(x_48, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = !lean_is_exclusive(x_48); +if (x_88 == 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_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_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_42); +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_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -lean_ctor_set(x_93, 2, x_42); -lean_ctor_set(x_83, 2, x_93); -return x_48; -} -} -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; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -x_97 = lean_ctor_get(x_83, 4); -x_98 = lean_ctor_get(x_83, 5); -lean_inc(x_98); -lean_inc(x_97); +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_83); -x_99 = lean_ctor_get(x_84, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_84, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_101 = x_84; -} else { - lean_dec_ref(x_84); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 3, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_102, 2, x_42); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_94); -lean_ctor_set(x_103, 1, x_95); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_97); -lean_ctor_set(x_103, 5, x_98); -lean_ctor_set(x_48, 1, x_103); +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_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_104 = lean_ctor_get(x_48, 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; +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); -lean_dec(x_48); -x_105 = lean_ctor_get(x_83, 0); +x_105 = lean_ctor_get(x_87, 3); lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_83, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 5); +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; +} else { + lean_dec_ref(x_87); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 4, 0); +} else { + x_107 = x_106; +} +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); -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_110 = x_83; -} else { - lean_dec_ref(x_83); - x_110 = lean_box(0); -} -x_111 = lean_ctor_get(x_84, 0); +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_84, 1); +x_112 = lean_ctor_get(x_86, 3); 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); - x_113 = x_84; +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; } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + lean_dec_ref(x_86); + x_115 = lean_box(0); } -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 3, 0); +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 { - x_114 = x_113; + lean_dec_ref(x_87); + x_119 = lean_box(0); } -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_42); -if (lean_is_scalar(x_110)) { - x_115 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_115 = x_110; + x_120 = x_119; } -lean_ctor_set(x_115, 0, x_105); -lean_ctor_set(x_115, 1, x_106); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_107); -lean_ctor_set(x_115, 4, x_108); -lean_ctor_set(x_115, 5, x_109); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_104); -lean_ctor_set(x_116, 1, x_115); -return x_116; +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_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_8, 0); -x_118 = lean_ctor_get(x_8, 1); -x_119 = lean_ctor_get(x_8, 2); -x_120 = lean_ctor_get(x_8, 3); -x_121 = lean_ctor_get(x_8, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_8); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_36); -lean_ctor_set(x_122, 1, x_24); -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_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_124, x_35); -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; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); +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); -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; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_126, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +lean_inc(x_126); +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_126, 4); +x_133 = lean_ctor_get(x_132, 2); lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); +x_134 = lean_ctor_get(x_131, 0); 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_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; } else { - lean_dec_ref(x_126); + lean_dec_ref(x_131); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); +x_136 = lean_ctor_get(x_132, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); +x_137 = lean_ctor_get(x_132, 1); lean_inc(x_137); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - x_138 = x_127; +x_138 = lean_ctor_get(x_132, 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; } else { - lean_dec_ref(x_127); - x_138 = lean_box(0); + lean_dec_ref(x_132); + x_141 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_42); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -if (lean_is_scalar(x_129)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_129; -} -lean_ctor_set(x_141, 0, x_128); -lean_ctor_set(x_141, 1, x_140); -return x_141; -} -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; -x_142 = lean_ctor_get(x_125, 1); +x_142 = lean_ctor_get(x_133, 0); lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); +x_143 = lean_ctor_get(x_133, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 0); +x_144 = lean_ctor_get(x_133, 3); lean_inc(x_144); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_145 = x_125; +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; } else { - lean_dec_ref(x_125); + lean_dec_ref(x_133); x_145 = lean_box(0); } -x_146 = lean_ctor_get(x_142, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 3); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 4); -lean_inc(x_149); -x_150 = lean_ctor_get(x_142, 5); -lean_inc(x_150); -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_151 = x_142; -} else { - lean_dec_ref(x_142); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_143, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 3, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -lean_ctor_set(x_155, 2, x_42); -if (lean_is_scalar(x_151)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_151; -} -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); if (lean_is_scalar(x_145)) { - x_157 = lean_alloc_ctor(1, 2, 0); + x_146 = lean_alloc_ctor(0, 4, 0); } else { - x_157 = x_145; + x_146 = x_145; } -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; +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); +if (lean_is_scalar(x_135)) { + x_148 = lean_alloc_ctor(0, 2, 0); +} else { + x_148 = x_135; +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_149, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_131, 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); +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_42); +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(1, 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_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_40, 0); -x_159 = lean_ctor_get(x_40, 1); -x_160 = lean_ctor_get(x_40, 2); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_40); -x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_162 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_162, 0, x_158); -lean_ctor_set(x_162, 1, x_159); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_35, 2, x_162); -x_163 = lean_ctor_get(x_8, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 2); -lean_inc(x_165); -x_166 = lean_ctor_get(x_8, 3); -lean_inc(x_166); -x_167 = lean_ctor_get(x_8, 4); +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); 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_168 = x_8; + x_177 = x_8; } else { lean_dec_ref(x_8); - x_168 = lean_box(0); + x_177 = lean_box(0); } -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_36); -lean_ctor_set(x_169, 1, x_24); -x_170 = lean_array_push(x_165, x_169); -if (lean_is_scalar(x_168)) { - x_171 = lean_alloc_ctor(0, 5, 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); } else { - x_171 = x_168; + x_180 = x_177; } -lean_ctor_set(x_171, 0, x_163); -lean_ctor_set(x_171, 1, x_164); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_166); -lean_ctor_set(x_171, 4, x_167); -x_172 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_171, x_35); -if (lean_obj_tag(x_172) == 0) +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_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_173 = lean_ctor_get(x_172, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_176 = x_172; -} else { - lean_dec_ref(x_172); - 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_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_174, 1); +x_184 = lean_ctor_get(x_181, 0); lean_inc(x_184); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - x_185 = x_174; +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_174); + lean_dec_ref(x_181); x_185 = lean_box(0); } -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 3, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -lean_ctor_set(x_186, 2, x_160); -if (lean_is_scalar(x_182)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_182; -} -lean_ctor_set(x_187, 0, x_177); -lean_ctor_set(x_187, 1, x_178); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_179); -lean_ctor_set(x_187, 4, x_180); -lean_ctor_set(x_187, 5, x_181); -if (lean_is_scalar(x_176)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_176; -} -lean_ctor_set(x_188, 0, x_175); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -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; -x_189 = lean_ctor_get(x_172, 1); +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_189, 2); +x_190 = lean_ctor_get(x_182, 5); lean_inc(x_190); -x_191 = lean_ctor_get(x_172, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_192 = x_172; +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_172); - x_192 = lean_box(0); + lean_dec_ref(x_182); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 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_189, 1); +x_194 = lean_ctor_get(x_183, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); -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; +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_189); - x_198 = lean_box(0); + lean_dec_ref(x_183); + x_195 = lean_box(0); } -x_199 = lean_ctor_get(x_190, 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; +} +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_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_199, 2); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - x_201 = x_190; +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; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_181); + x_202 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_205); +x_206 = lean_ctor_get(x_199, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_199, 5); +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 { - x_202 = x_201; + lean_dec_ref(x_199); + x_208 = lean_box(0); } -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_160); -if (lean_is_scalar(x_198)) { - x_203 = lean_alloc_ctor(0, 6, 0); +x_209 = lean_ctor_get(x_200, 0); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 3); +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; } else { - x_203 = x_198; + lean_dec_ref(x_200); + x_212 = lean_box(0); } -lean_ctor_set(x_203, 0, x_193); -lean_ctor_set(x_203, 1, x_194); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_195); -lean_ctor_set(x_203, 4, x_196); -lean_ctor_set(x_203, 5, x_197); -if (lean_is_scalar(x_192)) { - x_204 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); } else { - x_204 = x_192; + x_213 = x_212; } -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +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); +} 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_202)) { + x_215 = lean_alloc_ctor(1, 2, 0); +} else { + x_215 = x_202; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } 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; -x_205 = lean_ctor_get(x_35, 2); -x_206 = lean_ctor_get(x_35, 0); -x_207 = lean_ctor_get(x_35, 1); -x_208 = lean_ctor_get(x_35, 3); -x_209 = lean_ctor_get(x_35, 4); -x_210 = lean_ctor_get(x_35, 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_35); -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); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - x_214 = x_205; -} else { - lean_dec_ref(x_205); - x_214 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 3, 0); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_211); -lean_ctor_set(x_216, 1, x_212); -lean_ctor_set(x_216, 2, x_215); -x_217 = lean_alloc_ctor(0, 6, 0); -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); -x_218 = lean_ctor_get(x_8, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_8, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_8, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_8, 3); +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); -x_222 = lean_ctor_get(x_8, 4); +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_223 = x_8; + x_235 = x_8; } else { lean_dec_ref(x_8); - x_223 = lean_box(0); + x_235 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_36); -lean_ctor_set(x_224, 1, x_24); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { - x_226 = lean_alloc_ctor(0, 5, 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_226 = x_223; + x_238 = x_235; } -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_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_226, x_217); -if (lean_obj_tag(x_227) == 0) +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_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_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_227, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_231 = x_227; +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_227); - x_231 = lean_box(0); + lean_dec_ref(x_239); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_228, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); -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; +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_228); - x_237 = lean_box(0); + lean_dec_ref(x_240); + x_249 = 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); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - x_240 = x_229; +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_229); - x_240 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - x_241 = x_240; + x_254 = x_253; } -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_213); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); +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_242 = x_237; + x_255 = x_249; } -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 2, 0); +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_243 = x_231; + x_256 = x_243; } -lean_ctor_set(x_243, 0, x_230); -lean_ctor_set(x_243, 1, x_242); -return 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_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_244 = lean_ctor_get(x_227, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 2); -lean_inc(x_245); -x_246 = lean_ctor_get(x_227, 0); -lean_inc(x_246); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_247 = x_227; +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_227); - x_247 = lean_box(0); + lean_dec_ref(x_239); + x_260 = lean_box(0); } -x_248 = lean_ctor_get(x_244, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_244, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_244, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_244, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 5); -lean_inc(x_252); -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_253 = x_244; +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_244); - x_253 = lean_box(0); + lean_dec_ref(x_257); + x_266 = lean_box(0); } -x_254 = lean_ctor_get(x_245, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 1); -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); - x_256 = x_245; +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_245); - x_256 = lean_box(0); + lean_dec_ref(x_258); + x_270 = lean_box(0); } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 4, 0); } else { - x_257 = x_256; + x_271 = x_270; } -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_213); -if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); +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_258 = x_253; + x_272 = x_266; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_261); +lean_ctor_set(x_272, 1, x_262); +lean_ctor_set(x_272, 2, x_271); +lean_ctor_set(x_272, 3, x_263); +lean_ctor_set(x_272, 4, x_264); +lean_ctor_set(x_272, 5, x_265); +if (lean_is_scalar(x_260)) { + x_273 = lean_alloc_ctor(1, 2, 0); } else { - x_259 = x_247; + x_273 = x_260; } -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; } } } default: { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_29, 1); -lean_inc(x_260); +lean_object* x_274; lean_object* x_275; +x_274 = lean_ctor_get(x_29, 1); +lean_inc(x_274); lean_dec(x_29); lean_inc(x_8); -x_261 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_260); -if (lean_obj_tag(x_261) == 0) +x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); +if (lean_obj_tag(x_275) == 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_276; +x_276 = lean_ctor_get(x_275, 0); +lean_inc(x_276); +if (lean_obj_tag(x_276) == 0) { -lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_dec(x_24); -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_7, x_264); +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); lean_dec(x_7); -x_7 = x_265; -x_9 = x_263; +x_7 = x_279; +x_9 = x_277; 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_7, x_269); -lean_dec(x_7); -x_271 = !lean_is_exclusive(x_267); -if (x_271 == 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_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_8); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_8, 2); -x_278 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_24); -x_279 = lean_array_push(x_277, x_278); -lean_ctor_set(x_8, 2, x_279); -x_280 = 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_270, x_8, x_267); -if (lean_obj_tag(x_280) == 0) -{ -lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_281 = lean_ctor_get(x_280, 1); +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); -x_282 = lean_ctor_get(x_281, 2); +lean_dec(x_275); +x_282 = lean_ctor_get(x_276, 0); 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); +lean_dec(x_276); +x_283 = lean_unsigned_to_nat(1u); +x_284 = lean_nat_add(x_7, x_283); +lean_dec(x_7); 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); +x_287 = !lean_is_exclusive(x_286); 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_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_289; lean_object* x_290; lean_object* x_291; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_282); -x_291 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_291, 0, x_289); -lean_ctor_set(x_291, 1, x_290); -lean_ctor_set(x_291, 2, x_274); -lean_ctor_set(x_281, 2, x_291); -return x_280; -} -} -else +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_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_292 = lean_ctor_get(x_281, 0); -x_293 = lean_ctor_get(x_281, 1); -x_294 = lean_ctor_get(x_281, 3); -x_295 = lean_ctor_get(x_281, 4); -x_296 = lean_ctor_get(x_281, 5); -lean_inc(x_296); +lean_object* x_295; lean_object* x_296; uint8_t x_297; +x_295 = lean_ctor_get(x_294, 1); lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_281); -x_297 = lean_ctor_get(x_282, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_282, 1); -lean_inc(x_298); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_299 = x_282; -} else { - lean_dec_ref(x_282); - x_299 = lean_box(0); -} -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 3, 0); -} else { - x_300 = x_299; -} -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_274); -x_301 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_301, 0, x_292); -lean_ctor_set(x_301, 1, x_293); -lean_ctor_set(x_301, 2, x_300); -lean_ctor_set(x_301, 3, x_294); -lean_ctor_set(x_301, 4, x_295); -lean_ctor_set(x_301, 5, x_296); -lean_ctor_set(x_280, 1, x_301); -return x_280; -} +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_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_302 = lean_ctor_get(x_280, 0); -lean_inc(x_302); -lean_dec(x_280); -x_303 = lean_ctor_get(x_281, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_281, 1); -lean_inc(x_304); -x_305 = lean_ctor_get(x_281, 3); +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); -x_306 = lean_ctor_get(x_281, 4); -lean_inc(x_306); -x_307 = lean_ctor_get(x_281, 5); -lean_inc(x_307); -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_308 = x_281; -} else { - lean_dec_ref(x_281); - x_308 = lean_box(0); +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; } -x_309 = lean_ctor_get(x_282, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_282, 1); +} +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); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_311 = x_282; +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_inc(x_313); +x_314 = lean_ctor_get(x_296, 3); +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_282); - x_311 = lean_box(0); + lean_dec_ref(x_296); + x_315 = lean_box(0); } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_315)) { + x_316 = lean_alloc_ctor(0, 4, 0); } else { - x_312 = x_311; + x_316 = x_315; } -lean_ctor_set(x_312, 0, x_309); -lean_ctor_set(x_312, 1, x_310); -lean_ctor_set(x_312, 2, x_274); -if (lean_is_scalar(x_308)) { - x_313 = lean_alloc_ctor(0, 6, 0); -} else { - x_313 = x_308; -} -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); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_302); -lean_ctor_set(x_314, 1, x_313); -return x_314; +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_315; lean_object* x_316; uint8_t x_317; -x_315 = lean_ctor_get(x_280, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_315, 2); -lean_inc(x_316); -x_317 = !lean_is_exclusive(x_280); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_280, 1); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_315); -if (x_319 == 0) -{ -lean_object* x_320; uint8_t x_321; -x_320 = lean_ctor_get(x_315, 2); -lean_dec(x_320); -x_321 = !lean_is_exclusive(x_316); -if (x_321 == 0) -{ -lean_object* x_322; -x_322 = lean_ctor_get(x_316, 2); -lean_dec(x_322); -lean_ctor_set(x_316, 2, x_274); -return x_280; -} -else -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_323 = lean_ctor_get(x_316, 0); -x_324 = lean_ctor_get(x_316, 1); -lean_inc(x_324); +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_inc(x_323); -lean_dec(x_316); -x_325 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_325, 0, x_323); -lean_ctor_set(x_325, 1, x_324); -lean_ctor_set(x_325, 2, x_274); -lean_ctor_set(x_315, 2, x_325); -return x_280; +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); } -} -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; -x_326 = lean_ctor_get(x_315, 0); -x_327 = lean_ctor_get(x_315, 1); -x_328 = lean_ctor_get(x_315, 3); -x_329 = lean_ctor_get(x_315, 4); -x_330 = lean_ctor_get(x_315, 5); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_inc(x_327); +x_325 = lean_ctor_get(x_296, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_296, 1); lean_inc(x_326); -lean_dec(x_315); -x_331 = lean_ctor_get(x_316, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_316, 1); +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); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_333 = x_316; -} else { - lean_dec_ref(x_316); - x_333 = lean_box(0); -} -if (lean_is_scalar(x_333)) { - x_334 = lean_alloc_ctor(0, 3, 0); -} else { - x_334 = x_333; -} -lean_ctor_set(x_334, 0, x_331); -lean_ctor_set(x_334, 1, x_332); -lean_ctor_set(x_334, 2, x_274); -x_335 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_335, 0, x_326); -lean_ctor_set(x_335, 1, x_327); -lean_ctor_set(x_335, 2, x_334); -lean_ctor_set(x_335, 3, x_328); -lean_ctor_set(x_335, 4, x_329); -lean_ctor_set(x_335, 5, x_330); -lean_ctor_set(x_280, 1, x_335); -return x_280; -} +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_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_336 = lean_ctor_get(x_280, 0); -lean_inc(x_336); -lean_dec(x_280); -x_337 = lean_ctor_get(x_315, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_315, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_315, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_315, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_315, 5); +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); -if (lean_is_exclusive(x_315)) { - lean_ctor_release(x_315, 0); - lean_ctor_release(x_315, 1); - lean_ctor_release(x_315, 2); - lean_ctor_release(x_315, 3); - lean_ctor_release(x_315, 4); - lean_ctor_release(x_315, 5); - x_342 = x_315; -} else { - lean_dec_ref(x_315); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_316, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_316, 1); -lean_inc(x_344); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_345 = x_316; -} else { - lean_dec_ref(x_316); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 3, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_274); -if (lean_is_scalar(x_342)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_342; -} -lean_ctor_set(x_347, 0, x_337); -lean_ctor_set(x_347, 1, x_338); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_339); -lean_ctor_set(x_347, 4, x_340); -lean_ctor_set(x_347, 5, x_341); -x_348 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_348, 0, x_336); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} +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_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_349 = lean_ctor_get(x_8, 0); -x_350 = lean_ctor_get(x_8, 1); -x_351 = lean_ctor_get(x_8, 2); -x_352 = lean_ctor_get(x_8, 3); -x_353 = lean_ctor_get(x_8, 4); -lean_inc(x_353); -lean_inc(x_352); -lean_inc(x_351); -lean_inc(x_350); +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); -lean_dec(x_8); -x_354 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_354, 0, x_268); -lean_ctor_set(x_354, 1, x_24); -x_355 = lean_array_push(x_351, x_354); -x_356 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_356, 0, x_349); -lean_ctor_set(x_356, 1, x_350); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_352); -lean_ctor_set(x_356, 4, x_353); -x_357 = 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_270, x_356, x_267); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; -x_358 = lean_ctor_get(x_357, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_358, 2); -lean_inc(x_359); -x_360 = lean_ctor_get(x_357, 0); -lean_inc(x_360); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_361 = x_357; +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_357); + 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_358, 0); +x_362 = lean_ctor_get(x_333, 0); lean_inc(x_362); -x_363 = lean_ctor_get(x_358, 1); +x_363 = lean_ctor_get(x_333, 1); lean_inc(x_363); -x_364 = lean_ctor_get(x_358, 3); +x_364 = lean_ctor_get(x_333, 3); lean_inc(x_364); -x_365 = lean_ctor_get(x_358, 4); -lean_inc(x_365); -x_366 = lean_ctor_get(x_358, 5); -lean_inc(x_366); -if (lean_is_exclusive(x_358)) { - lean_ctor_release(x_358, 0); - lean_ctor_release(x_358, 1); - lean_ctor_release(x_358, 2); - lean_ctor_release(x_358, 3); - lean_ctor_release(x_358, 4); - lean_ctor_release(x_358, 5); - x_367 = x_358; +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_358); - x_367 = lean_box(0); + lean_dec_ref(x_333); + x_365 = lean_box(0); } -x_368 = lean_ctor_get(x_359, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_359, 1); -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); - x_370 = x_359; +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_359); - x_370 = lean_box(0); + x_366 = x_365; } -if (lean_is_scalar(x_370)) { - x_371 = lean_alloc_ctor(0, 3, 0); -} else { - x_371 = x_370; -} -lean_ctor_set(x_371, 0, x_368); -lean_ctor_set(x_371, 1, x_369); -lean_ctor_set(x_371, 2, x_274); -if (lean_is_scalar(x_367)) { - x_372 = lean_alloc_ctor(0, 6, 0); -} else { - x_372 = x_367; -} -lean_ctor_set(x_372, 0, x_362); -lean_ctor_set(x_372, 1, x_363); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_364); -lean_ctor_set(x_372, 4, x_365); -lean_ctor_set(x_372, 5, x_366); +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_373 = lean_alloc_ctor(0, 2, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_373 = x_361; + 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; +} } -lean_ctor_set(x_373, 0, x_360); -lean_ctor_set(x_373, 1, x_372); -return x_373; } else { -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_374 = lean_ctor_get(x_357, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_357, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_377 = x_357; -} else { - lean_dec_ref(x_357); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); +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_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) +{ +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_374, 1); +x_379 = lean_ctor_get(x_378, 2); lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); +x_380 = lean_ctor_get(x_377, 0); lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); +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); -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); +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_375, 1); +x_385 = lean_ctor_get(x_378, 4); lean_inc(x_385); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - lean_ctor_release(x_375, 2); - x_386 = x_375; +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_375); - x_386 = lean_box(0); + lean_dec_ref(x_378); + x_387 = lean_box(0); } -if (lean_is_scalar(x_386)) { - x_387 = lean_alloc_ctor(0, 3, 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 { - x_387 = x_386; + lean_dec_ref(x_379); + x_391 = lean_box(0); } -lean_ctor_set(x_387, 0, x_384); -lean_ctor_set(x_387, 1, x_385); -lean_ctor_set(x_387, 2, x_274); -if (lean_is_scalar(x_383)) { - x_388 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_391)) { + x_392 = lean_alloc_ctor(0, 4, 0); } else { - x_388 = x_383; + x_392 = x_391; } -lean_ctor_set(x_388, 0, x_378); -lean_ctor_set(x_388, 1, x_379); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_380); -lean_ctor_set(x_388, 4, x_381); -lean_ctor_set(x_388, 5, x_382); -if (lean_is_scalar(x_377)) { - x_389 = lean_alloc_ctor(1, 2, 0); +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_389 = x_377; -} -lean_ctor_set(x_389, 0, x_376); -lean_ctor_set(x_389, 1, x_388); -return x_389; + 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; } 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; -x_390 = lean_ctor_get(x_272, 0); -x_391 = lean_ctor_get(x_272, 1); -x_392 = lean_ctor_get(x_272, 2); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_272); -x_393 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_394 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_394, 0, x_390); -lean_ctor_set(x_394, 1, x_391); -lean_ctor_set(x_394, 2, x_393); -lean_ctor_set(x_267, 2, x_394); -x_395 = lean_ctor_get(x_8, 0); +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; 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_8, 1); +x_396 = lean_ctor_get(x_395, 2); lean_inc(x_396); -x_397 = lean_ctor_get(x_8, 2); +x_397 = lean_ctor_get(x_377, 0); lean_inc(x_397); -x_398 = lean_ctor_get(x_8, 3); -lean_inc(x_398); -x_399 = lean_ctor_get(x_8, 4); +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); +} +x_399 = lean_ctor_get(x_395, 0); lean_inc(x_399); -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_400 = x_8; +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_8); - x_400 = lean_box(0); + lean_dec_ref(x_395); + x_404 = lean_box(0); } -x_401 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_401, 0, x_268); -lean_ctor_set(x_401, 1, x_24); -x_402 = lean_array_push(x_397, x_401); -if (lean_is_scalar(x_400)) { - x_403 = lean_alloc_ctor(0, 5, 0); -} else { - x_403 = x_400; -} -lean_ctor_set(x_403, 0, x_395); -lean_ctor_set(x_403, 1, x_396); -lean_ctor_set(x_403, 2, x_402); -lean_ctor_set(x_403, 3, x_398); -lean_ctor_set(x_403, 4, x_399); -x_404 = 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_270, x_403, x_267); -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_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; -x_405 = lean_ctor_get(x_404, 1); +x_405 = lean_ctor_get(x_396, 0); lean_inc(x_405); -x_406 = lean_ctor_get(x_405, 2); +x_406 = lean_ctor_get(x_396, 1); lean_inc(x_406); -x_407 = lean_ctor_get(x_404, 0); +x_407 = lean_ctor_get(x_396, 3); lean_inc(x_407); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_408 = x_404; +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; } else { - lean_dec_ref(x_404); + lean_dec_ref(x_396); x_408 = lean_box(0); } -x_409 = lean_ctor_get(x_405, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_405, 1); -lean_inc(x_410); -x_411 = lean_ctor_get(x_405, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_405, 4); -lean_inc(x_412); -x_413 = lean_ctor_get(x_405, 5); -lean_inc(x_413); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - lean_ctor_release(x_405, 4); - lean_ctor_release(x_405, 5); - x_414 = x_405; -} else { - lean_dec_ref(x_405); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_406, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_406, 1); -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); - x_417 = x_406; -} else { - lean_dec_ref(x_406); - x_417 = lean_box(0); -} -if (lean_is_scalar(x_417)) { - x_418 = lean_alloc_ctor(0, 3, 0); -} else { - x_418 = x_417; -} -lean_ctor_set(x_418, 0, x_415); -lean_ctor_set(x_418, 1, x_416); -lean_ctor_set(x_418, 2, x_392); -if (lean_is_scalar(x_414)) { - x_419 = lean_alloc_ctor(0, 6, 0); -} else { - x_419 = x_414; -} -lean_ctor_set(x_419, 0, x_409); -lean_ctor_set(x_419, 1, x_410); -lean_ctor_set(x_419, 2, x_418); -lean_ctor_set(x_419, 3, x_411); -lean_ctor_set(x_419, 4, x_412); -lean_ctor_set(x_419, 5, x_413); if (lean_is_scalar(x_408)) { - x_420 = lean_alloc_ctor(0, 2, 0); + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_420 = x_408; + x_409 = x_408; +} +lean_ctor_set(x_409, 0, x_405); +lean_ctor_set(x_409, 1, x_406); +lean_ctor_set(x_409, 2, x_288); +lean_ctor_set(x_409, 3, x_407); +if (lean_is_scalar(x_404)) { + x_410 = lean_alloc_ctor(0, 6, 0); +} else { + x_410 = x_404; +} +lean_ctor_set(x_410, 0, x_399); +lean_ctor_set(x_410, 1, x_400); +lean_ctor_set(x_410, 2, x_409); +lean_ctor_set(x_410, 3, x_401); +lean_ctor_set(x_410, 4, x_402); +lean_ctor_set(x_410, 5, x_403); +if (lean_is_scalar(x_398)) { + x_411 = lean_alloc_ctor(1, 2, 0); +} else { + x_411 = x_398; +} +lean_ctor_set(x_411, 0, x_397); +lean_ctor_set(x_411, 1, x_410); +return x_411; +} } -lean_ctor_set(x_420, 0, x_407); -lean_ctor_set(x_420, 1, x_419); -return x_420; } else { -lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_421 = lean_ctor_get(x_404, 1); +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_421, 2); +x_422 = lean_ctor_get(x_8, 4); lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 0); -lean_inc(x_423); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_424 = x_404; -} else { - lean_dec_ref(x_404); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_421, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_421, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_421, 3); -lean_inc(x_427); -x_428 = lean_ctor_get(x_421, 4); -lean_inc(x_428); -x_429 = lean_ctor_get(x_421, 5); -lean_inc(x_429); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - lean_ctor_release(x_421, 2); - lean_ctor_release(x_421, 3); - lean_ctor_release(x_421, 4); - lean_ctor_release(x_421, 5); - x_430 = x_421; -} else { - lean_dec_ref(x_421); - x_430 = lean_box(0); -} -x_431 = lean_ctor_get(x_422, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_422, 1); -lean_inc(x_432); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - lean_ctor_release(x_422, 2); - x_433 = x_422; -} else { - lean_dec_ref(x_422); - x_433 = lean_box(0); -} -if (lean_is_scalar(x_433)) { - x_434 = lean_alloc_ctor(0, 3, 0); -} else { - x_434 = x_433; -} -lean_ctor_set(x_434, 0, x_431); -lean_ctor_set(x_434, 1, x_432); -lean_ctor_set(x_434, 2, x_392); -if (lean_is_scalar(x_430)) { - x_435 = lean_alloc_ctor(0, 6, 0); -} else { - x_435 = x_430; -} -lean_ctor_set(x_435, 0, x_425); -lean_ctor_set(x_435, 1, x_426); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_427); -lean_ctor_set(x_435, 4, x_428); -lean_ctor_set(x_435, 5, x_429); -if (lean_is_scalar(x_424)) { - x_436 = lean_alloc_ctor(1, 2, 0); -} else { - x_436 = x_424; -} -lean_ctor_set(x_436, 0, x_423); -lean_ctor_set(x_436, 1, x_435); -return x_436; -} -} -} -else -{ -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; 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_437 = lean_ctor_get(x_267, 2); -x_438 = lean_ctor_get(x_267, 0); -x_439 = lean_ctor_get(x_267, 1); -x_440 = lean_ctor_get(x_267, 3); -x_441 = lean_ctor_get(x_267, 4); -x_442 = lean_ctor_get(x_267, 5); -lean_inc(x_442); -lean_inc(x_441); -lean_inc(x_440); -lean_inc(x_437); -lean_inc(x_439); -lean_inc(x_438); -lean_dec(x_267); -x_443 = lean_ctor_get(x_437, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_437, 1); -lean_inc(x_444); -x_445 = lean_ctor_get(x_437, 2); -lean_inc(x_445); -if (lean_is_exclusive(x_437)) { - lean_ctor_release(x_437, 0); - lean_ctor_release(x_437, 1); - lean_ctor_release(x_437, 2); - x_446 = x_437; -} else { - lean_dec_ref(x_437); - x_446 = lean_box(0); -} -x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_446)) { - x_448 = lean_alloc_ctor(0, 3, 0); -} else { - x_448 = x_446; -} -lean_ctor_set(x_448, 0, x_443); -lean_ctor_set(x_448, 1, x_444); -lean_ctor_set(x_448, 2, x_447); -x_449 = lean_alloc_ctor(0, 6, 0); -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); -x_450 = lean_ctor_get(x_8, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_8, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_8, 2); -lean_inc(x_452); -x_453 = lean_ctor_get(x_8, 3); -lean_inc(x_453); -x_454 = lean_ctor_get(x_8, 4); -lean_inc(x_454); 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_455 = x_8; + x_423 = x_8; } else { lean_dec_ref(x_8); - x_455 = lean_box(0); + x_423 = lean_box(0); } -x_456 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_456, 0, x_268); -lean_ctor_set(x_456, 1, x_24); -x_457 = lean_array_push(x_452, x_456); -if (lean_is_scalar(x_455)) { - x_458 = lean_alloc_ctor(0, 5, 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); } else { - x_458 = x_455; + x_426 = x_423; } -lean_ctor_set(x_458, 0, x_450); -lean_ctor_set(x_458, 1, x_451); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_453); -lean_ctor_set(x_458, 4, x_454); -x_459 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_458, x_449); -if (lean_obj_tag(x_459) == 0) +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_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_460 = lean_ctor_get(x_459, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_460, 2); -lean_inc(x_461); -x_462 = lean_ctor_get(x_459, 0); -lean_inc(x_462); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_463 = x_459; +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_459); - x_463 = lean_box(0); + lean_dec_ref(x_427); + x_431 = lean_box(0); } -x_464 = lean_ctor_get(x_460, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_460, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_460, 3); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_445); + x_454 = 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; +} else { + lean_dec_ref(x_446); + x_458 = lean_box(0); +} +if (lean_is_scalar(x_458)) { + x_459 = lean_alloc_ctor(0, 4, 0); +} else { + x_459 = x_458; +} +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); +} else { + x_460 = x_454; +} +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); +} else { + x_461 = x_448; +} +lean_ctor_set(x_461, 0, x_447); +lean_ctor_set(x_461, 1, x_460); +return x_461; +} +} +} +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); -x_468 = lean_ctor_get(x_460, 5); +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); -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); - lean_ctor_release(x_460, 4); - lean_ctor_release(x_460, 5); - x_469 = x_460; -} else { - lean_dec_ref(x_460); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_461, 0); +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_461, 1); +x_471 = lean_ctor_get(x_462, 3); lean_inc(x_471); -if (lean_is_exclusive(x_461)) { - lean_ctor_release(x_461, 0); - lean_ctor_release(x_461, 1); - lean_ctor_release(x_461, 2); - x_472 = x_461; +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; } else { - lean_dec_ref(x_461); + lean_dec_ref(x_462); x_472 = lean_box(0); } +x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_472)) { - x_473 = lean_alloc_ctor(0, 3, 0); + x_474 = lean_alloc_ctor(0, 4, 0); } else { - x_473 = x_472; + x_474 = x_472; } -lean_ctor_set(x_473, 0, x_470); -lean_ctor_set(x_473, 1, x_471); -lean_ctor_set(x_473, 2, x_445); -if (lean_is_scalar(x_469)) { - x_474 = lean_alloc_ctor(0, 6, 0); -} else { - x_474 = x_469; -} -lean_ctor_set(x_474, 0, x_464); -lean_ctor_set(x_474, 1, x_465); +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_466); -lean_ctor_set(x_474, 4, x_467); -lean_ctor_set(x_474, 5, x_468); -if (lean_is_scalar(x_463)) { - x_475 = lean_alloc_ctor(0, 2, 0); -} else { - x_475 = x_463; -} -lean_ctor_set(x_475, 0, x_462); -lean_ctor_set(x_475, 1, x_474); -return x_475; -} -else -{ -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_476 = lean_ctor_get(x_459, 1); +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_476, 2); +x_477 = lean_ctor_get(x_8, 1); lean_inc(x_477); -x_478 = lean_ctor_get(x_459, 0); +x_478 = lean_ctor_get(x_8, 2); lean_inc(x_478); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_479 = x_459; -} else { - lean_dec_ref(x_459); - x_479 = lean_box(0); -} -x_480 = lean_ctor_get(x_476, 0); +x_479 = lean_ctor_get(x_8, 3); +lean_inc(x_479); +x_480 = lean_ctor_get(x_8, 4); 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; +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; } else { - lean_dec_ref(x_476); - x_485 = lean_box(0); + lean_dec_ref(x_8); + x_481 = lean_box(0); } -x_486 = lean_ctor_get(x_477, 0); +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); +} else { + x_484 = x_481; +} +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_477, 1); +x_487 = lean_ctor_get(x_486, 2); lean_inc(x_487); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - x_488 = x_477; +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; } else { - lean_dec_ref(x_477); - x_488 = lean_box(0); + lean_dec_ref(x_485); + x_489 = lean_box(0); } -if (lean_is_scalar(x_488)) { - x_489 = lean_alloc_ctor(0, 3, 0); +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 { - x_489 = x_488; + lean_dec_ref(x_486); + x_495 = lean_box(0); } -lean_ctor_set(x_489, 0, x_486); -lean_ctor_set(x_489, 1, x_487); -lean_ctor_set(x_489, 2, x_445); -if (lean_is_scalar(x_485)) { - x_490 = lean_alloc_ctor(0, 6, 0); +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 { - x_490 = x_485; + lean_dec_ref(x_487); + x_499 = lean_box(0); } -lean_ctor_set(x_490, 0, x_480); -lean_ctor_set(x_490, 1, x_481); -lean_ctor_set(x_490, 2, x_489); -lean_ctor_set(x_490, 3, x_482); -lean_ctor_set(x_490, 4, x_483); -lean_ctor_set(x_490, 5, x_484); -if (lean_is_scalar(x_479)) { - x_491 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_499)) { + x_500 = lean_alloc_ctor(0, 4, 0); } else { - x_491 = x_479; + x_500 = x_499; } -lean_ctor_set(x_491, 0, x_478); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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_492; +uint8_t x_520; 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_492 = !lean_is_exclusive(x_261); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_275); +if (x_520 == 0) { -return x_261; +return x_275; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_261, 0); -x_494 = lean_ctor_get(x_261, 1); -lean_inc(x_494); -lean_inc(x_493); -lean_dec(x_261); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } @@ -17207,7 +17631,7 @@ return x_495; } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -17215,52 +17639,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_29); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_29); +if (x_524 == 0) { return x_29; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_29, 0); -x_498 = lean_ctor_get(x_29, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_29); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } else { -uint8_t x_500; +uint8_t x_528; 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_500 = !lean_is_exclusive(x_25); -if (x_500 == 0) +x_528 = !lean_is_exclusive(x_25); +if (x_528 == 0) { return x_25; } else { -lean_object* x_501; lean_object* x_502; lean_object* x_503; -x_501 = lean_ctor_get(x_25, 0); -x_502 = lean_ctor_get(x_25, 1); -lean_inc(x_502); -lean_inc(x_501); +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_dec(x_25); -x_503 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_503, 0, x_501); -lean_ctor_set(x_503, 1, x_502); -return x_503; +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; } } } @@ -31666,82 +32090,89 @@ return x_48; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_59 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -lean_ctor_set(x_59, 2, x_42); -lean_ctor_set(x_49, 2, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_49, 0); -x_61 = lean_ctor_get(x_49, 1); -x_62 = lean_ctor_get(x_49, 3); -x_63 = lean_ctor_get(x_49, 4); -x_64 = lean_ctor_get(x_49, 5); +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_inc(x_62); lean_inc(x_61); -lean_inc(x_60); lean_dec(x_49); -x_65 = lean_ctor_get(x_50, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_50, 1); +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); - x_67 = x_50; + lean_ctor_release(x_50, 3); + x_69 = x_50; } else { lean_dec_ref(x_50); - x_67 = lean_box(0); + x_69 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_70 = x_69; } -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_42); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_60); -lean_ctor_set(x_69, 1, x_61); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_62); -lean_ctor_set(x_69, 4, x_63); -lean_ctor_set(x_69, 5, x_64); -lean_ctor_set(x_48, 1, x_69); +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; } } 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; -x_70 = lean_ctor_get(x_48, 0); -lean_inc(x_70); -lean_dec(x_48); -x_71 = lean_ctor_get(x_49, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_49, 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; lean_object* x_84; lean_object* x_85; +x_72 = lean_ctor_get(x_48, 0); lean_inc(x_72); -x_73 = lean_ctor_get(x_49, 3); +lean_dec(x_48); +x_73 = lean_ctor_get(x_49, 0); lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 4); +x_74 = lean_ctor_get(x_49, 1); lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 5); +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); @@ -31749,1900 +32180,1999 @@ if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 3); lean_ctor_release(x_49, 4); lean_ctor_release(x_49, 5); - x_76 = x_49; + x_78 = x_49; } else { lean_dec_ref(x_49); - x_76 = lean_box(0); + x_78 = lean_box(0); } -x_77 = lean_ctor_get(x_50, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_50, 1); -lean_inc(x_78); +x_79 = lean_ctor_get(x_50, 0); +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); - x_79 = x_50; + lean_ctor_release(x_50, 3); + x_82 = x_50; } else { lean_dec_ref(x_50); - x_79 = lean_box(0); + x_82 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_83 = x_82; } -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_42); -if (lean_is_scalar(x_76)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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_81 = x_76; + x_84 = x_78; } -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); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_70); -lean_ctor_set(x_82, 1, x_81); -return x_82; +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; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_48, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_48); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; +lean_object* x_86; lean_object* x_87; uint8_t x_88; x_86 = lean_ctor_get(x_48, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = !lean_is_exclusive(x_48); +if (x_88 == 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_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_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_42); +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_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -lean_ctor_set(x_93, 2, x_42); -lean_ctor_set(x_83, 2, x_93); -return x_48; -} -} -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; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -x_97 = lean_ctor_get(x_83, 4); -x_98 = lean_ctor_get(x_83, 5); -lean_inc(x_98); -lean_inc(x_97); +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_83); -x_99 = lean_ctor_get(x_84, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_84, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_101 = x_84; -} else { - lean_dec_ref(x_84); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 3, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_102, 2, x_42); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_94); -lean_ctor_set(x_103, 1, x_95); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_97); -lean_ctor_set(x_103, 5, x_98); -lean_ctor_set(x_48, 1, x_103); +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_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_104 = lean_ctor_get(x_48, 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; +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); -lean_dec(x_48); -x_105 = lean_ctor_get(x_83, 0); +x_105 = lean_ctor_get(x_87, 3); lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_83, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 5); +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; +} else { + lean_dec_ref(x_87); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 4, 0); +} else { + x_107 = x_106; +} +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); -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_110 = x_83; -} else { - lean_dec_ref(x_83); - x_110 = lean_box(0); -} -x_111 = lean_ctor_get(x_84, 0); +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_84, 1); +x_112 = lean_ctor_get(x_86, 3); 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); - x_113 = x_84; +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; } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + lean_dec_ref(x_86); + x_115 = lean_box(0); } -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 3, 0); +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 { - x_114 = x_113; + lean_dec_ref(x_87); + x_119 = lean_box(0); } -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_42); -if (lean_is_scalar(x_110)) { - x_115 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_115 = x_110; + x_120 = x_119; } -lean_ctor_set(x_115, 0, x_105); -lean_ctor_set(x_115, 1, x_106); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_107); -lean_ctor_set(x_115, 4, x_108); -lean_ctor_set(x_115, 5, x_109); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_104); -lean_ctor_set(x_116, 1, x_115); -return x_116; +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_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_8, 0); -x_118 = lean_ctor_get(x_8, 1); -x_119 = lean_ctor_get(x_8, 2); -x_120 = lean_ctor_get(x_8, 3); -x_121 = lean_ctor_get(x_8, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_8); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_36); -lean_ctor_set(x_122, 1, x_24); -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___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_124, x_35); -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; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); +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); -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; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_126, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +lean_inc(x_126); +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_Init_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_126, 4); +x_133 = lean_ctor_get(x_132, 2); lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); +x_134 = lean_ctor_get(x_131, 0); 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_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; } else { - lean_dec_ref(x_126); + lean_dec_ref(x_131); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); +x_136 = lean_ctor_get(x_132, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); +x_137 = lean_ctor_get(x_132, 1); lean_inc(x_137); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - x_138 = x_127; +x_138 = lean_ctor_get(x_132, 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; } else { - lean_dec_ref(x_127); - x_138 = lean_box(0); + lean_dec_ref(x_132); + x_141 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_42); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -if (lean_is_scalar(x_129)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_129; -} -lean_ctor_set(x_141, 0, x_128); -lean_ctor_set(x_141, 1, x_140); -return x_141; -} -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; -x_142 = lean_ctor_get(x_125, 1); +x_142 = lean_ctor_get(x_133, 0); lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); +x_143 = lean_ctor_get(x_133, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 0); +x_144 = lean_ctor_get(x_133, 3); lean_inc(x_144); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_145 = x_125; +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; } else { - lean_dec_ref(x_125); + lean_dec_ref(x_133); x_145 = lean_box(0); } -x_146 = lean_ctor_get(x_142, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 3); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 4); -lean_inc(x_149); -x_150 = lean_ctor_get(x_142, 5); -lean_inc(x_150); -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_151 = x_142; -} else { - lean_dec_ref(x_142); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_143, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 3, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -lean_ctor_set(x_155, 2, x_42); -if (lean_is_scalar(x_151)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_151; -} -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); if (lean_is_scalar(x_145)) { - x_157 = lean_alloc_ctor(1, 2, 0); + x_146 = lean_alloc_ctor(0, 4, 0); } else { - x_157 = x_145; + x_146 = x_145; } -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; +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); +if (lean_is_scalar(x_135)) { + x_148 = lean_alloc_ctor(0, 2, 0); +} else { + x_148 = x_135; +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_149, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_131, 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); +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_42); +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(1, 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_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_40, 0); -x_159 = lean_ctor_get(x_40, 1); -x_160 = lean_ctor_get(x_40, 2); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_40); -x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_162 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_162, 0, x_158); -lean_ctor_set(x_162, 1, x_159); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_35, 2, x_162); -x_163 = lean_ctor_get(x_8, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 2); -lean_inc(x_165); -x_166 = lean_ctor_get(x_8, 3); -lean_inc(x_166); -x_167 = lean_ctor_get(x_8, 4); +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); 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_168 = x_8; + x_177 = x_8; } else { lean_dec_ref(x_8); - x_168 = lean_box(0); + x_177 = lean_box(0); } -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_36); -lean_ctor_set(x_169, 1, x_24); -x_170 = lean_array_push(x_165, x_169); -if (lean_is_scalar(x_168)) { - x_171 = lean_alloc_ctor(0, 5, 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); } else { - x_171 = x_168; + x_180 = x_177; } -lean_ctor_set(x_171, 0, x_163); -lean_ctor_set(x_171, 1, x_164); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_166); -lean_ctor_set(x_171, 4, x_167); -x_172 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_171, x_35); -if (lean_obj_tag(x_172) == 0) +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_Init_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_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_173 = lean_ctor_get(x_172, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_176 = x_172; -} else { - lean_dec_ref(x_172); - 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_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_174, 1); +x_184 = lean_ctor_get(x_181, 0); lean_inc(x_184); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - x_185 = x_174; +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_174); + lean_dec_ref(x_181); x_185 = lean_box(0); } -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 3, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -lean_ctor_set(x_186, 2, x_160); -if (lean_is_scalar(x_182)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_182; -} -lean_ctor_set(x_187, 0, x_177); -lean_ctor_set(x_187, 1, x_178); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_179); -lean_ctor_set(x_187, 4, x_180); -lean_ctor_set(x_187, 5, x_181); -if (lean_is_scalar(x_176)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_176; -} -lean_ctor_set(x_188, 0, x_175); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -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; -x_189 = lean_ctor_get(x_172, 1); +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_189, 2); +x_190 = lean_ctor_get(x_182, 5); lean_inc(x_190); -x_191 = lean_ctor_get(x_172, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_192 = x_172; +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_172); - x_192 = lean_box(0); + lean_dec_ref(x_182); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 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_189, 1); +x_194 = lean_ctor_get(x_183, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); -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; +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_189); - x_198 = lean_box(0); + lean_dec_ref(x_183); + x_195 = lean_box(0); } -x_199 = lean_ctor_get(x_190, 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; +} +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_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_199, 2); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - x_201 = x_190; +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; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_181); + x_202 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_205); +x_206 = lean_ctor_get(x_199, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_199, 5); +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 { - x_202 = x_201; + lean_dec_ref(x_199); + x_208 = lean_box(0); } -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_160); -if (lean_is_scalar(x_198)) { - x_203 = lean_alloc_ctor(0, 6, 0); +x_209 = lean_ctor_get(x_200, 0); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 3); +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; } else { - x_203 = x_198; + lean_dec_ref(x_200); + x_212 = lean_box(0); } -lean_ctor_set(x_203, 0, x_193); -lean_ctor_set(x_203, 1, x_194); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_195); -lean_ctor_set(x_203, 4, x_196); -lean_ctor_set(x_203, 5, x_197); -if (lean_is_scalar(x_192)) { - x_204 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); } else { - x_204 = x_192; + x_213 = x_212; } -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +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); +} 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_202)) { + x_215 = lean_alloc_ctor(1, 2, 0); +} else { + x_215 = x_202; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } 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; -x_205 = lean_ctor_get(x_35, 2); -x_206 = lean_ctor_get(x_35, 0); -x_207 = lean_ctor_get(x_35, 1); -x_208 = lean_ctor_get(x_35, 3); -x_209 = lean_ctor_get(x_35, 4); -x_210 = lean_ctor_get(x_35, 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_35); -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); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - x_214 = x_205; -} else { - lean_dec_ref(x_205); - x_214 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 3, 0); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_211); -lean_ctor_set(x_216, 1, x_212); -lean_ctor_set(x_216, 2, x_215); -x_217 = lean_alloc_ctor(0, 6, 0); -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); -x_218 = lean_ctor_get(x_8, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_8, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_8, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_8, 3); +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); -x_222 = lean_ctor_get(x_8, 4); +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_223 = x_8; + x_235 = x_8; } else { lean_dec_ref(x_8); - x_223 = lean_box(0); + x_235 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_36); -lean_ctor_set(x_224, 1, x_24); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { - x_226 = lean_alloc_ctor(0, 5, 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_226 = x_223; + x_238 = x_235; } -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___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_226, x_217); -if (lean_obj_tag(x_227) == 0) +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_Init_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_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_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_227, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_231 = x_227; +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_227); - x_231 = lean_box(0); + lean_dec_ref(x_239); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_228, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); -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; +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_228); - x_237 = lean_box(0); + lean_dec_ref(x_240); + x_249 = 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); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - x_240 = x_229; +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_229); - x_240 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - x_241 = x_240; + x_254 = x_253; } -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_213); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); +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_242 = x_237; + x_255 = x_249; } -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 2, 0); +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_243 = x_231; + x_256 = x_243; } -lean_ctor_set(x_243, 0, x_230); -lean_ctor_set(x_243, 1, x_242); -return 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_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_244 = lean_ctor_get(x_227, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 2); -lean_inc(x_245); -x_246 = lean_ctor_get(x_227, 0); -lean_inc(x_246); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_247 = x_227; +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_227); - x_247 = lean_box(0); + lean_dec_ref(x_239); + x_260 = lean_box(0); } -x_248 = lean_ctor_get(x_244, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_244, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_244, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_244, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 5); -lean_inc(x_252); -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_253 = x_244; +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_244); - x_253 = lean_box(0); + lean_dec_ref(x_257); + x_266 = lean_box(0); } -x_254 = lean_ctor_get(x_245, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 1); -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); - x_256 = x_245; +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_245); - x_256 = lean_box(0); + lean_dec_ref(x_258); + x_270 = lean_box(0); } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 4, 0); } else { - x_257 = x_256; + x_271 = x_270; } -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_213); -if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); +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_258 = x_253; + x_272 = x_266; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_261); +lean_ctor_set(x_272, 1, x_262); +lean_ctor_set(x_272, 2, x_271); +lean_ctor_set(x_272, 3, x_263); +lean_ctor_set(x_272, 4, x_264); +lean_ctor_set(x_272, 5, x_265); +if (lean_is_scalar(x_260)) { + x_273 = lean_alloc_ctor(1, 2, 0); } else { - x_259 = x_247; + x_273 = x_260; } -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; } } } default: { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_29, 1); -lean_inc(x_260); +lean_object* x_274; lean_object* x_275; +x_274 = lean_ctor_get(x_29, 1); +lean_inc(x_274); lean_dec(x_29); lean_inc(x_8); -x_261 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_260); -if (lean_obj_tag(x_261) == 0) +x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); +if (lean_obj_tag(x_275) == 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_276; +x_276 = lean_ctor_get(x_275, 0); +lean_inc(x_276); +if (lean_obj_tag(x_276) == 0) { -lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_dec(x_24); -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_7, x_264); +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); lean_dec(x_7); -x_7 = x_265; -x_9 = x_263; +x_7 = x_279; +x_9 = x_277; 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_7, x_269); -lean_dec(x_7); -x_271 = !lean_is_exclusive(x_267); -if (x_271 == 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_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_8); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_8, 2); -x_278 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_24); -x_279 = lean_array_push(x_277, x_278); -lean_ctor_set(x_8, 2, x_279); -x_280 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_8, x_267); -if (lean_obj_tag(x_280) == 0) -{ -lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_281 = lean_ctor_get(x_280, 1); +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); -x_282 = lean_ctor_get(x_281, 2); +lean_dec(x_275); +x_282 = lean_ctor_get(x_276, 0); 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); +lean_dec(x_276); +x_283 = lean_unsigned_to_nat(1u); +x_284 = lean_nat_add(x_7, x_283); +lean_dec(x_7); 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); +x_287 = !lean_is_exclusive(x_286); 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_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_289; lean_object* x_290; lean_object* x_291; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_282); -x_291 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_291, 0, x_289); -lean_ctor_set(x_291, 1, x_290); -lean_ctor_set(x_291, 2, x_274); -lean_ctor_set(x_281, 2, x_291); -return x_280; -} -} -else +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_Init_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_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_292 = lean_ctor_get(x_281, 0); -x_293 = lean_ctor_get(x_281, 1); -x_294 = lean_ctor_get(x_281, 3); -x_295 = lean_ctor_get(x_281, 4); -x_296 = lean_ctor_get(x_281, 5); -lean_inc(x_296); +lean_object* x_295; lean_object* x_296; uint8_t x_297; +x_295 = lean_ctor_get(x_294, 1); lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_281); -x_297 = lean_ctor_get(x_282, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_282, 1); -lean_inc(x_298); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_299 = x_282; -} else { - lean_dec_ref(x_282); - x_299 = lean_box(0); -} -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 3, 0); -} else { - x_300 = x_299; -} -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_274); -x_301 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_301, 0, x_292); -lean_ctor_set(x_301, 1, x_293); -lean_ctor_set(x_301, 2, x_300); -lean_ctor_set(x_301, 3, x_294); -lean_ctor_set(x_301, 4, x_295); -lean_ctor_set(x_301, 5, x_296); -lean_ctor_set(x_280, 1, x_301); -return x_280; -} +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_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_302 = lean_ctor_get(x_280, 0); -lean_inc(x_302); -lean_dec(x_280); -x_303 = lean_ctor_get(x_281, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_281, 1); -lean_inc(x_304); -x_305 = lean_ctor_get(x_281, 3); +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); -x_306 = lean_ctor_get(x_281, 4); -lean_inc(x_306); -x_307 = lean_ctor_get(x_281, 5); -lean_inc(x_307); -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_308 = x_281; -} else { - lean_dec_ref(x_281); - x_308 = lean_box(0); +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; } -x_309 = lean_ctor_get(x_282, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_282, 1); +} +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); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_311 = x_282; +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_inc(x_313); +x_314 = lean_ctor_get(x_296, 3); +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_282); - x_311 = lean_box(0); + lean_dec_ref(x_296); + x_315 = lean_box(0); } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_315)) { + x_316 = lean_alloc_ctor(0, 4, 0); } else { - x_312 = x_311; + x_316 = x_315; } -lean_ctor_set(x_312, 0, x_309); -lean_ctor_set(x_312, 1, x_310); -lean_ctor_set(x_312, 2, x_274); -if (lean_is_scalar(x_308)) { - x_313 = lean_alloc_ctor(0, 6, 0); -} else { - x_313 = x_308; -} -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); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_302); -lean_ctor_set(x_314, 1, x_313); -return x_314; +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_315; lean_object* x_316; uint8_t x_317; -x_315 = lean_ctor_get(x_280, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_315, 2); -lean_inc(x_316); -x_317 = !lean_is_exclusive(x_280); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_280, 1); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_315); -if (x_319 == 0) -{ -lean_object* x_320; uint8_t x_321; -x_320 = lean_ctor_get(x_315, 2); -lean_dec(x_320); -x_321 = !lean_is_exclusive(x_316); -if (x_321 == 0) -{ -lean_object* x_322; -x_322 = lean_ctor_get(x_316, 2); -lean_dec(x_322); -lean_ctor_set(x_316, 2, x_274); -return x_280; -} -else -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_323 = lean_ctor_get(x_316, 0); -x_324 = lean_ctor_get(x_316, 1); -lean_inc(x_324); +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_inc(x_323); -lean_dec(x_316); -x_325 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_325, 0, x_323); -lean_ctor_set(x_325, 1, x_324); -lean_ctor_set(x_325, 2, x_274); -lean_ctor_set(x_315, 2, x_325); -return x_280; +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); } -} -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; -x_326 = lean_ctor_get(x_315, 0); -x_327 = lean_ctor_get(x_315, 1); -x_328 = lean_ctor_get(x_315, 3); -x_329 = lean_ctor_get(x_315, 4); -x_330 = lean_ctor_get(x_315, 5); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_inc(x_327); +x_325 = lean_ctor_get(x_296, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_296, 1); lean_inc(x_326); -lean_dec(x_315); -x_331 = lean_ctor_get(x_316, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_316, 1); +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); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_333 = x_316; -} else { - lean_dec_ref(x_316); - x_333 = lean_box(0); -} -if (lean_is_scalar(x_333)) { - x_334 = lean_alloc_ctor(0, 3, 0); -} else { - x_334 = x_333; -} -lean_ctor_set(x_334, 0, x_331); -lean_ctor_set(x_334, 1, x_332); -lean_ctor_set(x_334, 2, x_274); -x_335 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_335, 0, x_326); -lean_ctor_set(x_335, 1, x_327); -lean_ctor_set(x_335, 2, x_334); -lean_ctor_set(x_335, 3, x_328); -lean_ctor_set(x_335, 4, x_329); -lean_ctor_set(x_335, 5, x_330); -lean_ctor_set(x_280, 1, x_335); -return x_280; -} +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_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_336 = lean_ctor_get(x_280, 0); -lean_inc(x_336); -lean_dec(x_280); -x_337 = lean_ctor_get(x_315, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_315, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_315, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_315, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_315, 5); +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); -if (lean_is_exclusive(x_315)) { - lean_ctor_release(x_315, 0); - lean_ctor_release(x_315, 1); - lean_ctor_release(x_315, 2); - lean_ctor_release(x_315, 3); - lean_ctor_release(x_315, 4); - lean_ctor_release(x_315, 5); - x_342 = x_315; -} else { - lean_dec_ref(x_315); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_316, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_316, 1); -lean_inc(x_344); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_345 = x_316; -} else { - lean_dec_ref(x_316); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 3, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_274); -if (lean_is_scalar(x_342)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_342; -} -lean_ctor_set(x_347, 0, x_337); -lean_ctor_set(x_347, 1, x_338); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_339); -lean_ctor_set(x_347, 4, x_340); -lean_ctor_set(x_347, 5, x_341); -x_348 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_348, 0, x_336); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} +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_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_349 = lean_ctor_get(x_8, 0); -x_350 = lean_ctor_get(x_8, 1); -x_351 = lean_ctor_get(x_8, 2); -x_352 = lean_ctor_get(x_8, 3); -x_353 = lean_ctor_get(x_8, 4); -lean_inc(x_353); -lean_inc(x_352); -lean_inc(x_351); -lean_inc(x_350); +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); -lean_dec(x_8); -x_354 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_354, 0, x_268); -lean_ctor_set(x_354, 1, x_24); -x_355 = lean_array_push(x_351, x_354); -x_356 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_356, 0, x_349); -lean_ctor_set(x_356, 1, x_350); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_352); -lean_ctor_set(x_356, 4, x_353); -x_357 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_356, x_267); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; -x_358 = lean_ctor_get(x_357, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_358, 2); -lean_inc(x_359); -x_360 = lean_ctor_get(x_357, 0); -lean_inc(x_360); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_361 = x_357; +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_357); + 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_358, 0); +x_362 = lean_ctor_get(x_333, 0); lean_inc(x_362); -x_363 = lean_ctor_get(x_358, 1); +x_363 = lean_ctor_get(x_333, 1); lean_inc(x_363); -x_364 = lean_ctor_get(x_358, 3); +x_364 = lean_ctor_get(x_333, 3); lean_inc(x_364); -x_365 = lean_ctor_get(x_358, 4); -lean_inc(x_365); -x_366 = lean_ctor_get(x_358, 5); -lean_inc(x_366); -if (lean_is_exclusive(x_358)) { - lean_ctor_release(x_358, 0); - lean_ctor_release(x_358, 1); - lean_ctor_release(x_358, 2); - lean_ctor_release(x_358, 3); - lean_ctor_release(x_358, 4); - lean_ctor_release(x_358, 5); - x_367 = x_358; +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_358); - x_367 = lean_box(0); + lean_dec_ref(x_333); + x_365 = lean_box(0); } -x_368 = lean_ctor_get(x_359, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_359, 1); -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); - x_370 = x_359; +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_359); - x_370 = lean_box(0); + x_366 = x_365; } -if (lean_is_scalar(x_370)) { - x_371 = lean_alloc_ctor(0, 3, 0); -} else { - x_371 = x_370; -} -lean_ctor_set(x_371, 0, x_368); -lean_ctor_set(x_371, 1, x_369); -lean_ctor_set(x_371, 2, x_274); -if (lean_is_scalar(x_367)) { - x_372 = lean_alloc_ctor(0, 6, 0); -} else { - x_372 = x_367; -} -lean_ctor_set(x_372, 0, x_362); -lean_ctor_set(x_372, 1, x_363); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_364); -lean_ctor_set(x_372, 4, x_365); -lean_ctor_set(x_372, 5, x_366); +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_373 = lean_alloc_ctor(0, 2, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_373 = x_361; + 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; +} } -lean_ctor_set(x_373, 0, x_360); -lean_ctor_set(x_373, 1, x_372); -return x_373; } else { -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_374 = lean_ctor_get(x_357, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_357, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_377 = x_357; -} else { - lean_dec_ref(x_357); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); +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_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_Init_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) +{ +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_374, 1); +x_379 = lean_ctor_get(x_378, 2); lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); +x_380 = lean_ctor_get(x_377, 0); lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); +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); -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); +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_375, 1); +x_385 = lean_ctor_get(x_378, 4); lean_inc(x_385); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - lean_ctor_release(x_375, 2); - x_386 = x_375; +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_375); - x_386 = lean_box(0); + lean_dec_ref(x_378); + x_387 = lean_box(0); } -if (lean_is_scalar(x_386)) { - x_387 = lean_alloc_ctor(0, 3, 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 { - x_387 = x_386; + lean_dec_ref(x_379); + x_391 = lean_box(0); } -lean_ctor_set(x_387, 0, x_384); -lean_ctor_set(x_387, 1, x_385); -lean_ctor_set(x_387, 2, x_274); -if (lean_is_scalar(x_383)) { - x_388 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_391)) { + x_392 = lean_alloc_ctor(0, 4, 0); } else { - x_388 = x_383; + x_392 = x_391; } -lean_ctor_set(x_388, 0, x_378); -lean_ctor_set(x_388, 1, x_379); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_380); -lean_ctor_set(x_388, 4, x_381); -lean_ctor_set(x_388, 5, x_382); -if (lean_is_scalar(x_377)) { - x_389 = lean_alloc_ctor(1, 2, 0); +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_389 = x_377; -} -lean_ctor_set(x_389, 0, x_376); -lean_ctor_set(x_389, 1, x_388); -return x_389; + 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; } 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; -x_390 = lean_ctor_get(x_272, 0); -x_391 = lean_ctor_get(x_272, 1); -x_392 = lean_ctor_get(x_272, 2); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_272); -x_393 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_394 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_394, 0, x_390); -lean_ctor_set(x_394, 1, x_391); -lean_ctor_set(x_394, 2, x_393); -lean_ctor_set(x_267, 2, x_394); -x_395 = lean_ctor_get(x_8, 0); +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; 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_8, 1); +x_396 = lean_ctor_get(x_395, 2); lean_inc(x_396); -x_397 = lean_ctor_get(x_8, 2); +x_397 = lean_ctor_get(x_377, 0); lean_inc(x_397); -x_398 = lean_ctor_get(x_8, 3); -lean_inc(x_398); -x_399 = lean_ctor_get(x_8, 4); +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); +} +x_399 = lean_ctor_get(x_395, 0); lean_inc(x_399); -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_400 = x_8; +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_8); - x_400 = lean_box(0); + lean_dec_ref(x_395); + x_404 = lean_box(0); } -x_401 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_401, 0, x_268); -lean_ctor_set(x_401, 1, x_24); -x_402 = lean_array_push(x_397, x_401); -if (lean_is_scalar(x_400)) { - x_403 = lean_alloc_ctor(0, 5, 0); -} else { - x_403 = x_400; -} -lean_ctor_set(x_403, 0, x_395); -lean_ctor_set(x_403, 1, x_396); -lean_ctor_set(x_403, 2, x_402); -lean_ctor_set(x_403, 3, x_398); -lean_ctor_set(x_403, 4, x_399); -x_404 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_403, x_267); -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_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; -x_405 = lean_ctor_get(x_404, 1); +x_405 = lean_ctor_get(x_396, 0); lean_inc(x_405); -x_406 = lean_ctor_get(x_405, 2); +x_406 = lean_ctor_get(x_396, 1); lean_inc(x_406); -x_407 = lean_ctor_get(x_404, 0); +x_407 = lean_ctor_get(x_396, 3); lean_inc(x_407); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_408 = x_404; +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; } else { - lean_dec_ref(x_404); + lean_dec_ref(x_396); x_408 = lean_box(0); } -x_409 = lean_ctor_get(x_405, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_405, 1); -lean_inc(x_410); -x_411 = lean_ctor_get(x_405, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_405, 4); -lean_inc(x_412); -x_413 = lean_ctor_get(x_405, 5); -lean_inc(x_413); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - lean_ctor_release(x_405, 4); - lean_ctor_release(x_405, 5); - x_414 = x_405; -} else { - lean_dec_ref(x_405); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_406, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_406, 1); -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); - x_417 = x_406; -} else { - lean_dec_ref(x_406); - x_417 = lean_box(0); -} -if (lean_is_scalar(x_417)) { - x_418 = lean_alloc_ctor(0, 3, 0); -} else { - x_418 = x_417; -} -lean_ctor_set(x_418, 0, x_415); -lean_ctor_set(x_418, 1, x_416); -lean_ctor_set(x_418, 2, x_392); -if (lean_is_scalar(x_414)) { - x_419 = lean_alloc_ctor(0, 6, 0); -} else { - x_419 = x_414; -} -lean_ctor_set(x_419, 0, x_409); -lean_ctor_set(x_419, 1, x_410); -lean_ctor_set(x_419, 2, x_418); -lean_ctor_set(x_419, 3, x_411); -lean_ctor_set(x_419, 4, x_412); -lean_ctor_set(x_419, 5, x_413); if (lean_is_scalar(x_408)) { - x_420 = lean_alloc_ctor(0, 2, 0); + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_420 = x_408; + x_409 = x_408; +} +lean_ctor_set(x_409, 0, x_405); +lean_ctor_set(x_409, 1, x_406); +lean_ctor_set(x_409, 2, x_288); +lean_ctor_set(x_409, 3, x_407); +if (lean_is_scalar(x_404)) { + x_410 = lean_alloc_ctor(0, 6, 0); +} else { + x_410 = x_404; +} +lean_ctor_set(x_410, 0, x_399); +lean_ctor_set(x_410, 1, x_400); +lean_ctor_set(x_410, 2, x_409); +lean_ctor_set(x_410, 3, x_401); +lean_ctor_set(x_410, 4, x_402); +lean_ctor_set(x_410, 5, x_403); +if (lean_is_scalar(x_398)) { + x_411 = lean_alloc_ctor(1, 2, 0); +} else { + x_411 = x_398; +} +lean_ctor_set(x_411, 0, x_397); +lean_ctor_set(x_411, 1, x_410); +return x_411; +} } -lean_ctor_set(x_420, 0, x_407); -lean_ctor_set(x_420, 1, x_419); -return x_420; } else { -lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_421 = lean_ctor_get(x_404, 1); +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_421, 2); +x_422 = lean_ctor_get(x_8, 4); lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 0); -lean_inc(x_423); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_424 = x_404; -} else { - lean_dec_ref(x_404); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_421, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_421, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_421, 3); -lean_inc(x_427); -x_428 = lean_ctor_get(x_421, 4); -lean_inc(x_428); -x_429 = lean_ctor_get(x_421, 5); -lean_inc(x_429); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - lean_ctor_release(x_421, 2); - lean_ctor_release(x_421, 3); - lean_ctor_release(x_421, 4); - lean_ctor_release(x_421, 5); - x_430 = x_421; -} else { - lean_dec_ref(x_421); - x_430 = lean_box(0); -} -x_431 = lean_ctor_get(x_422, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_422, 1); -lean_inc(x_432); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - lean_ctor_release(x_422, 2); - x_433 = x_422; -} else { - lean_dec_ref(x_422); - x_433 = lean_box(0); -} -if (lean_is_scalar(x_433)) { - x_434 = lean_alloc_ctor(0, 3, 0); -} else { - x_434 = x_433; -} -lean_ctor_set(x_434, 0, x_431); -lean_ctor_set(x_434, 1, x_432); -lean_ctor_set(x_434, 2, x_392); -if (lean_is_scalar(x_430)) { - x_435 = lean_alloc_ctor(0, 6, 0); -} else { - x_435 = x_430; -} -lean_ctor_set(x_435, 0, x_425); -lean_ctor_set(x_435, 1, x_426); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_427); -lean_ctor_set(x_435, 4, x_428); -lean_ctor_set(x_435, 5, x_429); -if (lean_is_scalar(x_424)) { - x_436 = lean_alloc_ctor(1, 2, 0); -} else { - x_436 = x_424; -} -lean_ctor_set(x_436, 0, x_423); -lean_ctor_set(x_436, 1, x_435); -return x_436; -} -} -} -else -{ -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; 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_437 = lean_ctor_get(x_267, 2); -x_438 = lean_ctor_get(x_267, 0); -x_439 = lean_ctor_get(x_267, 1); -x_440 = lean_ctor_get(x_267, 3); -x_441 = lean_ctor_get(x_267, 4); -x_442 = lean_ctor_get(x_267, 5); -lean_inc(x_442); -lean_inc(x_441); -lean_inc(x_440); -lean_inc(x_437); -lean_inc(x_439); -lean_inc(x_438); -lean_dec(x_267); -x_443 = lean_ctor_get(x_437, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_437, 1); -lean_inc(x_444); -x_445 = lean_ctor_get(x_437, 2); -lean_inc(x_445); -if (lean_is_exclusive(x_437)) { - lean_ctor_release(x_437, 0); - lean_ctor_release(x_437, 1); - lean_ctor_release(x_437, 2); - x_446 = x_437; -} else { - lean_dec_ref(x_437); - x_446 = lean_box(0); -} -x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_446)) { - x_448 = lean_alloc_ctor(0, 3, 0); -} else { - x_448 = x_446; -} -lean_ctor_set(x_448, 0, x_443); -lean_ctor_set(x_448, 1, x_444); -lean_ctor_set(x_448, 2, x_447); -x_449 = lean_alloc_ctor(0, 6, 0); -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); -x_450 = lean_ctor_get(x_8, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_8, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_8, 2); -lean_inc(x_452); -x_453 = lean_ctor_get(x_8, 3); -lean_inc(x_453); -x_454 = lean_ctor_get(x_8, 4); -lean_inc(x_454); 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_455 = x_8; + x_423 = x_8; } else { lean_dec_ref(x_8); - x_455 = lean_box(0); + x_423 = lean_box(0); } -x_456 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_456, 0, x_268); -lean_ctor_set(x_456, 1, x_24); -x_457 = lean_array_push(x_452, x_456); -if (lean_is_scalar(x_455)) { - x_458 = lean_alloc_ctor(0, 5, 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); } else { - x_458 = x_455; + x_426 = x_423; } -lean_ctor_set(x_458, 0, x_450); -lean_ctor_set(x_458, 1, x_451); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_453); -lean_ctor_set(x_458, 4, x_454); -x_459 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_458, x_449); -if (lean_obj_tag(x_459) == 0) +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_Init_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_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_460 = lean_ctor_get(x_459, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_460, 2); -lean_inc(x_461); -x_462 = lean_ctor_get(x_459, 0); -lean_inc(x_462); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_463 = x_459; +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_459); - x_463 = lean_box(0); + lean_dec_ref(x_427); + x_431 = lean_box(0); } -x_464 = lean_ctor_get(x_460, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_460, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_460, 3); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_445); + x_454 = 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; +} else { + lean_dec_ref(x_446); + x_458 = lean_box(0); +} +if (lean_is_scalar(x_458)) { + x_459 = lean_alloc_ctor(0, 4, 0); +} else { + x_459 = x_458; +} +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); +} else { + x_460 = x_454; +} +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); +} else { + x_461 = x_448; +} +lean_ctor_set(x_461, 0, x_447); +lean_ctor_set(x_461, 1, x_460); +return x_461; +} +} +} +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); -x_468 = lean_ctor_get(x_460, 5); +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); -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); - lean_ctor_release(x_460, 4); - lean_ctor_release(x_460, 5); - x_469 = x_460; -} else { - lean_dec_ref(x_460); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_461, 0); +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_461, 1); +x_471 = lean_ctor_get(x_462, 3); lean_inc(x_471); -if (lean_is_exclusive(x_461)) { - lean_ctor_release(x_461, 0); - lean_ctor_release(x_461, 1); - lean_ctor_release(x_461, 2); - x_472 = x_461; +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; } else { - lean_dec_ref(x_461); + lean_dec_ref(x_462); x_472 = lean_box(0); } +x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_472)) { - x_473 = lean_alloc_ctor(0, 3, 0); + x_474 = lean_alloc_ctor(0, 4, 0); } else { - x_473 = x_472; + x_474 = x_472; } -lean_ctor_set(x_473, 0, x_470); -lean_ctor_set(x_473, 1, x_471); -lean_ctor_set(x_473, 2, x_445); -if (lean_is_scalar(x_469)) { - x_474 = lean_alloc_ctor(0, 6, 0); -} else { - x_474 = x_469; -} -lean_ctor_set(x_474, 0, x_464); -lean_ctor_set(x_474, 1, x_465); +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_466); -lean_ctor_set(x_474, 4, x_467); -lean_ctor_set(x_474, 5, x_468); -if (lean_is_scalar(x_463)) { - x_475 = lean_alloc_ctor(0, 2, 0); -} else { - x_475 = x_463; -} -lean_ctor_set(x_475, 0, x_462); -lean_ctor_set(x_475, 1, x_474); -return x_475; -} -else -{ -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_476 = lean_ctor_get(x_459, 1); +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_476, 2); +x_477 = lean_ctor_get(x_8, 1); lean_inc(x_477); -x_478 = lean_ctor_get(x_459, 0); +x_478 = lean_ctor_get(x_8, 2); lean_inc(x_478); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_479 = x_459; -} else { - lean_dec_ref(x_459); - x_479 = lean_box(0); -} -x_480 = lean_ctor_get(x_476, 0); +x_479 = lean_ctor_get(x_8, 3); +lean_inc(x_479); +x_480 = lean_ctor_get(x_8, 4); 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; +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; } else { - lean_dec_ref(x_476); - x_485 = lean_box(0); + lean_dec_ref(x_8); + x_481 = lean_box(0); } -x_486 = lean_ctor_get(x_477, 0); +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); +} else { + x_484 = x_481; +} +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_Init_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_477, 1); +x_487 = lean_ctor_get(x_486, 2); lean_inc(x_487); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - x_488 = x_477; +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; } else { - lean_dec_ref(x_477); - x_488 = lean_box(0); + lean_dec_ref(x_485); + x_489 = lean_box(0); } -if (lean_is_scalar(x_488)) { - x_489 = lean_alloc_ctor(0, 3, 0); +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 { - x_489 = x_488; + lean_dec_ref(x_486); + x_495 = lean_box(0); } -lean_ctor_set(x_489, 0, x_486); -lean_ctor_set(x_489, 1, x_487); -lean_ctor_set(x_489, 2, x_445); -if (lean_is_scalar(x_485)) { - x_490 = lean_alloc_ctor(0, 6, 0); +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 { - x_490 = x_485; + lean_dec_ref(x_487); + x_499 = lean_box(0); } -lean_ctor_set(x_490, 0, x_480); -lean_ctor_set(x_490, 1, x_481); -lean_ctor_set(x_490, 2, x_489); -lean_ctor_set(x_490, 3, x_482); -lean_ctor_set(x_490, 4, x_483); -lean_ctor_set(x_490, 5, x_484); -if (lean_is_scalar(x_479)) { - x_491 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_499)) { + x_500 = lean_alloc_ctor(0, 4, 0); } else { - x_491 = x_479; + x_500 = x_499; } -lean_ctor_set(x_491, 0, x_478); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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_492; +uint8_t x_520; 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_492 = !lean_is_exclusive(x_261); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_275); +if (x_520 == 0) { -return x_261; +return x_275; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_261, 0); -x_494 = lean_ctor_get(x_261, 1); -lean_inc(x_494); -lean_inc(x_493); -lean_dec(x_261); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } @@ -33650,7 +34180,7 @@ return x_495; } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -33658,52 +34188,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_29); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_29); +if (x_524 == 0) { return x_29; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_29, 0); -x_498 = lean_ctor_get(x_29, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_29); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } else { -uint8_t x_500; +uint8_t x_528; 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_500 = !lean_is_exclusive(x_25); -if (x_500 == 0) +x_528 = !lean_is_exclusive(x_25); +if (x_528 == 0) { return x_25; } else { -lean_object* x_501; lean_object* x_502; lean_object* x_503; -x_501 = lean_ctor_get(x_25, 0); -x_502 = lean_ctor_get(x_25, 1); -lean_inc(x_502); -lean_inc(x_501); +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_dec(x_25); -x_503 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_503, 0, x_501); -lean_ctor_set(x_503, 1, x_502); -return x_503; +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; } } } @@ -33936,82 +34466,89 @@ return x_46; } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; +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_57 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -lean_ctor_set(x_57, 2, x_40); -lean_ctor_set(x_47, 2, x_57); +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; } } 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; -x_58 = lean_ctor_get(x_47, 0); -x_59 = lean_ctor_get(x_47, 1); -x_60 = lean_ctor_get(x_47, 3); -x_61 = lean_ctor_get(x_47, 4); -x_62 = lean_ctor_get(x_47, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +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_inc(x_58); lean_dec(x_47); -x_63 = lean_ctor_get(x_48, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_48, 1); +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); - x_65 = x_48; + lean_ctor_release(x_48, 3); + x_67 = x_48; } else { lean_dec_ref(x_48); - x_65 = lean_box(0); + x_67 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 4, 0); } else { - x_66 = x_65; + x_68 = x_67; } -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_40); -x_67 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_67, 0, x_58); -lean_ctor_set(x_67, 1, x_59); -lean_ctor_set(x_67, 2, x_66); -lean_ctor_set(x_67, 3, x_60); -lean_ctor_set(x_67, 4, x_61); -lean_ctor_set(x_67, 5, x_62); -lean_ctor_set(x_46, 1, 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_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; } } 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; -x_68 = lean_ctor_get(x_46, 0); -lean_inc(x_68); -lean_dec(x_46); -x_69 = lean_ctor_get(x_47, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_47, 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; lean_object* x_82; lean_object* x_83; +x_70 = lean_ctor_get(x_46, 0); lean_inc(x_70); -x_71 = lean_ctor_get(x_47, 3); +lean_dec(x_46); +x_71 = lean_ctor_get(x_47, 0); lean_inc(x_71); -x_72 = lean_ctor_get(x_47, 4); +x_72 = lean_ctor_get(x_47, 1); lean_inc(x_72); -x_73 = lean_ctor_get(x_47, 5); +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); @@ -34019,1877 +34556,1976 @@ if (lean_is_exclusive(x_47)) { lean_ctor_release(x_47, 3); lean_ctor_release(x_47, 4); lean_ctor_release(x_47, 5); - x_74 = x_47; + x_76 = x_47; } else { lean_dec_ref(x_47); - x_74 = lean_box(0); + x_76 = lean_box(0); } -x_75 = lean_ctor_get(x_48, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_48, 1); -lean_inc(x_76); +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); - x_77 = x_48; + lean_ctor_release(x_48, 3); + x_80 = x_48; } else { lean_dec_ref(x_48); - x_77 = lean_box(0); + x_80 = lean_box(0); } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 4, 0); } else { - x_78 = x_77; + x_81 = x_80; } -lean_ctor_set(x_78, 0, x_75); -lean_ctor_set(x_78, 1, x_76); -lean_ctor_set(x_78, 2, x_40); -if (lean_is_scalar(x_74)) { - x_79 = lean_alloc_ctor(0, 6, 0); +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_79 = x_74; + x_82 = x_76; } -lean_ctor_set(x_79, 0, x_69); -lean_ctor_set(x_79, 1, x_70); -lean_ctor_set(x_79, 2, x_78); -lean_ctor_set(x_79, 3, x_71); -lean_ctor_set(x_79, 4, x_72); -lean_ctor_set(x_79, 5, x_73); -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_68); -lean_ctor_set(x_80, 1, x_79); -return x_80; +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; } } else { -lean_object* x_81; lean_object* x_82; uint8_t x_83; -x_81 = lean_ctor_get(x_46, 1); -lean_inc(x_81); -x_82 = lean_ctor_get(x_81, 2); -lean_inc(x_82); -x_83 = !lean_is_exclusive(x_46); -if (x_83 == 0) -{ -lean_object* x_84; uint8_t x_85; +lean_object* x_84; lean_object* x_85; uint8_t x_86; x_84 = lean_ctor_get(x_46, 1); -lean_dec(x_84); -x_85 = !lean_is_exclusive(x_81); -if (x_85 == 0) +lean_inc(x_84); +x_85 = lean_ctor_get(x_84, 2); +lean_inc(x_85); +x_86 = !lean_is_exclusive(x_46); +if (x_86 == 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_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_88; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -lean_ctor_set(x_82, 2, x_40); +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_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_82, 0); -x_90 = lean_ctor_get(x_82, 1); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_82); -x_91 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_91, 0, x_89); -lean_ctor_set(x_91, 1, x_90); -lean_ctor_set(x_91, 2, x_40); -lean_ctor_set(x_81, 2, x_91); -return x_46; -} -} -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; -x_92 = lean_ctor_get(x_81, 0); -x_93 = lean_ctor_get(x_81, 1); -x_94 = lean_ctor_get(x_81, 3); -x_95 = lean_ctor_get(x_81, 4); -x_96 = lean_ctor_get(x_81, 5); -lean_inc(x_96); -lean_inc(x_95); +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_81); -x_97 = lean_ctor_get(x_82, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_82, 1); -lean_inc(x_98); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - x_99 = x_82; -} else { - lean_dec_ref(x_82); - x_99 = lean_box(0); -} -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 3, 0); -} else { - x_100 = x_99; -} -lean_ctor_set(x_100, 0, x_97); -lean_ctor_set(x_100, 1, x_98); -lean_ctor_set(x_100, 2, x_40); -x_101 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_101, 0, x_92); -lean_ctor_set(x_101, 1, x_93); -lean_ctor_set(x_101, 2, x_100); -lean_ctor_set(x_101, 3, x_94); -lean_ctor_set(x_101, 4, x_95); -lean_ctor_set(x_101, 5, x_96); -lean_ctor_set(x_46, 1, x_101); +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_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_102 = lean_ctor_get(x_46, 0); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_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); -lean_dec(x_46); -x_103 = lean_ctor_get(x_81, 0); +x_103 = lean_ctor_get(x_85, 3); lean_inc(x_103); -x_104 = lean_ctor_get(x_81, 1); -lean_inc(x_104); -x_105 = lean_ctor_get(x_81, 3); -lean_inc(x_105); -x_106 = lean_ctor_get(x_81, 4); -lean_inc(x_106); -x_107 = lean_ctor_get(x_81, 5); +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; +} else { + lean_dec_ref(x_85); + 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_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); -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_108 = x_81; -} else { - lean_dec_ref(x_81); - x_108 = lean_box(0); -} -x_109 = lean_ctor_get(x_82, 0); +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_82, 1); +x_110 = lean_ctor_get(x_84, 3); 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); - x_111 = x_82; +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; } else { - lean_dec_ref(x_82); - x_111 = lean_box(0); + lean_dec_ref(x_84); + x_113 = lean_box(0); } -if (lean_is_scalar(x_111)) { - x_112 = lean_alloc_ctor(0, 3, 0); +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 { - x_112 = x_111; + lean_dec_ref(x_85); + x_117 = lean_box(0); } -lean_ctor_set(x_112, 0, x_109); -lean_ctor_set(x_112, 1, x_110); -lean_ctor_set(x_112, 2, x_40); -if (lean_is_scalar(x_108)) { - x_113 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_117)) { + x_118 = lean_alloc_ctor(0, 4, 0); } else { - x_113 = x_108; + x_118 = x_117; } -lean_ctor_set(x_113, 0, x_103); -lean_ctor_set(x_113, 1, x_104); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_105); -lean_ctor_set(x_113, 4, x_106); -lean_ctor_set(x_113, 5, x_107); -x_114 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_114, 0, x_102); -lean_ctor_set(x_114, 1, x_113); -return x_114; +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_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_115 = lean_ctor_get(x_13, 0); -x_116 = lean_ctor_get(x_13, 1); -x_117 = lean_ctor_get(x_13, 2); -x_118 = lean_ctor_get(x_13, 3); -x_119 = lean_ctor_get(x_13, 4); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_13); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_34); -lean_ctor_set(x_120, 1, x_22); -x_121 = lean_array_push(x_117, x_120); -x_122 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_122, 0, x_115); -lean_ctor_set(x_122, 1, x_116); -lean_ctor_set(x_122, 2, x_121); -lean_ctor_set(x_122, 3, x_118); -lean_ctor_set(x_122, 4, x_119); -x_123 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_122, x_33); -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_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_124, 2); +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); -x_126 = lean_ctor_get(x_123, 0); -lean_inc(x_126); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - x_127 = x_123; -} else { - lean_dec_ref(x_123); - x_127 = lean_box(0); -} -x_128 = lean_ctor_get(x_124, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_124, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_124, 3); +lean_inc(x_124); +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_Init_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_124, 4); +x_131 = lean_ctor_get(x_130, 2); lean_inc(x_131); -x_132 = lean_ctor_get(x_124, 5); +x_132 = lean_ctor_get(x_129, 0); lean_inc(x_132); -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_133 = x_124; +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + x_133 = x_129; } else { - lean_dec_ref(x_124); + lean_dec_ref(x_129); x_133 = lean_box(0); } -x_134 = lean_ctor_get(x_125, 0); +x_134 = lean_ctor_get(x_130, 0); lean_inc(x_134); -x_135 = lean_ctor_get(x_125, 1); +x_135 = lean_ctor_get(x_130, 1); lean_inc(x_135); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - x_136 = x_125; +x_136 = lean_ctor_get(x_130, 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; } else { - lean_dec_ref(x_125); - x_136 = lean_box(0); + lean_dec_ref(x_130); + x_139 = lean_box(0); } -if (lean_is_scalar(x_136)) { - x_137 = lean_alloc_ctor(0, 3, 0); -} else { - x_137 = x_136; -} -lean_ctor_set(x_137, 0, x_134); -lean_ctor_set(x_137, 1, x_135); -lean_ctor_set(x_137, 2, x_40); -if (lean_is_scalar(x_133)) { - x_138 = lean_alloc_ctor(0, 6, 0); -} else { - x_138 = x_133; -} -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); -if (lean_is_scalar(x_127)) { - x_139 = lean_alloc_ctor(0, 2, 0); -} else { - x_139 = x_127; -} -lean_ctor_set(x_139, 0, x_126); -lean_ctor_set(x_139, 1, x_138); -return x_139; -} -else -{ -lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_140 = lean_ctor_get(x_123, 1); +x_140 = lean_ctor_get(x_131, 0); lean_inc(x_140); -x_141 = lean_ctor_get(x_140, 2); +x_141 = lean_ctor_get(x_131, 1); lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 0); +x_142 = lean_ctor_get(x_131, 3); lean_inc(x_142); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - x_143 = x_123; +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; } else { - lean_dec_ref(x_123); + lean_dec_ref(x_131); x_143 = lean_box(0); } -x_144 = lean_ctor_get(x_140, 0); -lean_inc(x_144); -x_145 = lean_ctor_get(x_140, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_140, 3); -lean_inc(x_146); -x_147 = lean_ctor_get(x_140, 4); -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; -} else { - lean_dec_ref(x_140); - x_149 = lean_box(0); -} -x_150 = lean_ctor_get(x_141, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_141, 1); -lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - x_152 = x_141; -} else { - lean_dec_ref(x_141); - x_152 = lean_box(0); -} -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 3, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_150); -lean_ctor_set(x_153, 1, x_151); -lean_ctor_set(x_153, 2, x_40); -if (lean_is_scalar(x_149)) { - x_154 = lean_alloc_ctor(0, 6, 0); -} else { - x_154 = x_149; -} -lean_ctor_set(x_154, 0, x_144); -lean_ctor_set(x_154, 1, x_145); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_146); -lean_ctor_set(x_154, 4, x_147); -lean_ctor_set(x_154, 5, x_148); if (lean_is_scalar(x_143)) { - x_155 = lean_alloc_ctor(1, 2, 0); + x_144 = lean_alloc_ctor(0, 4, 0); } else { - x_155 = x_143; + x_144 = x_143; } -lean_ctor_set(x_155, 0, x_142); -lean_ctor_set(x_155, 1, x_154); -return x_155; +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); +if (lean_is_scalar(x_133)) { + x_146 = lean_alloc_ctor(0, 2, 0); +} else { + x_146 = x_133; +} +lean_ctor_set(x_146, 0, x_132); +lean_ctor_set(x_146, 1, x_145); +return x_146; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; +x_147 = lean_ctor_get(x_129, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_147, 2); +lean_inc(x_148); +x_149 = lean_ctor_get(x_129, 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); +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; +} else { + lean_dec_ref(x_147); + x_156 = 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; +} else { + lean_dec_ref(x_148); + 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_40); +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(1, 2, 0); +} else { + x_163 = x_150; +} +lean_ctor_set(x_163, 0, x_149); +lean_ctor_set(x_163, 1, x_162); +return x_163; } } } 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; -x_156 = lean_ctor_get(x_38, 0); -x_157 = lean_ctor_get(x_38, 1); -x_158 = lean_ctor_get(x_38, 2); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_38); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_160, 0, x_156); -lean_ctor_set(x_160, 1, x_157); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_33, 2, x_160); -x_161 = lean_ctor_get(x_13, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_13, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_13, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_13, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_13, 4); +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); 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_166 = x_13; + x_175 = x_13; } else { lean_dec_ref(x_13); - x_166 = lean_box(0); + x_175 = lean_box(0); } -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_34); -lean_ctor_set(x_167, 1, x_22); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 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); } else { - x_169 = x_166; + x_178 = x_175; } -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_Init_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_169, x_33); -if (lean_obj_tag(x_170) == 0) +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_Init_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_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_171 = lean_ctor_get(x_170, 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_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_172, 1); +x_182 = lean_ctor_get(x_179, 0); lean_inc(x_182); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - lean_ctor_release(x_172, 2); - x_183 = x_172; +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_172); + lean_dec_ref(x_179); x_183 = lean_box(0); } -if (lean_is_scalar(x_183)) { - x_184 = lean_alloc_ctor(0, 3, 0); -} else { - x_184 = x_183; -} -lean_ctor_set(x_184, 0, x_181); -lean_ctor_set(x_184, 1, x_182); -lean_ctor_set(x_184, 2, x_158); -if (lean_is_scalar(x_180)) { - x_185 = lean_alloc_ctor(0, 6, 0); -} else { - x_185 = x_180; -} -lean_ctor_set(x_185, 0, x_175); -lean_ctor_set(x_185, 1, x_176); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_177); -lean_ctor_set(x_185, 4, x_178); -lean_ctor_set(x_185, 5, x_179); -if (lean_is_scalar(x_174)) { - x_186 = lean_alloc_ctor(0, 2, 0); -} else { - x_186 = x_174; -} -lean_ctor_set(x_186, 0, x_173); -lean_ctor_set(x_186, 1, x_185); -return x_186; -} -else -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_187 = lean_ctor_get(x_170, 1); +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_187, 2); +x_188 = lean_ctor_get(x_180, 5); lean_inc(x_188); -x_189 = lean_ctor_get(x_170, 0); -lean_inc(x_189); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - x_190 = x_170; +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_170); - x_190 = lean_box(0); + lean_dec_ref(x_180); + x_189 = lean_box(0); } -x_191 = lean_ctor_get(x_187, 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_187, 1); +x_192 = lean_ctor_get(x_181, 3); 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); -x_195 = lean_ctor_get(x_187, 5); -lean_inc(x_195); -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_196 = x_187; +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_187); - x_196 = lean_box(0); + lean_dec_ref(x_181); + x_193 = lean_box(0); } -x_197 = lean_ctor_get(x_188, 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; +} +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_inc(x_197); -x_198 = lean_ctor_get(x_188, 1); +x_198 = lean_ctor_get(x_197, 2); lean_inc(x_198); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - x_199 = x_188; +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; } else { - lean_dec_ref(x_188); - x_199 = lean_box(0); + lean_dec_ref(x_179); + x_200 = lean_box(0); } -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 4); +lean_inc(x_204); +x_205 = lean_ctor_get(x_197, 5); +lean_inc(x_205); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_206 = x_197; } else { - x_200 = x_199; + lean_dec_ref(x_197); + x_206 = lean_box(0); } -lean_ctor_set(x_200, 0, x_197); -lean_ctor_set(x_200, 1, x_198); -lean_ctor_set(x_200, 2, x_158); -if (lean_is_scalar(x_196)) { - x_201 = lean_alloc_ctor(0, 6, 0); +x_207 = lean_ctor_get(x_198, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_198, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_198, 3); +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; } else { - x_201 = x_196; + lean_dec_ref(x_198); + x_210 = lean_box(0); } -lean_ctor_set(x_201, 0, x_191); -lean_ctor_set(x_201, 1, x_192); -lean_ctor_set(x_201, 2, x_200); -lean_ctor_set(x_201, 3, x_193); -lean_ctor_set(x_201, 4, x_194); -lean_ctor_set(x_201, 5, x_195); -if (lean_is_scalar(x_190)) { - x_202 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 4, 0); } else { - x_202 = x_190; + x_211 = x_210; } -lean_ctor_set(x_202, 0, x_189); -lean_ctor_set(x_202, 1, x_201); -return x_202; +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); +} else { + x_212 = x_206; +} +lean_ctor_set(x_212, 0, x_201); +lean_ctor_set(x_212, 1, x_202); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_203); +lean_ctor_set(x_212, 4, x_204); +lean_ctor_set(x_212, 5, x_205); +if (lean_is_scalar(x_200)) { + x_213 = lean_alloc_ctor(1, 2, 0); +} else { + x_213 = x_200; +} +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; } } } else { -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; 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_203 = lean_ctor_get(x_33, 2); -x_204 = lean_ctor_get(x_33, 0); -x_205 = lean_ctor_get(x_33, 1); -x_206 = lean_ctor_get(x_33, 3); -x_207 = lean_ctor_get(x_33, 4); -x_208 = lean_ctor_get(x_33, 5); -lean_inc(x_208); -lean_inc(x_207); -lean_inc(x_206); -lean_inc(x_203); -lean_inc(x_205); -lean_inc(x_204); -lean_dec(x_33); -x_209 = lean_ctor_get(x_203, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_203, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_203, 2); -lean_inc(x_211); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - x_212 = x_203; -} else { - lean_dec_ref(x_203); - 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, 3, 0); -} else { - x_214 = x_212; -} -lean_ctor_set(x_214, 0, x_209); -lean_ctor_set(x_214, 1, x_210); -lean_ctor_set(x_214, 2, x_213); -x_215 = 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); -x_216 = lean_ctor_get(x_13, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_13, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_13, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_13, 3); +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); -x_220 = lean_ctor_get(x_13, 4); +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_221 = x_13; + x_233 = x_13; } else { lean_dec_ref(x_13); - x_221 = lean_box(0); + x_233 = lean_box(0); } -x_222 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_222, 0, x_34); -lean_ctor_set(x_222, 1, x_22); -x_223 = lean_array_push(x_218, x_222); -if (lean_is_scalar(x_221)) { - x_224 = lean_alloc_ctor(0, 5, 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_224 = x_221; + x_236 = x_233; } -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___at___private_Init_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_224, x_215); -if (lean_obj_tag(x_225) == 0) +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_Init_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_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; -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; +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_225); - x_229 = lean_box(0); + lean_dec_ref(x_237); + x_241 = 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; +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_226); - x_235 = lean_box(0); + lean_dec_ref(x_238); + x_247 = 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); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - lean_ctor_release(x_227, 2); - x_238 = x_227; +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_227); - x_238 = lean_box(0); + lean_dec_ref(x_239); + x_251 = lean_box(0); } -if (lean_is_scalar(x_238)) { - x_239 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_251)) { + x_252 = lean_alloc_ctor(0, 4, 0); } else { - x_239 = x_238; + x_252 = x_251; } -lean_ctor_set(x_239, 0, x_236); -lean_ctor_set(x_239, 1, x_237); -lean_ctor_set(x_239, 2, x_211); -if (lean_is_scalar(x_235)) { - x_240 = lean_alloc_ctor(0, 6, 0); +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_240 = x_235; + x_253 = x_247; } -lean_ctor_set(x_240, 0, x_230); -lean_ctor_set(x_240, 1, x_231); -lean_ctor_set(x_240, 2, x_239); -lean_ctor_set(x_240, 3, x_232); -lean_ctor_set(x_240, 4, x_233); -lean_ctor_set(x_240, 5, x_234); -if (lean_is_scalar(x_229)) { - x_241 = lean_alloc_ctor(0, 2, 0); +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_241 = x_229; + x_254 = x_241; } -lean_ctor_set(x_241, 0, x_228); -lean_ctor_set(x_241, 1, x_240); -return 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_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; -x_242 = lean_ctor_get(x_225, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_242, 2); -lean_inc(x_243); -x_244 = lean_ctor_get(x_225, 0); -lean_inc(x_244); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_245 = x_225; +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_225); - x_245 = lean_box(0); + lean_dec_ref(x_237); + x_258 = lean_box(0); } -x_246 = lean_ctor_get(x_242, 0); -lean_inc(x_246); -x_247 = lean_ctor_get(x_242, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_242, 3); -lean_inc(x_248); -x_249 = lean_ctor_get(x_242, 4); -lean_inc(x_249); -x_250 = lean_ctor_get(x_242, 5); -lean_inc(x_250); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - lean_ctor_release(x_242, 2); - lean_ctor_release(x_242, 3); - lean_ctor_release(x_242, 4); - lean_ctor_release(x_242, 5); - x_251 = x_242; +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_242); - x_251 = lean_box(0); + lean_dec_ref(x_255); + x_264 = lean_box(0); } -x_252 = lean_ctor_get(x_243, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_243, 1); -lean_inc(x_253); -if (lean_is_exclusive(x_243)) { - lean_ctor_release(x_243, 0); - lean_ctor_release(x_243, 1); - lean_ctor_release(x_243, 2); - x_254 = x_243; +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_243); - x_254 = lean_box(0); + lean_dec_ref(x_256); + x_268 = lean_box(0); } -if (lean_is_scalar(x_254)) { - x_255 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_268)) { + x_269 = lean_alloc_ctor(0, 4, 0); } else { - x_255 = x_254; + x_269 = x_268; } -lean_ctor_set(x_255, 0, x_252); -lean_ctor_set(x_255, 1, x_253); -lean_ctor_set(x_255, 2, x_211); -if (lean_is_scalar(x_251)) { - x_256 = lean_alloc_ctor(0, 6, 0); +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_256 = x_251; + x_270 = x_264; } -lean_ctor_set(x_256, 0, x_246); -lean_ctor_set(x_256, 1, x_247); -lean_ctor_set(x_256, 2, x_255); -lean_ctor_set(x_256, 3, x_248); -lean_ctor_set(x_256, 4, x_249); -lean_ctor_set(x_256, 5, x_250); -if (lean_is_scalar(x_245)) { - x_257 = lean_alloc_ctor(1, 2, 0); +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_257 = x_245; + x_271 = x_258; } -lean_ctor_set(x_257, 0, x_244); -lean_ctor_set(x_257, 1, x_256); -return x_257; +lean_ctor_set(x_271, 0, x_257); +lean_ctor_set(x_271, 1, x_270); +return x_271; } } } default: { -lean_object* x_258; lean_object* x_259; -x_258 = lean_ctor_get(x_27, 1); -lean_inc(x_258); +lean_object* x_272; lean_object* x_273; +x_272 = lean_ctor_get(x_27, 1); +lean_inc(x_272); lean_dec(x_27); lean_inc(x_13); -x_259 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_258); -if (lean_obj_tag(x_259) == 0) +x_273 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_272); +if (lean_obj_tag(x_273) == 0) { -lean_object* x_260; -x_260 = lean_ctor_get(x_259, 0); -lean_inc(x_260); -if (lean_obj_tag(x_260) == 0) +lean_object* x_274; +x_274 = lean_ctor_get(x_273, 0); +lean_inc(x_274); +if (lean_obj_tag(x_274) == 0) { -lean_object* x_261; lean_object* x_262; lean_object* x_263; +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_dec(x_22); -x_261 = lean_ctor_get(x_259, 1); -lean_inc(x_261); -lean_dec(x_259); -x_262 = lean_unsigned_to_nat(1u); -x_263 = lean_nat_add(x_12, x_262); +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); lean_dec(x_12); -x_12 = x_263; -x_14 = x_261; +x_12 = x_277; +x_14 = x_275; goto _start; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; uint8_t x_269; -x_265 = lean_ctor_get(x_259, 1); -lean_inc(x_265); -lean_dec(x_259); -x_266 = lean_ctor_get(x_260, 0); -lean_inc(x_266); -lean_dec(x_260); -x_267 = lean_unsigned_to_nat(1u); -x_268 = lean_nat_add(x_12, x_267); -lean_dec(x_12); -x_269 = !lean_is_exclusive(x_265); -if (x_269 == 0) -{ -lean_object* x_270; uint8_t x_271; -x_270 = lean_ctor_get(x_265, 2); -x_271 = !lean_is_exclusive(x_270); -if (x_271 == 0) -{ -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_270, 2); -x_273 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_270, 2, x_273); -x_274 = !lean_is_exclusive(x_13); -if (x_274 == 0) -{ -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; -x_275 = lean_ctor_get(x_13, 2); -x_276 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_22); -x_277 = lean_array_push(x_275, x_276); -lean_ctor_set(x_13, 2, x_277); -x_278 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_268, x_13, x_265); -if (lean_obj_tag(x_278) == 0) -{ -lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_279 = lean_ctor_get(x_278, 1); +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); -x_280 = lean_ctor_get(x_279, 2); +lean_dec(x_273); +x_280 = lean_ctor_get(x_274, 0); lean_inc(x_280); -x_281 = !lean_is_exclusive(x_278); -if (x_281 == 0) -{ -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_278, 1); -lean_dec(x_282); +lean_dec(x_274); +x_281 = lean_unsigned_to_nat(1u); +x_282 = lean_nat_add(x_12, x_281); +lean_dec(x_12); x_283 = !lean_is_exclusive(x_279); if (x_283 == 0) { lean_object* x_284; uint8_t x_285; x_284 = lean_ctor_get(x_279, 2); -lean_dec(x_284); -x_285 = !lean_is_exclusive(x_280); +x_285 = !lean_is_exclusive(x_284); if (x_285 == 0) { -lean_object* x_286; -x_286 = lean_ctor_get(x_280, 2); -lean_dec(x_286); -lean_ctor_set(x_280, 2, x_272); -return x_278; -} -else +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_287; lean_object* x_288; lean_object* x_289; -x_287 = lean_ctor_get(x_280, 0); -x_288 = lean_ctor_get(x_280, 1); -lean_inc(x_288); -lean_inc(x_287); -lean_dec(x_280); -x_289 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_289, 0, x_287); -lean_ctor_set(x_289, 1, x_288); -lean_ctor_set(x_289, 2, x_272); -lean_ctor_set(x_279, 2, x_289); -return x_278; -} -} -else +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_Init_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_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_290 = lean_ctor_get(x_279, 0); -x_291 = lean_ctor_get(x_279, 1); -x_292 = lean_ctor_get(x_279, 3); -x_293 = lean_ctor_get(x_279, 4); -x_294 = lean_ctor_get(x_279, 5); -lean_inc(x_294); +lean_object* x_293; lean_object* x_294; uint8_t x_295; +x_293 = lean_ctor_get(x_292, 1); lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); -lean_dec(x_279); -x_295 = lean_ctor_get(x_280, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_280, 1); -lean_inc(x_296); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - x_297 = x_280; -} else { - lean_dec_ref(x_280); - x_297 = lean_box(0); -} -if (lean_is_scalar(x_297)) { - x_298 = lean_alloc_ctor(0, 3, 0); -} else { - x_298 = x_297; -} -lean_ctor_set(x_298, 0, x_295); -lean_ctor_set(x_298, 1, x_296); -lean_ctor_set(x_298, 2, x_272); -x_299 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_299, 0, x_290); -lean_ctor_set(x_299, 1, x_291); -lean_ctor_set(x_299, 2, x_298); -lean_ctor_set(x_299, 3, x_292); -lean_ctor_set(x_299, 4, x_293); -lean_ctor_set(x_299, 5, x_294); -lean_ctor_set(x_278, 1, x_299); -return x_278; -} +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_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; -x_300 = lean_ctor_get(x_278, 0); -lean_inc(x_300); -lean_dec(x_278); -x_301 = lean_ctor_get(x_279, 0); -lean_inc(x_301); -x_302 = lean_ctor_get(x_279, 1); -lean_inc(x_302); -x_303 = lean_ctor_get(x_279, 3); +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); -x_304 = lean_ctor_get(x_279, 4); -lean_inc(x_304); -x_305 = lean_ctor_get(x_279, 5); -lean_inc(x_305); -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); - lean_ctor_release(x_279, 4); - lean_ctor_release(x_279, 5); - x_306 = x_279; -} else { - lean_dec_ref(x_279); - x_306 = lean_box(0); +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; } -x_307 = lean_ctor_get(x_280, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_280, 1); +} +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); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - x_309 = x_280; +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_inc(x_311); +x_312 = lean_ctor_get(x_294, 3); +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_280); - x_309 = lean_box(0); + lean_dec_ref(x_294); + x_313 = lean_box(0); } -if (lean_is_scalar(x_309)) { - x_310 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_313)) { + x_314 = lean_alloc_ctor(0, 4, 0); } else { - x_310 = x_309; + x_314 = x_313; } -lean_ctor_set(x_310, 0, x_307); -lean_ctor_set(x_310, 1, x_308); -lean_ctor_set(x_310, 2, x_272); -if (lean_is_scalar(x_306)) { - x_311 = lean_alloc_ctor(0, 6, 0); -} else { - x_311 = x_306; -} -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); -x_312 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_312, 0, x_300); -lean_ctor_set(x_312, 1, x_311); -return x_312; +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_313; lean_object* x_314; uint8_t x_315; -x_313 = lean_ctor_get(x_278, 1); -lean_inc(x_313); -x_314 = lean_ctor_get(x_313, 2); -lean_inc(x_314); -x_315 = !lean_is_exclusive(x_278); -if (x_315 == 0) -{ -lean_object* x_316; uint8_t x_317; -x_316 = lean_ctor_get(x_278, 1); -lean_dec(x_316); -x_317 = !lean_is_exclusive(x_313); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_313, 2); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_314); -if (x_319 == 0) -{ -lean_object* x_320; -x_320 = lean_ctor_get(x_314, 2); -lean_dec(x_320); -lean_ctor_set(x_314, 2, x_272); -return x_278; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_314, 0); -x_322 = lean_ctor_get(x_314, 1); -lean_inc(x_322); +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_inc(x_321); -lean_dec(x_314); -x_323 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_323, 0, x_321); -lean_ctor_set(x_323, 1, x_322); -lean_ctor_set(x_323, 2, x_272); -lean_ctor_set(x_313, 2, x_323); -return x_278; +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); } -} -else -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_324 = lean_ctor_get(x_313, 0); -x_325 = lean_ctor_get(x_313, 1); -x_326 = lean_ctor_get(x_313, 3); -x_327 = lean_ctor_get(x_313, 4); -x_328 = lean_ctor_get(x_313, 5); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); +x_323 = lean_ctor_get(x_294, 0); +lean_inc(x_323); +x_324 = lean_ctor_get(x_294, 1); lean_inc(x_324); -lean_dec(x_313); -x_329 = lean_ctor_get(x_314, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_314, 1); +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); -if (lean_is_exclusive(x_314)) { - lean_ctor_release(x_314, 0); - lean_ctor_release(x_314, 1); - lean_ctor_release(x_314, 2); - x_331 = x_314; -} else { - lean_dec_ref(x_314); - x_331 = lean_box(0); -} -if (lean_is_scalar(x_331)) { - x_332 = lean_alloc_ctor(0, 3, 0); -} else { - x_332 = x_331; -} -lean_ctor_set(x_332, 0, x_329); -lean_ctor_set(x_332, 1, x_330); -lean_ctor_set(x_332, 2, x_272); -x_333 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_333, 0, x_324); -lean_ctor_set(x_333, 1, x_325); -lean_ctor_set(x_333, 2, x_332); -lean_ctor_set(x_333, 3, x_326); -lean_ctor_set(x_333, 4, x_327); -lean_ctor_set(x_333, 5, x_328); -lean_ctor_set(x_278, 1, x_333); -return x_278; -} +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_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_334 = lean_ctor_get(x_278, 0); -lean_inc(x_334); -lean_dec(x_278); -x_335 = lean_ctor_get(x_313, 0); -lean_inc(x_335); -x_336 = lean_ctor_get(x_313, 1); -lean_inc(x_336); -x_337 = lean_ctor_get(x_313, 3); -lean_inc(x_337); -x_338 = lean_ctor_get(x_313, 4); -lean_inc(x_338); -x_339 = lean_ctor_get(x_313, 5); +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); -if (lean_is_exclusive(x_313)) { - lean_ctor_release(x_313, 0); - lean_ctor_release(x_313, 1); - lean_ctor_release(x_313, 2); - lean_ctor_release(x_313, 3); - lean_ctor_release(x_313, 4); - lean_ctor_release(x_313, 5); - x_340 = x_313; -} else { - lean_dec_ref(x_313); - x_340 = lean_box(0); -} -x_341 = lean_ctor_get(x_314, 0); -lean_inc(x_341); -x_342 = lean_ctor_get(x_314, 1); -lean_inc(x_342); -if (lean_is_exclusive(x_314)) { - lean_ctor_release(x_314, 0); - lean_ctor_release(x_314, 1); - lean_ctor_release(x_314, 2); - x_343 = x_314; -} else { - lean_dec_ref(x_314); - x_343 = lean_box(0); -} -if (lean_is_scalar(x_343)) { - x_344 = lean_alloc_ctor(0, 3, 0); -} else { - x_344 = x_343; -} -lean_ctor_set(x_344, 0, x_341); -lean_ctor_set(x_344, 1, x_342); -lean_ctor_set(x_344, 2, x_272); -if (lean_is_scalar(x_340)) { - x_345 = lean_alloc_ctor(0, 6, 0); -} else { - x_345 = x_340; -} -lean_ctor_set(x_345, 0, x_335); -lean_ctor_set(x_345, 1, x_336); -lean_ctor_set(x_345, 2, x_344); -lean_ctor_set(x_345, 3, x_337); -lean_ctor_set(x_345, 4, x_338); -lean_ctor_set(x_345, 5, x_339); -x_346 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_346, 0, x_334); -lean_ctor_set(x_346, 1, x_345); -return x_346; -} +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_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_347 = lean_ctor_get(x_13, 0); -x_348 = lean_ctor_get(x_13, 1); -x_349 = lean_ctor_get(x_13, 2); -x_350 = lean_ctor_get(x_13, 3); -x_351 = lean_ctor_get(x_13, 4); -lean_inc(x_351); -lean_inc(x_350); -lean_inc(x_349); -lean_inc(x_348); +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); -lean_dec(x_13); -x_352 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_352, 0, x_266); -lean_ctor_set(x_352, 1, x_22); -x_353 = lean_array_push(x_349, x_352); -x_354 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_354, 0, x_347); -lean_ctor_set(x_354, 1, x_348); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_350); -lean_ctor_set(x_354, 4, x_351); -x_355 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_268, x_354, x_265); -if (lean_obj_tag(x_355) == 0) -{ -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; -x_356 = lean_ctor_get(x_355, 1); -lean_inc(x_356); -x_357 = lean_ctor_get(x_356, 2); -lean_inc(x_357); -x_358 = lean_ctor_get(x_355, 0); -lean_inc(x_358); -if (lean_is_exclusive(x_355)) { - lean_ctor_release(x_355, 0); - lean_ctor_release(x_355, 1); - x_359 = x_355; +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_355); + 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_356, 0); +x_360 = lean_ctor_get(x_331, 0); lean_inc(x_360); -x_361 = lean_ctor_get(x_356, 1); +x_361 = lean_ctor_get(x_331, 1); lean_inc(x_361); -x_362 = lean_ctor_get(x_356, 3); +x_362 = lean_ctor_get(x_331, 3); lean_inc(x_362); -x_363 = lean_ctor_get(x_356, 4); -lean_inc(x_363); -x_364 = lean_ctor_get(x_356, 5); -lean_inc(x_364); -if (lean_is_exclusive(x_356)) { - lean_ctor_release(x_356, 0); - lean_ctor_release(x_356, 1); - lean_ctor_release(x_356, 2); - lean_ctor_release(x_356, 3); - lean_ctor_release(x_356, 4); - lean_ctor_release(x_356, 5); - x_365 = x_356; +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_356); - x_365 = lean_box(0); + lean_dec_ref(x_331); + x_363 = lean_box(0); } -x_366 = lean_ctor_get(x_357, 0); -lean_inc(x_366); -x_367 = lean_ctor_get(x_357, 1); -lean_inc(x_367); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - lean_ctor_release(x_357, 2); - x_368 = x_357; +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_357); - x_368 = lean_box(0); + x_364 = x_363; } -if (lean_is_scalar(x_368)) { - x_369 = lean_alloc_ctor(0, 3, 0); -} else { - x_369 = x_368; -} -lean_ctor_set(x_369, 0, x_366); -lean_ctor_set(x_369, 1, x_367); -lean_ctor_set(x_369, 2, x_272); -if (lean_is_scalar(x_365)) { - x_370 = lean_alloc_ctor(0, 6, 0); -} else { - x_370 = x_365; -} -lean_ctor_set(x_370, 0, x_360); -lean_ctor_set(x_370, 1, x_361); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_362); -lean_ctor_set(x_370, 4, x_363); -lean_ctor_set(x_370, 5, x_364); +lean_ctor_set(x_364, 0, x_360); +lean_ctor_set(x_364, 1, x_361); +lean_ctor_set(x_364, 2, x_286); +lean_ctor_set(x_364, 3, x_362); if (lean_is_scalar(x_359)) { - x_371 = lean_alloc_ctor(0, 2, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_371 = x_359; + 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; +} } -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; 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; -x_372 = lean_ctor_get(x_355, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_372, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_355, 0); -lean_inc(x_374); -if (lean_is_exclusive(x_355)) { - lean_ctor_release(x_355, 0); - lean_ctor_release(x_355, 1); - x_375 = x_355; -} else { - lean_dec_ref(x_355); - x_375 = lean_box(0); -} -x_376 = lean_ctor_get(x_372, 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; +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_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_Init_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) +{ +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_372, 1); +x_377 = lean_ctor_get(x_376, 2); lean_inc(x_377); -x_378 = lean_ctor_get(x_372, 3); +x_378 = lean_ctor_get(x_375, 0); lean_inc(x_378); -x_379 = lean_ctor_get(x_372, 4); -lean_inc(x_379); -x_380 = lean_ctor_get(x_372, 5); +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); -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); +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_373, 1); +x_383 = lean_ctor_get(x_376, 4); lean_inc(x_383); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - lean_ctor_release(x_373, 2); - x_384 = x_373; +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_373); - x_384 = lean_box(0); + lean_dec_ref(x_376); + x_385 = lean_box(0); } -if (lean_is_scalar(x_384)) { - x_385 = lean_alloc_ctor(0, 3, 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 { - x_385 = x_384; + lean_dec_ref(x_377); + x_389 = lean_box(0); } -lean_ctor_set(x_385, 0, x_382); -lean_ctor_set(x_385, 1, x_383); -lean_ctor_set(x_385, 2, x_272); -if (lean_is_scalar(x_381)) { - x_386 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_389)) { + x_390 = lean_alloc_ctor(0, 4, 0); } else { - x_386 = x_381; + x_390 = x_389; } -lean_ctor_set(x_386, 0, x_376); -lean_ctor_set(x_386, 1, x_377); -lean_ctor_set(x_386, 2, x_385); -lean_ctor_set(x_386, 3, x_378); -lean_ctor_set(x_386, 4, x_379); -lean_ctor_set(x_386, 5, x_380); -if (lean_is_scalar(x_375)) { - x_387 = lean_alloc_ctor(1, 2, 0); +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_387 = x_375; -} -lean_ctor_set(x_387, 0, x_374); -lean_ctor_set(x_387, 1, x_386); -return x_387; + 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; } else { -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_270, 0); -x_389 = lean_ctor_get(x_270, 1); -x_390 = lean_ctor_get(x_270, 2); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_dec(x_270); -x_391 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_392 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_392, 0, x_388); -lean_ctor_set(x_392, 1, x_389); -lean_ctor_set(x_392, 2, x_391); -lean_ctor_set(x_265, 2, x_392); -x_393 = lean_ctor_get(x_13, 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; 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_13, 1); +x_394 = lean_ctor_get(x_393, 2); lean_inc(x_394); -x_395 = lean_ctor_get(x_13, 2); +x_395 = lean_ctor_get(x_375, 0); lean_inc(x_395); -x_396 = lean_ctor_get(x_13, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_13, 4); +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); +} +x_397 = lean_ctor_get(x_393, 0); lean_inc(x_397); -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_398 = x_13; +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_13); - x_398 = lean_box(0); + lean_dec_ref(x_393); + x_402 = lean_box(0); } -x_399 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_399, 0, x_266); -lean_ctor_set(x_399, 1, x_22); -x_400 = lean_array_push(x_395, x_399); -if (lean_is_scalar(x_398)) { - x_401 = lean_alloc_ctor(0, 5, 0); -} else { - x_401 = x_398; -} -lean_ctor_set(x_401, 0, x_393); -lean_ctor_set(x_401, 1, x_394); -lean_ctor_set(x_401, 2, x_400); -lean_ctor_set(x_401, 3, x_396); -lean_ctor_set(x_401, 4, x_397); -x_402 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_268, x_401, x_265); -if (lean_obj_tag(x_402) == 0) -{ -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; lean_object* x_418; -x_403 = lean_ctor_get(x_402, 1); +x_403 = lean_ctor_get(x_394, 0); lean_inc(x_403); -x_404 = lean_ctor_get(x_403, 2); +x_404 = lean_ctor_get(x_394, 1); lean_inc(x_404); -x_405 = lean_ctor_get(x_402, 0); +x_405 = lean_ctor_get(x_394, 3); lean_inc(x_405); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - x_406 = x_402; +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; } else { - lean_dec_ref(x_402); + lean_dec_ref(x_394); x_406 = lean_box(0); } -x_407 = lean_ctor_get(x_403, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_403, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_403, 3); -lean_inc(x_409); -x_410 = lean_ctor_get(x_403, 4); -lean_inc(x_410); -x_411 = lean_ctor_get(x_403, 5); -lean_inc(x_411); -if (lean_is_exclusive(x_403)) { - lean_ctor_release(x_403, 0); - lean_ctor_release(x_403, 1); - lean_ctor_release(x_403, 2); - lean_ctor_release(x_403, 3); - lean_ctor_release(x_403, 4); - lean_ctor_release(x_403, 5); - x_412 = x_403; -} else { - lean_dec_ref(x_403); - x_412 = lean_box(0); -} -x_413 = lean_ctor_get(x_404, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_404, 1); -lean_inc(x_414); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - x_415 = x_404; -} else { - lean_dec_ref(x_404); - x_415 = lean_box(0); -} -if (lean_is_scalar(x_415)) { - x_416 = lean_alloc_ctor(0, 3, 0); -} else { - x_416 = x_415; -} -lean_ctor_set(x_416, 0, x_413); -lean_ctor_set(x_416, 1, x_414); -lean_ctor_set(x_416, 2, x_390); -if (lean_is_scalar(x_412)) { - x_417 = lean_alloc_ctor(0, 6, 0); -} else { - x_417 = x_412; -} -lean_ctor_set(x_417, 0, x_407); -lean_ctor_set(x_417, 1, x_408); -lean_ctor_set(x_417, 2, x_416); -lean_ctor_set(x_417, 3, x_409); -lean_ctor_set(x_417, 4, x_410); -lean_ctor_set(x_417, 5, x_411); if (lean_is_scalar(x_406)) { - x_418 = lean_alloc_ctor(0, 2, 0); + x_407 = lean_alloc_ctor(0, 4, 0); } else { - x_418 = x_406; + x_407 = x_406; +} +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); +} else { + x_408 = x_402; +} +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); +} else { + x_409 = x_396; +} +lean_ctor_set(x_409, 0, x_395); +lean_ctor_set(x_409, 1, x_408); +return x_409; +} } -lean_ctor_set(x_418, 0, x_405); -lean_ctor_set(x_418, 1, x_417); -return x_418; } else { -lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_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_419 = lean_ctor_get(x_402, 1); +lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; +x_410 = lean_ctor_get(x_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_419, 2); +x_420 = lean_ctor_get(x_13, 4); lean_inc(x_420); -x_421 = lean_ctor_get(x_402, 0); -lean_inc(x_421); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - x_422 = x_402; -} else { - lean_dec_ref(x_402); - x_422 = lean_box(0); -} -x_423 = lean_ctor_get(x_419, 0); -lean_inc(x_423); -x_424 = lean_ctor_get(x_419, 1); -lean_inc(x_424); -x_425 = lean_ctor_get(x_419, 3); -lean_inc(x_425); -x_426 = lean_ctor_get(x_419, 4); -lean_inc(x_426); -x_427 = lean_ctor_get(x_419, 5); -lean_inc(x_427); -if (lean_is_exclusive(x_419)) { - lean_ctor_release(x_419, 0); - lean_ctor_release(x_419, 1); - lean_ctor_release(x_419, 2); - lean_ctor_release(x_419, 3); - lean_ctor_release(x_419, 4); - lean_ctor_release(x_419, 5); - x_428 = x_419; -} else { - lean_dec_ref(x_419); - x_428 = lean_box(0); -} -x_429 = lean_ctor_get(x_420, 0); -lean_inc(x_429); -x_430 = lean_ctor_get(x_420, 1); -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); - x_431 = x_420; -} else { - lean_dec_ref(x_420); - x_431 = lean_box(0); -} -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 3, 0); -} else { - x_432 = x_431; -} -lean_ctor_set(x_432, 0, x_429); -lean_ctor_set(x_432, 1, x_430); -lean_ctor_set(x_432, 2, x_390); -if (lean_is_scalar(x_428)) { - x_433 = lean_alloc_ctor(0, 6, 0); -} else { - x_433 = x_428; -} -lean_ctor_set(x_433, 0, x_423); -lean_ctor_set(x_433, 1, x_424); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_425); -lean_ctor_set(x_433, 4, x_426); -lean_ctor_set(x_433, 5, x_427); -if (lean_is_scalar(x_422)) { - x_434 = lean_alloc_ctor(1, 2, 0); -} else { - x_434 = x_422; -} -lean_ctor_set(x_434, 0, x_421); -lean_ctor_set(x_434, 1, x_433); -return x_434; -} -} -} -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; 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_435 = lean_ctor_get(x_265, 2); -x_436 = lean_ctor_get(x_265, 0); -x_437 = lean_ctor_get(x_265, 1); -x_438 = lean_ctor_get(x_265, 3); -x_439 = lean_ctor_get(x_265, 4); -x_440 = lean_ctor_get(x_265, 5); -lean_inc(x_440); -lean_inc(x_439); -lean_inc(x_438); -lean_inc(x_435); -lean_inc(x_437); -lean_inc(x_436); -lean_dec(x_265); -x_441 = lean_ctor_get(x_435, 0); -lean_inc(x_441); -x_442 = lean_ctor_get(x_435, 1); -lean_inc(x_442); -x_443 = lean_ctor_get(x_435, 2); -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); - x_444 = x_435; -} else { - lean_dec_ref(x_435); - x_444 = lean_box(0); -} -x_445 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_444)) { - x_446 = lean_alloc_ctor(0, 3, 0); -} else { - x_446 = x_444; -} -lean_ctor_set(x_446, 0, x_441); -lean_ctor_set(x_446, 1, x_442); -lean_ctor_set(x_446, 2, x_445); -x_447 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_447, 0, x_436); -lean_ctor_set(x_447, 1, x_437); -lean_ctor_set(x_447, 2, x_446); -lean_ctor_set(x_447, 3, x_438); -lean_ctor_set(x_447, 4, x_439); -lean_ctor_set(x_447, 5, x_440); -x_448 = lean_ctor_get(x_13, 0); -lean_inc(x_448); -x_449 = lean_ctor_get(x_13, 1); -lean_inc(x_449); -x_450 = lean_ctor_get(x_13, 2); -lean_inc(x_450); -x_451 = lean_ctor_get(x_13, 3); -lean_inc(x_451); -x_452 = lean_ctor_get(x_13, 4); -lean_inc(x_452); 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_453 = x_13; + x_421 = x_13; } else { lean_dec_ref(x_13); - x_453 = lean_box(0); + x_421 = lean_box(0); } -x_454 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_454, 0, x_266); -lean_ctor_set(x_454, 1, x_22); -x_455 = lean_array_push(x_450, x_454); -if (lean_is_scalar(x_453)) { - x_456 = lean_alloc_ctor(0, 5, 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); } else { - x_456 = x_453; + x_424 = x_421; } -lean_ctor_set(x_456, 0, x_448); -lean_ctor_set(x_456, 1, x_449); -lean_ctor_set(x_456, 2, x_455); -lean_ctor_set(x_456, 3, x_451); -lean_ctor_set(x_456, 4, x_452); -x_457 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_268, x_456, x_447); -if (lean_obj_tag(x_457) == 0) +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_Init_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_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; -x_458 = lean_ctor_get(x_457, 1); -lean_inc(x_458); -x_459 = lean_ctor_get(x_458, 2); -lean_inc(x_459); -x_460 = lean_ctor_get(x_457, 0); -lean_inc(x_460); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - x_461 = x_457; +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_457); - x_461 = lean_box(0); + lean_dec_ref(x_425); + x_429 = lean_box(0); } -x_462 = lean_ctor_get(x_458, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_458, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_458, 3); -lean_inc(x_464); -x_465 = lean_ctor_get(x_458, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_443); + x_452 = 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; +} else { + lean_dec_ref(x_444); + x_456 = lean_box(0); +} +if (lean_is_scalar(x_456)) { + x_457 = lean_alloc_ctor(0, 4, 0); +} else { + x_457 = x_456; +} +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); +} else { + x_458 = x_452; +} +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); +} else { + x_459 = x_446; +} +lean_ctor_set(x_459, 0, x_445); +lean_ctor_set(x_459, 1, x_458); +return x_459; +} +} +} +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); -x_466 = lean_ctor_get(x_458, 5); +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); -if (lean_is_exclusive(x_458)) { - lean_ctor_release(x_458, 0); - lean_ctor_release(x_458, 1); - lean_ctor_release(x_458, 2); - lean_ctor_release(x_458, 3); - lean_ctor_release(x_458, 4); - lean_ctor_release(x_458, 5); - x_467 = x_458; -} else { - lean_dec_ref(x_458); - x_467 = lean_box(0); -} -x_468 = lean_ctor_get(x_459, 0); +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_459, 1); +x_469 = lean_ctor_get(x_460, 3); lean_inc(x_469); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - lean_ctor_release(x_459, 2); - x_470 = x_459; +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; } else { - lean_dec_ref(x_459); + lean_dec_ref(x_460); x_470 = lean_box(0); } +x_471 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_470)) { - x_471 = lean_alloc_ctor(0, 3, 0); + x_472 = lean_alloc_ctor(0, 4, 0); } else { - x_471 = x_470; + x_472 = x_470; } -lean_ctor_set(x_471, 0, x_468); -lean_ctor_set(x_471, 1, x_469); -lean_ctor_set(x_471, 2, x_443); -if (lean_is_scalar(x_467)) { - x_472 = lean_alloc_ctor(0, 6, 0); -} else { - x_472 = x_467; -} -lean_ctor_set(x_472, 0, x_462); -lean_ctor_set(x_472, 1, x_463); +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_464); -lean_ctor_set(x_472, 4, x_465); -lean_ctor_set(x_472, 5, x_466); -if (lean_is_scalar(x_461)) { - x_473 = lean_alloc_ctor(0, 2, 0); -} else { - x_473 = x_461; -} -lean_ctor_set(x_473, 0, x_460); -lean_ctor_set(x_473, 1, x_472); -return x_473; -} -else -{ -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; lean_object* x_489; -x_474 = lean_ctor_get(x_457, 1); +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_474, 2); +x_475 = lean_ctor_get(x_13, 1); lean_inc(x_475); -x_476 = lean_ctor_get(x_457, 0); +x_476 = lean_ctor_get(x_13, 2); lean_inc(x_476); -if (lean_is_exclusive(x_457)) { - lean_ctor_release(x_457, 0); - lean_ctor_release(x_457, 1); - x_477 = x_457; -} else { - lean_dec_ref(x_457); - x_477 = lean_box(0); -} -x_478 = lean_ctor_get(x_474, 0); +x_477 = lean_ctor_get(x_13, 3); +lean_inc(x_477); +x_478 = lean_ctor_get(x_13, 4); lean_inc(x_478); -x_479 = lean_ctor_get(x_474, 1); -lean_inc(x_479); -x_480 = lean_ctor_get(x_474, 3); -lean_inc(x_480); -x_481 = lean_ctor_get(x_474, 4); -lean_inc(x_481); -x_482 = lean_ctor_get(x_474, 5); -lean_inc(x_482); -if (lean_is_exclusive(x_474)) { - lean_ctor_release(x_474, 0); - lean_ctor_release(x_474, 1); - lean_ctor_release(x_474, 2); - lean_ctor_release(x_474, 3); - lean_ctor_release(x_474, 4); - lean_ctor_release(x_474, 5); - x_483 = x_474; +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; } else { - lean_dec_ref(x_474); - x_483 = lean_box(0); + lean_dec_ref(x_13); + x_479 = lean_box(0); } -x_484 = lean_ctor_get(x_475, 0); +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); +} else { + x_482 = x_479; +} +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_Init_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_475, 1); +x_485 = lean_ctor_get(x_484, 2); lean_inc(x_485); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - lean_ctor_release(x_475, 1); - lean_ctor_release(x_475, 2); - x_486 = x_475; +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; } else { - lean_dec_ref(x_475); - x_486 = lean_box(0); + lean_dec_ref(x_483); + x_487 = lean_box(0); } -if (lean_is_scalar(x_486)) { - x_487 = lean_alloc_ctor(0, 3, 0); +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 { - x_487 = x_486; + lean_dec_ref(x_484); + x_493 = lean_box(0); } -lean_ctor_set(x_487, 0, x_484); -lean_ctor_set(x_487, 1, x_485); -lean_ctor_set(x_487, 2, x_443); -if (lean_is_scalar(x_483)) { - x_488 = lean_alloc_ctor(0, 6, 0); +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 { - x_488 = x_483; + lean_dec_ref(x_485); + x_497 = lean_box(0); } -lean_ctor_set(x_488, 0, x_478); -lean_ctor_set(x_488, 1, x_479); -lean_ctor_set(x_488, 2, x_487); -lean_ctor_set(x_488, 3, x_480); -lean_ctor_set(x_488, 4, x_481); -lean_ctor_set(x_488, 5, x_482); -if (lean_is_scalar(x_477)) { - x_489 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_497)) { + x_498 = lean_alloc_ctor(0, 4, 0); } else { - x_489 = x_477; + x_498 = x_497; } -lean_ctor_set(x_489, 0, x_476); -lean_ctor_set(x_489, 1, x_488); -return x_489; +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_490; +uint8_t x_518; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -35900,23 +36536,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_490 = !lean_is_exclusive(x_259); -if (x_490 == 0) +x_518 = !lean_is_exclusive(x_273); +if (x_518 == 0) { -return x_259; +return x_273; } else { -lean_object* x_491; lean_object* x_492; lean_object* x_493; -x_491 = lean_ctor_get(x_259, 0); -x_492 = lean_ctor_get(x_259, 1); -lean_inc(x_492); -lean_inc(x_491); -lean_dec(x_259); -x_493 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_493, 0, x_491); -lean_ctor_set(x_493, 1, x_492); -return x_493; +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; } } } @@ -35924,7 +36560,7 @@ return x_493; } else { -uint8_t x_494; +uint8_t x_522; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -35936,29 +36572,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_494 = !lean_is_exclusive(x_27); -if (x_494 == 0) +x_522 = !lean_is_exclusive(x_27); +if (x_522 == 0) { return x_27; } else { -lean_object* x_495; lean_object* x_496; lean_object* x_497; -x_495 = lean_ctor_get(x_27, 0); -x_496 = lean_ctor_get(x_27, 1); -lean_inc(x_496); -lean_inc(x_495); +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_dec(x_27); -x_497 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_497, 0, x_495); -lean_ctor_set(x_497, 1, x_496); -return x_497; +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; } } } else { -uint8_t x_498; +uint8_t x_526; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -35969,23 +36605,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_498 = !lean_is_exclusive(x_23); -if (x_498 == 0) +x_526 = !lean_is_exclusive(x_23); +if (x_526 == 0) { return x_23; } else { -lean_object* x_499; lean_object* x_500; lean_object* x_501; -x_499 = lean_ctor_get(x_23, 0); -x_500 = lean_ctor_get(x_23, 1); -lean_inc(x_500); -lean_inc(x_499); +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_dec(x_23); -x_501 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_501, 0, x_499); -lean_ctor_set(x_501, 1, x_500); -return x_501; +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; } } } @@ -36165,82 +36801,89 @@ return x_48; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; +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_59 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -lean_ctor_set(x_59, 2, x_42); -lean_ctor_set(x_49, 2, x_59); +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; } } 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; -x_60 = lean_ctor_get(x_49, 0); -x_61 = lean_ctor_get(x_49, 1); -x_62 = lean_ctor_get(x_49, 3); -x_63 = lean_ctor_get(x_49, 4); -x_64 = lean_ctor_get(x_49, 5); +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_inc(x_62); lean_inc(x_61); -lean_inc(x_60); lean_dec(x_49); -x_65 = lean_ctor_get(x_50, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_50, 1); +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); - x_67 = x_50; + lean_ctor_release(x_50, 3); + x_69 = x_50; } else { lean_dec_ref(x_50); - x_67 = lean_box(0); + x_69 = lean_box(0); } -if (lean_is_scalar(x_67)) { - x_68 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_68 = x_67; + x_70 = x_69; } -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_42); -x_69 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_69, 0, x_60); -lean_ctor_set(x_69, 1, x_61); -lean_ctor_set(x_69, 2, x_68); -lean_ctor_set(x_69, 3, x_62); -lean_ctor_set(x_69, 4, x_63); -lean_ctor_set(x_69, 5, x_64); -lean_ctor_set(x_48, 1, x_69); +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; } } 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; -x_70 = lean_ctor_get(x_48, 0); -lean_inc(x_70); -lean_dec(x_48); -x_71 = lean_ctor_get(x_49, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_49, 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; lean_object* x_84; lean_object* x_85; +x_72 = lean_ctor_get(x_48, 0); lean_inc(x_72); -x_73 = lean_ctor_get(x_49, 3); +lean_dec(x_48); +x_73 = lean_ctor_get(x_49, 0); lean_inc(x_73); -x_74 = lean_ctor_get(x_49, 4); +x_74 = lean_ctor_get(x_49, 1); lean_inc(x_74); -x_75 = lean_ctor_get(x_49, 5); +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); @@ -36248,1900 +36891,1999 @@ if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 3); lean_ctor_release(x_49, 4); lean_ctor_release(x_49, 5); - x_76 = x_49; + x_78 = x_49; } else { lean_dec_ref(x_49); - x_76 = lean_box(0); + x_78 = lean_box(0); } -x_77 = lean_ctor_get(x_50, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_50, 1); -lean_inc(x_78); +x_79 = lean_ctor_get(x_50, 0); +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); - x_79 = x_50; + lean_ctor_release(x_50, 3); + x_82 = x_50; } else { lean_dec_ref(x_50); - x_79 = lean_box(0); + x_82 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 4, 0); } else { - x_80 = x_79; + x_83 = x_82; } -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_42); -if (lean_is_scalar(x_76)) { - x_81 = lean_alloc_ctor(0, 6, 0); +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_81 = x_76; + x_84 = x_78; } -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); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_70); -lean_ctor_set(x_82, 1, x_81); -return x_82; +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; } } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_48, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_48); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; +lean_object* x_86; lean_object* x_87; uint8_t x_88; x_86 = lean_ctor_get(x_48, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_83); -if (x_87 == 0) +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = !lean_is_exclusive(x_48); +if (x_88 == 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_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_90; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -lean_ctor_set(x_84, 2, x_42); +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_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_84, 0); -x_92 = lean_ctor_get(x_84, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_84); -x_93 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -lean_ctor_set(x_93, 2, x_42); -lean_ctor_set(x_83, 2, x_93); -return x_48; -} -} -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; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -x_97 = lean_ctor_get(x_83, 4); -x_98 = lean_ctor_get(x_83, 5); -lean_inc(x_98); -lean_inc(x_97); +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_83); -x_99 = lean_ctor_get(x_84, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_84, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_101 = x_84; -} else { - lean_dec_ref(x_84); - x_101 = lean_box(0); -} -if (lean_is_scalar(x_101)) { - x_102 = lean_alloc_ctor(0, 3, 0); -} else { - x_102 = x_101; -} -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_102, 2, x_42); -x_103 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_103, 0, x_94); -lean_ctor_set(x_103, 1, x_95); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_97); -lean_ctor_set(x_103, 5, x_98); -lean_ctor_set(x_48, 1, x_103); +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_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_104 = lean_ctor_get(x_48, 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; +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); -lean_dec(x_48); -x_105 = lean_ctor_get(x_83, 0); +x_105 = lean_ctor_get(x_87, 3); lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 1); -lean_inc(x_106); -x_107 = lean_ctor_get(x_83, 3); -lean_inc(x_107); -x_108 = lean_ctor_get(x_83, 4); -lean_inc(x_108); -x_109 = lean_ctor_get(x_83, 5); +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; +} else { + lean_dec_ref(x_87); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 4, 0); +} else { + x_107 = x_106; +} +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); -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_110 = x_83; -} else { - lean_dec_ref(x_83); - x_110 = lean_box(0); -} -x_111 = lean_ctor_get(x_84, 0); +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_84, 1); +x_112 = lean_ctor_get(x_86, 3); 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); - x_113 = x_84; +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; } else { - lean_dec_ref(x_84); - x_113 = lean_box(0); + lean_dec_ref(x_86); + x_115 = lean_box(0); } -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 3, 0); +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 { - x_114 = x_113; + lean_dec_ref(x_87); + x_119 = lean_box(0); } -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_42); -if (lean_is_scalar(x_110)) { - x_115 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 4, 0); } else { - x_115 = x_110; + x_120 = x_119; } -lean_ctor_set(x_115, 0, x_105); -lean_ctor_set(x_115, 1, x_106); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_107); -lean_ctor_set(x_115, 4, x_108); -lean_ctor_set(x_115, 5, x_109); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_104); -lean_ctor_set(x_116, 1, x_115); -return x_116; +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_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_8, 0); -x_118 = lean_ctor_get(x_8, 1); -x_119 = lean_ctor_get(x_8, 2); -x_120 = lean_ctor_get(x_8, 3); -x_121 = lean_ctor_get(x_8, 4); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_8); -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_36); -lean_ctor_set(x_122, 1, x_24); -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___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_124, x_35); -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; -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_126, 2); +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); -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; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_126, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 3); +lean_inc(x_126); +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_Init_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_126, 4); +x_133 = lean_ctor_get(x_132, 2); lean_inc(x_133); -x_134 = lean_ctor_get(x_126, 5); +x_134 = lean_ctor_get(x_131, 0); 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_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; } else { - lean_dec_ref(x_126); + lean_dec_ref(x_131); x_135 = lean_box(0); } -x_136 = lean_ctor_get(x_127, 0); +x_136 = lean_ctor_get(x_132, 0); lean_inc(x_136); -x_137 = lean_ctor_get(x_127, 1); +x_137 = lean_ctor_get(x_132, 1); lean_inc(x_137); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - x_138 = x_127; +x_138 = lean_ctor_get(x_132, 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; } else { - lean_dec_ref(x_127); - x_138 = lean_box(0); + lean_dec_ref(x_132); + x_141 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(0, 3, 0); -} else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -lean_ctor_set(x_139, 2, x_42); -if (lean_is_scalar(x_135)) { - x_140 = lean_alloc_ctor(0, 6, 0); -} else { - x_140 = x_135; -} -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); -if (lean_is_scalar(x_129)) { - x_141 = lean_alloc_ctor(0, 2, 0); -} else { - x_141 = x_129; -} -lean_ctor_set(x_141, 0, x_128); -lean_ctor_set(x_141, 1, x_140); -return x_141; -} -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; -x_142 = lean_ctor_get(x_125, 1); +x_142 = lean_ctor_get(x_133, 0); lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); +x_143 = lean_ctor_get(x_133, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 0); +x_144 = lean_ctor_get(x_133, 3); lean_inc(x_144); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_145 = x_125; +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; } else { - lean_dec_ref(x_125); + lean_dec_ref(x_133); x_145 = lean_box(0); } -x_146 = lean_ctor_get(x_142, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 3); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 4); -lean_inc(x_149); -x_150 = lean_ctor_get(x_142, 5); -lean_inc(x_150); -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_151 = x_142; -} else { - lean_dec_ref(x_142); - x_151 = lean_box(0); -} -x_152 = lean_ctor_get(x_143, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 3, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -lean_ctor_set(x_155, 2, x_42); -if (lean_is_scalar(x_151)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_151; -} -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); if (lean_is_scalar(x_145)) { - x_157 = lean_alloc_ctor(1, 2, 0); + x_146 = lean_alloc_ctor(0, 4, 0); } else { - x_157 = x_145; + x_146 = x_145; } -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; +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); +if (lean_is_scalar(x_135)) { + x_148 = lean_alloc_ctor(0, 2, 0); +} else { + x_148 = x_135; +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_149 = lean_ctor_get(x_131, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_149, 2); +lean_inc(x_150); +x_151 = lean_ctor_get(x_131, 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); +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_42); +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(1, 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_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_40, 0); -x_159 = lean_ctor_get(x_40, 1); -x_160 = lean_ctor_get(x_40, 2); -lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_dec(x_40); -x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_162 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_162, 0, x_158); -lean_ctor_set(x_162, 1, x_159); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_35, 2, x_162); -x_163 = lean_ctor_get(x_8, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 1); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 2); -lean_inc(x_165); -x_166 = lean_ctor_get(x_8, 3); -lean_inc(x_166); -x_167 = lean_ctor_get(x_8, 4); +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); 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_168 = x_8; + x_177 = x_8; } else { lean_dec_ref(x_8); - x_168 = lean_box(0); + x_177 = lean_box(0); } -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_36); -lean_ctor_set(x_169, 1, x_24); -x_170 = lean_array_push(x_165, x_169); -if (lean_is_scalar(x_168)) { - x_171 = lean_alloc_ctor(0, 5, 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); } else { - x_171 = x_168; + x_180 = x_177; } -lean_ctor_set(x_171, 0, x_163); -lean_ctor_set(x_171, 1, x_164); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_166); -lean_ctor_set(x_171, 4, x_167); -x_172 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_171, x_35); -if (lean_obj_tag(x_172) == 0) +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_Init_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_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_173 = lean_ctor_get(x_172, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_173, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_172, 0); -lean_inc(x_175); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_176 = x_172; -} else { - lean_dec_ref(x_172); - 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_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_174, 1); +x_184 = lean_ctor_get(x_181, 0); lean_inc(x_184); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - x_185 = x_174; +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_174); + lean_dec_ref(x_181); x_185 = lean_box(0); } -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(0, 3, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -lean_ctor_set(x_186, 2, x_160); -if (lean_is_scalar(x_182)) { - x_187 = lean_alloc_ctor(0, 6, 0); -} else { - x_187 = x_182; -} -lean_ctor_set(x_187, 0, x_177); -lean_ctor_set(x_187, 1, x_178); -lean_ctor_set(x_187, 2, x_186); -lean_ctor_set(x_187, 3, x_179); -lean_ctor_set(x_187, 4, x_180); -lean_ctor_set(x_187, 5, x_181); -if (lean_is_scalar(x_176)) { - x_188 = lean_alloc_ctor(0, 2, 0); -} else { - x_188 = x_176; -} -lean_ctor_set(x_188, 0, x_175); -lean_ctor_set(x_188, 1, x_187); -return x_188; -} -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; -x_189 = lean_ctor_get(x_172, 1); +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_189, 2); +x_190 = lean_ctor_get(x_182, 5); lean_inc(x_190); -x_191 = lean_ctor_get(x_172, 0); -lean_inc(x_191); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - x_192 = x_172; +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_172); - x_192 = lean_box(0); + lean_dec_ref(x_182); + x_191 = lean_box(0); } -x_193 = lean_ctor_get(x_189, 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_189, 1); +x_194 = lean_ctor_get(x_183, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_189, 5); -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; +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_189); - x_198 = lean_box(0); + lean_dec_ref(x_183); + x_195 = lean_box(0); } -x_199 = lean_ctor_get(x_190, 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; +} +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_inc(x_199); -x_200 = lean_ctor_get(x_190, 1); +x_200 = lean_ctor_get(x_199, 2); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - x_201 = x_190; +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; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_181); + x_202 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_205); +x_206 = lean_ctor_get(x_199, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_199, 5); +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 { - x_202 = x_201; + lean_dec_ref(x_199); + x_208 = lean_box(0); } -lean_ctor_set(x_202, 0, x_199); -lean_ctor_set(x_202, 1, x_200); -lean_ctor_set(x_202, 2, x_160); -if (lean_is_scalar(x_198)) { - x_203 = lean_alloc_ctor(0, 6, 0); +x_209 = lean_ctor_get(x_200, 0); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 1); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 3); +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; } else { - x_203 = x_198; + lean_dec_ref(x_200); + x_212 = lean_box(0); } -lean_ctor_set(x_203, 0, x_193); -lean_ctor_set(x_203, 1, x_194); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_195); -lean_ctor_set(x_203, 4, x_196); -lean_ctor_set(x_203, 5, x_197); -if (lean_is_scalar(x_192)) { - x_204 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 4, 0); } else { - x_204 = x_192; + x_213 = x_212; } -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +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); +} 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_202)) { + x_215 = lean_alloc_ctor(1, 2, 0); +} else { + x_215 = x_202; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } 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; -x_205 = lean_ctor_get(x_35, 2); -x_206 = lean_ctor_get(x_35, 0); -x_207 = lean_ctor_get(x_35, 1); -x_208 = lean_ctor_get(x_35, 3); -x_209 = lean_ctor_get(x_35, 4); -x_210 = lean_ctor_get(x_35, 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_35); -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); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - x_214 = x_205; -} else { - lean_dec_ref(x_205); - x_214 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 3, 0); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_211); -lean_ctor_set(x_216, 1, x_212); -lean_ctor_set(x_216, 2, x_215); -x_217 = lean_alloc_ctor(0, 6, 0); -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); -x_218 = lean_ctor_get(x_8, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_8, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_8, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_8, 3); +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); -x_222 = lean_ctor_get(x_8, 4); +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_223 = x_8; + x_235 = x_8; } else { lean_dec_ref(x_8); - x_223 = lean_box(0); + x_235 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_36); -lean_ctor_set(x_224, 1, x_24); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { - x_226 = lean_alloc_ctor(0, 5, 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_226 = x_223; + x_238 = x_235; } -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___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_38, x_226, x_217); -if (lean_obj_tag(x_227) == 0) +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_Init_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_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_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_228, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_227, 0); -lean_inc(x_230); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_231 = x_227; +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_227); - x_231 = lean_box(0); + lean_dec_ref(x_239); + x_243 = lean_box(0); } -x_232 = lean_ctor_get(x_228, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); -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; +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_228); - x_237 = lean_box(0); + lean_dec_ref(x_240); + x_249 = 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); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - x_240 = x_229; +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_229); - x_240 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 4, 0); } else { - x_241 = x_240; + x_254 = x_253; } -lean_ctor_set(x_241, 0, x_238); -lean_ctor_set(x_241, 1, x_239); -lean_ctor_set(x_241, 2, x_213); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(0, 6, 0); +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_242 = x_237; + x_255 = x_249; } -lean_ctor_set(x_242, 0, x_232); -lean_ctor_set(x_242, 1, x_233); -lean_ctor_set(x_242, 2, x_241); -lean_ctor_set(x_242, 3, x_234); -lean_ctor_set(x_242, 4, x_235); -lean_ctor_set(x_242, 5, x_236); -if (lean_is_scalar(x_231)) { - x_243 = lean_alloc_ctor(0, 2, 0); +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_243 = x_231; + x_256 = x_243; } -lean_ctor_set(x_243, 0, x_230); -lean_ctor_set(x_243, 1, x_242); -return 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_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_244 = lean_ctor_get(x_227, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_244, 2); -lean_inc(x_245); -x_246 = lean_ctor_get(x_227, 0); -lean_inc(x_246); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_247 = x_227; +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_227); - x_247 = lean_box(0); + lean_dec_ref(x_239); + x_260 = lean_box(0); } -x_248 = lean_ctor_get(x_244, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_244, 1); -lean_inc(x_249); -x_250 = lean_ctor_get(x_244, 3); -lean_inc(x_250); -x_251 = lean_ctor_get(x_244, 4); -lean_inc(x_251); -x_252 = lean_ctor_get(x_244, 5); -lean_inc(x_252); -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_253 = x_244; +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_244); - x_253 = lean_box(0); + lean_dec_ref(x_257); + x_266 = lean_box(0); } -x_254 = lean_ctor_get(x_245, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 1); -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); - x_256 = x_245; +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_245); - x_256 = lean_box(0); + lean_dec_ref(x_258); + x_270 = lean_box(0); } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_270)) { + x_271 = lean_alloc_ctor(0, 4, 0); } else { - x_257 = x_256; + x_271 = x_270; } -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_213); -if (lean_is_scalar(x_253)) { - x_258 = lean_alloc_ctor(0, 6, 0); +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_258 = x_253; + x_272 = x_266; } -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_249); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_250); -lean_ctor_set(x_258, 4, x_251); -lean_ctor_set(x_258, 5, x_252); -if (lean_is_scalar(x_247)) { - x_259 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_261); +lean_ctor_set(x_272, 1, x_262); +lean_ctor_set(x_272, 2, x_271); +lean_ctor_set(x_272, 3, x_263); +lean_ctor_set(x_272, 4, x_264); +lean_ctor_set(x_272, 5, x_265); +if (lean_is_scalar(x_260)) { + x_273 = lean_alloc_ctor(1, 2, 0); } else { - x_259 = x_247; + x_273 = x_260; } -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; } } } default: { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_29, 1); -lean_inc(x_260); +lean_object* x_274; lean_object* x_275; +x_274 = lean_ctor_get(x_29, 1); +lean_inc(x_274); lean_dec(x_29); lean_inc(x_8); -x_261 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_260); -if (lean_obj_tag(x_261) == 0) +x_275 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_274); +if (lean_obj_tag(x_275) == 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_276; +x_276 = lean_ctor_get(x_275, 0); +lean_inc(x_276); +if (lean_obj_tag(x_276) == 0) { -lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_dec(x_24); -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_7, x_264); +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); lean_dec(x_7); -x_7 = x_265; -x_9 = x_263; +x_7 = x_279; +x_9 = x_277; 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_7, x_269); -lean_dec(x_7); -x_271 = !lean_is_exclusive(x_267); -if (x_271 == 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_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_8); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_8, 2); -x_278 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_24); -x_279 = lean_array_push(x_277, x_278); -lean_ctor_set(x_8, 2, x_279); -x_280 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_8, x_267); -if (lean_obj_tag(x_280) == 0) -{ -lean_object* x_281; lean_object* x_282; uint8_t x_283; -x_281 = lean_ctor_get(x_280, 1); +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); -x_282 = lean_ctor_get(x_281, 2); +lean_dec(x_275); +x_282 = lean_ctor_get(x_276, 0); 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); +lean_dec(x_276); +x_283 = lean_unsigned_to_nat(1u); +x_284 = lean_nat_add(x_7, x_283); +lean_dec(x_7); 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); +x_287 = !lean_is_exclusive(x_286); 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_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_289; lean_object* x_290; lean_object* x_291; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_282); -x_291 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_291, 0, x_289); -lean_ctor_set(x_291, 1, x_290); -lean_ctor_set(x_291, 2, x_274); -lean_ctor_set(x_281, 2, x_291); -return x_280; -} -} -else +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_Init_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_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_292 = lean_ctor_get(x_281, 0); -x_293 = lean_ctor_get(x_281, 1); -x_294 = lean_ctor_get(x_281, 3); -x_295 = lean_ctor_get(x_281, 4); -x_296 = lean_ctor_get(x_281, 5); -lean_inc(x_296); +lean_object* x_295; lean_object* x_296; uint8_t x_297; +x_295 = lean_ctor_get(x_294, 1); lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_281); -x_297 = lean_ctor_get(x_282, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_282, 1); -lean_inc(x_298); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_299 = x_282; -} else { - lean_dec_ref(x_282); - x_299 = lean_box(0); -} -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 3, 0); -} else { - x_300 = x_299; -} -lean_ctor_set(x_300, 0, x_297); -lean_ctor_set(x_300, 1, x_298); -lean_ctor_set(x_300, 2, x_274); -x_301 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_301, 0, x_292); -lean_ctor_set(x_301, 1, x_293); -lean_ctor_set(x_301, 2, x_300); -lean_ctor_set(x_301, 3, x_294); -lean_ctor_set(x_301, 4, x_295); -lean_ctor_set(x_301, 5, x_296); -lean_ctor_set(x_280, 1, x_301); -return x_280; -} +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_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_302 = lean_ctor_get(x_280, 0); -lean_inc(x_302); -lean_dec(x_280); -x_303 = lean_ctor_get(x_281, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_281, 1); -lean_inc(x_304); -x_305 = lean_ctor_get(x_281, 3); +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); -x_306 = lean_ctor_get(x_281, 4); -lean_inc(x_306); -x_307 = lean_ctor_get(x_281, 5); -lean_inc(x_307); -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_308 = x_281; -} else { - lean_dec_ref(x_281); - x_308 = lean_box(0); +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; } -x_309 = lean_ctor_get(x_282, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_282, 1); +} +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); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - x_311 = x_282; +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_inc(x_313); +x_314 = lean_ctor_get(x_296, 3); +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_282); - x_311 = lean_box(0); + lean_dec_ref(x_296); + x_315 = lean_box(0); } -if (lean_is_scalar(x_311)) { - x_312 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_315)) { + x_316 = lean_alloc_ctor(0, 4, 0); } else { - x_312 = x_311; + x_316 = x_315; } -lean_ctor_set(x_312, 0, x_309); -lean_ctor_set(x_312, 1, x_310); -lean_ctor_set(x_312, 2, x_274); -if (lean_is_scalar(x_308)) { - x_313 = lean_alloc_ctor(0, 6, 0); -} else { - x_313 = x_308; -} -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); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_302); -lean_ctor_set(x_314, 1, x_313); -return x_314; +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_315; lean_object* x_316; uint8_t x_317; -x_315 = lean_ctor_get(x_280, 1); -lean_inc(x_315); -x_316 = lean_ctor_get(x_315, 2); -lean_inc(x_316); -x_317 = !lean_is_exclusive(x_280); -if (x_317 == 0) -{ -lean_object* x_318; uint8_t x_319; -x_318 = lean_ctor_get(x_280, 1); -lean_dec(x_318); -x_319 = !lean_is_exclusive(x_315); -if (x_319 == 0) -{ -lean_object* x_320; uint8_t x_321; -x_320 = lean_ctor_get(x_315, 2); -lean_dec(x_320); -x_321 = !lean_is_exclusive(x_316); -if (x_321 == 0) -{ -lean_object* x_322; -x_322 = lean_ctor_get(x_316, 2); -lean_dec(x_322); -lean_ctor_set(x_316, 2, x_274); -return x_280; -} -else -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_323 = lean_ctor_get(x_316, 0); -x_324 = lean_ctor_get(x_316, 1); -lean_inc(x_324); +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_inc(x_323); -lean_dec(x_316); -x_325 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_325, 0, x_323); -lean_ctor_set(x_325, 1, x_324); -lean_ctor_set(x_325, 2, x_274); -lean_ctor_set(x_315, 2, x_325); -return x_280; +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); } -} -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; -x_326 = lean_ctor_get(x_315, 0); -x_327 = lean_ctor_get(x_315, 1); -x_328 = lean_ctor_get(x_315, 3); -x_329 = lean_ctor_get(x_315, 4); -x_330 = lean_ctor_get(x_315, 5); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_inc(x_327); +x_325 = lean_ctor_get(x_296, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_296, 1); lean_inc(x_326); -lean_dec(x_315); -x_331 = lean_ctor_get(x_316, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_316, 1); +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); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_333 = x_316; -} else { - lean_dec_ref(x_316); - x_333 = lean_box(0); -} -if (lean_is_scalar(x_333)) { - x_334 = lean_alloc_ctor(0, 3, 0); -} else { - x_334 = x_333; -} -lean_ctor_set(x_334, 0, x_331); -lean_ctor_set(x_334, 1, x_332); -lean_ctor_set(x_334, 2, x_274); -x_335 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_335, 0, x_326); -lean_ctor_set(x_335, 1, x_327); -lean_ctor_set(x_335, 2, x_334); -lean_ctor_set(x_335, 3, x_328); -lean_ctor_set(x_335, 4, x_329); -lean_ctor_set(x_335, 5, x_330); -lean_ctor_set(x_280, 1, x_335); -return x_280; -} +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_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_336 = lean_ctor_get(x_280, 0); -lean_inc(x_336); -lean_dec(x_280); -x_337 = lean_ctor_get(x_315, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_315, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_315, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_315, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_315, 5); +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); -if (lean_is_exclusive(x_315)) { - lean_ctor_release(x_315, 0); - lean_ctor_release(x_315, 1); - lean_ctor_release(x_315, 2); - lean_ctor_release(x_315, 3); - lean_ctor_release(x_315, 4); - lean_ctor_release(x_315, 5); - x_342 = x_315; -} else { - lean_dec_ref(x_315); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_316, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_316, 1); -lean_inc(x_344); -if (lean_is_exclusive(x_316)) { - lean_ctor_release(x_316, 0); - lean_ctor_release(x_316, 1); - lean_ctor_release(x_316, 2); - x_345 = x_316; -} else { - lean_dec_ref(x_316); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 3, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_343); -lean_ctor_set(x_346, 1, x_344); -lean_ctor_set(x_346, 2, x_274); -if (lean_is_scalar(x_342)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_342; -} -lean_ctor_set(x_347, 0, x_337); -lean_ctor_set(x_347, 1, x_338); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_339); -lean_ctor_set(x_347, 4, x_340); -lean_ctor_set(x_347, 5, x_341); -x_348 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_348, 0, x_336); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} +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_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_349 = lean_ctor_get(x_8, 0); -x_350 = lean_ctor_get(x_8, 1); -x_351 = lean_ctor_get(x_8, 2); -x_352 = lean_ctor_get(x_8, 3); -x_353 = lean_ctor_get(x_8, 4); -lean_inc(x_353); -lean_inc(x_352); -lean_inc(x_351); -lean_inc(x_350); +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); -lean_dec(x_8); -x_354 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_354, 0, x_268); -lean_ctor_set(x_354, 1, x_24); -x_355 = lean_array_push(x_351, x_354); -x_356 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_356, 0, x_349); -lean_ctor_set(x_356, 1, x_350); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_352); -lean_ctor_set(x_356, 4, x_353); -x_357 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_356, x_267); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; -x_358 = lean_ctor_get(x_357, 1); -lean_inc(x_358); -x_359 = lean_ctor_get(x_358, 2); -lean_inc(x_359); -x_360 = lean_ctor_get(x_357, 0); -lean_inc(x_360); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_361 = x_357; +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_357); + 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_358, 0); +x_362 = lean_ctor_get(x_333, 0); lean_inc(x_362); -x_363 = lean_ctor_get(x_358, 1); +x_363 = lean_ctor_get(x_333, 1); lean_inc(x_363); -x_364 = lean_ctor_get(x_358, 3); +x_364 = lean_ctor_get(x_333, 3); lean_inc(x_364); -x_365 = lean_ctor_get(x_358, 4); -lean_inc(x_365); -x_366 = lean_ctor_get(x_358, 5); -lean_inc(x_366); -if (lean_is_exclusive(x_358)) { - lean_ctor_release(x_358, 0); - lean_ctor_release(x_358, 1); - lean_ctor_release(x_358, 2); - lean_ctor_release(x_358, 3); - lean_ctor_release(x_358, 4); - lean_ctor_release(x_358, 5); - x_367 = x_358; +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_358); - x_367 = lean_box(0); + lean_dec_ref(x_333); + x_365 = lean_box(0); } -x_368 = lean_ctor_get(x_359, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_359, 1); -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); - x_370 = x_359; +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_359); - x_370 = lean_box(0); + x_366 = x_365; } -if (lean_is_scalar(x_370)) { - x_371 = lean_alloc_ctor(0, 3, 0); -} else { - x_371 = x_370; -} -lean_ctor_set(x_371, 0, x_368); -lean_ctor_set(x_371, 1, x_369); -lean_ctor_set(x_371, 2, x_274); -if (lean_is_scalar(x_367)) { - x_372 = lean_alloc_ctor(0, 6, 0); -} else { - x_372 = x_367; -} -lean_ctor_set(x_372, 0, x_362); -lean_ctor_set(x_372, 1, x_363); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_364); -lean_ctor_set(x_372, 4, x_365); -lean_ctor_set(x_372, 5, x_366); +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_373 = lean_alloc_ctor(0, 2, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_373 = x_361; + 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; +} } -lean_ctor_set(x_373, 0, x_360); -lean_ctor_set(x_373, 1, x_372); -return x_373; } else { -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_374 = lean_ctor_get(x_357, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_374, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_357, 0); -lean_inc(x_376); -if (lean_is_exclusive(x_357)) { - lean_ctor_release(x_357, 0); - lean_ctor_release(x_357, 1); - x_377 = x_357; -} else { - lean_dec_ref(x_357); - x_377 = lean_box(0); -} -x_378 = lean_ctor_get(x_374, 0); +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_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_Init_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) +{ +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_374, 1); +x_379 = lean_ctor_get(x_378, 2); lean_inc(x_379); -x_380 = lean_ctor_get(x_374, 3); +x_380 = lean_ctor_get(x_377, 0); lean_inc(x_380); -x_381 = lean_ctor_get(x_374, 4); -lean_inc(x_381); -x_382 = lean_ctor_get(x_374, 5); +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); -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); +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_375, 1); +x_385 = lean_ctor_get(x_378, 4); lean_inc(x_385); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - lean_ctor_release(x_375, 2); - x_386 = x_375; +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_375); - x_386 = lean_box(0); + lean_dec_ref(x_378); + x_387 = lean_box(0); } -if (lean_is_scalar(x_386)) { - x_387 = lean_alloc_ctor(0, 3, 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 { - x_387 = x_386; + lean_dec_ref(x_379); + x_391 = lean_box(0); } -lean_ctor_set(x_387, 0, x_384); -lean_ctor_set(x_387, 1, x_385); -lean_ctor_set(x_387, 2, x_274); -if (lean_is_scalar(x_383)) { - x_388 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_391)) { + x_392 = lean_alloc_ctor(0, 4, 0); } else { - x_388 = x_383; + x_392 = x_391; } -lean_ctor_set(x_388, 0, x_378); -lean_ctor_set(x_388, 1, x_379); -lean_ctor_set(x_388, 2, x_387); -lean_ctor_set(x_388, 3, x_380); -lean_ctor_set(x_388, 4, x_381); -lean_ctor_set(x_388, 5, x_382); -if (lean_is_scalar(x_377)) { - x_389 = lean_alloc_ctor(1, 2, 0); +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_389 = x_377; -} -lean_ctor_set(x_389, 0, x_376); -lean_ctor_set(x_389, 1, x_388); -return x_389; + 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; } 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; -x_390 = lean_ctor_get(x_272, 0); -x_391 = lean_ctor_get(x_272, 1); -x_392 = lean_ctor_get(x_272, 2); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_272); -x_393 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_394 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_394, 0, x_390); -lean_ctor_set(x_394, 1, x_391); -lean_ctor_set(x_394, 2, x_393); -lean_ctor_set(x_267, 2, x_394); -x_395 = lean_ctor_get(x_8, 0); +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; 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_8, 1); +x_396 = lean_ctor_get(x_395, 2); lean_inc(x_396); -x_397 = lean_ctor_get(x_8, 2); +x_397 = lean_ctor_get(x_377, 0); lean_inc(x_397); -x_398 = lean_ctor_get(x_8, 3); -lean_inc(x_398); -x_399 = lean_ctor_get(x_8, 4); +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); +} +x_399 = lean_ctor_get(x_395, 0); lean_inc(x_399); -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_400 = x_8; +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_8); - x_400 = lean_box(0); + lean_dec_ref(x_395); + x_404 = lean_box(0); } -x_401 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_401, 0, x_268); -lean_ctor_set(x_401, 1, x_24); -x_402 = lean_array_push(x_397, x_401); -if (lean_is_scalar(x_400)) { - x_403 = lean_alloc_ctor(0, 5, 0); -} else { - x_403 = x_400; -} -lean_ctor_set(x_403, 0, x_395); -lean_ctor_set(x_403, 1, x_396); -lean_ctor_set(x_403, 2, x_402); -lean_ctor_set(x_403, 3, x_398); -lean_ctor_set(x_403, 4, x_399); -x_404 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_403, x_267); -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_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; -x_405 = lean_ctor_get(x_404, 1); +x_405 = lean_ctor_get(x_396, 0); lean_inc(x_405); -x_406 = lean_ctor_get(x_405, 2); +x_406 = lean_ctor_get(x_396, 1); lean_inc(x_406); -x_407 = lean_ctor_get(x_404, 0); +x_407 = lean_ctor_get(x_396, 3); lean_inc(x_407); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_408 = x_404; +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; } else { - lean_dec_ref(x_404); + lean_dec_ref(x_396); x_408 = lean_box(0); } -x_409 = lean_ctor_get(x_405, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_405, 1); -lean_inc(x_410); -x_411 = lean_ctor_get(x_405, 3); -lean_inc(x_411); -x_412 = lean_ctor_get(x_405, 4); -lean_inc(x_412); -x_413 = lean_ctor_get(x_405, 5); -lean_inc(x_413); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - lean_ctor_release(x_405, 4); - lean_ctor_release(x_405, 5); - x_414 = x_405; -} else { - lean_dec_ref(x_405); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_406, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_406, 1); -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); - x_417 = x_406; -} else { - lean_dec_ref(x_406); - x_417 = lean_box(0); -} -if (lean_is_scalar(x_417)) { - x_418 = lean_alloc_ctor(0, 3, 0); -} else { - x_418 = x_417; -} -lean_ctor_set(x_418, 0, x_415); -lean_ctor_set(x_418, 1, x_416); -lean_ctor_set(x_418, 2, x_392); -if (lean_is_scalar(x_414)) { - x_419 = lean_alloc_ctor(0, 6, 0); -} else { - x_419 = x_414; -} -lean_ctor_set(x_419, 0, x_409); -lean_ctor_set(x_419, 1, x_410); -lean_ctor_set(x_419, 2, x_418); -lean_ctor_set(x_419, 3, x_411); -lean_ctor_set(x_419, 4, x_412); -lean_ctor_set(x_419, 5, x_413); if (lean_is_scalar(x_408)) { - x_420 = lean_alloc_ctor(0, 2, 0); + x_409 = lean_alloc_ctor(0, 4, 0); } else { - x_420 = x_408; + x_409 = x_408; +} +lean_ctor_set(x_409, 0, x_405); +lean_ctor_set(x_409, 1, x_406); +lean_ctor_set(x_409, 2, x_288); +lean_ctor_set(x_409, 3, x_407); +if (lean_is_scalar(x_404)) { + x_410 = lean_alloc_ctor(0, 6, 0); +} else { + x_410 = x_404; +} +lean_ctor_set(x_410, 0, x_399); +lean_ctor_set(x_410, 1, x_400); +lean_ctor_set(x_410, 2, x_409); +lean_ctor_set(x_410, 3, x_401); +lean_ctor_set(x_410, 4, x_402); +lean_ctor_set(x_410, 5, x_403); +if (lean_is_scalar(x_398)) { + x_411 = lean_alloc_ctor(1, 2, 0); +} else { + x_411 = x_398; +} +lean_ctor_set(x_411, 0, x_397); +lean_ctor_set(x_411, 1, x_410); +return x_411; +} } -lean_ctor_set(x_420, 0, x_407); -lean_ctor_set(x_420, 1, x_419); -return x_420; } else { -lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_421 = lean_ctor_get(x_404, 1); +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_421, 2); +x_422 = lean_ctor_get(x_8, 4); lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 0); -lean_inc(x_423); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - x_424 = x_404; -} else { - lean_dec_ref(x_404); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_421, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_421, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_421, 3); -lean_inc(x_427); -x_428 = lean_ctor_get(x_421, 4); -lean_inc(x_428); -x_429 = lean_ctor_get(x_421, 5); -lean_inc(x_429); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - lean_ctor_release(x_421, 2); - lean_ctor_release(x_421, 3); - lean_ctor_release(x_421, 4); - lean_ctor_release(x_421, 5); - x_430 = x_421; -} else { - lean_dec_ref(x_421); - x_430 = lean_box(0); -} -x_431 = lean_ctor_get(x_422, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_422, 1); -lean_inc(x_432); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - lean_ctor_release(x_422, 2); - x_433 = x_422; -} else { - lean_dec_ref(x_422); - x_433 = lean_box(0); -} -if (lean_is_scalar(x_433)) { - x_434 = lean_alloc_ctor(0, 3, 0); -} else { - x_434 = x_433; -} -lean_ctor_set(x_434, 0, x_431); -lean_ctor_set(x_434, 1, x_432); -lean_ctor_set(x_434, 2, x_392); -if (lean_is_scalar(x_430)) { - x_435 = lean_alloc_ctor(0, 6, 0); -} else { - x_435 = x_430; -} -lean_ctor_set(x_435, 0, x_425); -lean_ctor_set(x_435, 1, x_426); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_427); -lean_ctor_set(x_435, 4, x_428); -lean_ctor_set(x_435, 5, x_429); -if (lean_is_scalar(x_424)) { - x_436 = lean_alloc_ctor(1, 2, 0); -} else { - x_436 = x_424; -} -lean_ctor_set(x_436, 0, x_423); -lean_ctor_set(x_436, 1, x_435); -return x_436; -} -} -} -else -{ -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; 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_437 = lean_ctor_get(x_267, 2); -x_438 = lean_ctor_get(x_267, 0); -x_439 = lean_ctor_get(x_267, 1); -x_440 = lean_ctor_get(x_267, 3); -x_441 = lean_ctor_get(x_267, 4); -x_442 = lean_ctor_get(x_267, 5); -lean_inc(x_442); -lean_inc(x_441); -lean_inc(x_440); -lean_inc(x_437); -lean_inc(x_439); -lean_inc(x_438); -lean_dec(x_267); -x_443 = lean_ctor_get(x_437, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_437, 1); -lean_inc(x_444); -x_445 = lean_ctor_get(x_437, 2); -lean_inc(x_445); -if (lean_is_exclusive(x_437)) { - lean_ctor_release(x_437, 0); - lean_ctor_release(x_437, 1); - lean_ctor_release(x_437, 2); - x_446 = x_437; -} else { - lean_dec_ref(x_437); - x_446 = lean_box(0); -} -x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_446)) { - x_448 = lean_alloc_ctor(0, 3, 0); -} else { - x_448 = x_446; -} -lean_ctor_set(x_448, 0, x_443); -lean_ctor_set(x_448, 1, x_444); -lean_ctor_set(x_448, 2, x_447); -x_449 = lean_alloc_ctor(0, 6, 0); -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); -x_450 = lean_ctor_get(x_8, 0); -lean_inc(x_450); -x_451 = lean_ctor_get(x_8, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_8, 2); -lean_inc(x_452); -x_453 = lean_ctor_get(x_8, 3); -lean_inc(x_453); -x_454 = lean_ctor_get(x_8, 4); -lean_inc(x_454); 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_455 = x_8; + x_423 = x_8; } else { lean_dec_ref(x_8); - x_455 = lean_box(0); + x_423 = lean_box(0); } -x_456 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_456, 0, x_268); -lean_ctor_set(x_456, 1, x_24); -x_457 = lean_array_push(x_452, x_456); -if (lean_is_scalar(x_455)) { - x_458 = lean_alloc_ctor(0, 5, 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); } else { - x_458 = x_455; + x_426 = x_423; } -lean_ctor_set(x_458, 0, x_450); -lean_ctor_set(x_458, 1, x_451); -lean_ctor_set(x_458, 2, x_457); -lean_ctor_set(x_458, 3, x_453); -lean_ctor_set(x_458, 4, x_454); -x_459 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_270, x_458, x_449); -if (lean_obj_tag(x_459) == 0) +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_Init_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_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_460 = lean_ctor_get(x_459, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_460, 2); -lean_inc(x_461); -x_462 = lean_ctor_get(x_459, 0); -lean_inc(x_462); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_463 = x_459; +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_459); - x_463 = lean_box(0); + lean_dec_ref(x_427); + x_431 = lean_box(0); } -x_464 = lean_ctor_get(x_460, 0); -lean_inc(x_464); -x_465 = lean_ctor_get(x_460, 1); -lean_inc(x_465); -x_466 = lean_ctor_get(x_460, 3); -lean_inc(x_466); -x_467 = lean_ctor_get(x_460, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_445); + x_454 = 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; +} else { + lean_dec_ref(x_446); + x_458 = lean_box(0); +} +if (lean_is_scalar(x_458)) { + x_459 = lean_alloc_ctor(0, 4, 0); +} else { + x_459 = x_458; +} +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); +} else { + x_460 = x_454; +} +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); +} else { + x_461 = x_448; +} +lean_ctor_set(x_461, 0, x_447); +lean_ctor_set(x_461, 1, x_460); +return x_461; +} +} +} +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); -x_468 = lean_ctor_get(x_460, 5); +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); -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); - lean_ctor_release(x_460, 4); - lean_ctor_release(x_460, 5); - x_469 = x_460; -} else { - lean_dec_ref(x_460); - x_469 = lean_box(0); -} -x_470 = lean_ctor_get(x_461, 0); +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_461, 1); +x_471 = lean_ctor_get(x_462, 3); lean_inc(x_471); -if (lean_is_exclusive(x_461)) { - lean_ctor_release(x_461, 0); - lean_ctor_release(x_461, 1); - lean_ctor_release(x_461, 2); - x_472 = x_461; +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; } else { - lean_dec_ref(x_461); + lean_dec_ref(x_462); x_472 = lean_box(0); } +x_473 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_472)) { - x_473 = lean_alloc_ctor(0, 3, 0); + x_474 = lean_alloc_ctor(0, 4, 0); } else { - x_473 = x_472; + x_474 = x_472; } -lean_ctor_set(x_473, 0, x_470); -lean_ctor_set(x_473, 1, x_471); -lean_ctor_set(x_473, 2, x_445); -if (lean_is_scalar(x_469)) { - x_474 = lean_alloc_ctor(0, 6, 0); -} else { - x_474 = x_469; -} -lean_ctor_set(x_474, 0, x_464); -lean_ctor_set(x_474, 1, x_465); +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_466); -lean_ctor_set(x_474, 4, x_467); -lean_ctor_set(x_474, 5, x_468); -if (lean_is_scalar(x_463)) { - x_475 = lean_alloc_ctor(0, 2, 0); -} else { - x_475 = x_463; -} -lean_ctor_set(x_475, 0, x_462); -lean_ctor_set(x_475, 1, x_474); -return x_475; -} -else -{ -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_476 = lean_ctor_get(x_459, 1); +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_476, 2); +x_477 = lean_ctor_get(x_8, 1); lean_inc(x_477); -x_478 = lean_ctor_get(x_459, 0); +x_478 = lean_ctor_get(x_8, 2); lean_inc(x_478); -if (lean_is_exclusive(x_459)) { - lean_ctor_release(x_459, 0); - lean_ctor_release(x_459, 1); - x_479 = x_459; -} else { - lean_dec_ref(x_459); - x_479 = lean_box(0); -} -x_480 = lean_ctor_get(x_476, 0); +x_479 = lean_ctor_get(x_8, 3); +lean_inc(x_479); +x_480 = lean_ctor_get(x_8, 4); 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; +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; } else { - lean_dec_ref(x_476); - x_485 = lean_box(0); + lean_dec_ref(x_8); + x_481 = lean_box(0); } -x_486 = lean_ctor_get(x_477, 0); +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); +} else { + x_484 = x_481; +} +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_Init_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_477, 1); +x_487 = lean_ctor_get(x_486, 2); lean_inc(x_487); -if (lean_is_exclusive(x_477)) { - lean_ctor_release(x_477, 0); - lean_ctor_release(x_477, 1); - lean_ctor_release(x_477, 2); - x_488 = x_477; +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; } else { - lean_dec_ref(x_477); - x_488 = lean_box(0); + lean_dec_ref(x_485); + x_489 = lean_box(0); } -if (lean_is_scalar(x_488)) { - x_489 = lean_alloc_ctor(0, 3, 0); +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 { - x_489 = x_488; + lean_dec_ref(x_486); + x_495 = lean_box(0); } -lean_ctor_set(x_489, 0, x_486); -lean_ctor_set(x_489, 1, x_487); -lean_ctor_set(x_489, 2, x_445); -if (lean_is_scalar(x_485)) { - x_490 = lean_alloc_ctor(0, 6, 0); +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 { - x_490 = x_485; + lean_dec_ref(x_487); + x_499 = lean_box(0); } -lean_ctor_set(x_490, 0, x_480); -lean_ctor_set(x_490, 1, x_481); -lean_ctor_set(x_490, 2, x_489); -lean_ctor_set(x_490, 3, x_482); -lean_ctor_set(x_490, 4, x_483); -lean_ctor_set(x_490, 5, x_484); -if (lean_is_scalar(x_479)) { - x_491 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_499)) { + x_500 = lean_alloc_ctor(0, 4, 0); } else { - x_491 = x_479; + x_500 = x_499; } -lean_ctor_set(x_491, 0, x_478); -lean_ctor_set(x_491, 1, x_490); -return x_491; +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_492; +uint8_t x_520; 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_492 = !lean_is_exclusive(x_261); -if (x_492 == 0) +x_520 = !lean_is_exclusive(x_275); +if (x_520 == 0) { -return x_261; +return x_275; } else { -lean_object* x_493; lean_object* x_494; lean_object* x_495; -x_493 = lean_ctor_get(x_261, 0); -x_494 = lean_ctor_get(x_261, 1); -lean_inc(x_494); -lean_inc(x_493); -lean_dec(x_261); -x_495 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_495, 0, x_493); -lean_ctor_set(x_495, 1, x_494); -return x_495; +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; } } } @@ -38149,7 +38891,7 @@ return x_495; } else { -uint8_t x_496; +uint8_t x_524; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -38157,52 +38899,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_496 = !lean_is_exclusive(x_29); -if (x_496 == 0) +x_524 = !lean_is_exclusive(x_29); +if (x_524 == 0) { return x_29; } else { -lean_object* x_497; lean_object* x_498; lean_object* x_499; -x_497 = lean_ctor_get(x_29, 0); -x_498 = lean_ctor_get(x_29, 1); -lean_inc(x_498); -lean_inc(x_497); +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_dec(x_29); -x_499 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_499, 0, x_497); -lean_ctor_set(x_499, 1, x_498); -return x_499; +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; } } } else { -uint8_t x_500; +uint8_t x_528; 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_500 = !lean_is_exclusive(x_25); -if (x_500 == 0) +x_528 = !lean_is_exclusive(x_25); +if (x_528 == 0) { return x_25; } else { -lean_object* x_501; lean_object* x_502; lean_object* x_503; -x_501 = lean_ctor_get(x_25, 0); -x_502 = lean_ctor_get(x_25, 1); -lean_inc(x_502); -lean_inc(x_501); +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_dec(x_25); -x_503 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_503, 0, x_501); -lean_ctor_set(x_503, 1, x_502); -return x_503; +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; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/FunInfo.c b/stage0/stdlib/Init/Lean/Meta/FunInfo.c index f10e614768..e6312769a7 100644 --- a/stage0/stdlib/Init/Lean/Meta/FunInfo.c +++ b/stage0/stdlib/Init/Lean/Meta/FunInfo.c @@ -1610,90 +1610,97 @@ return x_12; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; x_23 = lean_ctor_get(x_14, 0); x_24 = lean_ctor_get(x_14, 1); x_25 = lean_ctor_get(x_14, 2); +x_26 = lean_ctor_get(x_14, 3); +lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_dec(x_14); lean_inc(x_16); -x_26 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_24, x_10, x_16); -x_27 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_27, 0, x_23); -lean_ctor_set(x_27, 1, x_26); -lean_ctor_set(x_27, 2, x_25); -lean_ctor_set(x_13, 2, x_27); +x_27 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_24, x_10, x_16); +x_28 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_28, 0, x_23); +lean_ctor_set(x_28, 1, x_27); +lean_ctor_set(x_28, 2, x_25); +lean_ctor_set(x_28, 3, x_26); +lean_ctor_set(x_13, 2, x_28); return x_12; } } 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_13, 0); -x_29 = lean_ctor_get(x_13, 1); -x_30 = lean_ctor_get(x_13, 3); -x_31 = lean_ctor_get(x_13, 4); -x_32 = lean_ctor_get(x_13, 5); +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_29 = lean_ctor_get(x_13, 0); +x_30 = lean_ctor_get(x_13, 1); +x_31 = lean_ctor_get(x_13, 3); +x_32 = lean_ctor_get(x_13, 4); +x_33 = lean_ctor_get(x_13, 5); +lean_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_13); -x_33 = lean_ctor_get(x_14, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_14, 1); +x_34 = lean_ctor_get(x_14, 0); lean_inc(x_34); -x_35 = lean_ctor_get(x_14, 2); +x_35 = lean_ctor_get(x_14, 1); lean_inc(x_35); +x_36 = lean_ctor_get(x_14, 2); +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); - x_36 = x_14; + lean_ctor_release(x_14, 3); + x_38 = x_14; } else { lean_dec_ref(x_14); - x_36 = lean_box(0); + x_38 = lean_box(0); } lean_inc(x_16); -x_37 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_34, x_10, x_16); -if (lean_is_scalar(x_36)) { - x_38 = lean_alloc_ctor(0, 3, 0); +x_39 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_35, x_10, x_16); +if (lean_is_scalar(x_38)) { + x_40 = lean_alloc_ctor(0, 4, 0); } else { - x_38 = x_36; + x_40 = x_38; } -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_37); -lean_ctor_set(x_38, 2, x_35); -x_39 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_39, 0, x_28); -lean_ctor_set(x_39, 1, x_29); -lean_ctor_set(x_39, 2, x_38); -lean_ctor_set(x_39, 3, x_30); -lean_ctor_set(x_39, 4, x_31); -lean_ctor_set(x_39, 5, x_32); -lean_ctor_set(x_12, 1, x_39); +lean_ctor_set(x_40, 0, x_34); +lean_ctor_set(x_40, 1, x_39); +lean_ctor_set(x_40, 2, x_36); +lean_ctor_set(x_40, 3, x_37); +x_41 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_41, 0, x_29); +lean_ctor_set(x_41, 1, x_30); +lean_ctor_set(x_41, 2, x_40); +lean_ctor_set(x_41, 3, x_31); +lean_ctor_set(x_41, 4, x_32); +lean_ctor_set(x_41, 5, x_33); +lean_ctor_set(x_12, 1, x_41); return x_12; } } 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; -x_40 = lean_ctor_get(x_12, 0); -lean_inc(x_40); -lean_dec(x_12); -x_41 = lean_ctor_get(x_13, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_13, 1); +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_42 = lean_ctor_get(x_12, 0); lean_inc(x_42); -x_43 = lean_ctor_get(x_13, 3); +lean_dec(x_12); +x_43 = lean_ctor_get(x_13, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_13, 4); +x_44 = lean_ctor_get(x_13, 1); lean_inc(x_44); -x_45 = lean_ctor_get(x_13, 5); +x_45 = lean_ctor_get(x_13, 3); lean_inc(x_45); +x_46 = lean_ctor_get(x_13, 4); +lean_inc(x_46); +x_47 = lean_ctor_get(x_13, 5); +lean_inc(x_47); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); @@ -1701,90 +1708,94 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_46 = x_13; + x_48 = x_13; } else { lean_dec_ref(x_13); - x_46 = lean_box(0); + x_48 = lean_box(0); } -x_47 = lean_ctor_get(x_14, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_14, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_14, 2); +x_49 = lean_ctor_get(x_14, 0); lean_inc(x_49); +x_50 = lean_ctor_get(x_14, 1); +lean_inc(x_50); +x_51 = lean_ctor_get(x_14, 2); +lean_inc(x_51); +x_52 = lean_ctor_get(x_14, 3); +lean_inc(x_52); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); - x_50 = x_14; + lean_ctor_release(x_14, 3); + x_53 = x_14; } else { lean_dec_ref(x_14); - x_50 = lean_box(0); + x_53 = lean_box(0); } -lean_inc(x_40); -x_51 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_48, x_10, x_40); -if (lean_is_scalar(x_50)) { - x_52 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_42); +x_54 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_50, x_10, x_42); +if (lean_is_scalar(x_53)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - x_52 = x_50; + x_55 = x_53; } -lean_ctor_set(x_52, 0, x_47); -lean_ctor_set(x_52, 1, x_51); -lean_ctor_set(x_52, 2, x_49); -if (lean_is_scalar(x_46)) { - x_53 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_55, 0, x_49); +lean_ctor_set(x_55, 1, x_54); +lean_ctor_set(x_55, 2, x_51); +lean_ctor_set(x_55, 3, x_52); +if (lean_is_scalar(x_48)) { + x_56 = lean_alloc_ctor(0, 6, 0); } else { - x_53 = x_46; + x_56 = x_48; } -lean_ctor_set(x_53, 0, x_41); -lean_ctor_set(x_53, 1, x_42); -lean_ctor_set(x_53, 2, x_52); -lean_ctor_set(x_53, 3, x_43); -lean_ctor_set(x_53, 4, x_44); -lean_ctor_set(x_53, 5, x_45); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_40); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_ctor_set(x_56, 0, x_43); +lean_ctor_set(x_56, 1, x_44); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_45); +lean_ctor_set(x_56, 4, x_46); +lean_ctor_set(x_56, 5, x_47); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_42); +lean_ctor_set(x_57, 1, x_56); +return x_57; } } else { -uint8_t x_55; +uint8_t x_58; lean_dec(x_10); -x_55 = !lean_is_exclusive(x_12); -if (x_55 == 0) +x_58 = !lean_is_exclusive(x_12); +if (x_58 == 0) { return x_12; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_12, 0); -x_57 = lean_ctor_get(x_12, 1); -lean_inc(x_57); -lean_inc(x_56); +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_12, 0); +x_60 = lean_ctor_get(x_12, 1); +lean_inc(x_60); +lean_inc(x_59); lean_dec(x_12); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_56); -lean_ctor_set(x_58, 1, x_57); -return x_58; +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } } else { -lean_object* x_59; lean_object* x_60; +lean_object* x_62; lean_object* x_63; lean_dec(x_10); lean_dec(x_4); lean_dec(x_3); -x_59 = lean_ctor_get(x_11, 0); -lean_inc(x_59); +x_62 = lean_ctor_get(x_11, 0); +lean_inc(x_62); lean_dec(x_11); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_59); -lean_ctor_set(x_60, 1, x_5); -return x_60; +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_5); +return x_63; } } } @@ -2788,82 +2799,89 @@ return x_51; } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; +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_62 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_62, 0, x_60); -lean_ctor_set(x_62, 1, x_61); -lean_ctor_set(x_62, 2, x_45); -lean_ctor_set(x_52, 2, x_62); +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; } } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_63 = lean_ctor_get(x_52, 0); -x_64 = lean_ctor_get(x_52, 1); -x_65 = lean_ctor_get(x_52, 3); -x_66 = lean_ctor_get(x_52, 4); -x_67 = lean_ctor_get(x_52, 5); +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +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_inc(x_65); lean_inc(x_64); -lean_inc(x_63); lean_dec(x_52); -x_68 = lean_ctor_get(x_53, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_53, 1); +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); - x_70 = x_53; + lean_ctor_release(x_53, 3); + x_72 = x_53; } else { lean_dec_ref(x_53); - x_70 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_70)) { - x_71 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_71 = x_70; + x_73 = x_72; } -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_69); -lean_ctor_set(x_71, 2, x_45); -x_72 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_72, 0, x_63); -lean_ctor_set(x_72, 1, x_64); -lean_ctor_set(x_72, 2, x_71); -lean_ctor_set(x_72, 3, x_65); -lean_ctor_set(x_72, 4, x_66); -lean_ctor_set(x_72, 5, x_67); -lean_ctor_set(x_51, 1, 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_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; } } 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; -x_73 = lean_ctor_get(x_51, 0); -lean_inc(x_73); -lean_dec(x_51); -x_74 = lean_ctor_get(x_52, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_52, 1); +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); -x_76 = lean_ctor_get(x_52, 3); +lean_dec(x_51); +x_76 = lean_ctor_get(x_52, 0); lean_inc(x_76); -x_77 = lean_ctor_get(x_52, 4); +x_77 = lean_ctor_get(x_52, 1); lean_inc(x_77); -x_78 = lean_ctor_get(x_52, 5); +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); @@ -2871,1898 +2889,1997 @@ if (lean_is_exclusive(x_52)) { lean_ctor_release(x_52, 3); lean_ctor_release(x_52, 4); lean_ctor_release(x_52, 5); - x_79 = x_52; + x_81 = x_52; } else { lean_dec_ref(x_52); - x_79 = lean_box(0); + x_81 = lean_box(0); } -x_80 = lean_ctor_get(x_53, 0); -lean_inc(x_80); -x_81 = lean_ctor_get(x_53, 1); -lean_inc(x_81); +x_82 = lean_ctor_get(x_53, 0); +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); - x_82 = x_53; + lean_ctor_release(x_53, 3); + x_85 = x_53; } else { lean_dec_ref(x_53); - x_82 = lean_box(0); + x_85 = lean_box(0); } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 4, 0); } else { - x_83 = x_82; + x_86 = x_85; } -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -lean_ctor_set(x_83, 2, x_45); -if (lean_is_scalar(x_79)) { - x_84 = lean_alloc_ctor(0, 6, 0); +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_84 = x_79; + x_87 = x_81; } -lean_ctor_set(x_84, 0, x_74); -lean_ctor_set(x_84, 1, x_75); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_76); -lean_ctor_set(x_84, 4, x_77); -lean_ctor_set(x_84, 5, x_78); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_73); -lean_ctor_set(x_85, 1, x_84); -return x_85; +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; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_51, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); -lean_inc(x_87); -x_88 = !lean_is_exclusive(x_51); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; +lean_object* x_89; lean_object* x_90; uint8_t x_91; x_89 = lean_ctor_get(x_51, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) +lean_inc(x_89); +x_90 = lean_ctor_get(x_89, 2); +lean_inc(x_90); +x_91 = !lean_is_exclusive(x_51); +if (x_91 == 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_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_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_45); +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_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -x_96 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -lean_ctor_set(x_96, 2, x_45); -lean_ctor_set(x_86, 2, x_96); -return x_51; -} -} -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; -x_97 = lean_ctor_get(x_86, 0); -x_98 = lean_ctor_get(x_86, 1); -x_99 = lean_ctor_get(x_86, 3); -x_100 = lean_ctor_get(x_86, 4); -x_101 = lean_ctor_get(x_86, 5); -lean_inc(x_101); -lean_inc(x_100); +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_86); -x_102 = lean_ctor_get(x_87, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_87, 1); -lean_inc(x_103); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - x_104 = x_87; -} else { - lean_dec_ref(x_87); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 3, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_102); -lean_ctor_set(x_105, 1, x_103); -lean_ctor_set(x_105, 2, x_45); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_97); -lean_ctor_set(x_106, 1, x_98); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_99); -lean_ctor_set(x_106, 4, x_100); -lean_ctor_set(x_106, 5, x_101); -lean_ctor_set(x_51, 1, x_106); +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_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_107 = lean_ctor_get(x_51, 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_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); -lean_dec(x_51); -x_108 = lean_ctor_get(x_86, 0); +x_108 = lean_ctor_get(x_90, 3); lean_inc(x_108); -x_109 = lean_ctor_get(x_86, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_86, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 5); +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; +} else { + lean_dec_ref(x_90); + 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_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); -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_113 = x_86; -} else { - lean_dec_ref(x_86); - x_113 = lean_box(0); -} -x_114 = lean_ctor_get(x_87, 0); +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_87, 1); +x_115 = lean_ctor_get(x_89, 3); lean_inc(x_115); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - x_116 = x_87; +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; } else { - lean_dec_ref(x_87); - x_116 = lean_box(0); + lean_dec_ref(x_89); + x_118 = lean_box(0); } -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(0, 3, 0); +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 { - x_117 = x_116; + lean_dec_ref(x_90); + x_122 = lean_box(0); } -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -lean_ctor_set(x_117, 2, x_45); -if (lean_is_scalar(x_113)) { - x_118 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_122)) { + x_123 = lean_alloc_ctor(0, 4, 0); } else { - x_118 = x_113; + x_123 = x_122; } -lean_ctor_set(x_118, 0, x_108); -lean_ctor_set(x_118, 1, x_109); -lean_ctor_set(x_118, 2, x_117); -lean_ctor_set(x_118, 3, x_110); -lean_ctor_set(x_118, 4, x_111); -lean_ctor_set(x_118, 5, x_112); -x_119 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_119, 0, x_107); -lean_ctor_set(x_119, 1, x_118); -return x_119; +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_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_6, 0); -x_121 = lean_ctor_get(x_6, 1); -x_122 = lean_ctor_get(x_6, 2); -x_123 = lean_ctor_get(x_6, 3); -x_124 = lean_ctor_get(x_6, 4); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_6); -x_125 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_125, 0, x_39); -lean_ctor_set(x_125, 1, x_27); -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_127, x_38); -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; -x_129 = lean_ctor_get(x_128, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_129, 2); +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); -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; -} else { - lean_dec_ref(x_128); - x_132 = lean_box(0); -} -x_133 = lean_ctor_get(x_129, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_129, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_129, 3); +lean_inc(x_129); +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_Init_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_129, 4); +x_136 = lean_ctor_get(x_135, 2); lean_inc(x_136); -x_137 = lean_ctor_get(x_129, 5); +x_137 = lean_ctor_get(x_134, 0); 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_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + x_138 = x_134; } else { - lean_dec_ref(x_129); + lean_dec_ref(x_134); x_138 = lean_box(0); } -x_139 = lean_ctor_get(x_130, 0); +x_139 = lean_ctor_get(x_135, 0); lean_inc(x_139); -x_140 = lean_ctor_get(x_130, 1); +x_140 = lean_ctor_get(x_135, 1); 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); - x_141 = x_130; +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_130); - x_141 = lean_box(0); + lean_dec_ref(x_135); + x_144 = lean_box(0); } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 3, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_139); -lean_ctor_set(x_142, 1, x_140); -lean_ctor_set(x_142, 2, x_45); -if (lean_is_scalar(x_138)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_138; -} -lean_ctor_set(x_143, 0, x_133); -lean_ctor_set(x_143, 1, x_134); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_135); -lean_ctor_set(x_143, 4, x_136); -lean_ctor_set(x_143, 5, x_137); -if (lean_is_scalar(x_132)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_132; -} -lean_ctor_set(x_144, 0, x_131); -lean_ctor_set(x_144, 1, x_143); -return x_144; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_145 = lean_ctor_get(x_128, 1); +x_145 = lean_ctor_get(x_136, 0); lean_inc(x_145); -x_146 = lean_ctor_get(x_145, 2); +x_146 = lean_ctor_get(x_136, 1); lean_inc(x_146); -x_147 = lean_ctor_get(x_128, 0); +x_147 = lean_ctor_get(x_136, 3); lean_inc(x_147); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_148 = x_128; +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_128); + lean_dec_ref(x_136); x_148 = lean_box(0); } -x_149 = lean_ctor_get(x_145, 0); -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; -} else { - lean_dec_ref(x_145); - x_154 = 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); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - lean_ctor_release(x_146, 1); - lean_ctor_release(x_146, 2); - x_157 = x_146; -} else { - lean_dec_ref(x_146); - x_157 = lean_box(0); -} -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 3, 0); -} else { - x_158 = x_157; -} -lean_ctor_set(x_158, 0, x_155); -lean_ctor_set(x_158, 1, x_156); -lean_ctor_set(x_158, 2, x_45); -if (lean_is_scalar(x_154)) { - x_159 = lean_alloc_ctor(0, 6, 0); -} else { - x_159 = x_154; -} -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); if (lean_is_scalar(x_148)) { - x_160 = lean_alloc_ctor(1, 2, 0); + x_149 = lean_alloc_ctor(0, 4, 0); } else { - x_160 = x_148; + x_149 = x_148; } -lean_ctor_set(x_160, 0, x_147); -lean_ctor_set(x_160, 1, x_159); -return x_160; +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); +if (lean_is_scalar(x_138)) { + x_151 = lean_alloc_ctor(0, 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_134, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_152, 2); +lean_inc(x_153); +x_154 = lean_ctor_get(x_134, 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); +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; +} else { + lean_dec_ref(x_152); + x_161 = 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; +} else { + lean_dec_ref(x_153); + x_165 = lean_box(0); +} +if (lean_is_scalar(x_165)) { + x_166 = lean_alloc_ctor(0, 4, 0); +} else { + x_166 = x_165; +} +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); +} else { + x_167 = x_161; +} +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_168, 0, x_154); +lean_ctor_set(x_168, 1, x_167); +return x_168; } } } 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; -x_161 = lean_ctor_get(x_43, 0); -x_162 = lean_ctor_get(x_43, 1); -x_163 = lean_ctor_get(x_43, 2); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_dec(x_43); -x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_165 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_165, 0, x_161); -lean_ctor_set(x_165, 1, x_162); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_38, 2, x_165); -x_166 = lean_ctor_get(x_6, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_6, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_6, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_6, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_6, 4); +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); 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_171 = x_6; + x_180 = x_6; } else { lean_dec_ref(x_6); - x_171 = lean_box(0); + x_180 = lean_box(0); } -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_39); -lean_ctor_set(x_172, 1, x_27); -x_173 = lean_array_push(x_168, x_172); -if (lean_is_scalar(x_171)) { - x_174 = lean_alloc_ctor(0, 5, 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); } else { - x_174 = x_171; + x_183 = x_180; } -lean_ctor_set(x_174, 0, x_166); -lean_ctor_set(x_174, 1, x_167); -lean_ctor_set(x_174, 2, x_173); -lean_ctor_set(x_174, 3, x_169); -lean_ctor_set(x_174, 4, x_170); -x_175 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_174, x_38); -if (lean_obj_tag(x_175) == 0) +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_Init_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_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_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_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_177, 1); +x_187 = lean_ctor_get(x_184, 0); lean_inc(x_187); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - x_188 = x_177; +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_177); + lean_dec_ref(x_184); x_188 = lean_box(0); } -if (lean_is_scalar(x_188)) { - x_189 = lean_alloc_ctor(0, 3, 0); -} else { - x_189 = x_188; -} -lean_ctor_set(x_189, 0, x_186); -lean_ctor_set(x_189, 1, x_187); -lean_ctor_set(x_189, 2, x_163); -if (lean_is_scalar(x_185)) { - x_190 = lean_alloc_ctor(0, 6, 0); -} else { - x_190 = x_185; -} -lean_ctor_set(x_190, 0, x_180); -lean_ctor_set(x_190, 1, x_181); -lean_ctor_set(x_190, 2, x_189); -lean_ctor_set(x_190, 3, x_182); -lean_ctor_set(x_190, 4, x_183); -lean_ctor_set(x_190, 5, x_184); -if (lean_is_scalar(x_179)) { - x_191 = lean_alloc_ctor(0, 2, 0); -} else { - x_191 = x_179; -} -lean_ctor_set(x_191, 0, x_178); -lean_ctor_set(x_191, 1, x_190); -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_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -x_192 = lean_ctor_get(x_175, 1); +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_192, 2); +x_193 = lean_ctor_get(x_185, 5); lean_inc(x_193); -x_194 = lean_ctor_get(x_175, 0); -lean_inc(x_194); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_195 = x_175; +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_175); - x_195 = lean_box(0); + lean_dec_ref(x_185); + x_194 = lean_box(0); } -x_196 = lean_ctor_get(x_192, 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_192, 1); +x_197 = lean_ctor_get(x_186, 3); lean_inc(x_197); -x_198 = lean_ctor_get(x_192, 3); -lean_inc(x_198); -x_199 = lean_ctor_get(x_192, 4); -lean_inc(x_199); -x_200 = lean_ctor_get(x_192, 5); -lean_inc(x_200); -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_201 = 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); + x_198 = x_186; } else { - lean_dec_ref(x_192); - x_201 = lean_box(0); + lean_dec_ref(x_186); + x_198 = lean_box(0); } -x_202 = lean_ctor_get(x_193, 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; +} +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_inc(x_202); -x_203 = lean_ctor_get(x_193, 1); +x_203 = lean_ctor_get(x_202, 2); lean_inc(x_203); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - lean_ctor_release(x_193, 2); - x_204 = x_193; +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; } else { - lean_dec_ref(x_193); - x_204 = lean_box(0); + lean_dec_ref(x_184); + x_205 = lean_box(0); } -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_208); +x_209 = lean_ctor_get(x_202, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_202, 5); +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 { - x_205 = x_204; + lean_dec_ref(x_202); + x_211 = lean_box(0); } -lean_ctor_set(x_205, 0, x_202); -lean_ctor_set(x_205, 1, x_203); -lean_ctor_set(x_205, 2, x_163); -if (lean_is_scalar(x_201)) { - x_206 = lean_alloc_ctor(0, 6, 0); +x_212 = lean_ctor_get(x_203, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_203, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_203, 3); +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; } else { - x_206 = x_201; + lean_dec_ref(x_203); + x_215 = lean_box(0); } -lean_ctor_set(x_206, 0, x_196); -lean_ctor_set(x_206, 1, x_197); -lean_ctor_set(x_206, 2, x_205); -lean_ctor_set(x_206, 3, x_198); -lean_ctor_set(x_206, 4, x_199); -lean_ctor_set(x_206, 5, x_200); -if (lean_is_scalar(x_195)) { - x_207 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_215)) { + x_216 = lean_alloc_ctor(0, 4, 0); } else { - x_207 = x_195; + x_216 = x_215; } -lean_ctor_set(x_207, 0, x_194); -lean_ctor_set(x_207, 1, x_206); -return x_207; +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); +} else { + x_217 = x_211; +} +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_218, 0, x_204); +lean_ctor_set(x_218, 1, x_217); +return x_218; } } } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; 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_208 = lean_ctor_get(x_38, 2); -x_209 = lean_ctor_get(x_38, 0); -x_210 = lean_ctor_get(x_38, 1); -x_211 = lean_ctor_get(x_38, 3); -x_212 = lean_ctor_get(x_38, 4); -x_213 = lean_ctor_get(x_38, 5); -lean_inc(x_213); -lean_inc(x_212); -lean_inc(x_211); -lean_inc(x_208); -lean_inc(x_210); -lean_inc(x_209); -lean_dec(x_38); -x_214 = lean_ctor_get(x_208, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_208, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_208, 2); -lean_inc(x_216); -if (lean_is_exclusive(x_208)) { - lean_ctor_release(x_208, 0); - lean_ctor_release(x_208, 1); - lean_ctor_release(x_208, 2); - x_217 = x_208; -} else { - lean_dec_ref(x_208); - x_217 = lean_box(0); -} -x_218 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_217)) { - x_219 = lean_alloc_ctor(0, 3, 0); -} else { - x_219 = x_217; -} -lean_ctor_set(x_219, 0, x_214); -lean_ctor_set(x_219, 1, x_215); -lean_ctor_set(x_219, 2, x_218); -x_220 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_220, 0, x_209); -lean_ctor_set(x_220, 1, x_210); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_211); -lean_ctor_set(x_220, 4, x_212); -lean_ctor_set(x_220, 5, x_213); -x_221 = lean_ctor_get(x_6, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_6, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_6, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_6, 3); +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); -x_225 = lean_ctor_get(x_6, 4); +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_226 = x_6; + x_238 = x_6; } else { lean_dec_ref(x_6); - x_226 = lean_box(0); + x_238 = lean_box(0); } -x_227 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_227, 0, x_39); -lean_ctor_set(x_227, 1, x_27); -x_228 = lean_array_push(x_223, x_227); -if (lean_is_scalar(x_226)) { - x_229 = lean_alloc_ctor(0, 5, 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_229 = x_226; + x_241 = x_238; } -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_41, x_229, x_220); -if (lean_obj_tag(x_230) == 0) +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_Init_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_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_231 = lean_ctor_get(x_230, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_231, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_230, 0); -lean_inc(x_233); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_234 = x_230; +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_230); - x_234 = lean_box(0); + lean_dec_ref(x_242); + x_246 = lean_box(0); } -x_235 = lean_ctor_get(x_231, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_231, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_231, 3); -lean_inc(x_237); -x_238 = lean_ctor_get(x_231, 4); -lean_inc(x_238); -x_239 = lean_ctor_get(x_231, 5); -lean_inc(x_239); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - lean_ctor_release(x_231, 4); - lean_ctor_release(x_231, 5); - x_240 = x_231; +x_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_231); - x_240 = lean_box(0); + lean_dec_ref(x_243); + x_252 = lean_box(0); } -x_241 = lean_ctor_get(x_232, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_232, 1); -lean_inc(x_242); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - lean_ctor_release(x_232, 1); - lean_ctor_release(x_232, 2); - x_243 = x_232; +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_232); - x_243 = lean_box(0); + lean_dec_ref(x_244); + x_256 = lean_box(0); } -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 4, 0); } else { - x_244 = x_243; + x_257 = x_256; } -lean_ctor_set(x_244, 0, x_241); -lean_ctor_set(x_244, 1, x_242); -lean_ctor_set(x_244, 2, x_216); -if (lean_is_scalar(x_240)) { - x_245 = lean_alloc_ctor(0, 6, 0); +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_245 = x_240; + x_258 = x_252; } -lean_ctor_set(x_245, 0, x_235); -lean_ctor_set(x_245, 1, x_236); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_237); -lean_ctor_set(x_245, 4, x_238); -lean_ctor_set(x_245, 5, x_239); -if (lean_is_scalar(x_234)) { - x_246 = lean_alloc_ctor(0, 2, 0); +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_246 = x_234; + x_259 = x_246; } -lean_ctor_set(x_246, 0, x_233); -lean_ctor_set(x_246, 1, x_245); -return 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_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_247 = lean_ctor_get(x_230, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_230, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_250 = x_230; +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_230); - x_250 = lean_box(0); + lean_dec_ref(x_242); + x_263 = 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; +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_247); - x_256 = lean_box(0); + lean_dec_ref(x_260); + x_269 = 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); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - x_259 = x_248; +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_248); - x_259 = lean_box(0); + lean_dec_ref(x_261); + x_273 = lean_box(0); } -if (lean_is_scalar(x_259)) { - x_260 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_273)) { + x_274 = lean_alloc_ctor(0, 4, 0); } else { - x_260 = x_259; + x_274 = x_273; } -lean_ctor_set(x_260, 0, x_257); -lean_ctor_set(x_260, 1, x_258); -lean_ctor_set(x_260, 2, x_216); -if (lean_is_scalar(x_256)) { - x_261 = lean_alloc_ctor(0, 6, 0); +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_261 = x_256; + x_275 = x_269; } -lean_ctor_set(x_261, 0, x_251); -lean_ctor_set(x_261, 1, x_252); -lean_ctor_set(x_261, 2, x_260); -lean_ctor_set(x_261, 3, x_253); -lean_ctor_set(x_261, 4, x_254); -lean_ctor_set(x_261, 5, x_255); -if (lean_is_scalar(x_250)) { - x_262 = lean_alloc_ctor(1, 2, 0); +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_262 = x_250; + x_276 = x_263; } -lean_ctor_set(x_262, 0, x_249); -lean_ctor_set(x_262, 1, x_261); -return x_262; +lean_ctor_set(x_276, 0, x_262); +lean_ctor_set(x_276, 1, x_275); +return x_276; } } } default: { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_32, 1); -lean_inc(x_263); +lean_object* x_277; lean_object* x_278; +x_277 = lean_ctor_get(x_32, 1); +lean_inc(x_277); lean_dec(x_32); lean_inc(x_6); -x_264 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_263); -if (lean_obj_tag(x_264) == 0) +x_278 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_277); +if (lean_obj_tag(x_278) == 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_279; +x_279 = lean_ctor_get(x_278, 0); +lean_inc(x_279); +if (lean_obj_tag(x_279) == 0) { -lean_object* x_266; lean_object* x_267; lean_object* x_268; +lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_dec(x_27); -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_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); lean_dec(x_5); -x_5 = x_268; -x_7 = x_266; +x_5 = x_282; +x_7 = x_280; 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_dec(x_5); -x_274 = !lean_is_exclusive(x_270); -if (x_274 == 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_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_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_27); -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_273, x_6, x_270); -if (lean_obj_tag(x_283) == 0) -{ -lean_object* x_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_283, 1); +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); -x_285 = lean_ctor_get(x_284, 2); +lean_dec(x_278); +x_285 = lean_ctor_get(x_279, 0); 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); +lean_dec(x_279); +x_286 = lean_unsigned_to_nat(1u); +x_287 = lean_nat_add(x_5, x_286); +lean_dec(x_5); 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); +x_290 = !lean_is_exclusive(x_289); 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_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_292; lean_object* x_293; lean_object* x_294; -x_292 = lean_ctor_get(x_285, 0); -x_293 = lean_ctor_get(x_285, 1); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_285); -x_294 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_294, 0, x_292); -lean_ctor_set(x_294, 1, x_293); -lean_ctor_set(x_294, 2, x_277); -lean_ctor_set(x_284, 2, x_294); -return x_283; -} -} -else +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_Init_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_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_295 = lean_ctor_get(x_284, 0); -x_296 = lean_ctor_get(x_284, 1); -x_297 = lean_ctor_get(x_284, 3); -x_298 = lean_ctor_get(x_284, 4); -x_299 = lean_ctor_get(x_284, 5); -lean_inc(x_299); +lean_object* x_298; lean_object* x_299; uint8_t x_300; +x_298 = lean_ctor_get(x_297, 1); lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); -lean_dec(x_284); -x_300 = lean_ctor_get(x_285, 0); -lean_inc(x_300); -x_301 = lean_ctor_get(x_285, 1); -lean_inc(x_301); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - x_302 = x_285; -} else { - lean_dec_ref(x_285); - x_302 = lean_box(0); -} -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 3, 0); -} else { - x_303 = x_302; -} -lean_ctor_set(x_303, 0, x_300); -lean_ctor_set(x_303, 1, x_301); -lean_ctor_set(x_303, 2, x_277); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_295); -lean_ctor_set(x_304, 1, x_296); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_297); -lean_ctor_set(x_304, 4, x_298); -lean_ctor_set(x_304, 5, x_299); -lean_ctor_set(x_283, 1, x_304); -return x_283; -} +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_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_305 = lean_ctor_get(x_283, 0); -lean_inc(x_305); -lean_dec(x_283); -x_306 = lean_ctor_get(x_284, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_284, 1); -lean_inc(x_307); -x_308 = lean_ctor_get(x_284, 3); +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); -x_309 = lean_ctor_get(x_284, 4); -lean_inc(x_309); -x_310 = lean_ctor_get(x_284, 5); -lean_inc(x_310); -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_311 = x_284; -} else { - lean_dec_ref(x_284); - x_311 = lean_box(0); +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; } -x_312 = lean_ctor_get(x_285, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 1); +} +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); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - x_314 = x_285; +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_inc(x_316); +x_317 = lean_ctor_get(x_299, 3); +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_285); - x_314 = lean_box(0); + lean_dec_ref(x_299); + x_318 = lean_box(0); } -if (lean_is_scalar(x_314)) { - x_315 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_318)) { + x_319 = lean_alloc_ctor(0, 4, 0); } else { - x_315 = x_314; + x_319 = x_318; } -lean_ctor_set(x_315, 0, x_312); -lean_ctor_set(x_315, 1, x_313); -lean_ctor_set(x_315, 2, x_277); -if (lean_is_scalar(x_311)) { - x_316 = lean_alloc_ctor(0, 6, 0); -} else { - x_316 = x_311; -} -lean_ctor_set(x_316, 0, x_306); -lean_ctor_set(x_316, 1, x_307); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_308); -lean_ctor_set(x_316, 4, x_309); -lean_ctor_set(x_316, 5, x_310); -x_317 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_317, 0, x_305); -lean_ctor_set(x_317, 1, x_316); -return x_317; +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_318; lean_object* x_319; uint8_t x_320; -x_318 = lean_ctor_get(x_283, 1); -lean_inc(x_318); -x_319 = lean_ctor_get(x_318, 2); -lean_inc(x_319); -x_320 = !lean_is_exclusive(x_283); -if (x_320 == 0) -{ -lean_object* x_321; uint8_t x_322; -x_321 = lean_ctor_get(x_283, 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_277); -return x_283; -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_319, 0); -x_327 = lean_ctor_get(x_319, 1); -lean_inc(x_327); +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_inc(x_326); -lean_dec(x_319); -x_328 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_328, 0, x_326); -lean_ctor_set(x_328, 1, x_327); -lean_ctor_set(x_328, 2, x_277); -lean_ctor_set(x_318, 2, x_328); -return x_283; +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); } -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_329 = lean_ctor_get(x_318, 0); -x_330 = lean_ctor_get(x_318, 1); -x_331 = lean_ctor_get(x_318, 3); -x_332 = lean_ctor_get(x_318, 4); -x_333 = lean_ctor_get(x_318, 5); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); +x_328 = lean_ctor_get(x_299, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_299, 1); lean_inc(x_329); -lean_dec(x_318); -x_334 = lean_ctor_get(x_319, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_319, 1); +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); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - x_336 = x_319; -} else { - lean_dec_ref(x_319); - x_336 = lean_box(0); -} -if (lean_is_scalar(x_336)) { - x_337 = lean_alloc_ctor(0, 3, 0); -} else { - x_337 = x_336; -} -lean_ctor_set(x_337, 0, x_334); -lean_ctor_set(x_337, 1, x_335); -lean_ctor_set(x_337, 2, x_277); -x_338 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_338, 0, x_329); -lean_ctor_set(x_338, 1, x_330); -lean_ctor_set(x_338, 2, x_337); -lean_ctor_set(x_338, 3, x_331); -lean_ctor_set(x_338, 4, x_332); -lean_ctor_set(x_338, 5, x_333); -lean_ctor_set(x_283, 1, x_338); -return x_283; -} +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_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_339 = lean_ctor_get(x_283, 0); -lean_inc(x_339); -lean_dec(x_283); -x_340 = lean_ctor_get(x_318, 0); -lean_inc(x_340); -x_341 = lean_ctor_get(x_318, 1); -lean_inc(x_341); -x_342 = lean_ctor_get(x_318, 3); -lean_inc(x_342); -x_343 = lean_ctor_get(x_318, 4); -lean_inc(x_343); -x_344 = lean_ctor_get(x_318, 5); +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); -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_345 = x_318; -} else { - lean_dec_ref(x_318); - x_345 = lean_box(0); -} -x_346 = lean_ctor_get(x_319, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_319, 1); -lean_inc(x_347); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - x_348 = x_319; -} else { - lean_dec_ref(x_319); - x_348 = lean_box(0); -} -if (lean_is_scalar(x_348)) { - x_349 = lean_alloc_ctor(0, 3, 0); -} else { - x_349 = x_348; -} -lean_ctor_set(x_349, 0, x_346); -lean_ctor_set(x_349, 1, x_347); -lean_ctor_set(x_349, 2, x_277); -if (lean_is_scalar(x_345)) { - x_350 = lean_alloc_ctor(0, 6, 0); -} else { - x_350 = x_345; -} -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); -x_351 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_351, 0, x_339); -lean_ctor_set(x_351, 1, x_350); -return x_351; -} +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_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_352 = lean_ctor_get(x_6, 0); -x_353 = lean_ctor_get(x_6, 1); -x_354 = lean_ctor_get(x_6, 2); -x_355 = lean_ctor_get(x_6, 3); -x_356 = lean_ctor_get(x_6, 4); -lean_inc(x_356); -lean_inc(x_355); -lean_inc(x_354); -lean_inc(x_353); +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); -lean_dec(x_6); -x_357 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_357, 0, x_271); -lean_ctor_set(x_357, 1, x_27); -x_358 = lean_array_push(x_354, x_357); -x_359 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_359, 0, x_352); -lean_ctor_set(x_359, 1, x_353); -lean_ctor_set(x_359, 2, x_358); -lean_ctor_set(x_359, 3, x_355); -lean_ctor_set(x_359, 4, x_356); -x_360 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_273, x_359, x_270); -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; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; -x_361 = lean_ctor_get(x_360, 1); -lean_inc(x_361); -x_362 = lean_ctor_get(x_361, 2); -lean_inc(x_362); -x_363 = lean_ctor_get(x_360, 0); -lean_inc(x_363); -if (lean_is_exclusive(x_360)) { - lean_ctor_release(x_360, 0); - lean_ctor_release(x_360, 1); - x_364 = x_360; +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_360); + 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_361, 0); +x_365 = lean_ctor_get(x_336, 0); lean_inc(x_365); -x_366 = lean_ctor_get(x_361, 1); +x_366 = lean_ctor_get(x_336, 1); lean_inc(x_366); -x_367 = lean_ctor_get(x_361, 3); +x_367 = lean_ctor_get(x_336, 3); lean_inc(x_367); -x_368 = lean_ctor_get(x_361, 4); -lean_inc(x_368); -x_369 = lean_ctor_get(x_361, 5); -lean_inc(x_369); -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_370 = x_361; +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_361); - x_370 = lean_box(0); + lean_dec_ref(x_336); + x_368 = lean_box(0); } -x_371 = lean_ctor_get(x_362, 0); -lean_inc(x_371); -x_372 = lean_ctor_get(x_362, 1); -lean_inc(x_372); -if (lean_is_exclusive(x_362)) { - lean_ctor_release(x_362, 0); - lean_ctor_release(x_362, 1); - lean_ctor_release(x_362, 2); - x_373 = x_362; +if (lean_is_scalar(x_368)) { + x_369 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_362); - x_373 = lean_box(0); + x_369 = x_368; } -if (lean_is_scalar(x_373)) { - x_374 = lean_alloc_ctor(0, 3, 0); -} else { - x_374 = x_373; -} -lean_ctor_set(x_374, 0, x_371); -lean_ctor_set(x_374, 1, x_372); -lean_ctor_set(x_374, 2, x_277); -if (lean_is_scalar(x_370)) { - x_375 = lean_alloc_ctor(0, 6, 0); -} else { - x_375 = x_370; -} -lean_ctor_set(x_375, 0, x_365); -lean_ctor_set(x_375, 1, x_366); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_367); -lean_ctor_set(x_375, 4, x_368); -lean_ctor_set(x_375, 5, x_369); +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_376 = lean_alloc_ctor(0, 2, 0); + x_370 = lean_alloc_ctor(0, 6, 0); } else { - x_376 = x_364; + 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; +} } -lean_ctor_set(x_376, 0, x_363); -lean_ctor_set(x_376, 1, x_375); -return x_376; } else { -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_377 = lean_ctor_get(x_360, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_377, 2); -lean_inc(x_378); -x_379 = lean_ctor_get(x_360, 0); -lean_inc(x_379); -if (lean_is_exclusive(x_360)) { - lean_ctor_release(x_360, 0); - lean_ctor_release(x_360, 1); - x_380 = x_360; -} else { - lean_dec_ref(x_360); - x_380 = lean_box(0); -} -x_381 = lean_ctor_get(x_377, 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; +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_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_Init_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) +{ +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_377, 1); +x_382 = lean_ctor_get(x_381, 2); lean_inc(x_382); -x_383 = lean_ctor_get(x_377, 3); +x_383 = lean_ctor_get(x_380, 0); lean_inc(x_383); -x_384 = lean_ctor_get(x_377, 4); -lean_inc(x_384); -x_385 = lean_ctor_get(x_377, 5); +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); -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_386 = x_377; -} else { - lean_dec_ref(x_377); - x_386 = lean_box(0); -} -x_387 = lean_ctor_get(x_378, 0); +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_378, 1); +x_388 = lean_ctor_get(x_381, 4); lean_inc(x_388); -if (lean_is_exclusive(x_378)) { - lean_ctor_release(x_378, 0); - lean_ctor_release(x_378, 1); - lean_ctor_release(x_378, 2); - x_389 = x_378; +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_378); - x_389 = lean_box(0); + lean_dec_ref(x_381); + x_390 = lean_box(0); } -if (lean_is_scalar(x_389)) { - x_390 = lean_alloc_ctor(0, 3, 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 { - x_390 = x_389; + lean_dec_ref(x_382); + x_394 = lean_box(0); } -lean_ctor_set(x_390, 0, x_387); -lean_ctor_set(x_390, 1, x_388); -lean_ctor_set(x_390, 2, x_277); -if (lean_is_scalar(x_386)) { - x_391 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_394)) { + x_395 = lean_alloc_ctor(0, 4, 0); } else { - x_391 = x_386; + x_395 = x_394; } -lean_ctor_set(x_391, 0, x_381); -lean_ctor_set(x_391, 1, x_382); -lean_ctor_set(x_391, 2, x_390); -lean_ctor_set(x_391, 3, x_383); -lean_ctor_set(x_391, 4, x_384); -lean_ctor_set(x_391, 5, x_385); -if (lean_is_scalar(x_380)) { - x_392 = lean_alloc_ctor(1, 2, 0); +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_392 = x_380; -} -lean_ctor_set(x_392, 0, x_379); -lean_ctor_set(x_392, 1, x_391); -return x_392; + 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; } 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; -x_393 = lean_ctor_get(x_275, 0); -x_394 = lean_ctor_get(x_275, 1); -x_395 = lean_ctor_get(x_275, 2); -lean_inc(x_395); -lean_inc(x_394); -lean_inc(x_393); -lean_dec(x_275); -x_396 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_397 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_397, 0, x_393); -lean_ctor_set(x_397, 1, x_394); -lean_ctor_set(x_397, 2, x_396); -lean_ctor_set(x_270, 2, x_397); -x_398 = lean_ctor_get(x_6, 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; 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_6, 1); +x_399 = lean_ctor_get(x_398, 2); lean_inc(x_399); -x_400 = lean_ctor_get(x_6, 2); +x_400 = lean_ctor_get(x_380, 0); lean_inc(x_400); -x_401 = lean_ctor_get(x_6, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_6, 4); +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); +} +x_402 = lean_ctor_get(x_398, 0); lean_inc(x_402); -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_403 = x_6; +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_6); - x_403 = lean_box(0); + lean_dec_ref(x_398); + x_407 = lean_box(0); } -x_404 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_404, 0, x_271); -lean_ctor_set(x_404, 1, x_27); -x_405 = lean_array_push(x_400, x_404); -if (lean_is_scalar(x_403)) { - x_406 = lean_alloc_ctor(0, 5, 0); -} else { - x_406 = x_403; -} -lean_ctor_set(x_406, 0, x_398); -lean_ctor_set(x_406, 1, x_399); -lean_ctor_set(x_406, 2, x_405); -lean_ctor_set(x_406, 3, x_401); -lean_ctor_set(x_406, 4, x_402); -x_407 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_273, x_406, x_270); -if (lean_obj_tag(x_407) == 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; 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_407, 1); +x_408 = lean_ctor_get(x_399, 0); lean_inc(x_408); -x_409 = lean_ctor_get(x_408, 2); +x_409 = lean_ctor_get(x_399, 1); lean_inc(x_409); -x_410 = lean_ctor_get(x_407, 0); +x_410 = lean_ctor_get(x_399, 3); lean_inc(x_410); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - x_411 = x_407; +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; } else { - lean_dec_ref(x_407); + lean_dec_ref(x_399); x_411 = lean_box(0); } -x_412 = lean_ctor_get(x_408, 0); -lean_inc(x_412); -x_413 = lean_ctor_get(x_408, 1); -lean_inc(x_413); -x_414 = lean_ctor_get(x_408, 3); -lean_inc(x_414); -x_415 = lean_ctor_get(x_408, 4); -lean_inc(x_415); -x_416 = lean_ctor_get(x_408, 5); -lean_inc(x_416); -if (lean_is_exclusive(x_408)) { - lean_ctor_release(x_408, 0); - lean_ctor_release(x_408, 1); - lean_ctor_release(x_408, 2); - lean_ctor_release(x_408, 3); - lean_ctor_release(x_408, 4); - lean_ctor_release(x_408, 5); - x_417 = x_408; -} else { - lean_dec_ref(x_408); - x_417 = lean_box(0); -} -x_418 = lean_ctor_get(x_409, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_409, 1); -lean_inc(x_419); -if (lean_is_exclusive(x_409)) { - lean_ctor_release(x_409, 0); - lean_ctor_release(x_409, 1); - lean_ctor_release(x_409, 2); - x_420 = x_409; -} else { - lean_dec_ref(x_409); - x_420 = lean_box(0); -} -if (lean_is_scalar(x_420)) { - x_421 = lean_alloc_ctor(0, 3, 0); -} else { - x_421 = x_420; -} -lean_ctor_set(x_421, 0, x_418); -lean_ctor_set(x_421, 1, x_419); -lean_ctor_set(x_421, 2, x_395); -if (lean_is_scalar(x_417)) { - x_422 = lean_alloc_ctor(0, 6, 0); -} else { - x_422 = x_417; -} -lean_ctor_set(x_422, 0, x_412); -lean_ctor_set(x_422, 1, x_413); -lean_ctor_set(x_422, 2, x_421); -lean_ctor_set(x_422, 3, x_414); -lean_ctor_set(x_422, 4, x_415); -lean_ctor_set(x_422, 5, x_416); if (lean_is_scalar(x_411)) { - x_423 = lean_alloc_ctor(0, 2, 0); + x_412 = lean_alloc_ctor(0, 4, 0); } else { - x_423 = x_411; + x_412 = x_411; +} +lean_ctor_set(x_412, 0, x_408); +lean_ctor_set(x_412, 1, x_409); +lean_ctor_set(x_412, 2, x_291); +lean_ctor_set(x_412, 3, x_410); +if (lean_is_scalar(x_407)) { + x_413 = lean_alloc_ctor(0, 6, 0); +} else { + x_413 = x_407; +} +lean_ctor_set(x_413, 0, x_402); +lean_ctor_set(x_413, 1, x_403); +lean_ctor_set(x_413, 2, x_412); +lean_ctor_set(x_413, 3, x_404); +lean_ctor_set(x_413, 4, x_405); +lean_ctor_set(x_413, 5, x_406); +if (lean_is_scalar(x_401)) { + x_414 = lean_alloc_ctor(1, 2, 0); +} else { + x_414 = x_401; +} +lean_ctor_set(x_414, 0, x_400); +lean_ctor_set(x_414, 1, x_413); +return x_414; +} } -lean_ctor_set(x_423, 0, x_410); -lean_ctor_set(x_423, 1, x_422); -return x_423; } else { -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_424 = lean_ctor_get(x_407, 1); +lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; +x_415 = lean_ctor_get(x_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_424, 2); +x_425 = lean_ctor_get(x_6, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_407, 0); -lean_inc(x_426); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - x_427 = x_407; -} else { - lean_dec_ref(x_407); - 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); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - lean_ctor_release(x_425, 2); - x_436 = x_425; -} else { - lean_dec_ref(x_425); - x_436 = lean_box(0); -} -if (lean_is_scalar(x_436)) { - x_437 = lean_alloc_ctor(0, 3, 0); -} else { - x_437 = x_436; -} -lean_ctor_set(x_437, 0, x_434); -lean_ctor_set(x_437, 1, x_435); -lean_ctor_set(x_437, 2, x_395); -if (lean_is_scalar(x_433)) { - x_438 = lean_alloc_ctor(0, 6, 0); -} else { - x_438 = x_433; -} -lean_ctor_set(x_438, 0, x_428); -lean_ctor_set(x_438, 1, x_429); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_430); -lean_ctor_set(x_438, 4, x_431); -lean_ctor_set(x_438, 5, x_432); -if (lean_is_scalar(x_427)) { - x_439 = lean_alloc_ctor(1, 2, 0); -} else { - x_439 = x_427; -} -lean_ctor_set(x_439, 0, x_426); -lean_ctor_set(x_439, 1, x_438); -return x_439; -} -} -} -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; -x_440 = lean_ctor_get(x_270, 2); -x_441 = lean_ctor_get(x_270, 0); -x_442 = lean_ctor_get(x_270, 1); -x_443 = lean_ctor_get(x_270, 3); -x_444 = lean_ctor_get(x_270, 4); -x_445 = lean_ctor_get(x_270, 5); -lean_inc(x_445); -lean_inc(x_444); -lean_inc(x_443); -lean_inc(x_440); -lean_inc(x_442); -lean_inc(x_441); -lean_dec(x_270); -x_446 = lean_ctor_get(x_440, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_440, 1); -lean_inc(x_447); -x_448 = lean_ctor_get(x_440, 2); -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); - x_449 = x_440; -} else { - lean_dec_ref(x_440); - x_449 = lean_box(0); -} -x_450 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_449)) { - x_451 = lean_alloc_ctor(0, 3, 0); -} else { - x_451 = x_449; -} -lean_ctor_set(x_451, 0, x_446); -lean_ctor_set(x_451, 1, x_447); -lean_ctor_set(x_451, 2, x_450); -x_452 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_452, 0, x_441); -lean_ctor_set(x_452, 1, x_442); -lean_ctor_set(x_452, 2, x_451); -lean_ctor_set(x_452, 3, x_443); -lean_ctor_set(x_452, 4, x_444); -lean_ctor_set(x_452, 5, x_445); -x_453 = lean_ctor_get(x_6, 0); -lean_inc(x_453); -x_454 = lean_ctor_get(x_6, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_6, 2); -lean_inc(x_455); -x_456 = lean_ctor_get(x_6, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_6, 4); -lean_inc(x_457); 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_458 = x_6; + x_426 = x_6; } else { lean_dec_ref(x_6); - x_458 = lean_box(0); + x_426 = lean_box(0); } -x_459 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_459, 0, x_271); -lean_ctor_set(x_459, 1, x_27); -x_460 = lean_array_push(x_455, x_459); -if (lean_is_scalar(x_458)) { - x_461 = lean_alloc_ctor(0, 5, 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); } else { - x_461 = x_458; + x_429 = x_426; } -lean_ctor_set(x_461, 0, x_453); -lean_ctor_set(x_461, 1, x_454); -lean_ctor_set(x_461, 2, x_460); -lean_ctor_set(x_461, 3, x_456); -lean_ctor_set(x_461, 4, x_457); -x_462 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_273, x_461, x_452); -if (lean_obj_tag(x_462) == 0) +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_Init_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_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; -x_463 = lean_ctor_get(x_462, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_463, 2); -lean_inc(x_464); -x_465 = lean_ctor_get(x_462, 0); -lean_inc(x_465); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - x_466 = x_462; +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_462); - x_466 = lean_box(0); + lean_dec_ref(x_430); + x_434 = lean_box(0); } -x_467 = lean_ctor_get(x_463, 0); -lean_inc(x_467); -x_468 = lean_ctor_get(x_463, 1); -lean_inc(x_468); -x_469 = lean_ctor_get(x_463, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_463, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_448); + x_457 = 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; +} else { + lean_dec_ref(x_449); + x_461 = lean_box(0); +} +if (lean_is_scalar(x_461)) { + x_462 = lean_alloc_ctor(0, 4, 0); +} else { + x_462 = x_461; +} +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); +} else { + x_463 = x_457; +} +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); +} else { + x_464 = x_451; +} +lean_ctor_set(x_464, 0, x_450); +lean_ctor_set(x_464, 1, x_463); +return x_464; +} +} +} +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); -x_471 = lean_ctor_get(x_463, 5); +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); -if (lean_is_exclusive(x_463)) { - lean_ctor_release(x_463, 0); - lean_ctor_release(x_463, 1); - lean_ctor_release(x_463, 2); - lean_ctor_release(x_463, 3); - lean_ctor_release(x_463, 4); - lean_ctor_release(x_463, 5); - x_472 = x_463; -} else { - lean_dec_ref(x_463); - x_472 = lean_box(0); -} -x_473 = lean_ctor_get(x_464, 0); +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_464, 1); +x_474 = lean_ctor_get(x_465, 3); lean_inc(x_474); -if (lean_is_exclusive(x_464)) { - lean_ctor_release(x_464, 0); - lean_ctor_release(x_464, 1); - lean_ctor_release(x_464, 2); - x_475 = x_464; +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; } else { - lean_dec_ref(x_464); + lean_dec_ref(x_465); x_475 = lean_box(0); } +x_476 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_475)) { - x_476 = lean_alloc_ctor(0, 3, 0); + x_477 = lean_alloc_ctor(0, 4, 0); } else { - x_476 = x_475; + x_477 = x_475; } -lean_ctor_set(x_476, 0, x_473); -lean_ctor_set(x_476, 1, x_474); -lean_ctor_set(x_476, 2, x_448); -if (lean_is_scalar(x_472)) { - x_477 = lean_alloc_ctor(0, 6, 0); -} else { - x_477 = x_472; -} -lean_ctor_set(x_477, 0, x_467); -lean_ctor_set(x_477, 1, x_468); +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_469); -lean_ctor_set(x_477, 4, x_470); -lean_ctor_set(x_477, 5, x_471); -if (lean_is_scalar(x_466)) { - x_478 = lean_alloc_ctor(0, 2, 0); -} else { - x_478 = x_466; -} -lean_ctor_set(x_478, 0, x_465); -lean_ctor_set(x_478, 1, x_477); -return x_478; -} -else -{ -lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; 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; -x_479 = lean_ctor_get(x_462, 1); +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_479, 2); +x_480 = lean_ctor_get(x_6, 1); lean_inc(x_480); -x_481 = lean_ctor_get(x_462, 0); +x_481 = lean_ctor_get(x_6, 2); lean_inc(x_481); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - x_482 = x_462; -} else { - lean_dec_ref(x_462); - x_482 = lean_box(0); -} -x_483 = lean_ctor_get(x_479, 0); +x_482 = lean_ctor_get(x_6, 3); +lean_inc(x_482); +x_483 = lean_ctor_get(x_6, 4); lean_inc(x_483); -x_484 = lean_ctor_get(x_479, 1); -lean_inc(x_484); -x_485 = lean_ctor_get(x_479, 3); -lean_inc(x_485); -x_486 = lean_ctor_get(x_479, 4); -lean_inc(x_486); -x_487 = lean_ctor_get(x_479, 5); -lean_inc(x_487); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - lean_ctor_release(x_479, 2); - lean_ctor_release(x_479, 3); - lean_ctor_release(x_479, 4); - lean_ctor_release(x_479, 5); - x_488 = x_479; +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; } else { - lean_dec_ref(x_479); - x_488 = lean_box(0); + lean_dec_ref(x_6); + x_484 = lean_box(0); } -x_489 = lean_ctor_get(x_480, 0); +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); +} else { + x_487 = x_484; +} +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_Init_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_480, 1); +x_490 = lean_ctor_get(x_489, 2); lean_inc(x_490); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - lean_ctor_release(x_480, 2); - x_491 = x_480; +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; } else { - lean_dec_ref(x_480); - x_491 = lean_box(0); + lean_dec_ref(x_488); + x_492 = lean_box(0); } -if (lean_is_scalar(x_491)) { - x_492 = lean_alloc_ctor(0, 3, 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 { - x_492 = x_491; + lean_dec_ref(x_489); + x_498 = lean_box(0); } -lean_ctor_set(x_492, 0, x_489); -lean_ctor_set(x_492, 1, x_490); -lean_ctor_set(x_492, 2, x_448); -if (lean_is_scalar(x_488)) { - x_493 = lean_alloc_ctor(0, 6, 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 { - x_493 = x_488; + lean_dec_ref(x_490); + x_502 = lean_box(0); } -lean_ctor_set(x_493, 0, x_483); -lean_ctor_set(x_493, 1, x_484); -lean_ctor_set(x_493, 2, x_492); -lean_ctor_set(x_493, 3, x_485); -lean_ctor_set(x_493, 4, x_486); -lean_ctor_set(x_493, 5, x_487); -if (lean_is_scalar(x_482)) { - x_494 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_502)) { + x_503 = lean_alloc_ctor(0, 4, 0); } else { - x_494 = x_482; + x_503 = x_502; } -lean_ctor_set(x_494, 0, x_481); -lean_ctor_set(x_494, 1, x_493); -return x_494; +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_495; +uint8_t x_523; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_495 = !lean_is_exclusive(x_264); -if (x_495 == 0) +x_523 = !lean_is_exclusive(x_278); +if (x_523 == 0) { -return x_264; +return x_278; } else { -lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_496 = lean_ctor_get(x_264, 0); -x_497 = lean_ctor_get(x_264, 1); -lean_inc(x_497); -lean_inc(x_496); -lean_dec(x_264); -x_498 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_498, 0, x_496); -lean_ctor_set(x_498, 1, x_497); -return x_498; +lean_object* x_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; } } } @@ -4770,56 +4887,56 @@ return x_498; } else { -uint8_t x_499; +uint8_t x_527; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_499 = !lean_is_exclusive(x_32); -if (x_499 == 0) +x_527 = !lean_is_exclusive(x_32); +if (x_527 == 0) { return x_32; } else { -lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_500 = lean_ctor_get(x_32, 0); -x_501 = lean_ctor_get(x_32, 1); -lean_inc(x_501); -lean_inc(x_500); +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_dec(x_32); -x_502 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_502, 0, x_500); -lean_ctor_set(x_502, 1, x_501); -return x_502; +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; } } } else { -uint8_t x_503; +uint8_t x_531; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_503 = !lean_is_exclusive(x_28); -if (x_503 == 0) +x_531 = !lean_is_exclusive(x_28); +if (x_531 == 0) { return x_28; } else { -lean_object* x_504; lean_object* x_505; lean_object* x_506; -x_504 = lean_ctor_get(x_28, 0); -x_505 = lean_ctor_get(x_28, 1); -lean_inc(x_505); -lean_inc(x_504); +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_dec(x_28); -x_506 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_506, 0, x_504); -lean_ctor_set(x_506, 1, x_505); -return x_506; +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; } } } @@ -5052,82 +5169,89 @@ return x_43; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; +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_54 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -lean_ctor_set(x_54, 2, x_37); -lean_ctor_set(x_44, 2, x_54); +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; } } 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; -x_55 = lean_ctor_get(x_44, 0); -x_56 = lean_ctor_get(x_44, 1); -x_57 = lean_ctor_get(x_44, 3); -x_58 = lean_ctor_get(x_44, 4); -x_59 = lean_ctor_get(x_44, 5); +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +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_inc(x_57); lean_inc(x_56); -lean_inc(x_55); lean_dec(x_44); -x_60 = lean_ctor_get(x_45, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_45, 1); +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); - x_62 = x_45; + lean_ctor_release(x_45, 3); + x_64 = x_45; } else { lean_dec_ref(x_45); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 4, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_61); -lean_ctor_set(x_63, 2, x_37); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_55); -lean_ctor_set(x_64, 1, x_56); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_57); -lean_ctor_set(x_64, 4, x_58); -lean_ctor_set(x_64, 5, x_59); -lean_ctor_set(x_43, 1, x_64); +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; } } 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_43, 0); -lean_inc(x_65); -lean_dec(x_43); -x_66 = lean_ctor_get(x_44, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_44, 1); +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); -x_68 = lean_ctor_get(x_44, 3); +lean_dec(x_43); +x_68 = lean_ctor_get(x_44, 0); lean_inc(x_68); -x_69 = lean_ctor_get(x_44, 4); +x_69 = lean_ctor_get(x_44, 1); lean_inc(x_69); -x_70 = lean_ctor_get(x_44, 5); +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); @@ -5135,1877 +5259,1976 @@ if (lean_is_exclusive(x_44)) { lean_ctor_release(x_44, 3); lean_ctor_release(x_44, 4); lean_ctor_release(x_44, 5); - x_71 = x_44; + x_73 = x_44; } else { lean_dec_ref(x_44); - x_71 = lean_box(0); + x_73 = lean_box(0); } -x_72 = lean_ctor_get(x_45, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_45, 1); -lean_inc(x_73); +x_74 = lean_ctor_get(x_45, 0); +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); - x_74 = x_45; + lean_ctor_release(x_45, 3); + x_77 = x_45; } else { lean_dec_ref(x_45); - x_74 = lean_box(0); + x_77 = lean_box(0); } -if (lean_is_scalar(x_74)) { - x_75 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(0, 4, 0); } else { - x_75 = x_74; + x_78 = x_77; } -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_37); -if (lean_is_scalar(x_71)) { - x_76 = lean_alloc_ctor(0, 6, 0); +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_76 = x_71; + x_79 = x_73; } -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_67); -lean_ctor_set(x_76, 2, x_75); -lean_ctor_set(x_76, 3, x_68); -lean_ctor_set(x_76, 4, x_69); -lean_ctor_set(x_76, 5, x_70); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_65); -lean_ctor_set(x_77, 1, x_76); -return x_77; +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; } } else { -lean_object* x_78; lean_object* x_79; uint8_t x_80; -x_78 = lean_ctor_get(x_43, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 2); -lean_inc(x_79); -x_80 = !lean_is_exclusive(x_43); -if (x_80 == 0) -{ -lean_object* x_81; uint8_t x_82; +lean_object* x_81; lean_object* x_82; uint8_t x_83; x_81 = lean_ctor_get(x_43, 1); -lean_dec(x_81); -x_82 = !lean_is_exclusive(x_78); -if (x_82 == 0) +lean_inc(x_81); +x_82 = lean_ctor_get(x_81, 2); +lean_inc(x_82); +x_83 = !lean_is_exclusive(x_43); +if (x_83 == 0) { -lean_object* x_83; uint8_t x_84; -x_83 = lean_ctor_get(x_78, 2); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_79); -if (x_84 == 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_85; -x_85 = lean_ctor_get(x_79, 2); -lean_dec(x_85); -lean_ctor_set(x_79, 2, x_37); +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_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_79, 0); -x_87 = lean_ctor_get(x_79, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_79); -x_88 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -lean_ctor_set(x_88, 2, x_37); -lean_ctor_set(x_78, 2, x_88); -return x_43; -} -} -else -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_89 = lean_ctor_get(x_78, 0); -x_90 = lean_ctor_get(x_78, 1); -x_91 = lean_ctor_get(x_78, 3); -x_92 = lean_ctor_get(x_78, 4); -x_93 = lean_ctor_get(x_78, 5); -lean_inc(x_93); -lean_inc(x_92); +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_78); -x_94 = lean_ctor_get(x_79, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_79, 1); -lean_inc(x_95); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - x_96 = x_79; -} else { - lean_dec_ref(x_79); - x_96 = lean_box(0); -} -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 3, 0); -} else { - x_97 = x_96; -} -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_37); -x_98 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_98, 0, x_89); -lean_ctor_set(x_98, 1, x_90); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_91); -lean_ctor_set(x_98, 4, x_92); -lean_ctor_set(x_98, 5, x_93); -lean_ctor_set(x_43, 1, x_98); +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_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_99 = lean_ctor_get(x_43, 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; +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); -lean_dec(x_43); -x_100 = lean_ctor_get(x_78, 0); +x_100 = lean_ctor_get(x_82, 3); lean_inc(x_100); -x_101 = lean_ctor_get(x_78, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_78, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_78, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_78, 5); +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; +} else { + lean_dec_ref(x_82); + 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_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); -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_105 = x_78; -} else { - lean_dec_ref(x_78); - x_105 = lean_box(0); -} -x_106 = lean_ctor_get(x_79, 0); +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_79, 1); +x_107 = lean_ctor_get(x_81, 3); lean_inc(x_107); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - lean_ctor_release(x_79, 2); - x_108 = x_79; +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; } else { - lean_dec_ref(x_79); - x_108 = lean_box(0); + lean_dec_ref(x_81); + x_110 = lean_box(0); } -if (lean_is_scalar(x_108)) { - x_109 = lean_alloc_ctor(0, 3, 0); +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 { - x_109 = x_108; + lean_dec_ref(x_82); + x_114 = lean_box(0); } -lean_ctor_set(x_109, 0, x_106); -lean_ctor_set(x_109, 1, x_107); -lean_ctor_set(x_109, 2, x_37); -if (lean_is_scalar(x_105)) { - x_110 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_114)) { + x_115 = lean_alloc_ctor(0, 4, 0); } else { - x_110 = x_105; + x_115 = x_114; } -lean_ctor_set(x_110, 0, x_100); -lean_ctor_set(x_110, 1, x_101); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_102); -lean_ctor_set(x_110, 4, x_103); -lean_ctor_set(x_110, 5, x_104); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_99); -lean_ctor_set(x_111, 1, x_110); -return x_111; +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_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_11, 0); -x_113 = lean_ctor_get(x_11, 1); -x_114 = lean_ctor_get(x_11, 2); -x_115 = lean_ctor_get(x_11, 3); -x_116 = lean_ctor_get(x_11, 4); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_11); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_31); -lean_ctor_set(x_117, 1, x_19); -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___private_Init_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_119, x_30); -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; -x_121 = lean_ctor_get(x_120, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_121, 2); +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); -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; -} else { - lean_dec_ref(x_120); - x_124 = lean_box(0); -} -x_125 = lean_ctor_get(x_121, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_121, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_121, 3); +lean_inc(x_121); +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_Init_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_121, 4); +x_128 = lean_ctor_get(x_127, 2); lean_inc(x_128); -x_129 = lean_ctor_get(x_121, 5); +x_129 = lean_ctor_get(x_126, 0); 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_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + x_130 = x_126; } else { - lean_dec_ref(x_121); + lean_dec_ref(x_126); x_130 = lean_box(0); } -x_131 = lean_ctor_get(x_122, 0); +x_131 = lean_ctor_get(x_127, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_122, 1); +x_132 = lean_ctor_get(x_127, 1); 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); - x_133 = x_122; +x_133 = lean_ctor_get(x_127, 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; } else { - lean_dec_ref(x_122); - x_133 = lean_box(0); + lean_dec_ref(x_127); + x_136 = lean_box(0); } -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(0, 3, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_131); -lean_ctor_set(x_134, 1, x_132); -lean_ctor_set(x_134, 2, x_37); -if (lean_is_scalar(x_130)) { - x_135 = lean_alloc_ctor(0, 6, 0); -} else { - x_135 = x_130; -} -lean_ctor_set(x_135, 0, x_125); -lean_ctor_set(x_135, 1, x_126); -lean_ctor_set(x_135, 2, x_134); -lean_ctor_set(x_135, 3, x_127); -lean_ctor_set(x_135, 4, x_128); -lean_ctor_set(x_135, 5, x_129); -if (lean_is_scalar(x_124)) { - x_136 = lean_alloc_ctor(0, 2, 0); -} else { - x_136 = x_124; -} -lean_ctor_set(x_136, 0, x_123); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -x_137 = lean_ctor_get(x_120, 1); +x_137 = lean_ctor_get(x_128, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_137, 2); +x_138 = lean_ctor_get(x_128, 1); lean_inc(x_138); -x_139 = lean_ctor_get(x_120, 0); +x_139 = lean_ctor_get(x_128, 3); lean_inc(x_139); -if (lean_is_exclusive(x_120)) { - lean_ctor_release(x_120, 0); - lean_ctor_release(x_120, 1); - x_140 = x_120; +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; } else { - lean_dec_ref(x_120); + lean_dec_ref(x_128); x_140 = lean_box(0); } -x_141 = lean_ctor_get(x_137, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_137, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_137, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_137, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_137, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - lean_ctor_release(x_137, 2); - lean_ctor_release(x_137, 3); - lean_ctor_release(x_137, 4); - lean_ctor_release(x_137, 5); - x_146 = x_137; -} else { - lean_dec_ref(x_137); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_138, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_138, 1); -lean_inc(x_148); -if (lean_is_exclusive(x_138)) { - lean_ctor_release(x_138, 0); - lean_ctor_release(x_138, 1); - lean_ctor_release(x_138, 2); - x_149 = x_138; -} else { - lean_dec_ref(x_138); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 3, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_147); -lean_ctor_set(x_150, 1, x_148); -lean_ctor_set(x_150, 2, x_37); -if (lean_is_scalar(x_146)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_146; -} -lean_ctor_set(x_151, 0, x_141); -lean_ctor_set(x_151, 1, x_142); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_143); -lean_ctor_set(x_151, 4, x_144); -lean_ctor_set(x_151, 5, x_145); if (lean_is_scalar(x_140)) { - x_152 = lean_alloc_ctor(1, 2, 0); + x_141 = lean_alloc_ctor(0, 4, 0); } else { - x_152 = x_140; + x_141 = x_140; } -lean_ctor_set(x_152, 0, x_139); -lean_ctor_set(x_152, 1, x_151); -return x_152; +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); +if (lean_is_scalar(x_130)) { + x_143 = lean_alloc_ctor(0, 2, 0); +} else { + x_143 = x_130; +} +lean_ctor_set(x_143, 0, x_129); +lean_ctor_set(x_143, 1, x_142); +return x_143; +} +else +{ +lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; +x_144 = lean_ctor_get(x_126, 1); +lean_inc(x_144); +x_145 = lean_ctor_get(x_144, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_126, 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); +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; +} else { + lean_dec_ref(x_144); + x_153 = 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; +} else { + lean_dec_ref(x_145); + 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_37); +lean_ctor_set(x_158, 3, x_156); +if (lean_is_scalar(x_153)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_153; +} +lean_ctor_set(x_159, 0, x_148); +lean_ctor_set(x_159, 1, x_149); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_150); +lean_ctor_set(x_159, 4, x_151); +lean_ctor_set(x_159, 5, x_152); +if (lean_is_scalar(x_147)) { + x_160 = lean_alloc_ctor(1, 2, 0); +} else { + x_160 = x_147; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; } } } else { -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_153 = lean_ctor_get(x_35, 0); -x_154 = lean_ctor_get(x_35, 1); -x_155 = lean_ctor_get(x_35, 2); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_dec(x_35); -x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_157 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_157, 0, x_153); -lean_ctor_set(x_157, 1, x_154); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_30, 2, x_157); -x_158 = lean_ctor_get(x_11, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_11, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_11, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_11, 3); -lean_inc(x_161); -x_162 = lean_ctor_get(x_11, 4); +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); 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_163 = x_11; + x_172 = x_11; } else { lean_dec_ref(x_11); - x_163 = lean_box(0); + x_172 = lean_box(0); } -x_164 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_164, 0, x_31); -lean_ctor_set(x_164, 1, x_19); -x_165 = lean_array_push(x_160, x_164); -if (lean_is_scalar(x_163)) { - x_166 = lean_alloc_ctor(0, 5, 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); } else { - x_166 = x_163; + x_175 = x_172; } -lean_ctor_set(x_166, 0, x_158); -lean_ctor_set(x_166, 1, x_159); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_161); -lean_ctor_set(x_166, 4, x_162); -x_167 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_166, x_30); -if (lean_obj_tag(x_167) == 0) +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_Init_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_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; -x_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_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_169, 1); +x_179 = lean_ctor_get(x_176, 0); lean_inc(x_179); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - lean_ctor_release(x_169, 2); - x_180 = x_169; +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_169); + lean_dec_ref(x_176); x_180 = lean_box(0); } -if (lean_is_scalar(x_180)) { - x_181 = lean_alloc_ctor(0, 3, 0); -} else { - x_181 = x_180; -} -lean_ctor_set(x_181, 0, x_178); -lean_ctor_set(x_181, 1, x_179); -lean_ctor_set(x_181, 2, x_155); -if (lean_is_scalar(x_177)) { - x_182 = lean_alloc_ctor(0, 6, 0); -} else { - x_182 = x_177; -} -lean_ctor_set(x_182, 0, x_172); -lean_ctor_set(x_182, 1, x_173); -lean_ctor_set(x_182, 2, x_181); -lean_ctor_set(x_182, 3, x_174); -lean_ctor_set(x_182, 4, x_175); -lean_ctor_set(x_182, 5, x_176); -if (lean_is_scalar(x_171)) { - x_183 = lean_alloc_ctor(0, 2, 0); -} else { - x_183 = x_171; -} -lean_ctor_set(x_183, 0, x_170); -lean_ctor_set(x_183, 1, x_182); -return x_183; -} -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; lean_object* x_199; -x_184 = lean_ctor_get(x_167, 1); +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_184, 2); +x_185 = lean_ctor_get(x_177, 5); lean_inc(x_185); -x_186 = lean_ctor_get(x_167, 0); -lean_inc(x_186); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - x_187 = x_167; +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_167); - x_187 = lean_box(0); + lean_dec_ref(x_177); + x_186 = lean_box(0); } -x_188 = lean_ctor_get(x_184, 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_184, 1); +x_189 = lean_ctor_get(x_178, 3); lean_inc(x_189); -x_190 = lean_ctor_get(x_184, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_184, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_184, 5); -lean_inc(x_192); -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_193 = x_184; +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_184); - x_193 = lean_box(0); + lean_dec_ref(x_178); + x_190 = lean_box(0); } -x_194 = lean_ctor_get(x_185, 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; +} +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_inc(x_194); -x_195 = lean_ctor_get(x_185, 1); +x_195 = lean_ctor_get(x_194, 2); 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); - x_196 = x_185; +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; } else { - lean_dec_ref(x_185); - x_196 = lean_box(0); + lean_dec_ref(x_176); + x_197 = lean_box(0); } -if (lean_is_scalar(x_196)) { - x_197 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_200); +x_201 = lean_ctor_get(x_194, 4); +lean_inc(x_201); +x_202 = lean_ctor_get(x_194, 5); +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 { - x_197 = x_196; + lean_dec_ref(x_194); + x_203 = lean_box(0); } -lean_ctor_set(x_197, 0, x_194); -lean_ctor_set(x_197, 1, x_195); -lean_ctor_set(x_197, 2, x_155); -if (lean_is_scalar(x_193)) { - x_198 = lean_alloc_ctor(0, 6, 0); +x_204 = lean_ctor_get(x_195, 0); +lean_inc(x_204); +x_205 = lean_ctor_get(x_195, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_195, 3); +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; } else { - x_198 = x_193; + lean_dec_ref(x_195); + x_207 = lean_box(0); } -lean_ctor_set(x_198, 0, x_188); -lean_ctor_set(x_198, 1, x_189); -lean_ctor_set(x_198, 2, x_197); -lean_ctor_set(x_198, 3, x_190); -lean_ctor_set(x_198, 4, x_191); -lean_ctor_set(x_198, 5, x_192); -if (lean_is_scalar(x_187)) { - x_199 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 4, 0); } else { - x_199 = x_187; + x_208 = x_207; } -lean_ctor_set(x_199, 0, x_186); -lean_ctor_set(x_199, 1, x_198); -return x_199; +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); +} 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(1, 2, 0); +} else { + x_210 = x_197; +} +lean_ctor_set(x_210, 0, x_196); +lean_ctor_set(x_210, 1, x_209); +return x_210; } } } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; 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_200 = lean_ctor_get(x_30, 2); -x_201 = lean_ctor_get(x_30, 0); -x_202 = lean_ctor_get(x_30, 1); -x_203 = lean_ctor_get(x_30, 3); -x_204 = lean_ctor_get(x_30, 4); -x_205 = lean_ctor_get(x_30, 5); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_200); -lean_inc(x_202); -lean_inc(x_201); -lean_dec(x_30); -x_206 = lean_ctor_get(x_200, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_200, 1); -lean_inc(x_207); -x_208 = lean_ctor_get(x_200, 2); -lean_inc(x_208); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - x_209 = x_200; -} else { - lean_dec_ref(x_200); - x_209 = lean_box(0); -} -x_210 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_209)) { - x_211 = lean_alloc_ctor(0, 3, 0); -} else { - x_211 = x_209; -} -lean_ctor_set(x_211, 0, x_206); -lean_ctor_set(x_211, 1, x_207); -lean_ctor_set(x_211, 2, x_210); -x_212 = 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); -x_213 = lean_ctor_get(x_11, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_11, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_11, 2); -lean_inc(x_215); -x_216 = lean_ctor_get(x_11, 3); +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); -x_217 = lean_ctor_get(x_11, 4); +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_218 = x_11; + x_230 = x_11; } else { lean_dec_ref(x_11); - x_218 = lean_box(0); + x_230 = lean_box(0); } -x_219 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_219, 0, x_31); -lean_ctor_set(x_219, 1, x_19); -x_220 = lean_array_push(x_215, x_219); -if (lean_is_scalar(x_218)) { - x_221 = lean_alloc_ctor(0, 5, 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_221 = x_218; + x_233 = x_230; } -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___private_Init_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_221, x_212); -if (lean_obj_tag(x_222) == 0) +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_Init_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_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; -x_223 = lean_ctor_get(x_222, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_223, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_222, 0); -lean_inc(x_225); -if (lean_is_exclusive(x_222)) { - lean_ctor_release(x_222, 0); - lean_ctor_release(x_222, 1); - x_226 = x_222; +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_222); - x_226 = lean_box(0); + lean_dec_ref(x_234); + x_238 = lean_box(0); } -x_227 = lean_ctor_get(x_223, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_223, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_223, 4); -lean_inc(x_230); -x_231 = lean_ctor_get(x_223, 5); -lean_inc(x_231); -if (lean_is_exclusive(x_223)) { - lean_ctor_release(x_223, 0); - lean_ctor_release(x_223, 1); - lean_ctor_release(x_223, 2); - lean_ctor_release(x_223, 3); - lean_ctor_release(x_223, 4); - lean_ctor_release(x_223, 5); - x_232 = x_223; +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_223); - x_232 = lean_box(0); + lean_dec_ref(x_235); + x_244 = lean_box(0); } -x_233 = lean_ctor_get(x_224, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_224, 1); -lean_inc(x_234); -if (lean_is_exclusive(x_224)) { - lean_ctor_release(x_224, 0); - lean_ctor_release(x_224, 1); - lean_ctor_release(x_224, 2); - x_235 = x_224; +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_224); - x_235 = lean_box(0); + lean_dec_ref(x_236); + x_248 = lean_box(0); } -if (lean_is_scalar(x_235)) { - x_236 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_248)) { + x_249 = lean_alloc_ctor(0, 4, 0); } else { - x_236 = x_235; + x_249 = x_248; } -lean_ctor_set(x_236, 0, x_233); -lean_ctor_set(x_236, 1, x_234); -lean_ctor_set(x_236, 2, x_208); -if (lean_is_scalar(x_232)) { - x_237 = lean_alloc_ctor(0, 6, 0); +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_237 = x_232; + x_250 = x_244; } -lean_ctor_set(x_237, 0, x_227); -lean_ctor_set(x_237, 1, x_228); -lean_ctor_set(x_237, 2, x_236); -lean_ctor_set(x_237, 3, x_229); -lean_ctor_set(x_237, 4, x_230); -lean_ctor_set(x_237, 5, x_231); -if (lean_is_scalar(x_226)) { - x_238 = lean_alloc_ctor(0, 2, 0); +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_238 = x_226; + x_251 = x_238; } -lean_ctor_set(x_238, 0, x_225); -lean_ctor_set(x_238, 1, x_237); -return 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_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_239 = lean_ctor_get(x_222, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_239, 2); -lean_inc(x_240); -x_241 = lean_ctor_get(x_222, 0); -lean_inc(x_241); -if (lean_is_exclusive(x_222)) { - lean_ctor_release(x_222, 0); - lean_ctor_release(x_222, 1); - x_242 = x_222; +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_222); - x_242 = lean_box(0); + lean_dec_ref(x_234); + x_255 = lean_box(0); } -x_243 = lean_ctor_get(x_239, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_239, 1); -lean_inc(x_244); -x_245 = lean_ctor_get(x_239, 3); -lean_inc(x_245); -x_246 = lean_ctor_get(x_239, 4); -lean_inc(x_246); -x_247 = lean_ctor_get(x_239, 5); -lean_inc(x_247); -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); - lean_ctor_release(x_239, 4); - lean_ctor_release(x_239, 5); - x_248 = x_239; +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_239); - x_248 = lean_box(0); + lean_dec_ref(x_252); + x_261 = lean_box(0); } -x_249 = lean_ctor_get(x_240, 0); -lean_inc(x_249); -x_250 = lean_ctor_get(x_240, 1); -lean_inc(x_250); -if (lean_is_exclusive(x_240)) { - lean_ctor_release(x_240, 0); - lean_ctor_release(x_240, 1); - lean_ctor_release(x_240, 2); - x_251 = x_240; +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_240); - x_251 = lean_box(0); + lean_dec_ref(x_253); + x_265 = lean_box(0); } -if (lean_is_scalar(x_251)) { - x_252 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_265)) { + x_266 = lean_alloc_ctor(0, 4, 0); } else { - x_252 = x_251; + x_266 = x_265; } -lean_ctor_set(x_252, 0, x_249); -lean_ctor_set(x_252, 1, x_250); -lean_ctor_set(x_252, 2, x_208); -if (lean_is_scalar(x_248)) { - x_253 = lean_alloc_ctor(0, 6, 0); +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_253 = x_248; + x_267 = x_261; } -lean_ctor_set(x_253, 0, x_243); -lean_ctor_set(x_253, 1, x_244); -lean_ctor_set(x_253, 2, x_252); -lean_ctor_set(x_253, 3, x_245); -lean_ctor_set(x_253, 4, x_246); -lean_ctor_set(x_253, 5, x_247); -if (lean_is_scalar(x_242)) { - x_254 = lean_alloc_ctor(1, 2, 0); +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_254 = x_242; + x_268 = x_255; } -lean_ctor_set(x_254, 0, x_241); -lean_ctor_set(x_254, 1, x_253); -return x_254; +lean_ctor_set(x_268, 0, x_254); +lean_ctor_set(x_268, 1, x_267); +return x_268; } } } default: { -lean_object* x_255; lean_object* x_256; -x_255 = lean_ctor_get(x_24, 1); -lean_inc(x_255); +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_24, 1); +lean_inc(x_269); lean_dec(x_24); lean_inc(x_11); -x_256 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_255); -if (lean_obj_tag(x_256) == 0) +x_270 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_269); +if (lean_obj_tag(x_270) == 0) { -lean_object* x_257; -x_257 = lean_ctor_get(x_256, 0); -lean_inc(x_257); -if (lean_obj_tag(x_257) == 0) +lean_object* x_271; +x_271 = lean_ctor_get(x_270, 0); +lean_inc(x_271); +if (lean_obj_tag(x_271) == 0) { -lean_object* x_258; lean_object* x_259; lean_object* x_260; +lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_dec(x_19); -x_258 = lean_ctor_get(x_256, 1); -lean_inc(x_258); -lean_dec(x_256); -x_259 = lean_unsigned_to_nat(1u); -x_260 = lean_nat_add(x_10, x_259); +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); lean_dec(x_10); -x_10 = x_260; -x_12 = x_258; +x_10 = x_274; +x_12 = x_272; goto _start; } else { -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; uint8_t x_266; -x_262 = lean_ctor_get(x_256, 1); -lean_inc(x_262); -lean_dec(x_256); -x_263 = lean_ctor_get(x_257, 0); -lean_inc(x_263); -lean_dec(x_257); -x_264 = lean_unsigned_to_nat(1u); -x_265 = lean_nat_add(x_10, x_264); -lean_dec(x_10); -x_266 = !lean_is_exclusive(x_262); -if (x_266 == 0) -{ -lean_object* x_267; uint8_t x_268; -x_267 = lean_ctor_get(x_262, 2); -x_268 = !lean_is_exclusive(x_267); -if (x_268 == 0) -{ -lean_object* x_269; lean_object* x_270; uint8_t x_271; -x_269 = lean_ctor_get(x_267, 2); -x_270 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_267, 2, x_270); -x_271 = !lean_is_exclusive(x_11); -if (x_271 == 0) -{ -lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_272 = lean_ctor_get(x_11, 2); -x_273 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_273, 0, x_263); -lean_ctor_set(x_273, 1, x_19); -x_274 = lean_array_push(x_272, x_273); -lean_ctor_set(x_11, 2, x_274); -x_275 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_265, x_11, x_262); -if (lean_obj_tag(x_275) == 0) -{ -lean_object* x_276; lean_object* x_277; uint8_t x_278; -x_276 = lean_ctor_get(x_275, 1); +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); -x_277 = lean_ctor_get(x_276, 2); +lean_dec(x_270); +x_277 = lean_ctor_get(x_271, 0); lean_inc(x_277); -x_278 = !lean_is_exclusive(x_275); -if (x_278 == 0) -{ -lean_object* x_279; uint8_t x_280; -x_279 = lean_ctor_get(x_275, 1); -lean_dec(x_279); +lean_dec(x_271); +x_278 = lean_unsigned_to_nat(1u); +x_279 = lean_nat_add(x_10, x_278); +lean_dec(x_10); x_280 = !lean_is_exclusive(x_276); if (x_280 == 0) { lean_object* x_281; uint8_t x_282; x_281 = lean_ctor_get(x_276, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_277); +x_282 = !lean_is_exclusive(x_281); if (x_282 == 0) { -lean_object* x_283; -x_283 = lean_ctor_get(x_277, 2); -lean_dec(x_283); -lean_ctor_set(x_277, 2, x_269); -return x_275; -} -else +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_284; lean_object* x_285; lean_object* x_286; -x_284 = lean_ctor_get(x_277, 0); -x_285 = lean_ctor_get(x_277, 1); -lean_inc(x_285); -lean_inc(x_284); -lean_dec(x_277); -x_286 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_286, 0, x_284); -lean_ctor_set(x_286, 1, x_285); -lean_ctor_set(x_286, 2, x_269); -lean_ctor_set(x_276, 2, x_286); -return x_275; -} -} -else +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_Init_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_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_287 = lean_ctor_get(x_276, 0); -x_288 = lean_ctor_get(x_276, 1); -x_289 = lean_ctor_get(x_276, 3); -x_290 = lean_ctor_get(x_276, 4); -x_291 = lean_ctor_get(x_276, 5); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_289, 1); lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_dec(x_276); -x_292 = lean_ctor_get(x_277, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_277, 1); -lean_inc(x_293); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - x_294 = x_277; -} else { - lean_dec_ref(x_277); - x_294 = lean_box(0); -} -if (lean_is_scalar(x_294)) { - x_295 = lean_alloc_ctor(0, 3, 0); -} else { - x_295 = x_294; -} -lean_ctor_set(x_295, 0, x_292); -lean_ctor_set(x_295, 1, x_293); -lean_ctor_set(x_295, 2, x_269); -x_296 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_296, 0, x_287); -lean_ctor_set(x_296, 1, x_288); -lean_ctor_set(x_296, 2, x_295); -lean_ctor_set(x_296, 3, x_289); -lean_ctor_set(x_296, 4, x_290); -lean_ctor_set(x_296, 5, x_291); -lean_ctor_set(x_275, 1, x_296); -return x_275; -} +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_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_297 = lean_ctor_get(x_275, 0); -lean_inc(x_297); -lean_dec(x_275); -x_298 = lean_ctor_get(x_276, 0); -lean_inc(x_298); -x_299 = lean_ctor_get(x_276, 1); -lean_inc(x_299); -x_300 = lean_ctor_get(x_276, 3); +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); -x_301 = lean_ctor_get(x_276, 4); -lean_inc(x_301); -x_302 = lean_ctor_get(x_276, 5); -lean_inc(x_302); -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_303 = x_276; -} else { - lean_dec_ref(x_276); - x_303 = lean_box(0); +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; } -x_304 = lean_ctor_get(x_277, 0); -lean_inc(x_304); -x_305 = lean_ctor_get(x_277, 1); +} +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); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - x_306 = x_277; +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_inc(x_308); +x_309 = lean_ctor_get(x_291, 3); +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_277); - x_306 = lean_box(0); + lean_dec_ref(x_291); + x_310 = lean_box(0); } -if (lean_is_scalar(x_306)) { - x_307 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_310)) { + x_311 = lean_alloc_ctor(0, 4, 0); } else { - x_307 = x_306; + x_311 = x_310; } -lean_ctor_set(x_307, 0, x_304); -lean_ctor_set(x_307, 1, x_305); -lean_ctor_set(x_307, 2, x_269); -if (lean_is_scalar(x_303)) { - x_308 = lean_alloc_ctor(0, 6, 0); -} else { - x_308 = x_303; -} -lean_ctor_set(x_308, 0, x_298); -lean_ctor_set(x_308, 1, x_299); -lean_ctor_set(x_308, 2, x_307); -lean_ctor_set(x_308, 3, x_300); -lean_ctor_set(x_308, 4, x_301); -lean_ctor_set(x_308, 5, x_302); -x_309 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_309, 0, x_297); -lean_ctor_set(x_309, 1, x_308); -return x_309; +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_310; lean_object* x_311; uint8_t x_312; -x_310 = lean_ctor_get(x_275, 1); -lean_inc(x_310); -x_311 = lean_ctor_get(x_310, 2); -lean_inc(x_311); -x_312 = !lean_is_exclusive(x_275); -if (x_312 == 0) -{ -lean_object* x_313; uint8_t x_314; -x_313 = lean_ctor_get(x_275, 1); -lean_dec(x_313); -x_314 = !lean_is_exclusive(x_310); -if (x_314 == 0) -{ -lean_object* x_315; uint8_t x_316; -x_315 = lean_ctor_get(x_310, 2); -lean_dec(x_315); -x_316 = !lean_is_exclusive(x_311); -if (x_316 == 0) -{ -lean_object* x_317; -x_317 = lean_ctor_get(x_311, 2); -lean_dec(x_317); -lean_ctor_set(x_311, 2, x_269); -return x_275; -} -else -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_311, 0); -x_319 = lean_ctor_get(x_311, 1); -lean_inc(x_319); +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_inc(x_318); -lean_dec(x_311); -x_320 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_320, 0, x_318); -lean_ctor_set(x_320, 1, x_319); -lean_ctor_set(x_320, 2, x_269); -lean_ctor_set(x_310, 2, x_320); -return x_275; +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); } -} -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; -x_321 = lean_ctor_get(x_310, 0); -x_322 = lean_ctor_get(x_310, 1); -x_323 = lean_ctor_get(x_310, 3); -x_324 = lean_ctor_get(x_310, 4); -x_325 = lean_ctor_get(x_310, 5); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); +x_320 = lean_ctor_get(x_291, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_291, 1); lean_inc(x_321); -lean_dec(x_310); -x_326 = lean_ctor_get(x_311, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_311, 1); +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); -if (lean_is_exclusive(x_311)) { - lean_ctor_release(x_311, 0); - lean_ctor_release(x_311, 1); - lean_ctor_release(x_311, 2); - x_328 = x_311; -} else { - lean_dec_ref(x_311); - x_328 = lean_box(0); -} -if (lean_is_scalar(x_328)) { - x_329 = lean_alloc_ctor(0, 3, 0); -} else { - x_329 = x_328; -} -lean_ctor_set(x_329, 0, x_326); -lean_ctor_set(x_329, 1, x_327); -lean_ctor_set(x_329, 2, x_269); -x_330 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_330, 0, x_321); -lean_ctor_set(x_330, 1, x_322); -lean_ctor_set(x_330, 2, x_329); -lean_ctor_set(x_330, 3, x_323); -lean_ctor_set(x_330, 4, x_324); -lean_ctor_set(x_330, 5, x_325); -lean_ctor_set(x_275, 1, x_330); -return x_275; -} +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_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_331 = lean_ctor_get(x_275, 0); -lean_inc(x_331); -lean_dec(x_275); -x_332 = lean_ctor_get(x_310, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_310, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_310, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_310, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_310, 5); +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); -if (lean_is_exclusive(x_310)) { - lean_ctor_release(x_310, 0); - lean_ctor_release(x_310, 1); - lean_ctor_release(x_310, 2); - lean_ctor_release(x_310, 3); - lean_ctor_release(x_310, 4); - lean_ctor_release(x_310, 5); - x_337 = x_310; -} else { - lean_dec_ref(x_310); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_311, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_311, 1); -lean_inc(x_339); -if (lean_is_exclusive(x_311)) { - lean_ctor_release(x_311, 0); - lean_ctor_release(x_311, 1); - lean_ctor_release(x_311, 2); - x_340 = x_311; -} else { - lean_dec_ref(x_311); - x_340 = lean_box(0); -} -if (lean_is_scalar(x_340)) { - x_341 = lean_alloc_ctor(0, 3, 0); -} else { - x_341 = x_340; -} -lean_ctor_set(x_341, 0, x_338); -lean_ctor_set(x_341, 1, x_339); -lean_ctor_set(x_341, 2, x_269); -if (lean_is_scalar(x_337)) { - x_342 = lean_alloc_ctor(0, 6, 0); -} else { - x_342 = x_337; -} -lean_ctor_set(x_342, 0, x_332); -lean_ctor_set(x_342, 1, x_333); -lean_ctor_set(x_342, 2, x_341); -lean_ctor_set(x_342, 3, x_334); -lean_ctor_set(x_342, 4, x_335); -lean_ctor_set(x_342, 5, x_336); -x_343 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_343, 0, x_331); -lean_ctor_set(x_343, 1, x_342); -return x_343; -} +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_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_344 = lean_ctor_get(x_11, 0); -x_345 = lean_ctor_get(x_11, 1); -x_346 = lean_ctor_get(x_11, 2); -x_347 = lean_ctor_get(x_11, 3); -x_348 = lean_ctor_get(x_11, 4); -lean_inc(x_348); -lean_inc(x_347); -lean_inc(x_346); -lean_inc(x_345); +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); -lean_dec(x_11); -x_349 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_349, 0, x_263); -lean_ctor_set(x_349, 1, x_19); -x_350 = lean_array_push(x_346, x_349); -x_351 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_351, 0, x_344); -lean_ctor_set(x_351, 1, x_345); -lean_ctor_set(x_351, 2, x_350); -lean_ctor_set(x_351, 3, x_347); -lean_ctor_set(x_351, 4, x_348); -x_352 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_265, x_351, x_262); -if (lean_obj_tag(x_352) == 0) -{ -lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; -x_353 = lean_ctor_get(x_352, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_353, 2); -lean_inc(x_354); -x_355 = lean_ctor_get(x_352, 0); -lean_inc(x_355); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - x_356 = x_352; +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_352); + 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_353, 0); +x_357 = lean_ctor_get(x_328, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_353, 1); +x_358 = lean_ctor_get(x_328, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_353, 3); +x_359 = lean_ctor_get(x_328, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_353, 4); -lean_inc(x_360); -x_361 = lean_ctor_get(x_353, 5); -lean_inc(x_361); -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); - lean_ctor_release(x_353, 4); - lean_ctor_release(x_353, 5); - x_362 = x_353; +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_353); - x_362 = lean_box(0); + lean_dec_ref(x_328); + x_360 = lean_box(0); } -x_363 = lean_ctor_get(x_354, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_354, 1); -lean_inc(x_364); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - lean_ctor_release(x_354, 2); - x_365 = x_354; +if (lean_is_scalar(x_360)) { + x_361 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_354); - x_365 = lean_box(0); + x_361 = x_360; } -if (lean_is_scalar(x_365)) { - x_366 = lean_alloc_ctor(0, 3, 0); -} else { - x_366 = x_365; -} -lean_ctor_set(x_366, 0, x_363); -lean_ctor_set(x_366, 1, x_364); -lean_ctor_set(x_366, 2, x_269); -if (lean_is_scalar(x_362)) { - x_367 = lean_alloc_ctor(0, 6, 0); -} else { - x_367 = x_362; -} -lean_ctor_set(x_367, 0, x_357); -lean_ctor_set(x_367, 1, x_358); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_359); -lean_ctor_set(x_367, 4, x_360); -lean_ctor_set(x_367, 5, x_361); +lean_ctor_set(x_361, 0, x_357); +lean_ctor_set(x_361, 1, x_358); +lean_ctor_set(x_361, 2, x_283); +lean_ctor_set(x_361, 3, x_359); if (lean_is_scalar(x_356)) { - x_368 = lean_alloc_ctor(0, 2, 0); + x_362 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_356; + 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; +} } -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; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_369 = lean_ctor_get(x_352, 1); -lean_inc(x_369); -x_370 = lean_ctor_get(x_369, 2); -lean_inc(x_370); -x_371 = lean_ctor_get(x_352, 0); -lean_inc(x_371); -if (lean_is_exclusive(x_352)) { - lean_ctor_release(x_352, 0); - lean_ctor_release(x_352, 1); - x_372 = x_352; -} else { - lean_dec_ref(x_352); - x_372 = lean_box(0); -} -x_373 = lean_ctor_get(x_369, 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; +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_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_Init_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) +{ +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_369, 1); +x_374 = lean_ctor_get(x_373, 2); lean_inc(x_374); -x_375 = lean_ctor_get(x_369, 3); +x_375 = lean_ctor_get(x_372, 0); lean_inc(x_375); -x_376 = lean_ctor_get(x_369, 4); -lean_inc(x_376); -x_377 = lean_ctor_get(x_369, 5); +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); -if (lean_is_exclusive(x_369)) { - lean_ctor_release(x_369, 0); - lean_ctor_release(x_369, 1); - lean_ctor_release(x_369, 2); - lean_ctor_release(x_369, 3); - lean_ctor_release(x_369, 4); - lean_ctor_release(x_369, 5); - x_378 = x_369; -} else { - lean_dec_ref(x_369); - x_378 = lean_box(0); -} -x_379 = lean_ctor_get(x_370, 0); +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_370, 1); +x_380 = lean_ctor_get(x_373, 4); lean_inc(x_380); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - lean_ctor_release(x_370, 2); - x_381 = x_370; +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_370); - x_381 = lean_box(0); + lean_dec_ref(x_373); + x_382 = lean_box(0); } -if (lean_is_scalar(x_381)) { - x_382 = lean_alloc_ctor(0, 3, 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 { - x_382 = x_381; + lean_dec_ref(x_374); + x_386 = lean_box(0); } -lean_ctor_set(x_382, 0, x_379); -lean_ctor_set(x_382, 1, x_380); -lean_ctor_set(x_382, 2, x_269); -if (lean_is_scalar(x_378)) { - x_383 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_386)) { + x_387 = lean_alloc_ctor(0, 4, 0); } else { - x_383 = x_378; + x_387 = x_386; } -lean_ctor_set(x_383, 0, x_373); -lean_ctor_set(x_383, 1, x_374); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_383, 3, x_375); -lean_ctor_set(x_383, 4, x_376); -lean_ctor_set(x_383, 5, x_377); -if (lean_is_scalar(x_372)) { - x_384 = lean_alloc_ctor(1, 2, 0); +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_384 = x_372; -} -lean_ctor_set(x_384, 0, x_371); -lean_ctor_set(x_384, 1, x_383); -return x_384; + 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; } 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; -x_385 = lean_ctor_get(x_267, 0); -x_386 = lean_ctor_get(x_267, 1); -x_387 = lean_ctor_get(x_267, 2); -lean_inc(x_387); -lean_inc(x_386); -lean_inc(x_385); -lean_dec(x_267); -x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_389 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_389, 0, x_385); -lean_ctor_set(x_389, 1, x_386); -lean_ctor_set(x_389, 2, x_388); -lean_ctor_set(x_262, 2, x_389); -x_390 = lean_ctor_get(x_11, 0); +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_11, 1); +x_391 = lean_ctor_get(x_390, 2); lean_inc(x_391); -x_392 = lean_ctor_get(x_11, 2); +x_392 = lean_ctor_get(x_372, 0); lean_inc(x_392); -x_393 = lean_ctor_get(x_11, 3); -lean_inc(x_393); -x_394 = lean_ctor_get(x_11, 4); +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); +} +x_394 = lean_ctor_get(x_390, 0); lean_inc(x_394); -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_395 = x_11; +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_11); - x_395 = lean_box(0); + lean_dec_ref(x_390); + x_399 = lean_box(0); } -x_396 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_396, 0, x_263); -lean_ctor_set(x_396, 1, x_19); -x_397 = lean_array_push(x_392, x_396); -if (lean_is_scalar(x_395)) { - x_398 = lean_alloc_ctor(0, 5, 0); -} else { - x_398 = x_395; -} -lean_ctor_set(x_398, 0, x_390); -lean_ctor_set(x_398, 1, x_391); -lean_ctor_set(x_398, 2, x_397); -lean_ctor_set(x_398, 3, x_393); -lean_ctor_set(x_398, 4, x_394); -x_399 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_265, x_398, x_262); -if (lean_obj_tag(x_399) == 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; lean_object* x_415; -x_400 = lean_ctor_get(x_399, 1); +x_400 = lean_ctor_get(x_391, 0); lean_inc(x_400); -x_401 = lean_ctor_get(x_400, 2); +x_401 = lean_ctor_get(x_391, 1); lean_inc(x_401); -x_402 = lean_ctor_get(x_399, 0); +x_402 = lean_ctor_get(x_391, 3); lean_inc(x_402); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - x_403 = 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); + x_403 = x_391; } else { - lean_dec_ref(x_399); + lean_dec_ref(x_391); x_403 = lean_box(0); } -x_404 = lean_ctor_get(x_400, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_400, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_400, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_400, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_400, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - lean_ctor_release(x_400, 2); - lean_ctor_release(x_400, 3); - lean_ctor_release(x_400, 4); - lean_ctor_release(x_400, 5); - x_409 = x_400; -} else { - lean_dec_ref(x_400); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_401, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_401, 1); -lean_inc(x_411); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - x_412 = x_401; -} else { - lean_dec_ref(x_401); - x_412 = lean_box(0); -} -if (lean_is_scalar(x_412)) { - x_413 = lean_alloc_ctor(0, 3, 0); -} else { - x_413 = x_412; -} -lean_ctor_set(x_413, 0, x_410); -lean_ctor_set(x_413, 1, x_411); -lean_ctor_set(x_413, 2, x_387); -if (lean_is_scalar(x_409)) { - x_414 = lean_alloc_ctor(0, 6, 0); -} else { - x_414 = x_409; -} -lean_ctor_set(x_414, 0, x_404); -lean_ctor_set(x_414, 1, x_405); -lean_ctor_set(x_414, 2, x_413); -lean_ctor_set(x_414, 3, x_406); -lean_ctor_set(x_414, 4, x_407); -lean_ctor_set(x_414, 5, x_408); if (lean_is_scalar(x_403)) { - x_415 = lean_alloc_ctor(0, 2, 0); + x_404 = lean_alloc_ctor(0, 4, 0); } else { - x_415 = x_403; + x_404 = x_403; +} +lean_ctor_set(x_404, 0, x_400); +lean_ctor_set(x_404, 1, x_401); +lean_ctor_set(x_404, 2, x_283); +lean_ctor_set(x_404, 3, x_402); +if (lean_is_scalar(x_399)) { + x_405 = lean_alloc_ctor(0, 6, 0); +} else { + x_405 = x_399; +} +lean_ctor_set(x_405, 0, x_394); +lean_ctor_set(x_405, 1, x_395); +lean_ctor_set(x_405, 2, x_404); +lean_ctor_set(x_405, 3, x_396); +lean_ctor_set(x_405, 4, x_397); +lean_ctor_set(x_405, 5, x_398); +if (lean_is_scalar(x_393)) { + x_406 = lean_alloc_ctor(1, 2, 0); +} else { + x_406 = x_393; +} +lean_ctor_set(x_406, 0, x_392); +lean_ctor_set(x_406, 1, x_405); +return x_406; +} } -lean_ctor_set(x_415, 0, x_402); -lean_ctor_set(x_415, 1, x_414); -return x_415; } else { -lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_416 = lean_ctor_get(x_399, 1); +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_416, 2); +x_417 = lean_ctor_get(x_11, 4); lean_inc(x_417); -x_418 = lean_ctor_get(x_399, 0); -lean_inc(x_418); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - x_419 = x_399; -} else { - lean_dec_ref(x_399); - x_419 = lean_box(0); -} -x_420 = lean_ctor_get(x_416, 0); -lean_inc(x_420); -x_421 = lean_ctor_get(x_416, 1); -lean_inc(x_421); -x_422 = lean_ctor_get(x_416, 3); -lean_inc(x_422); -x_423 = lean_ctor_get(x_416, 4); -lean_inc(x_423); -x_424 = lean_ctor_get(x_416, 5); -lean_inc(x_424); -if (lean_is_exclusive(x_416)) { - lean_ctor_release(x_416, 0); - lean_ctor_release(x_416, 1); - lean_ctor_release(x_416, 2); - lean_ctor_release(x_416, 3); - lean_ctor_release(x_416, 4); - lean_ctor_release(x_416, 5); - x_425 = x_416; -} else { - lean_dec_ref(x_416); - x_425 = lean_box(0); -} -x_426 = lean_ctor_get(x_417, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 1); -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); - x_428 = x_417; -} else { - lean_dec_ref(x_417); - x_428 = lean_box(0); -} -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 3, 0); -} else { - x_429 = x_428; -} -lean_ctor_set(x_429, 0, x_426); -lean_ctor_set(x_429, 1, x_427); -lean_ctor_set(x_429, 2, x_387); -if (lean_is_scalar(x_425)) { - x_430 = lean_alloc_ctor(0, 6, 0); -} else { - x_430 = x_425; -} -lean_ctor_set(x_430, 0, x_420); -lean_ctor_set(x_430, 1, x_421); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_422); -lean_ctor_set(x_430, 4, x_423); -lean_ctor_set(x_430, 5, x_424); -if (lean_is_scalar(x_419)) { - x_431 = lean_alloc_ctor(1, 2, 0); -} else { - x_431 = x_419; -} -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; -} -} -} -else -{ -lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_432 = lean_ctor_get(x_262, 2); -x_433 = lean_ctor_get(x_262, 0); -x_434 = lean_ctor_get(x_262, 1); -x_435 = lean_ctor_get(x_262, 3); -x_436 = lean_ctor_get(x_262, 4); -x_437 = lean_ctor_get(x_262, 5); -lean_inc(x_437); -lean_inc(x_436); -lean_inc(x_435); -lean_inc(x_432); -lean_inc(x_434); -lean_inc(x_433); -lean_dec(x_262); -x_438 = lean_ctor_get(x_432, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_432, 1); -lean_inc(x_439); -x_440 = lean_ctor_get(x_432, 2); -lean_inc(x_440); -if (lean_is_exclusive(x_432)) { - lean_ctor_release(x_432, 0); - lean_ctor_release(x_432, 1); - lean_ctor_release(x_432, 2); - x_441 = x_432; -} else { - lean_dec_ref(x_432); - x_441 = lean_box(0); -} -x_442 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_441)) { - x_443 = lean_alloc_ctor(0, 3, 0); -} else { - x_443 = x_441; -} -lean_ctor_set(x_443, 0, x_438); -lean_ctor_set(x_443, 1, x_439); -lean_ctor_set(x_443, 2, x_442); -x_444 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_444, 0, x_433); -lean_ctor_set(x_444, 1, x_434); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_435); -lean_ctor_set(x_444, 4, x_436); -lean_ctor_set(x_444, 5, x_437); -x_445 = lean_ctor_get(x_11, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_11, 1); -lean_inc(x_446); -x_447 = lean_ctor_get(x_11, 2); -lean_inc(x_447); -x_448 = lean_ctor_get(x_11, 3); -lean_inc(x_448); -x_449 = lean_ctor_get(x_11, 4); -lean_inc(x_449); 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_450 = x_11; + x_418 = x_11; } else { lean_dec_ref(x_11); - x_450 = lean_box(0); + x_418 = lean_box(0); } -x_451 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_451, 0, x_263); -lean_ctor_set(x_451, 1, x_19); -x_452 = lean_array_push(x_447, x_451); -if (lean_is_scalar(x_450)) { - x_453 = lean_alloc_ctor(0, 5, 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); } else { - x_453 = x_450; + x_421 = x_418; } -lean_ctor_set(x_453, 0, x_445); -lean_ctor_set(x_453, 1, x_446); -lean_ctor_set(x_453, 2, x_452); -lean_ctor_set(x_453, 3, x_448); -lean_ctor_set(x_453, 4, x_449); -x_454 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_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_265, x_453, x_444); -if (lean_obj_tag(x_454) == 0) +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_Init_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_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; -x_455 = lean_ctor_get(x_454, 1); -lean_inc(x_455); -x_456 = lean_ctor_get(x_455, 2); -lean_inc(x_456); -x_457 = lean_ctor_get(x_454, 0); -lean_inc(x_457); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - x_458 = x_454; +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_454); - x_458 = lean_box(0); + lean_dec_ref(x_422); + x_426 = lean_box(0); } -x_459 = lean_ctor_get(x_455, 0); -lean_inc(x_459); -x_460 = lean_ctor_get(x_455, 1); -lean_inc(x_460); -x_461 = lean_ctor_get(x_455, 3); -lean_inc(x_461); -x_462 = lean_ctor_get(x_455, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_440); + x_449 = 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; +} else { + lean_dec_ref(x_441); + x_453 = lean_box(0); +} +if (lean_is_scalar(x_453)) { + x_454 = lean_alloc_ctor(0, 4, 0); +} else { + x_454 = x_453; +} +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); +} else { + x_455 = x_449; +} +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); +} else { + x_456 = x_443; +} +lean_ctor_set(x_456, 0, x_442); +lean_ctor_set(x_456, 1, x_455); +return x_456; +} +} +} +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); -x_463 = lean_ctor_get(x_455, 5); +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); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - lean_ctor_release(x_455, 2); - lean_ctor_release(x_455, 3); - lean_ctor_release(x_455, 4); - lean_ctor_release(x_455, 5); - x_464 = x_455; -} else { - lean_dec_ref(x_455); - x_464 = lean_box(0); -} -x_465 = lean_ctor_get(x_456, 0); +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_456, 1); +x_466 = lean_ctor_get(x_457, 3); lean_inc(x_466); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - lean_ctor_release(x_456, 2); - x_467 = x_456; +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; } else { - lean_dec_ref(x_456); + lean_dec_ref(x_457); x_467 = lean_box(0); } +x_468 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_467)) { - x_468 = lean_alloc_ctor(0, 3, 0); + x_469 = lean_alloc_ctor(0, 4, 0); } else { - x_468 = x_467; + x_469 = x_467; } -lean_ctor_set(x_468, 0, x_465); -lean_ctor_set(x_468, 1, x_466); -lean_ctor_set(x_468, 2, x_440); -if (lean_is_scalar(x_464)) { - x_469 = lean_alloc_ctor(0, 6, 0); -} else { - x_469 = x_464; -} -lean_ctor_set(x_469, 0, x_459); -lean_ctor_set(x_469, 1, x_460); +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_461); -lean_ctor_set(x_469, 4, x_462); -lean_ctor_set(x_469, 5, x_463); -if (lean_is_scalar(x_458)) { - x_470 = lean_alloc_ctor(0, 2, 0); -} else { - x_470 = x_458; -} -lean_ctor_set(x_470, 0, x_457); -lean_ctor_set(x_470, 1, x_469); -return x_470; -} -else -{ -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; -x_471 = lean_ctor_get(x_454, 1); +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_471, 2); +x_472 = lean_ctor_get(x_11, 1); lean_inc(x_472); -x_473 = lean_ctor_get(x_454, 0); +x_473 = lean_ctor_get(x_11, 2); lean_inc(x_473); -if (lean_is_exclusive(x_454)) { - lean_ctor_release(x_454, 0); - lean_ctor_release(x_454, 1); - x_474 = x_454; -} else { - lean_dec_ref(x_454); - x_474 = lean_box(0); -} -x_475 = lean_ctor_get(x_471, 0); +x_474 = lean_ctor_get(x_11, 3); +lean_inc(x_474); +x_475 = lean_ctor_get(x_11, 4); lean_inc(x_475); -x_476 = lean_ctor_get(x_471, 1); -lean_inc(x_476); -x_477 = lean_ctor_get(x_471, 3); -lean_inc(x_477); -x_478 = lean_ctor_get(x_471, 4); -lean_inc(x_478); -x_479 = lean_ctor_get(x_471, 5); -lean_inc(x_479); -if (lean_is_exclusive(x_471)) { - lean_ctor_release(x_471, 0); - lean_ctor_release(x_471, 1); - lean_ctor_release(x_471, 2); - lean_ctor_release(x_471, 3); - lean_ctor_release(x_471, 4); - lean_ctor_release(x_471, 5); - x_480 = x_471; +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; } else { - lean_dec_ref(x_471); - x_480 = lean_box(0); + lean_dec_ref(x_11); + x_476 = lean_box(0); } -x_481 = lean_ctor_get(x_472, 0); +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); +} else { + x_479 = x_476; +} +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_Init_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_472, 1); +x_482 = lean_ctor_get(x_481, 2); lean_inc(x_482); -if (lean_is_exclusive(x_472)) { - lean_ctor_release(x_472, 0); - lean_ctor_release(x_472, 1); - lean_ctor_release(x_472, 2); - x_483 = x_472; +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; } else { - lean_dec_ref(x_472); - x_483 = lean_box(0); + lean_dec_ref(x_480); + x_484 = lean_box(0); } -if (lean_is_scalar(x_483)) { - x_484 = lean_alloc_ctor(0, 3, 0); +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 { - x_484 = x_483; + lean_dec_ref(x_481); + x_490 = lean_box(0); } -lean_ctor_set(x_484, 0, x_481); -lean_ctor_set(x_484, 1, x_482); -lean_ctor_set(x_484, 2, x_440); -if (lean_is_scalar(x_480)) { - x_485 = lean_alloc_ctor(0, 6, 0); +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 { - x_485 = x_480; + lean_dec_ref(x_482); + x_494 = lean_box(0); } -lean_ctor_set(x_485, 0, x_475); -lean_ctor_set(x_485, 1, x_476); -lean_ctor_set(x_485, 2, x_484); -lean_ctor_set(x_485, 3, x_477); -lean_ctor_set(x_485, 4, x_478); -lean_ctor_set(x_485, 5, x_479); -if (lean_is_scalar(x_474)) { - x_486 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_494)) { + x_495 = lean_alloc_ctor(0, 4, 0); } else { - x_486 = x_474; + x_495 = x_494; } -lean_ctor_set(x_486, 0, x_473); -lean_ctor_set(x_486, 1, x_485); -return x_486; +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_487; +uint8_t x_515; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -7014,23 +7237,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_487 = !lean_is_exclusive(x_256); -if (x_487 == 0) +x_515 = !lean_is_exclusive(x_270); +if (x_515 == 0) { -return x_256; +return x_270; } else { -lean_object* x_488; lean_object* x_489; lean_object* x_490; -x_488 = lean_ctor_get(x_256, 0); -x_489 = lean_ctor_get(x_256, 1); -lean_inc(x_489); -lean_inc(x_488); -lean_dec(x_256); -x_490 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_490, 0, x_488); -lean_ctor_set(x_490, 1, x_489); -return x_490; +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; } } } @@ -7038,7 +7261,7 @@ return x_490; } else { -uint8_t x_491; +uint8_t x_519; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -7048,29 +7271,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_491 = !lean_is_exclusive(x_24); -if (x_491 == 0) +x_519 = !lean_is_exclusive(x_24); +if (x_519 == 0) { return x_24; } else { -lean_object* x_492; lean_object* x_493; lean_object* x_494; -x_492 = lean_ctor_get(x_24, 0); -x_493 = lean_ctor_get(x_24, 1); -lean_inc(x_493); -lean_inc(x_492); +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_dec(x_24); -x_494 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_494, 0, x_492); -lean_ctor_set(x_494, 1, x_493); -return x_494; +x_522 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_522, 0, x_520); +lean_ctor_set(x_522, 1, x_521); +return x_522; } } } else { -uint8_t x_495; +uint8_t x_523; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -7079,23 +7302,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_495 = !lean_is_exclusive(x_20); -if (x_495 == 0) +x_523 = !lean_is_exclusive(x_20); +if (x_523 == 0) { return x_20; } else { -lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_496 = lean_ctor_get(x_20, 0); -x_497 = lean_ctor_get(x_20, 1); -lean_inc(x_497); -lean_inc(x_496); +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_dec(x_20); -x_498 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_498, 0, x_496); -lean_ctor_set(x_498, 1, x_497); -return x_498; +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; } } } @@ -7280,82 +7503,89 @@ return x_51; } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; +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_62 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_62, 0, x_60); -lean_ctor_set(x_62, 1, x_61); -lean_ctor_set(x_62, 2, x_45); -lean_ctor_set(x_52, 2, x_62); +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; } } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_63 = lean_ctor_get(x_52, 0); -x_64 = lean_ctor_get(x_52, 1); -x_65 = lean_ctor_get(x_52, 3); -x_66 = lean_ctor_get(x_52, 4); -x_67 = lean_ctor_get(x_52, 5); +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +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_inc(x_65); lean_inc(x_64); -lean_inc(x_63); lean_dec(x_52); -x_68 = lean_ctor_get(x_53, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_53, 1); +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); - x_70 = x_53; + lean_ctor_release(x_53, 3); + x_72 = x_53; } else { lean_dec_ref(x_53); - x_70 = lean_box(0); + x_72 = lean_box(0); } -if (lean_is_scalar(x_70)) { - x_71 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_72)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_71 = x_70; + x_73 = x_72; } -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_69); -lean_ctor_set(x_71, 2, x_45); -x_72 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_72, 0, x_63); -lean_ctor_set(x_72, 1, x_64); -lean_ctor_set(x_72, 2, x_71); -lean_ctor_set(x_72, 3, x_65); -lean_ctor_set(x_72, 4, x_66); -lean_ctor_set(x_72, 5, x_67); -lean_ctor_set(x_51, 1, 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_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; } } 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; -x_73 = lean_ctor_get(x_51, 0); -lean_inc(x_73); -lean_dec(x_51); -x_74 = lean_ctor_get(x_52, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_52, 1); +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); -x_76 = lean_ctor_get(x_52, 3); +lean_dec(x_51); +x_76 = lean_ctor_get(x_52, 0); lean_inc(x_76); -x_77 = lean_ctor_get(x_52, 4); +x_77 = lean_ctor_get(x_52, 1); lean_inc(x_77); -x_78 = lean_ctor_get(x_52, 5); +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); @@ -7363,1898 +7593,1997 @@ if (lean_is_exclusive(x_52)) { lean_ctor_release(x_52, 3); lean_ctor_release(x_52, 4); lean_ctor_release(x_52, 5); - x_79 = x_52; + x_81 = x_52; } else { lean_dec_ref(x_52); - x_79 = lean_box(0); + x_81 = lean_box(0); } -x_80 = lean_ctor_get(x_53, 0); -lean_inc(x_80); -x_81 = lean_ctor_get(x_53, 1); -lean_inc(x_81); +x_82 = lean_ctor_get(x_53, 0); +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); - x_82 = x_53; + lean_ctor_release(x_53, 3); + x_85 = x_53; } else { lean_dec_ref(x_53); - x_82 = lean_box(0); + x_85 = lean_box(0); } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 4, 0); } else { - x_83 = x_82; + x_86 = x_85; } -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -lean_ctor_set(x_83, 2, x_45); -if (lean_is_scalar(x_79)) { - x_84 = lean_alloc_ctor(0, 6, 0); +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_84 = x_79; + x_87 = x_81; } -lean_ctor_set(x_84, 0, x_74); -lean_ctor_set(x_84, 1, x_75); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_76); -lean_ctor_set(x_84, 4, x_77); -lean_ctor_set(x_84, 5, x_78); -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_73); -lean_ctor_set(x_85, 1, x_84); -return x_85; +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; } } else { -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_51, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); -lean_inc(x_87); -x_88 = !lean_is_exclusive(x_51); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; +lean_object* x_89; lean_object* x_90; uint8_t x_91; x_89 = lean_ctor_get(x_51, 1); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_86); -if (x_90 == 0) +lean_inc(x_89); +x_90 = lean_ctor_get(x_89, 2); +lean_inc(x_90); +x_91 = !lean_is_exclusive(x_51); +if (x_91 == 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_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_93; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -lean_ctor_set(x_87, 2, x_45); +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_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_87, 0); -x_95 = lean_ctor_get(x_87, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_87); -x_96 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -lean_ctor_set(x_96, 2, x_45); -lean_ctor_set(x_86, 2, x_96); -return x_51; -} -} -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; -x_97 = lean_ctor_get(x_86, 0); -x_98 = lean_ctor_get(x_86, 1); -x_99 = lean_ctor_get(x_86, 3); -x_100 = lean_ctor_get(x_86, 4); -x_101 = lean_ctor_get(x_86, 5); -lean_inc(x_101); -lean_inc(x_100); +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_86); -x_102 = lean_ctor_get(x_87, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_87, 1); -lean_inc(x_103); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - x_104 = x_87; -} else { - lean_dec_ref(x_87); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 3, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_102); -lean_ctor_set(x_105, 1, x_103); -lean_ctor_set(x_105, 2, x_45); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_97); -lean_ctor_set(x_106, 1, x_98); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_99); -lean_ctor_set(x_106, 4, x_100); -lean_ctor_set(x_106, 5, x_101); -lean_ctor_set(x_51, 1, x_106); +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_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_107 = lean_ctor_get(x_51, 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_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); -lean_dec(x_51); -x_108 = lean_ctor_get(x_86, 0); +x_108 = lean_ctor_get(x_90, 3); lean_inc(x_108); -x_109 = lean_ctor_get(x_86, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_86, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_86, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_86, 5); +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; +} else { + lean_dec_ref(x_90); + 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_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); -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_113 = x_86; -} else { - lean_dec_ref(x_86); - x_113 = lean_box(0); -} -x_114 = lean_ctor_get(x_87, 0); +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_87, 1); +x_115 = lean_ctor_get(x_89, 3); lean_inc(x_115); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - x_116 = x_87; +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; } else { - lean_dec_ref(x_87); - x_116 = lean_box(0); + lean_dec_ref(x_89); + x_118 = lean_box(0); } -if (lean_is_scalar(x_116)) { - x_117 = lean_alloc_ctor(0, 3, 0); +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 { - x_117 = x_116; + lean_dec_ref(x_90); + x_122 = lean_box(0); } -lean_ctor_set(x_117, 0, x_114); -lean_ctor_set(x_117, 1, x_115); -lean_ctor_set(x_117, 2, x_45); -if (lean_is_scalar(x_113)) { - x_118 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_122)) { + x_123 = lean_alloc_ctor(0, 4, 0); } else { - x_118 = x_113; + x_123 = x_122; } -lean_ctor_set(x_118, 0, x_108); -lean_ctor_set(x_118, 1, x_109); -lean_ctor_set(x_118, 2, x_117); -lean_ctor_set(x_118, 3, x_110); -lean_ctor_set(x_118, 4, x_111); -lean_ctor_set(x_118, 5, x_112); -x_119 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_119, 0, x_107); -lean_ctor_set(x_119, 1, x_118); -return x_119; +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_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_6, 0); -x_121 = lean_ctor_get(x_6, 1); -x_122 = lean_ctor_get(x_6, 2); -x_123 = lean_ctor_get(x_6, 3); -x_124 = lean_ctor_get(x_6, 4); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_6); -x_125 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_125, 0, x_39); -lean_ctor_set(x_125, 1, x_27); -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_127, x_38); -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; -x_129 = lean_ctor_get(x_128, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_129, 2); +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); -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; -} else { - lean_dec_ref(x_128); - x_132 = lean_box(0); -} -x_133 = lean_ctor_get(x_129, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_129, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_129, 3); +lean_inc(x_129); +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_Init_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_129, 4); +x_136 = lean_ctor_get(x_135, 2); lean_inc(x_136); -x_137 = lean_ctor_get(x_129, 5); +x_137 = lean_ctor_get(x_134, 0); 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_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + x_138 = x_134; } else { - lean_dec_ref(x_129); + lean_dec_ref(x_134); x_138 = lean_box(0); } -x_139 = lean_ctor_get(x_130, 0); +x_139 = lean_ctor_get(x_135, 0); lean_inc(x_139); -x_140 = lean_ctor_get(x_130, 1); +x_140 = lean_ctor_get(x_135, 1); 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); - x_141 = x_130; +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_130); - x_141 = lean_box(0); + lean_dec_ref(x_135); + x_144 = lean_box(0); } -if (lean_is_scalar(x_141)) { - x_142 = lean_alloc_ctor(0, 3, 0); -} else { - x_142 = x_141; -} -lean_ctor_set(x_142, 0, x_139); -lean_ctor_set(x_142, 1, x_140); -lean_ctor_set(x_142, 2, x_45); -if (lean_is_scalar(x_138)) { - x_143 = lean_alloc_ctor(0, 6, 0); -} else { - x_143 = x_138; -} -lean_ctor_set(x_143, 0, x_133); -lean_ctor_set(x_143, 1, x_134); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_135); -lean_ctor_set(x_143, 4, x_136); -lean_ctor_set(x_143, 5, x_137); -if (lean_is_scalar(x_132)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_132; -} -lean_ctor_set(x_144, 0, x_131); -lean_ctor_set(x_144, 1, x_143); -return x_144; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_145 = lean_ctor_get(x_128, 1); +x_145 = lean_ctor_get(x_136, 0); lean_inc(x_145); -x_146 = lean_ctor_get(x_145, 2); +x_146 = lean_ctor_get(x_136, 1); lean_inc(x_146); -x_147 = lean_ctor_get(x_128, 0); +x_147 = lean_ctor_get(x_136, 3); lean_inc(x_147); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_148 = x_128; +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_128); + lean_dec_ref(x_136); x_148 = lean_box(0); } -x_149 = lean_ctor_get(x_145, 0); -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; -} else { - lean_dec_ref(x_145); - x_154 = 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); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - lean_ctor_release(x_146, 1); - lean_ctor_release(x_146, 2); - x_157 = x_146; -} else { - lean_dec_ref(x_146); - x_157 = lean_box(0); -} -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 3, 0); -} else { - x_158 = x_157; -} -lean_ctor_set(x_158, 0, x_155); -lean_ctor_set(x_158, 1, x_156); -lean_ctor_set(x_158, 2, x_45); -if (lean_is_scalar(x_154)) { - x_159 = lean_alloc_ctor(0, 6, 0); -} else { - x_159 = x_154; -} -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); if (lean_is_scalar(x_148)) { - x_160 = lean_alloc_ctor(1, 2, 0); + x_149 = lean_alloc_ctor(0, 4, 0); } else { - x_160 = x_148; + x_149 = x_148; } -lean_ctor_set(x_160, 0, x_147); -lean_ctor_set(x_160, 1, x_159); -return x_160; +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); +if (lean_is_scalar(x_138)) { + x_151 = lean_alloc_ctor(0, 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_134, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_152, 2); +lean_inc(x_153); +x_154 = lean_ctor_get(x_134, 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); +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; +} else { + lean_dec_ref(x_152); + x_161 = 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; +} else { + lean_dec_ref(x_153); + x_165 = lean_box(0); +} +if (lean_is_scalar(x_165)) { + x_166 = lean_alloc_ctor(0, 4, 0); +} else { + x_166 = x_165; +} +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); +} else { + x_167 = x_161; +} +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_168, 0, x_154); +lean_ctor_set(x_168, 1, x_167); +return x_168; } } } 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; -x_161 = lean_ctor_get(x_43, 0); -x_162 = lean_ctor_get(x_43, 1); -x_163 = lean_ctor_get(x_43, 2); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_dec(x_43); -x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_165 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_165, 0, x_161); -lean_ctor_set(x_165, 1, x_162); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_38, 2, x_165); -x_166 = lean_ctor_get(x_6, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_6, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_6, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_6, 3); -lean_inc(x_169); -x_170 = lean_ctor_get(x_6, 4); +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); 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_171 = x_6; + x_180 = x_6; } else { lean_dec_ref(x_6); - x_171 = lean_box(0); + x_180 = lean_box(0); } -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_39); -lean_ctor_set(x_172, 1, x_27); -x_173 = lean_array_push(x_168, x_172); -if (lean_is_scalar(x_171)) { - x_174 = lean_alloc_ctor(0, 5, 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); } else { - x_174 = x_171; + x_183 = x_180; } -lean_ctor_set(x_174, 0, x_166); -lean_ctor_set(x_174, 1, x_167); -lean_ctor_set(x_174, 2, x_173); -lean_ctor_set(x_174, 3, x_169); -lean_ctor_set(x_174, 4, x_170); -x_175 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_174, x_38); -if (lean_obj_tag(x_175) == 0) +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_Init_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_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_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_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_177, 1); +x_187 = lean_ctor_get(x_184, 0); lean_inc(x_187); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - x_188 = x_177; +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_177); + lean_dec_ref(x_184); x_188 = lean_box(0); } -if (lean_is_scalar(x_188)) { - x_189 = lean_alloc_ctor(0, 3, 0); -} else { - x_189 = x_188; -} -lean_ctor_set(x_189, 0, x_186); -lean_ctor_set(x_189, 1, x_187); -lean_ctor_set(x_189, 2, x_163); -if (lean_is_scalar(x_185)) { - x_190 = lean_alloc_ctor(0, 6, 0); -} else { - x_190 = x_185; -} -lean_ctor_set(x_190, 0, x_180); -lean_ctor_set(x_190, 1, x_181); -lean_ctor_set(x_190, 2, x_189); -lean_ctor_set(x_190, 3, x_182); -lean_ctor_set(x_190, 4, x_183); -lean_ctor_set(x_190, 5, x_184); -if (lean_is_scalar(x_179)) { - x_191 = lean_alloc_ctor(0, 2, 0); -} else { - x_191 = x_179; -} -lean_ctor_set(x_191, 0, x_178); -lean_ctor_set(x_191, 1, x_190); -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_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -x_192 = lean_ctor_get(x_175, 1); +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_192, 2); +x_193 = lean_ctor_get(x_185, 5); lean_inc(x_193); -x_194 = lean_ctor_get(x_175, 0); -lean_inc(x_194); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - x_195 = x_175; +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_175); - x_195 = lean_box(0); + lean_dec_ref(x_185); + x_194 = lean_box(0); } -x_196 = lean_ctor_get(x_192, 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_192, 1); +x_197 = lean_ctor_get(x_186, 3); lean_inc(x_197); -x_198 = lean_ctor_get(x_192, 3); -lean_inc(x_198); -x_199 = lean_ctor_get(x_192, 4); -lean_inc(x_199); -x_200 = lean_ctor_get(x_192, 5); -lean_inc(x_200); -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_201 = 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); + x_198 = x_186; } else { - lean_dec_ref(x_192); - x_201 = lean_box(0); + lean_dec_ref(x_186); + x_198 = lean_box(0); } -x_202 = lean_ctor_get(x_193, 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; +} +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_inc(x_202); -x_203 = lean_ctor_get(x_193, 1); +x_203 = lean_ctor_get(x_202, 2); lean_inc(x_203); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - lean_ctor_release(x_193, 2); - x_204 = x_193; +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; } else { - lean_dec_ref(x_193); - x_204 = lean_box(0); + lean_dec_ref(x_184); + x_205 = lean_box(0); } -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_208); +x_209 = lean_ctor_get(x_202, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_202, 5); +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 { - x_205 = x_204; + lean_dec_ref(x_202); + x_211 = lean_box(0); } -lean_ctor_set(x_205, 0, x_202); -lean_ctor_set(x_205, 1, x_203); -lean_ctor_set(x_205, 2, x_163); -if (lean_is_scalar(x_201)) { - x_206 = lean_alloc_ctor(0, 6, 0); +x_212 = lean_ctor_get(x_203, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_203, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_203, 3); +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; } else { - x_206 = x_201; + lean_dec_ref(x_203); + x_215 = lean_box(0); } -lean_ctor_set(x_206, 0, x_196); -lean_ctor_set(x_206, 1, x_197); -lean_ctor_set(x_206, 2, x_205); -lean_ctor_set(x_206, 3, x_198); -lean_ctor_set(x_206, 4, x_199); -lean_ctor_set(x_206, 5, x_200); -if (lean_is_scalar(x_195)) { - x_207 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_215)) { + x_216 = lean_alloc_ctor(0, 4, 0); } else { - x_207 = x_195; + x_216 = x_215; } -lean_ctor_set(x_207, 0, x_194); -lean_ctor_set(x_207, 1, x_206); -return x_207; +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); +} else { + x_217 = x_211; +} +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_218, 0, x_204); +lean_ctor_set(x_218, 1, x_217); +return x_218; } } } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; 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_208 = lean_ctor_get(x_38, 2); -x_209 = lean_ctor_get(x_38, 0); -x_210 = lean_ctor_get(x_38, 1); -x_211 = lean_ctor_get(x_38, 3); -x_212 = lean_ctor_get(x_38, 4); -x_213 = lean_ctor_get(x_38, 5); -lean_inc(x_213); -lean_inc(x_212); -lean_inc(x_211); -lean_inc(x_208); -lean_inc(x_210); -lean_inc(x_209); -lean_dec(x_38); -x_214 = lean_ctor_get(x_208, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_208, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_208, 2); -lean_inc(x_216); -if (lean_is_exclusive(x_208)) { - lean_ctor_release(x_208, 0); - lean_ctor_release(x_208, 1); - lean_ctor_release(x_208, 2); - x_217 = x_208; -} else { - lean_dec_ref(x_208); - x_217 = lean_box(0); -} -x_218 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_217)) { - x_219 = lean_alloc_ctor(0, 3, 0); -} else { - x_219 = x_217; -} -lean_ctor_set(x_219, 0, x_214); -lean_ctor_set(x_219, 1, x_215); -lean_ctor_set(x_219, 2, x_218); -x_220 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_220, 0, x_209); -lean_ctor_set(x_220, 1, x_210); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_211); -lean_ctor_set(x_220, 4, x_212); -lean_ctor_set(x_220, 5, x_213); -x_221 = lean_ctor_get(x_6, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_6, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_6, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_6, 3); +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); -x_225 = lean_ctor_get(x_6, 4); +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_226 = x_6; + x_238 = x_6; } else { lean_dec_ref(x_6); - x_226 = lean_box(0); + x_238 = lean_box(0); } -x_227 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_227, 0, x_39); -lean_ctor_set(x_227, 1, x_27); -x_228 = lean_array_push(x_223, x_227); -if (lean_is_scalar(x_226)) { - x_229 = lean_alloc_ctor(0, 5, 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_229 = x_226; + x_241 = x_238; } -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_41, x_229, x_220); -if (lean_obj_tag(x_230) == 0) +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_Init_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_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_231 = lean_ctor_get(x_230, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_231, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_230, 0); -lean_inc(x_233); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_234 = x_230; +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_230); - x_234 = lean_box(0); + lean_dec_ref(x_242); + x_246 = lean_box(0); } -x_235 = lean_ctor_get(x_231, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_231, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_231, 3); -lean_inc(x_237); -x_238 = lean_ctor_get(x_231, 4); -lean_inc(x_238); -x_239 = lean_ctor_get(x_231, 5); -lean_inc(x_239); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - lean_ctor_release(x_231, 4); - lean_ctor_release(x_231, 5); - x_240 = x_231; +x_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_231); - x_240 = lean_box(0); + lean_dec_ref(x_243); + x_252 = lean_box(0); } -x_241 = lean_ctor_get(x_232, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_232, 1); -lean_inc(x_242); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - lean_ctor_release(x_232, 1); - lean_ctor_release(x_232, 2); - x_243 = x_232; +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_232); - x_243 = lean_box(0); + lean_dec_ref(x_244); + x_256 = lean_box(0); } -if (lean_is_scalar(x_243)) { - x_244 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 4, 0); } else { - x_244 = x_243; + x_257 = x_256; } -lean_ctor_set(x_244, 0, x_241); -lean_ctor_set(x_244, 1, x_242); -lean_ctor_set(x_244, 2, x_216); -if (lean_is_scalar(x_240)) { - x_245 = lean_alloc_ctor(0, 6, 0); +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_245 = x_240; + x_258 = x_252; } -lean_ctor_set(x_245, 0, x_235); -lean_ctor_set(x_245, 1, x_236); -lean_ctor_set(x_245, 2, x_244); -lean_ctor_set(x_245, 3, x_237); -lean_ctor_set(x_245, 4, x_238); -lean_ctor_set(x_245, 5, x_239); -if (lean_is_scalar(x_234)) { - x_246 = lean_alloc_ctor(0, 2, 0); +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_246 = x_234; + x_259 = x_246; } -lean_ctor_set(x_246, 0, x_233); -lean_ctor_set(x_246, 1, x_245); -return 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_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_247 = lean_ctor_get(x_230, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_230, 0); -lean_inc(x_249); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_250 = x_230; +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_230); - x_250 = lean_box(0); + lean_dec_ref(x_242); + x_263 = 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; +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_247); - x_256 = lean_box(0); + lean_dec_ref(x_260); + x_269 = 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); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - x_259 = x_248; +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_248); - x_259 = lean_box(0); + lean_dec_ref(x_261); + x_273 = lean_box(0); } -if (lean_is_scalar(x_259)) { - x_260 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_273)) { + x_274 = lean_alloc_ctor(0, 4, 0); } else { - x_260 = x_259; + x_274 = x_273; } -lean_ctor_set(x_260, 0, x_257); -lean_ctor_set(x_260, 1, x_258); -lean_ctor_set(x_260, 2, x_216); -if (lean_is_scalar(x_256)) { - x_261 = lean_alloc_ctor(0, 6, 0); +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_261 = x_256; + x_275 = x_269; } -lean_ctor_set(x_261, 0, x_251); -lean_ctor_set(x_261, 1, x_252); -lean_ctor_set(x_261, 2, x_260); -lean_ctor_set(x_261, 3, x_253); -lean_ctor_set(x_261, 4, x_254); -lean_ctor_set(x_261, 5, x_255); -if (lean_is_scalar(x_250)) { - x_262 = lean_alloc_ctor(1, 2, 0); +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_262 = x_250; + x_276 = x_263; } -lean_ctor_set(x_262, 0, x_249); -lean_ctor_set(x_262, 1, x_261); -return x_262; +lean_ctor_set(x_276, 0, x_262); +lean_ctor_set(x_276, 1, x_275); +return x_276; } } } default: { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_32, 1); -lean_inc(x_263); +lean_object* x_277; lean_object* x_278; +x_277 = lean_ctor_get(x_32, 1); +lean_inc(x_277); lean_dec(x_32); lean_inc(x_6); -x_264 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_263); -if (lean_obj_tag(x_264) == 0) +x_278 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_277); +if (lean_obj_tag(x_278) == 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_279; +x_279 = lean_ctor_get(x_278, 0); +lean_inc(x_279); +if (lean_obj_tag(x_279) == 0) { -lean_object* x_266; lean_object* x_267; lean_object* x_268; +lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_dec(x_27); -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_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); lean_dec(x_5); -x_5 = x_268; -x_7 = x_266; +x_5 = x_282; +x_7 = x_280; 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_dec(x_5); -x_274 = !lean_is_exclusive(x_270); -if (x_274 == 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_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_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_27); -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___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_273, x_6, x_270); -if (lean_obj_tag(x_283) == 0) -{ -lean_object* x_284; lean_object* x_285; uint8_t x_286; -x_284 = lean_ctor_get(x_283, 1); +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); -x_285 = lean_ctor_get(x_284, 2); +lean_dec(x_278); +x_285 = lean_ctor_get(x_279, 0); 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); +lean_dec(x_279); +x_286 = lean_unsigned_to_nat(1u); +x_287 = lean_nat_add(x_5, x_286); +lean_dec(x_5); 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); +x_290 = !lean_is_exclusive(x_289); 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_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_292; lean_object* x_293; lean_object* x_294; -x_292 = lean_ctor_get(x_285, 0); -x_293 = lean_ctor_get(x_285, 1); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_285); -x_294 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_294, 0, x_292); -lean_ctor_set(x_294, 1, x_293); -lean_ctor_set(x_294, 2, x_277); -lean_ctor_set(x_284, 2, x_294); -return x_283; -} -} -else +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_Init_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_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_295 = lean_ctor_get(x_284, 0); -x_296 = lean_ctor_get(x_284, 1); -x_297 = lean_ctor_get(x_284, 3); -x_298 = lean_ctor_get(x_284, 4); -x_299 = lean_ctor_get(x_284, 5); -lean_inc(x_299); +lean_object* x_298; lean_object* x_299; uint8_t x_300; +x_298 = lean_ctor_get(x_297, 1); lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); -lean_dec(x_284); -x_300 = lean_ctor_get(x_285, 0); -lean_inc(x_300); -x_301 = lean_ctor_get(x_285, 1); -lean_inc(x_301); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - x_302 = x_285; -} else { - lean_dec_ref(x_285); - x_302 = lean_box(0); -} -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 3, 0); -} else { - x_303 = x_302; -} -lean_ctor_set(x_303, 0, x_300); -lean_ctor_set(x_303, 1, x_301); -lean_ctor_set(x_303, 2, x_277); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_295); -lean_ctor_set(x_304, 1, x_296); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_297); -lean_ctor_set(x_304, 4, x_298); -lean_ctor_set(x_304, 5, x_299); -lean_ctor_set(x_283, 1, x_304); -return x_283; -} +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_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_305 = lean_ctor_get(x_283, 0); -lean_inc(x_305); -lean_dec(x_283); -x_306 = lean_ctor_get(x_284, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_284, 1); -lean_inc(x_307); -x_308 = lean_ctor_get(x_284, 3); +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); -x_309 = lean_ctor_get(x_284, 4); -lean_inc(x_309); -x_310 = lean_ctor_get(x_284, 5); -lean_inc(x_310); -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_311 = x_284; -} else { - lean_dec_ref(x_284); - x_311 = lean_box(0); +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; } -x_312 = lean_ctor_get(x_285, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_285, 1); +} +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); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - x_314 = x_285; +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_inc(x_316); +x_317 = lean_ctor_get(x_299, 3); +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_285); - x_314 = lean_box(0); + lean_dec_ref(x_299); + x_318 = lean_box(0); } -if (lean_is_scalar(x_314)) { - x_315 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_318)) { + x_319 = lean_alloc_ctor(0, 4, 0); } else { - x_315 = x_314; + x_319 = x_318; } -lean_ctor_set(x_315, 0, x_312); -lean_ctor_set(x_315, 1, x_313); -lean_ctor_set(x_315, 2, x_277); -if (lean_is_scalar(x_311)) { - x_316 = lean_alloc_ctor(0, 6, 0); -} else { - x_316 = x_311; -} -lean_ctor_set(x_316, 0, x_306); -lean_ctor_set(x_316, 1, x_307); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_308); -lean_ctor_set(x_316, 4, x_309); -lean_ctor_set(x_316, 5, x_310); -x_317 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_317, 0, x_305); -lean_ctor_set(x_317, 1, x_316); -return x_317; +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_318; lean_object* x_319; uint8_t x_320; -x_318 = lean_ctor_get(x_283, 1); -lean_inc(x_318); -x_319 = lean_ctor_get(x_318, 2); -lean_inc(x_319); -x_320 = !lean_is_exclusive(x_283); -if (x_320 == 0) -{ -lean_object* x_321; uint8_t x_322; -x_321 = lean_ctor_get(x_283, 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_277); -return x_283; -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_319, 0); -x_327 = lean_ctor_get(x_319, 1); -lean_inc(x_327); +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_inc(x_326); -lean_dec(x_319); -x_328 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_328, 0, x_326); -lean_ctor_set(x_328, 1, x_327); -lean_ctor_set(x_328, 2, x_277); -lean_ctor_set(x_318, 2, x_328); -return x_283; +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); } -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_329 = lean_ctor_get(x_318, 0); -x_330 = lean_ctor_get(x_318, 1); -x_331 = lean_ctor_get(x_318, 3); -x_332 = lean_ctor_get(x_318, 4); -x_333 = lean_ctor_get(x_318, 5); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); +x_328 = lean_ctor_get(x_299, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_299, 1); lean_inc(x_329); -lean_dec(x_318); -x_334 = lean_ctor_get(x_319, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_319, 1); +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); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - x_336 = x_319; -} else { - lean_dec_ref(x_319); - x_336 = lean_box(0); -} -if (lean_is_scalar(x_336)) { - x_337 = lean_alloc_ctor(0, 3, 0); -} else { - x_337 = x_336; -} -lean_ctor_set(x_337, 0, x_334); -lean_ctor_set(x_337, 1, x_335); -lean_ctor_set(x_337, 2, x_277); -x_338 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_338, 0, x_329); -lean_ctor_set(x_338, 1, x_330); -lean_ctor_set(x_338, 2, x_337); -lean_ctor_set(x_338, 3, x_331); -lean_ctor_set(x_338, 4, x_332); -lean_ctor_set(x_338, 5, x_333); -lean_ctor_set(x_283, 1, x_338); -return x_283; -} +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_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_339 = lean_ctor_get(x_283, 0); -lean_inc(x_339); -lean_dec(x_283); -x_340 = lean_ctor_get(x_318, 0); -lean_inc(x_340); -x_341 = lean_ctor_get(x_318, 1); -lean_inc(x_341); -x_342 = lean_ctor_get(x_318, 3); -lean_inc(x_342); -x_343 = lean_ctor_get(x_318, 4); -lean_inc(x_343); -x_344 = lean_ctor_get(x_318, 5); +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); -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_345 = x_318; -} else { - lean_dec_ref(x_318); - x_345 = lean_box(0); -} -x_346 = lean_ctor_get(x_319, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_319, 1); -lean_inc(x_347); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - lean_ctor_release(x_319, 2); - x_348 = x_319; -} else { - lean_dec_ref(x_319); - x_348 = lean_box(0); -} -if (lean_is_scalar(x_348)) { - x_349 = lean_alloc_ctor(0, 3, 0); -} else { - x_349 = x_348; -} -lean_ctor_set(x_349, 0, x_346); -lean_ctor_set(x_349, 1, x_347); -lean_ctor_set(x_349, 2, x_277); -if (lean_is_scalar(x_345)) { - x_350 = lean_alloc_ctor(0, 6, 0); -} else { - x_350 = x_345; -} -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); -x_351 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_351, 0, x_339); -lean_ctor_set(x_351, 1, x_350); -return x_351; -} +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_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_352 = lean_ctor_get(x_6, 0); -x_353 = lean_ctor_get(x_6, 1); -x_354 = lean_ctor_get(x_6, 2); -x_355 = lean_ctor_get(x_6, 3); -x_356 = lean_ctor_get(x_6, 4); -lean_inc(x_356); -lean_inc(x_355); -lean_inc(x_354); -lean_inc(x_353); +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); -lean_dec(x_6); -x_357 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_357, 0, x_271); -lean_ctor_set(x_357, 1, x_27); -x_358 = lean_array_push(x_354, x_357); -x_359 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_359, 0, x_352); -lean_ctor_set(x_359, 1, x_353); -lean_ctor_set(x_359, 2, x_358); -lean_ctor_set(x_359, 3, x_355); -lean_ctor_set(x_359, 4, x_356); -x_360 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_273, x_359, x_270); -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; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; -x_361 = lean_ctor_get(x_360, 1); -lean_inc(x_361); -x_362 = lean_ctor_get(x_361, 2); -lean_inc(x_362); -x_363 = lean_ctor_get(x_360, 0); -lean_inc(x_363); -if (lean_is_exclusive(x_360)) { - lean_ctor_release(x_360, 0); - lean_ctor_release(x_360, 1); - x_364 = x_360; +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_360); + 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_361, 0); +x_365 = lean_ctor_get(x_336, 0); lean_inc(x_365); -x_366 = lean_ctor_get(x_361, 1); +x_366 = lean_ctor_get(x_336, 1); lean_inc(x_366); -x_367 = lean_ctor_get(x_361, 3); +x_367 = lean_ctor_get(x_336, 3); lean_inc(x_367); -x_368 = lean_ctor_get(x_361, 4); -lean_inc(x_368); -x_369 = lean_ctor_get(x_361, 5); -lean_inc(x_369); -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_370 = x_361; +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_361); - x_370 = lean_box(0); + lean_dec_ref(x_336); + x_368 = lean_box(0); } -x_371 = lean_ctor_get(x_362, 0); -lean_inc(x_371); -x_372 = lean_ctor_get(x_362, 1); -lean_inc(x_372); -if (lean_is_exclusive(x_362)) { - lean_ctor_release(x_362, 0); - lean_ctor_release(x_362, 1); - lean_ctor_release(x_362, 2); - x_373 = x_362; +if (lean_is_scalar(x_368)) { + x_369 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_362); - x_373 = lean_box(0); + x_369 = x_368; } -if (lean_is_scalar(x_373)) { - x_374 = lean_alloc_ctor(0, 3, 0); -} else { - x_374 = x_373; -} -lean_ctor_set(x_374, 0, x_371); -lean_ctor_set(x_374, 1, x_372); -lean_ctor_set(x_374, 2, x_277); -if (lean_is_scalar(x_370)) { - x_375 = lean_alloc_ctor(0, 6, 0); -} else { - x_375 = x_370; -} -lean_ctor_set(x_375, 0, x_365); -lean_ctor_set(x_375, 1, x_366); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_367); -lean_ctor_set(x_375, 4, x_368); -lean_ctor_set(x_375, 5, x_369); +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_376 = lean_alloc_ctor(0, 2, 0); + x_370 = lean_alloc_ctor(0, 6, 0); } else { - x_376 = x_364; + 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; +} } -lean_ctor_set(x_376, 0, x_363); -lean_ctor_set(x_376, 1, x_375); -return x_376; } else { -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_377 = lean_ctor_get(x_360, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_377, 2); -lean_inc(x_378); -x_379 = lean_ctor_get(x_360, 0); -lean_inc(x_379); -if (lean_is_exclusive(x_360)) { - lean_ctor_release(x_360, 0); - lean_ctor_release(x_360, 1); - x_380 = x_360; -} else { - lean_dec_ref(x_360); - x_380 = lean_box(0); -} -x_381 = lean_ctor_get(x_377, 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; +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_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_Init_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) +{ +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_377, 1); +x_382 = lean_ctor_get(x_381, 2); lean_inc(x_382); -x_383 = lean_ctor_get(x_377, 3); +x_383 = lean_ctor_get(x_380, 0); lean_inc(x_383); -x_384 = lean_ctor_get(x_377, 4); -lean_inc(x_384); -x_385 = lean_ctor_get(x_377, 5); +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); -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_386 = x_377; -} else { - lean_dec_ref(x_377); - x_386 = lean_box(0); -} -x_387 = lean_ctor_get(x_378, 0); +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_378, 1); +x_388 = lean_ctor_get(x_381, 4); lean_inc(x_388); -if (lean_is_exclusive(x_378)) { - lean_ctor_release(x_378, 0); - lean_ctor_release(x_378, 1); - lean_ctor_release(x_378, 2); - x_389 = x_378; +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_378); - x_389 = lean_box(0); + lean_dec_ref(x_381); + x_390 = lean_box(0); } -if (lean_is_scalar(x_389)) { - x_390 = lean_alloc_ctor(0, 3, 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 { - x_390 = x_389; + lean_dec_ref(x_382); + x_394 = lean_box(0); } -lean_ctor_set(x_390, 0, x_387); -lean_ctor_set(x_390, 1, x_388); -lean_ctor_set(x_390, 2, x_277); -if (lean_is_scalar(x_386)) { - x_391 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_394)) { + x_395 = lean_alloc_ctor(0, 4, 0); } else { - x_391 = x_386; + x_395 = x_394; } -lean_ctor_set(x_391, 0, x_381); -lean_ctor_set(x_391, 1, x_382); -lean_ctor_set(x_391, 2, x_390); -lean_ctor_set(x_391, 3, x_383); -lean_ctor_set(x_391, 4, x_384); -lean_ctor_set(x_391, 5, x_385); -if (lean_is_scalar(x_380)) { - x_392 = lean_alloc_ctor(1, 2, 0); +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_392 = x_380; -} -lean_ctor_set(x_392, 0, x_379); -lean_ctor_set(x_392, 1, x_391); -return x_392; + 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; } 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; -x_393 = lean_ctor_get(x_275, 0); -x_394 = lean_ctor_get(x_275, 1); -x_395 = lean_ctor_get(x_275, 2); -lean_inc(x_395); -lean_inc(x_394); -lean_inc(x_393); -lean_dec(x_275); -x_396 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_397 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_397, 0, x_393); -lean_ctor_set(x_397, 1, x_394); -lean_ctor_set(x_397, 2, x_396); -lean_ctor_set(x_270, 2, x_397); -x_398 = lean_ctor_get(x_6, 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; 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_6, 1); +x_399 = lean_ctor_get(x_398, 2); lean_inc(x_399); -x_400 = lean_ctor_get(x_6, 2); +x_400 = lean_ctor_get(x_380, 0); lean_inc(x_400); -x_401 = lean_ctor_get(x_6, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_6, 4); +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); +} +x_402 = lean_ctor_get(x_398, 0); lean_inc(x_402); -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_403 = x_6; +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_6); - x_403 = lean_box(0); + lean_dec_ref(x_398); + x_407 = lean_box(0); } -x_404 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_404, 0, x_271); -lean_ctor_set(x_404, 1, x_27); -x_405 = lean_array_push(x_400, x_404); -if (lean_is_scalar(x_403)) { - x_406 = lean_alloc_ctor(0, 5, 0); -} else { - x_406 = x_403; -} -lean_ctor_set(x_406, 0, x_398); -lean_ctor_set(x_406, 1, x_399); -lean_ctor_set(x_406, 2, x_405); -lean_ctor_set(x_406, 3, x_401); -lean_ctor_set(x_406, 4, x_402); -x_407 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_273, x_406, x_270); -if (lean_obj_tag(x_407) == 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; 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_407, 1); +x_408 = lean_ctor_get(x_399, 0); lean_inc(x_408); -x_409 = lean_ctor_get(x_408, 2); +x_409 = lean_ctor_get(x_399, 1); lean_inc(x_409); -x_410 = lean_ctor_get(x_407, 0); +x_410 = lean_ctor_get(x_399, 3); lean_inc(x_410); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - x_411 = x_407; +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; } else { - lean_dec_ref(x_407); + lean_dec_ref(x_399); x_411 = lean_box(0); } -x_412 = lean_ctor_get(x_408, 0); -lean_inc(x_412); -x_413 = lean_ctor_get(x_408, 1); -lean_inc(x_413); -x_414 = lean_ctor_get(x_408, 3); -lean_inc(x_414); -x_415 = lean_ctor_get(x_408, 4); -lean_inc(x_415); -x_416 = lean_ctor_get(x_408, 5); -lean_inc(x_416); -if (lean_is_exclusive(x_408)) { - lean_ctor_release(x_408, 0); - lean_ctor_release(x_408, 1); - lean_ctor_release(x_408, 2); - lean_ctor_release(x_408, 3); - lean_ctor_release(x_408, 4); - lean_ctor_release(x_408, 5); - x_417 = x_408; -} else { - lean_dec_ref(x_408); - x_417 = lean_box(0); -} -x_418 = lean_ctor_get(x_409, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_409, 1); -lean_inc(x_419); -if (lean_is_exclusive(x_409)) { - lean_ctor_release(x_409, 0); - lean_ctor_release(x_409, 1); - lean_ctor_release(x_409, 2); - x_420 = x_409; -} else { - lean_dec_ref(x_409); - x_420 = lean_box(0); -} -if (lean_is_scalar(x_420)) { - x_421 = lean_alloc_ctor(0, 3, 0); -} else { - x_421 = x_420; -} -lean_ctor_set(x_421, 0, x_418); -lean_ctor_set(x_421, 1, x_419); -lean_ctor_set(x_421, 2, x_395); -if (lean_is_scalar(x_417)) { - x_422 = lean_alloc_ctor(0, 6, 0); -} else { - x_422 = x_417; -} -lean_ctor_set(x_422, 0, x_412); -lean_ctor_set(x_422, 1, x_413); -lean_ctor_set(x_422, 2, x_421); -lean_ctor_set(x_422, 3, x_414); -lean_ctor_set(x_422, 4, x_415); -lean_ctor_set(x_422, 5, x_416); if (lean_is_scalar(x_411)) { - x_423 = lean_alloc_ctor(0, 2, 0); + x_412 = lean_alloc_ctor(0, 4, 0); } else { - x_423 = x_411; + x_412 = x_411; +} +lean_ctor_set(x_412, 0, x_408); +lean_ctor_set(x_412, 1, x_409); +lean_ctor_set(x_412, 2, x_291); +lean_ctor_set(x_412, 3, x_410); +if (lean_is_scalar(x_407)) { + x_413 = lean_alloc_ctor(0, 6, 0); +} else { + x_413 = x_407; +} +lean_ctor_set(x_413, 0, x_402); +lean_ctor_set(x_413, 1, x_403); +lean_ctor_set(x_413, 2, x_412); +lean_ctor_set(x_413, 3, x_404); +lean_ctor_set(x_413, 4, x_405); +lean_ctor_set(x_413, 5, x_406); +if (lean_is_scalar(x_401)) { + x_414 = lean_alloc_ctor(1, 2, 0); +} else { + x_414 = x_401; +} +lean_ctor_set(x_414, 0, x_400); +lean_ctor_set(x_414, 1, x_413); +return x_414; +} } -lean_ctor_set(x_423, 0, x_410); -lean_ctor_set(x_423, 1, x_422); -return x_423; } else { -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_424 = lean_ctor_get(x_407, 1); +lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; +x_415 = lean_ctor_get(x_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_424, 2); +x_425 = lean_ctor_get(x_6, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_407, 0); -lean_inc(x_426); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - x_427 = x_407; -} else { - lean_dec_ref(x_407); - 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); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - lean_ctor_release(x_425, 2); - x_436 = x_425; -} else { - lean_dec_ref(x_425); - x_436 = lean_box(0); -} -if (lean_is_scalar(x_436)) { - x_437 = lean_alloc_ctor(0, 3, 0); -} else { - x_437 = x_436; -} -lean_ctor_set(x_437, 0, x_434); -lean_ctor_set(x_437, 1, x_435); -lean_ctor_set(x_437, 2, x_395); -if (lean_is_scalar(x_433)) { - x_438 = lean_alloc_ctor(0, 6, 0); -} else { - x_438 = x_433; -} -lean_ctor_set(x_438, 0, x_428); -lean_ctor_set(x_438, 1, x_429); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_430); -lean_ctor_set(x_438, 4, x_431); -lean_ctor_set(x_438, 5, x_432); -if (lean_is_scalar(x_427)) { - x_439 = lean_alloc_ctor(1, 2, 0); -} else { - x_439 = x_427; -} -lean_ctor_set(x_439, 0, x_426); -lean_ctor_set(x_439, 1, x_438); -return x_439; -} -} -} -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; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; -x_440 = lean_ctor_get(x_270, 2); -x_441 = lean_ctor_get(x_270, 0); -x_442 = lean_ctor_get(x_270, 1); -x_443 = lean_ctor_get(x_270, 3); -x_444 = lean_ctor_get(x_270, 4); -x_445 = lean_ctor_get(x_270, 5); -lean_inc(x_445); -lean_inc(x_444); -lean_inc(x_443); -lean_inc(x_440); -lean_inc(x_442); -lean_inc(x_441); -lean_dec(x_270); -x_446 = lean_ctor_get(x_440, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_440, 1); -lean_inc(x_447); -x_448 = lean_ctor_get(x_440, 2); -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); - x_449 = x_440; -} else { - lean_dec_ref(x_440); - x_449 = lean_box(0); -} -x_450 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_449)) { - x_451 = lean_alloc_ctor(0, 3, 0); -} else { - x_451 = x_449; -} -lean_ctor_set(x_451, 0, x_446); -lean_ctor_set(x_451, 1, x_447); -lean_ctor_set(x_451, 2, x_450); -x_452 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_452, 0, x_441); -lean_ctor_set(x_452, 1, x_442); -lean_ctor_set(x_452, 2, x_451); -lean_ctor_set(x_452, 3, x_443); -lean_ctor_set(x_452, 4, x_444); -lean_ctor_set(x_452, 5, x_445); -x_453 = lean_ctor_get(x_6, 0); -lean_inc(x_453); -x_454 = lean_ctor_get(x_6, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_6, 2); -lean_inc(x_455); -x_456 = lean_ctor_get(x_6, 3); -lean_inc(x_456); -x_457 = lean_ctor_get(x_6, 4); -lean_inc(x_457); 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_458 = x_6; + x_426 = x_6; } else { lean_dec_ref(x_6); - x_458 = lean_box(0); + x_426 = lean_box(0); } -x_459 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_459, 0, x_271); -lean_ctor_set(x_459, 1, x_27); -x_460 = lean_array_push(x_455, x_459); -if (lean_is_scalar(x_458)) { - x_461 = lean_alloc_ctor(0, 5, 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); } else { - x_461 = x_458; + x_429 = x_426; } -lean_ctor_set(x_461, 0, x_453); -lean_ctor_set(x_461, 1, x_454); -lean_ctor_set(x_461, 2, x_460); -lean_ctor_set(x_461, 3, x_456); -lean_ctor_set(x_461, 4, x_457); -x_462 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_273, x_461, x_452); -if (lean_obj_tag(x_462) == 0) +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_Init_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_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; -x_463 = lean_ctor_get(x_462, 1); -lean_inc(x_463); -x_464 = lean_ctor_get(x_463, 2); -lean_inc(x_464); -x_465 = lean_ctor_get(x_462, 0); -lean_inc(x_465); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - x_466 = x_462; +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_462); - x_466 = lean_box(0); + lean_dec_ref(x_430); + x_434 = lean_box(0); } -x_467 = lean_ctor_get(x_463, 0); -lean_inc(x_467); -x_468 = lean_ctor_get(x_463, 1); -lean_inc(x_468); -x_469 = lean_ctor_get(x_463, 3); -lean_inc(x_469); -x_470 = lean_ctor_get(x_463, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_448); + x_457 = 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; +} else { + lean_dec_ref(x_449); + x_461 = lean_box(0); +} +if (lean_is_scalar(x_461)) { + x_462 = lean_alloc_ctor(0, 4, 0); +} else { + x_462 = x_461; +} +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); +} else { + x_463 = x_457; +} +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); +} else { + x_464 = x_451; +} +lean_ctor_set(x_464, 0, x_450); +lean_ctor_set(x_464, 1, x_463); +return x_464; +} +} +} +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); -x_471 = lean_ctor_get(x_463, 5); +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); -if (lean_is_exclusive(x_463)) { - lean_ctor_release(x_463, 0); - lean_ctor_release(x_463, 1); - lean_ctor_release(x_463, 2); - lean_ctor_release(x_463, 3); - lean_ctor_release(x_463, 4); - lean_ctor_release(x_463, 5); - x_472 = x_463; -} else { - lean_dec_ref(x_463); - x_472 = lean_box(0); -} -x_473 = lean_ctor_get(x_464, 0); +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_464, 1); +x_474 = lean_ctor_get(x_465, 3); lean_inc(x_474); -if (lean_is_exclusive(x_464)) { - lean_ctor_release(x_464, 0); - lean_ctor_release(x_464, 1); - lean_ctor_release(x_464, 2); - x_475 = x_464; +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; } else { - lean_dec_ref(x_464); + lean_dec_ref(x_465); x_475 = lean_box(0); } +x_476 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_475)) { - x_476 = lean_alloc_ctor(0, 3, 0); + x_477 = lean_alloc_ctor(0, 4, 0); } else { - x_476 = x_475; + x_477 = x_475; } -lean_ctor_set(x_476, 0, x_473); -lean_ctor_set(x_476, 1, x_474); -lean_ctor_set(x_476, 2, x_448); -if (lean_is_scalar(x_472)) { - x_477 = lean_alloc_ctor(0, 6, 0); -} else { - x_477 = x_472; -} -lean_ctor_set(x_477, 0, x_467); -lean_ctor_set(x_477, 1, x_468); +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_469); -lean_ctor_set(x_477, 4, x_470); -lean_ctor_set(x_477, 5, x_471); -if (lean_is_scalar(x_466)) { - x_478 = lean_alloc_ctor(0, 2, 0); -} else { - x_478 = x_466; -} -lean_ctor_set(x_478, 0, x_465); -lean_ctor_set(x_478, 1, x_477); -return x_478; -} -else -{ -lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; 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; -x_479 = lean_ctor_get(x_462, 1); +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_479, 2); +x_480 = lean_ctor_get(x_6, 1); lean_inc(x_480); -x_481 = lean_ctor_get(x_462, 0); +x_481 = lean_ctor_get(x_6, 2); lean_inc(x_481); -if (lean_is_exclusive(x_462)) { - lean_ctor_release(x_462, 0); - lean_ctor_release(x_462, 1); - x_482 = x_462; -} else { - lean_dec_ref(x_462); - x_482 = lean_box(0); -} -x_483 = lean_ctor_get(x_479, 0); +x_482 = lean_ctor_get(x_6, 3); +lean_inc(x_482); +x_483 = lean_ctor_get(x_6, 4); lean_inc(x_483); -x_484 = lean_ctor_get(x_479, 1); -lean_inc(x_484); -x_485 = lean_ctor_get(x_479, 3); -lean_inc(x_485); -x_486 = lean_ctor_get(x_479, 4); -lean_inc(x_486); -x_487 = lean_ctor_get(x_479, 5); -lean_inc(x_487); -if (lean_is_exclusive(x_479)) { - lean_ctor_release(x_479, 0); - lean_ctor_release(x_479, 1); - lean_ctor_release(x_479, 2); - lean_ctor_release(x_479, 3); - lean_ctor_release(x_479, 4); - lean_ctor_release(x_479, 5); - x_488 = x_479; +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; } else { - lean_dec_ref(x_479); - x_488 = lean_box(0); + lean_dec_ref(x_6); + x_484 = lean_box(0); } -x_489 = lean_ctor_get(x_480, 0); +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); +} else { + x_487 = x_484; +} +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_Init_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_480, 1); +x_490 = lean_ctor_get(x_489, 2); lean_inc(x_490); -if (lean_is_exclusive(x_480)) { - lean_ctor_release(x_480, 0); - lean_ctor_release(x_480, 1); - lean_ctor_release(x_480, 2); - x_491 = x_480; +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; } else { - lean_dec_ref(x_480); - x_491 = lean_box(0); + lean_dec_ref(x_488); + x_492 = lean_box(0); } -if (lean_is_scalar(x_491)) { - x_492 = lean_alloc_ctor(0, 3, 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 { - x_492 = x_491; + lean_dec_ref(x_489); + x_498 = lean_box(0); } -lean_ctor_set(x_492, 0, x_489); -lean_ctor_set(x_492, 1, x_490); -lean_ctor_set(x_492, 2, x_448); -if (lean_is_scalar(x_488)) { - x_493 = lean_alloc_ctor(0, 6, 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 { - x_493 = x_488; + lean_dec_ref(x_490); + x_502 = lean_box(0); } -lean_ctor_set(x_493, 0, x_483); -lean_ctor_set(x_493, 1, x_484); -lean_ctor_set(x_493, 2, x_492); -lean_ctor_set(x_493, 3, x_485); -lean_ctor_set(x_493, 4, x_486); -lean_ctor_set(x_493, 5, x_487); -if (lean_is_scalar(x_482)) { - x_494 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_502)) { + x_503 = lean_alloc_ctor(0, 4, 0); } else { - x_494 = x_482; + x_503 = x_502; } -lean_ctor_set(x_494, 0, x_481); -lean_ctor_set(x_494, 1, x_493); -return x_494; +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_495; +uint8_t x_523; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_495 = !lean_is_exclusive(x_264); -if (x_495 == 0) +x_523 = !lean_is_exclusive(x_278); +if (x_523 == 0) { -return x_264; +return x_278; } else { -lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_496 = lean_ctor_get(x_264, 0); -x_497 = lean_ctor_get(x_264, 1); -lean_inc(x_497); -lean_inc(x_496); -lean_dec(x_264); -x_498 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_498, 0, x_496); -lean_ctor_set(x_498, 1, x_497); -return x_498; +lean_object* x_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; } } } @@ -9262,56 +9591,56 @@ return x_498; } else { -uint8_t x_499; +uint8_t x_527; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_499 = !lean_is_exclusive(x_32); -if (x_499 == 0) +x_527 = !lean_is_exclusive(x_32); +if (x_527 == 0) { return x_32; } else { -lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_500 = lean_ctor_get(x_32, 0); -x_501 = lean_ctor_get(x_32, 1); -lean_inc(x_501); -lean_inc(x_500); +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_dec(x_32); -x_502 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_502, 0, x_500); -lean_ctor_set(x_502, 1, x_501); -return x_502; +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; } } } else { -uint8_t x_503; +uint8_t x_531; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_503 = !lean_is_exclusive(x_28); -if (x_503 == 0) +x_531 = !lean_is_exclusive(x_28); +if (x_531 == 0) { return x_28; } else { -lean_object* x_504; lean_object* x_505; lean_object* x_506; -x_504 = lean_ctor_get(x_28, 0); -x_505 = lean_ctor_get(x_28, 1); -lean_inc(x_505); -lean_inc(x_504); +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_dec(x_28); -x_506 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_506, 0, x_504); -lean_ctor_set(x_506, 1, x_505); -return x_506; +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; } } } @@ -9758,90 +10087,97 @@ return x_27; } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; x_38 = lean_ctor_get(x_29, 0); x_39 = lean_ctor_get(x_29, 1); x_40 = lean_ctor_get(x_29, 2); +x_41 = lean_ctor_get(x_29, 3); +lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_dec(x_29); lean_inc(x_31); -x_41 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_39, x_15, x_31); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_38); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set(x_42, 2, x_40); -lean_ctor_set(x_28, 2, x_42); +x_42 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_39, x_15, x_31); +x_43 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_42); +lean_ctor_set(x_43, 2, x_40); +lean_ctor_set(x_43, 3, x_41); +lean_ctor_set(x_28, 2, x_43); return x_27; } } 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; -x_43 = lean_ctor_get(x_28, 0); -x_44 = lean_ctor_get(x_28, 1); -x_45 = lean_ctor_get(x_28, 3); -x_46 = lean_ctor_get(x_28, 4); -x_47 = lean_ctor_get(x_28, 5); +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_44 = lean_ctor_get(x_28, 0); +x_45 = lean_ctor_get(x_28, 1); +x_46 = lean_ctor_get(x_28, 3); +x_47 = lean_ctor_get(x_28, 4); +x_48 = lean_ctor_get(x_28, 5); +lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); -lean_inc(x_43); lean_dec(x_28); -x_48 = lean_ctor_get(x_29, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_29, 1); +x_49 = lean_ctor_get(x_29, 0); lean_inc(x_49); -x_50 = lean_ctor_get(x_29, 2); +x_50 = lean_ctor_get(x_29, 1); lean_inc(x_50); +x_51 = lean_ctor_get(x_29, 2); +lean_inc(x_51); +x_52 = lean_ctor_get(x_29, 3); +lean_inc(x_52); if (lean_is_exclusive(x_29)) { lean_ctor_release(x_29, 0); lean_ctor_release(x_29, 1); lean_ctor_release(x_29, 2); - x_51 = x_29; + lean_ctor_release(x_29, 3); + x_53 = x_29; } else { lean_dec_ref(x_29); - x_51 = lean_box(0); + x_53 = lean_box(0); } lean_inc(x_31); -x_52 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_49, x_15, x_31); -if (lean_is_scalar(x_51)) { - x_53 = lean_alloc_ctor(0, 3, 0); +x_54 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_50, x_15, x_31); +if (lean_is_scalar(x_53)) { + x_55 = lean_alloc_ctor(0, 4, 0); } else { - x_53 = x_51; + x_55 = x_53; } -lean_ctor_set(x_53, 0, x_48); -lean_ctor_set(x_53, 1, x_52); -lean_ctor_set(x_53, 2, x_50); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_44); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_45); -lean_ctor_set(x_54, 4, x_46); -lean_ctor_set(x_54, 5, x_47); -lean_ctor_set(x_27, 1, x_54); +lean_ctor_set(x_55, 0, x_49); +lean_ctor_set(x_55, 1, x_54); +lean_ctor_set(x_55, 2, x_51); +lean_ctor_set(x_55, 3, x_52); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_44); +lean_ctor_set(x_56, 1, x_45); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_46); +lean_ctor_set(x_56, 4, x_47); +lean_ctor_set(x_56, 5, x_48); +lean_ctor_set(x_27, 1, x_56); return x_27; } } 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; lean_object* x_69; -x_55 = lean_ctor_get(x_27, 0); -lean_inc(x_55); -lean_dec(x_27); -x_56 = lean_ctor_get(x_28, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_28, 1); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_57 = lean_ctor_get(x_27, 0); lean_inc(x_57); -x_58 = lean_ctor_get(x_28, 3); +lean_dec(x_27); +x_58 = lean_ctor_get(x_28, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_28, 4); +x_59 = lean_ctor_get(x_28, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_28, 5); +x_60 = lean_ctor_get(x_28, 3); lean_inc(x_60); +x_61 = lean_ctor_get(x_28, 4); +lean_inc(x_61); +x_62 = lean_ctor_get(x_28, 5); +lean_inc(x_62); if (lean_is_exclusive(x_28)) { lean_ctor_release(x_28, 0); lean_ctor_release(x_28, 1); @@ -9849,80 +10185,84 @@ if (lean_is_exclusive(x_28)) { lean_ctor_release(x_28, 3); lean_ctor_release(x_28, 4); lean_ctor_release(x_28, 5); - x_61 = x_28; + x_63 = x_28; } else { lean_dec_ref(x_28); - x_61 = lean_box(0); + x_63 = lean_box(0); } -x_62 = lean_ctor_get(x_29, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_29, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_29, 2); +x_64 = lean_ctor_get(x_29, 0); lean_inc(x_64); +x_65 = lean_ctor_get(x_29, 1); +lean_inc(x_65); +x_66 = lean_ctor_get(x_29, 2); +lean_inc(x_66); +x_67 = lean_ctor_get(x_29, 3); +lean_inc(x_67); if (lean_is_exclusive(x_29)) { lean_ctor_release(x_29, 0); lean_ctor_release(x_29, 1); lean_ctor_release(x_29, 2); - x_65 = x_29; + lean_ctor_release(x_29, 3); + x_68 = x_29; } else { lean_dec_ref(x_29); - x_65 = lean_box(0); + x_68 = lean_box(0); } -lean_inc(x_55); -x_66 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_63, x_15, x_55); -if (lean_is_scalar(x_65)) { - x_67 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_57); +x_69 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_65, x_15, x_57); +if (lean_is_scalar(x_68)) { + x_70 = lean_alloc_ctor(0, 4, 0); } else { - x_67 = x_65; + x_70 = x_68; } -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_66); -lean_ctor_set(x_67, 2, x_64); -if (lean_is_scalar(x_61)) { - x_68 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_64); +lean_ctor_set(x_70, 1, x_69); +lean_ctor_set(x_70, 2, x_66); +lean_ctor_set(x_70, 3, x_67); +if (lean_is_scalar(x_63)) { + x_71 = lean_alloc_ctor(0, 6, 0); } else { - x_68 = x_61; + x_71 = x_63; } -lean_ctor_set(x_68, 0, x_56); -lean_ctor_set(x_68, 1, x_57); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_58); -lean_ctor_set(x_68, 4, x_59); -lean_ctor_set(x_68, 5, x_60); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_55); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_58); +lean_ctor_set(x_71, 1, x_59); +lean_ctor_set(x_71, 2, x_70); +lean_ctor_set(x_71, 3, x_60); +lean_ctor_set(x_71, 4, x_61); +lean_ctor_set(x_71, 5, x_62); +x_72 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_72, 0, x_57); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } else { -uint8_t x_70; +uint8_t x_73; lean_dec(x_15); -x_70 = !lean_is_exclusive(x_27); -if (x_70 == 0) +x_73 = !lean_is_exclusive(x_27); +if (x_73 == 0) { return x_27; } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_27, 0); -x_72 = lean_ctor_get(x_27, 1); -lean_inc(x_72); -lean_inc(x_71); +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_27, 0); +x_75 = lean_ctor_get(x_27, 1); +lean_inc(x_75); +lean_inc(x_74); lean_dec(x_27); -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; +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_74; +uint8_t x_77; lean_free_object(x_3); lean_dec(x_15); lean_free_object(x_5); @@ -9932,23 +10272,23 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); -x_74 = !lean_is_exclusive(x_17); -if (x_74 == 0) +x_77 = !lean_is_exclusive(x_17); +if (x_77 == 0) { return x_17; } else { -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_17, 0); -x_76 = lean_ctor_get(x_17, 1); -lean_inc(x_76); -lean_inc(x_75); +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_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; +x_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; } } } @@ -9957,152 +10297,123 @@ else lean_dec(x_3); if (lean_obj_tag(x_17) == 0) { -lean_object* x_78; lean_object* x_79; uint8_t x_80; lean_object* x_81; lean_object* x_82; -x_78 = lean_ctor_get(x_17, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_17, 1); -lean_inc(x_79); +lean_object* x_81; lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; +x_81 = lean_ctor_get(x_17, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_17, 1); +lean_inc(x_82); lean_dec(x_17); -x_80 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 6, x_80); -x_81 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_81, 0, x_5); -lean_ctor_set(x_81, 1, x_6); -lean_ctor_set(x_81, 2, x_7); -lean_ctor_set(x_81, 3, x_8); -lean_ctor_set(x_81, 4, x_9); -x_82 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_78, x_2, x_81, x_79); -if (lean_obj_tag(x_82) == 0) +x_83 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 6, x_83); +x_84 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_84, 0, x_5); +lean_ctor_set(x_84, 1, x_6); +lean_ctor_set(x_84, 2, x_7); +lean_ctor_set(x_84, 3, x_8); +lean_ctor_set(x_84, 4, x_9); +x_85 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_81, x_2, x_84, x_82); +if (lean_obj_tag(x_85) == 0) { -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; 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_83 = lean_ctor_get(x_82, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = lean_ctor_get(x_82, 0); -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); -} -x_87 = lean_ctor_get(x_83, 0); +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_86 = lean_ctor_get(x_85, 1); +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); lean_inc(x_87); -x_88 = lean_ctor_get(x_83, 1); +x_88 = lean_ctor_get(x_85, 0); lean_inc(x_88); -x_89 = lean_ctor_get(x_83, 3); -lean_inc(x_89); -x_90 = lean_ctor_get(x_83, 4); +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_89 = x_85; +} else { + lean_dec_ref(x_85); + x_89 = lean_box(0); +} +x_90 = lean_ctor_get(x_86, 0); lean_inc(x_90); -x_91 = lean_ctor_get(x_83, 5); +x_91 = lean_ctor_get(x_86, 1); lean_inc(x_91); -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_92 = x_83; -} else { - lean_dec_ref(x_83); - x_92 = lean_box(0); -} -x_93 = lean_ctor_get(x_84, 0); +x_92 = lean_ctor_get(x_86, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_86, 4); lean_inc(x_93); -x_94 = lean_ctor_get(x_84, 1); +x_94 = lean_ctor_get(x_86, 5); lean_inc(x_94); -x_95 = lean_ctor_get(x_84, 2); -lean_inc(x_95); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - x_96 = x_84; +if (lean_is_exclusive(x_86)) { + lean_ctor_release(x_86, 0); + lean_ctor_release(x_86, 1); + lean_ctor_release(x_86, 2); + lean_ctor_release(x_86, 3); + lean_ctor_release(x_86, 4); + lean_ctor_release(x_86, 5); + x_95 = x_86; } else { - lean_dec_ref(x_84); - x_96 = lean_box(0); + lean_dec_ref(x_86); + x_95 = lean_box(0); } -lean_inc(x_85); -x_97 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_94, x_15, x_85); -if (lean_is_scalar(x_96)) { - x_98 = lean_alloc_ctor(0, 3, 0); +x_96 = lean_ctor_get(x_87, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_87, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_87, 2); +lean_inc(x_98); +x_99 = lean_ctor_get(x_87, 3); +lean_inc(x_99); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + x_100 = x_87; } else { - x_98 = x_96; + lean_dec_ref(x_87); + x_100 = lean_box(0); } -lean_ctor_set(x_98, 0, x_93); -lean_ctor_set(x_98, 1, x_97); -lean_ctor_set(x_98, 2, x_95); -if (lean_is_scalar(x_92)) { - x_99 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_88); +x_101 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_97, x_15, x_88); +if (lean_is_scalar(x_100)) { + x_102 = lean_alloc_ctor(0, 4, 0); } else { - x_99 = x_92; + x_102 = x_100; } -lean_ctor_set(x_99, 0, x_87); -lean_ctor_set(x_99, 1, x_88); -lean_ctor_set(x_99, 2, x_98); -lean_ctor_set(x_99, 3, x_89); -lean_ctor_set(x_99, 4, x_90); -lean_ctor_set(x_99, 5, x_91); -if (lean_is_scalar(x_86)) { - x_100 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_96); +lean_ctor_set(x_102, 1, x_101); +lean_ctor_set(x_102, 2, x_98); +lean_ctor_set(x_102, 3, x_99); +if (lean_is_scalar(x_95)) { + x_103 = lean_alloc_ctor(0, 6, 0); } else { - x_100 = x_86; + x_103 = x_95; } -lean_ctor_set(x_100, 0, x_85); -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_dec(x_15); -x_101 = lean_ctor_get(x_82, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_82, 1); -lean_inc(x_102); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - x_103 = x_82; +lean_ctor_set(x_103, 0, x_90); +lean_ctor_set(x_103, 1, x_91); +lean_ctor_set(x_103, 2, x_102); +lean_ctor_set(x_103, 3, x_92); +lean_ctor_set(x_103, 4, x_93); +lean_ctor_set(x_103, 5, x_94); +if (lean_is_scalar(x_89)) { + x_104 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_82); - x_103 = lean_box(0); + x_104 = x_89; } -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(1, 2, 0); -} else { - x_104 = x_103; -} -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); +lean_ctor_set(x_104, 0, x_88); +lean_ctor_set(x_104, 1, x_103); return x_104; } -} else { lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_dec(x_15); -lean_free_object(x_5); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_2); -x_105 = lean_ctor_get(x_17, 0); +x_105 = lean_ctor_get(x_85, 0); lean_inc(x_105); -x_106 = lean_ctor_get(x_17, 1); +x_106 = lean_ctor_get(x_85, 1); lean_inc(x_106); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - x_107 = x_17; +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_107 = x_85; } else { - lean_dec_ref(x_17); + lean_dec_ref(x_85); x_107 = lean_box(0); } if (lean_is_scalar(x_107)) { @@ -10115,10 +10426,43 @@ lean_ctor_set(x_108, 1, x_106); return x_108; } } +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; +lean_dec(x_15); +lean_free_object(x_5); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +x_109 = lean_ctor_get(x_17, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_17, 1); +lean_inc(x_110); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + x_111 = x_17; +} else { + lean_dec_ref(x_17); + x_111 = lean_box(0); +} +if (lean_is_scalar(x_111)) { + x_112 = lean_alloc_ctor(1, 2, 0); +} else { + x_112 = x_111; +} +lean_ctor_set(x_112, 0, x_109); +lean_ctor_set(x_112, 1, x_110); +return x_112; +} +} } else { -lean_object* x_109; lean_object* x_110; +lean_object* x_113; lean_object* x_114; lean_dec(x_15); lean_free_object(x_5); lean_dec(x_11); @@ -10129,233 +10473,237 @@ lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_109 = lean_ctor_get(x_16, 0); -lean_inc(x_109); +x_113 = lean_ctor_get(x_16, 0); +lean_inc(x_113); lean_dec(x_16); -x_110 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_110, 0, x_109); -lean_ctor_set(x_110, 1, x_4); -return x_110; +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_113); +lean_ctor_set(x_114, 1, x_4); +return x_114; } } else { -lean_object* x_111; uint8_t x_112; uint8_t x_113; uint8_t x_114; uint8_t x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_111 = lean_ctor_get(x_5, 0); -x_112 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_113 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_114 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_115 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -x_116 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); -x_117 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); -x_118 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); -lean_inc(x_111); +lean_object* x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; uint8_t x_119; uint8_t x_120; uint8_t x_121; uint8_t x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_115 = lean_ctor_get(x_5, 0); +x_116 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_117 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_118 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_119 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_120 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +x_121 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); +x_122 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); +lean_inc(x_115); lean_dec(x_5); -x_119 = lean_ctor_get(x_4, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -lean_dec(x_119); +x_123 = lean_ctor_get(x_4, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_123, 1); +lean_inc(x_124); +lean_dec(x_123); lean_inc(x_2); lean_inc(x_1); -x_121 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_121, 0, x_1); -lean_ctor_set(x_121, 1, x_2); -lean_ctor_set_uint8(x_121, sizeof(void*)*2, x_118); -x_122 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_120, x_121); -if (lean_obj_tag(x_122) == 0) +x_125 = lean_alloc_ctor(0, 2, 1); +lean_ctor_set(x_125, 0, x_1); +lean_ctor_set(x_125, 1, x_2); +lean_ctor_set_uint8(x_125, sizeof(void*)*2, x_122); +x_126 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_124, x_125); +if (lean_obj_tag(x_126) == 0) { -lean_object* x_123; lean_object* x_124; +lean_object* x_127; lean_object* x_128; lean_inc(x_3); -x_123 = l_Lean_Meta_inferType(x_1, x_3, x_4); +x_127 = l_Lean_Meta_inferType(x_1, x_3, x_4); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); lean_ctor_release(x_3, 3); lean_ctor_release(x_3, 4); - x_124 = x_3; + x_128 = x_3; } else { lean_dec_ref(x_3); - x_124 = lean_box(0); + x_128 = lean_box(0); } -if (lean_obj_tag(x_123) == 0) +if (lean_obj_tag(x_127) == 0) { -lean_object* x_125; lean_object* x_126; uint8_t x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_125 = lean_ctor_get(x_123, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_123, 1); -lean_inc(x_126); -lean_dec(x_123); -x_127 = 1; -x_128 = lean_alloc_ctor(0, 1, 7); -lean_ctor_set(x_128, 0, x_111); -lean_ctor_set_uint8(x_128, sizeof(void*)*1, x_112); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 1, x_113); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 2, x_114); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 3, x_115); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 4, x_116); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 5, x_117); -lean_ctor_set_uint8(x_128, sizeof(void*)*1 + 6, x_127); -if (lean_is_scalar(x_124)) { - x_129 = lean_alloc_ctor(0, 5, 0); +lean_object* x_129; lean_object* x_130; uint8_t x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +x_129 = lean_ctor_get(x_127, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 1); +lean_inc(x_130); +lean_dec(x_127); +x_131 = 1; +x_132 = lean_alloc_ctor(0, 1, 7); +lean_ctor_set(x_132, 0, x_115); +lean_ctor_set_uint8(x_132, sizeof(void*)*1, x_116); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 1, x_117); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 2, x_118); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 3, x_119); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 4, x_120); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 5, x_121); +lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 6, x_131); +if (lean_is_scalar(x_128)) { + x_133 = lean_alloc_ctor(0, 5, 0); } else { - x_129 = x_124; + x_133 = x_128; } -lean_ctor_set(x_129, 0, x_128); -lean_ctor_set(x_129, 1, x_6); -lean_ctor_set(x_129, 2, x_7); -lean_ctor_set(x_129, 3, x_8); -lean_ctor_set(x_129, 4, x_9); -x_130 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_125, x_2, x_129, x_126); -if (lean_obj_tag(x_130) == 0) +lean_ctor_set(x_133, 0, x_132); +lean_ctor_set(x_133, 1, x_6); +lean_ctor_set(x_133, 2, x_7); +lean_ctor_set(x_133, 3, x_8); +lean_ctor_set(x_133, 4, x_9); +x_134 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_129, x_2, x_133, x_130); +if (lean_obj_tag(x_134) == 0) { -lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_131 = lean_ctor_get(x_130, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_131, 2); -lean_inc(x_132); -x_133 = lean_ctor_get(x_130, 0); -lean_inc(x_133); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - x_134 = x_130; -} else { - lean_dec_ref(x_130); - x_134 = lean_box(0); -} -x_135 = lean_ctor_get(x_131, 0); +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; +x_135 = lean_ctor_get(x_134, 1); lean_inc(x_135); -x_136 = lean_ctor_get(x_131, 1); +x_136 = lean_ctor_get(x_135, 2); lean_inc(x_136); -x_137 = lean_ctor_get(x_131, 3); +x_137 = lean_ctor_get(x_134, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_131, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_131, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - lean_ctor_release(x_131, 4); - lean_ctor_release(x_131, 5); - x_140 = x_131; +if (lean_is_exclusive(x_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + x_138 = x_134; } else { - lean_dec_ref(x_131); - x_140 = lean_box(0); + lean_dec_ref(x_134); + x_138 = lean_box(0); } -x_141 = lean_ctor_get(x_132, 0); +x_139 = lean_ctor_get(x_135, 0); +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_132, 1); +x_142 = lean_ctor_get(x_135, 4); lean_inc(x_142); -x_143 = lean_ctor_get(x_132, 2); +x_143 = lean_ctor_get(x_135, 5); lean_inc(x_143); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - x_144 = x_132; +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_132); + lean_dec_ref(x_135); x_144 = lean_box(0); } -lean_inc(x_133); -x_145 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_142, x_121, x_133); +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, 2); +lean_inc(x_147); +x_148 = lean_ctor_get(x_136, 3); +lean_inc(x_148); +if (lean_is_exclusive(x_136)) { + lean_ctor_release(x_136, 0); + lean_ctor_release(x_136, 1); + lean_ctor_release(x_136, 2); + lean_ctor_release(x_136, 3); + x_149 = x_136; +} else { + lean_dec_ref(x_136); + x_149 = lean_box(0); +} +lean_inc(x_137); +x_150 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_146, x_125, x_137); +if (lean_is_scalar(x_149)) { + x_151 = lean_alloc_ctor(0, 4, 0); +} else { + x_151 = x_149; +} +lean_ctor_set(x_151, 0, x_145); +lean_ctor_set(x_151, 1, x_150); +lean_ctor_set(x_151, 2, x_147); +lean_ctor_set(x_151, 3, x_148); if (lean_is_scalar(x_144)) { - x_146 = lean_alloc_ctor(0, 3, 0); + x_152 = lean_alloc_ctor(0, 6, 0); } else { - x_146 = x_144; + x_152 = x_144; } -lean_ctor_set(x_146, 0, x_141); -lean_ctor_set(x_146, 1, x_145); -lean_ctor_set(x_146, 2, x_143); -if (lean_is_scalar(x_140)) { - x_147 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_152, 0, x_139); +lean_ctor_set(x_152, 1, x_140); +lean_ctor_set(x_152, 2, x_151); +lean_ctor_set(x_152, 3, x_141); +lean_ctor_set(x_152, 4, x_142); +lean_ctor_set(x_152, 5, x_143); +if (lean_is_scalar(x_138)) { + x_153 = lean_alloc_ctor(0, 2, 0); } else { - x_147 = x_140; + x_153 = x_138; } -lean_ctor_set(x_147, 0, x_135); -lean_ctor_set(x_147, 1, x_136); -lean_ctor_set(x_147, 2, x_146); -lean_ctor_set(x_147, 3, x_137); -lean_ctor_set(x_147, 4, x_138); -lean_ctor_set(x_147, 5, x_139); -if (lean_is_scalar(x_134)) { - x_148 = lean_alloc_ctor(0, 2, 0); -} else { - x_148 = x_134; -} -lean_ctor_set(x_148, 0, x_133); -lean_ctor_set(x_148, 1, x_147); -return x_148; +lean_ctor_set(x_153, 0, x_137); +lean_ctor_set(x_153, 1, x_152); +return x_153; } else { -lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -lean_dec(x_121); -x_149 = lean_ctor_get(x_130, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_130, 1); -lean_inc(x_150); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - x_151 = x_130; +lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; +lean_dec(x_125); +x_154 = lean_ctor_get(x_134, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_134, 1); +lean_inc(x_155); +if (lean_is_exclusive(x_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + x_156 = x_134; } else { - lean_dec_ref(x_130); - x_151 = lean_box(0); + lean_dec_ref(x_134); + x_156 = lean_box(0); } -if (lean_is_scalar(x_151)) { - x_152 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(1, 2, 0); } else { - x_152 = x_151; + x_157 = x_156; } -lean_ctor_set(x_152, 0, x_149); -lean_ctor_set(x_152, 1, x_150); -return x_152; +lean_ctor_set(x_157, 0, x_154); +lean_ctor_set(x_157, 1, x_155); +return x_157; } } else { -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; -lean_dec(x_124); -lean_dec(x_121); -lean_dec(x_111); +lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +lean_dec(x_128); +lean_dec(x_125); +lean_dec(x_115); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); -x_153 = lean_ctor_get(x_123, 0); -lean_inc(x_153); -x_154 = lean_ctor_get(x_123, 1); -lean_inc(x_154); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - x_155 = x_123; +x_158 = lean_ctor_get(x_127, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_127, 1); +lean_inc(x_159); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + x_160 = x_127; } else { - lean_dec_ref(x_123); - x_155 = lean_box(0); + lean_dec_ref(x_127); + x_160 = lean_box(0); } -if (lean_is_scalar(x_155)) { - x_156 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_160)) { + x_161 = lean_alloc_ctor(1, 2, 0); } else { - x_156 = x_155; + x_161 = x_160; } -lean_ctor_set(x_156, 0, x_153); -lean_ctor_set(x_156, 1, x_154); -return x_156; +lean_ctor_set(x_161, 0, x_158); +lean_ctor_set(x_161, 1, x_159); +return x_161; } } else { -lean_object* x_157; lean_object* x_158; -lean_dec(x_121); -lean_dec(x_111); +lean_object* x_162; lean_object* x_163; +lean_dec(x_125); +lean_dec(x_115); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); @@ -10363,13 +10711,13 @@ lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_157 = lean_ctor_get(x_122, 0); -lean_inc(x_157); -lean_dec(x_122); -x_158 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_158, 0, x_157); -lean_ctor_set(x_158, 1, x_4); -return x_158; +x_162 = lean_ctor_get(x_126, 0); +lean_inc(x_162); +lean_dec(x_126); +x_163 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_163, 0, x_162); +lean_ctor_set(x_163, 1, x_4); +return x_163; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/InferType.c b/stage0/stdlib/Init/Lean/Meta/InferType.c index aa2b077670..60a2b9c9e6 100644 --- a/stage0/stdlib/Init/Lean/Meta/InferType.c +++ b/stage0/stdlib/Init/Lean/Meta/InferType.c @@ -3625,90 +3625,97 @@ return x_8; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; x_19 = lean_ctor_get(x_10, 0); x_20 = lean_ctor_get(x_10, 1); x_21 = lean_ctor_get(x_10, 2); +x_22 = lean_ctor_get(x_10, 3); +lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_dec(x_10); lean_inc(x_12); -x_22 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); -x_23 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -lean_ctor_set(x_23, 2, x_21); -lean_ctor_set(x_9, 2, x_23); +x_23 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); +x_24 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_24, 0, x_23); +lean_ctor_set(x_24, 1, x_20); +lean_ctor_set(x_24, 2, x_21); +lean_ctor_set(x_24, 3, x_22); +lean_ctor_set(x_9, 2, x_24); return x_8; } } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_24 = lean_ctor_get(x_9, 0); -x_25 = lean_ctor_get(x_9, 1); -x_26 = lean_ctor_get(x_9, 3); -x_27 = lean_ctor_get(x_9, 4); -x_28 = lean_ctor_get(x_9, 5); +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_25 = lean_ctor_get(x_9, 0); +x_26 = lean_ctor_get(x_9, 1); +x_27 = lean_ctor_get(x_9, 3); +x_28 = lean_ctor_get(x_9, 4); +x_29 = lean_ctor_get(x_9, 5); +lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); lean_dec(x_9); -x_29 = lean_ctor_get(x_10, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_10, 1); +x_30 = lean_ctor_get(x_10, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_10, 2); +x_31 = lean_ctor_get(x_10, 1); lean_inc(x_31); +x_32 = lean_ctor_get(x_10, 2); +lean_inc(x_32); +x_33 = lean_ctor_get(x_10, 3); +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); - x_32 = x_10; + lean_ctor_release(x_10, 3); + x_34 = x_10; } else { lean_dec_ref(x_10); - x_32 = lean_box(0); + x_34 = lean_box(0); } lean_inc(x_12); -x_33 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_29, x_1, x_12); -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 3, 0); +x_35 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_30, x_1, x_12); +if (lean_is_scalar(x_34)) { + x_36 = lean_alloc_ctor(0, 4, 0); } else { - x_34 = x_32; + x_36 = x_34; } -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_30); -lean_ctor_set(x_34, 2, x_31); -x_35 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_35, 0, x_24); -lean_ctor_set(x_35, 1, x_25); -lean_ctor_set(x_35, 2, x_34); -lean_ctor_set(x_35, 3, x_26); -lean_ctor_set(x_35, 4, x_27); -lean_ctor_set(x_35, 5, x_28); -lean_ctor_set(x_8, 1, x_35); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_31); +lean_ctor_set(x_36, 2, x_32); +lean_ctor_set(x_36, 3, x_33); +x_37 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_37, 0, x_25); +lean_ctor_set(x_37, 1, x_26); +lean_ctor_set(x_37, 2, x_36); +lean_ctor_set(x_37, 3, x_27); +lean_ctor_set(x_37, 4, x_28); +lean_ctor_set(x_37, 5, x_29); +lean_ctor_set(x_8, 1, x_37); return x_8; } } 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_8, 0); -lean_inc(x_36); -lean_dec(x_8); -x_37 = lean_ctor_get(x_9, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_9, 1); +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_38 = lean_ctor_get(x_8, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_9, 3); +lean_dec(x_8); +x_39 = lean_ctor_get(x_9, 0); lean_inc(x_39); -x_40 = lean_ctor_get(x_9, 4); +x_40 = lean_ctor_get(x_9, 1); lean_inc(x_40); -x_41 = lean_ctor_get(x_9, 5); +x_41 = lean_ctor_get(x_9, 3); lean_inc(x_41); +x_42 = lean_ctor_get(x_9, 4); +lean_inc(x_42); +x_43 = lean_ctor_get(x_9, 5); +lean_inc(x_43); if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 0); lean_ctor_release(x_9, 1); @@ -3716,90 +3723,94 @@ if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 3); lean_ctor_release(x_9, 4); lean_ctor_release(x_9, 5); - x_42 = x_9; + x_44 = x_9; } else { lean_dec_ref(x_9); - x_42 = lean_box(0); + x_44 = lean_box(0); } -x_43 = lean_ctor_get(x_10, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_10, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_10, 2); +x_45 = lean_ctor_get(x_10, 0); lean_inc(x_45); +x_46 = lean_ctor_get(x_10, 1); +lean_inc(x_46); +x_47 = lean_ctor_get(x_10, 2); +lean_inc(x_47); +x_48 = lean_ctor_get(x_10, 3); +lean_inc(x_48); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); - x_46 = x_10; + lean_ctor_release(x_10, 3); + x_49 = x_10; } else { lean_dec_ref(x_10); - x_46 = lean_box(0); + x_49 = lean_box(0); } -lean_inc(x_36); -x_47 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_43, x_1, x_36); -if (lean_is_scalar(x_46)) { - x_48 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_38); +x_50 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_45, x_1, x_38); +if (lean_is_scalar(x_49)) { + x_51 = lean_alloc_ctor(0, 4, 0); } else { - x_48 = x_46; + x_51 = x_49; } -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_44); -lean_ctor_set(x_48, 2, x_45); -if (lean_is_scalar(x_42)) { - x_49 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_51, 0, x_50); +lean_ctor_set(x_51, 1, x_46); +lean_ctor_set(x_51, 2, x_47); +lean_ctor_set(x_51, 3, x_48); +if (lean_is_scalar(x_44)) { + x_52 = lean_alloc_ctor(0, 6, 0); } else { - x_49 = x_42; + x_52 = x_44; } -lean_ctor_set(x_49, 0, x_37); -lean_ctor_set(x_49, 1, x_38); -lean_ctor_set(x_49, 2, x_48); -lean_ctor_set(x_49, 3, x_39); -lean_ctor_set(x_49, 4, x_40); -lean_ctor_set(x_49, 5, x_41); -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; +lean_ctor_set(x_52, 0, x_39); +lean_ctor_set(x_52, 1, x_40); +lean_ctor_set(x_52, 2, x_51); +lean_ctor_set(x_52, 3, x_41); +lean_ctor_set(x_52, 4, x_42); +lean_ctor_set(x_52, 5, x_43); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_38); +lean_ctor_set(x_53, 1, x_52); +return x_53; } } else { -uint8_t x_51; +uint8_t x_54; lean_dec(x_1); -x_51 = !lean_is_exclusive(x_8); -if (x_51 == 0) +x_54 = !lean_is_exclusive(x_8); +if (x_54 == 0) { return x_8; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_8, 0); -x_53 = lean_ctor_get(x_8, 1); -lean_inc(x_53); -lean_inc(x_52); +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_8, 0); +x_56 = lean_ctor_get(x_8, 1); +lean_inc(x_56); +lean_inc(x_55); lean_dec(x_8); -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_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_55; lean_object* x_56; +lean_object* x_58; lean_object* x_59; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_55 = lean_ctor_get(x_7, 0); -lean_inc(x_55); +x_58 = lean_ctor_get(x_7, 0); +lean_inc(x_58); lean_dec(x_7); -x_56 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_56, 0, x_55); -lean_ctor_set(x_56, 1, x_4); -return x_56; +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_58); +lean_ctor_set(x_59, 1, x_4); +return x_59; } } } @@ -3982,90 +3993,97 @@ return x_30; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; x_41 = lean_ctor_get(x_32, 0); x_42 = lean_ctor_get(x_32, 1); x_43 = lean_ctor_get(x_32, 2); +x_44 = lean_ctor_get(x_32, 3); +lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); lean_inc(x_41); lean_dec(x_32); lean_inc(x_34); -x_44 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_44); -lean_ctor_set(x_45, 1, x_42); -lean_ctor_set(x_45, 2, x_43); -lean_ctor_set(x_31, 2, x_45); +x_45 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); +x_46 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_46, 1, x_42); +lean_ctor_set(x_46, 2, x_43); +lean_ctor_set(x_46, 3, x_44); +lean_ctor_set(x_31, 2, x_46); return x_30; } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_46 = lean_ctor_get(x_31, 0); -x_47 = lean_ctor_get(x_31, 1); -x_48 = lean_ctor_get(x_31, 3); -x_49 = lean_ctor_get(x_31, 4); -x_50 = lean_ctor_get(x_31, 5); +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_47 = lean_ctor_get(x_31, 0); +x_48 = lean_ctor_get(x_31, 1); +x_49 = lean_ctor_get(x_31, 3); +x_50 = lean_ctor_get(x_31, 4); +x_51 = lean_ctor_get(x_31, 5); +lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); -lean_inc(x_46); lean_dec(x_31); -x_51 = lean_ctor_get(x_32, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_32, 1); +x_52 = lean_ctor_get(x_32, 0); lean_inc(x_52); -x_53 = lean_ctor_get(x_32, 2); +x_53 = lean_ctor_get(x_32, 1); lean_inc(x_53); +x_54 = lean_ctor_get(x_32, 2); +lean_inc(x_54); +x_55 = lean_ctor_get(x_32, 3); +lean_inc(x_55); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); - x_54 = x_32; + lean_ctor_release(x_32, 3); + x_56 = x_32; } else { lean_dec_ref(x_32); - x_54 = lean_box(0); + x_56 = lean_box(0); } lean_inc(x_34); -x_55 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_51, x_1, x_34); -if (lean_is_scalar(x_54)) { - x_56 = lean_alloc_ctor(0, 3, 0); +x_57 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_52, x_1, x_34); +if (lean_is_scalar(x_56)) { + x_58 = lean_alloc_ctor(0, 4, 0); } else { - x_56 = x_54; + x_58 = x_56; } -lean_ctor_set(x_56, 0, x_55); -lean_ctor_set(x_56, 1, x_52); -lean_ctor_set(x_56, 2, x_53); -x_57 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_57, 0, x_46); -lean_ctor_set(x_57, 1, x_47); -lean_ctor_set(x_57, 2, x_56); -lean_ctor_set(x_57, 3, x_48); -lean_ctor_set(x_57, 4, x_49); -lean_ctor_set(x_57, 5, x_50); -lean_ctor_set(x_30, 1, x_57); +lean_ctor_set(x_58, 0, x_57); +lean_ctor_set(x_58, 1, x_53); +lean_ctor_set(x_58, 2, x_54); +lean_ctor_set(x_58, 3, x_55); +x_59 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_59, 0, x_47); +lean_ctor_set(x_59, 1, x_48); +lean_ctor_set(x_59, 2, x_58); +lean_ctor_set(x_59, 3, x_49); +lean_ctor_set(x_59, 4, x_50); +lean_ctor_set(x_59, 5, x_51); +lean_ctor_set(x_30, 1, x_59); return x_30; } } 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; -x_58 = lean_ctor_get(x_30, 0); -lean_inc(x_58); -lean_dec(x_30); -x_59 = lean_ctor_get(x_31, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_31, 1); +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_60 = lean_ctor_get(x_30, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_31, 3); +lean_dec(x_30); +x_61 = lean_ctor_get(x_31, 0); lean_inc(x_61); -x_62 = lean_ctor_get(x_31, 4); +x_62 = lean_ctor_get(x_31, 1); lean_inc(x_62); -x_63 = lean_ctor_get(x_31, 5); +x_63 = lean_ctor_get(x_31, 3); lean_inc(x_63); +x_64 = lean_ctor_get(x_31, 4); +lean_inc(x_64); +x_65 = lean_ctor_get(x_31, 5); +lean_inc(x_65); if (lean_is_exclusive(x_31)) { lean_ctor_release(x_31, 0); lean_ctor_release(x_31, 1); @@ -4073,799 +4091,836 @@ if (lean_is_exclusive(x_31)) { lean_ctor_release(x_31, 3); lean_ctor_release(x_31, 4); lean_ctor_release(x_31, 5); - x_64 = x_31; + x_66 = x_31; } else { lean_dec_ref(x_31); - x_64 = lean_box(0); + x_66 = lean_box(0); } -x_65 = lean_ctor_get(x_32, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_32, 1); -lean_inc(x_66); -x_67 = lean_ctor_get(x_32, 2); +x_67 = lean_ctor_get(x_32, 0); lean_inc(x_67); +x_68 = lean_ctor_get(x_32, 1); +lean_inc(x_68); +x_69 = lean_ctor_get(x_32, 2); +lean_inc(x_69); +x_70 = lean_ctor_get(x_32, 3); +lean_inc(x_70); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); - x_68 = x_32; + lean_ctor_release(x_32, 3); + x_71 = x_32; } else { lean_dec_ref(x_32); - x_68 = lean_box(0); + x_71 = lean_box(0); } -lean_inc(x_58); -x_69 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_65, x_1, x_58); -if (lean_is_scalar(x_68)) { - x_70 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_60); +x_72 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_67, x_1, x_60); +if (lean_is_scalar(x_71)) { + x_73 = lean_alloc_ctor(0, 4, 0); } else { - x_70 = x_68; + x_73 = x_71; } -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_66); -lean_ctor_set(x_70, 2, x_67); -if (lean_is_scalar(x_64)) { - x_71 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_73, 0, x_72); +lean_ctor_set(x_73, 1, x_68); +lean_ctor_set(x_73, 2, x_69); +lean_ctor_set(x_73, 3, x_70); +if (lean_is_scalar(x_66)) { + x_74 = lean_alloc_ctor(0, 6, 0); } else { - x_71 = x_64; + x_74 = x_66; } -lean_ctor_set(x_71, 0, x_59); -lean_ctor_set(x_71, 1, x_60); -lean_ctor_set(x_71, 2, x_70); -lean_ctor_set(x_71, 3, x_61); -lean_ctor_set(x_71, 4, x_62); -lean_ctor_set(x_71, 5, x_63); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_58); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_ctor_set(x_74, 0, x_61); +lean_ctor_set(x_74, 1, x_62); +lean_ctor_set(x_74, 2, x_73); +lean_ctor_set(x_74, 3, x_63); +lean_ctor_set(x_74, 4, x_64); +lean_ctor_set(x_74, 5, x_65); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_60); +lean_ctor_set(x_75, 1, x_74); +return x_75; } } else { -uint8_t x_73; +uint8_t x_76; lean_dec(x_1); -x_73 = !lean_is_exclusive(x_30); -if (x_73 == 0) +x_76 = !lean_is_exclusive(x_30); +if (x_76 == 0) { return x_30; } else { -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_30, 0); -x_75 = lean_ctor_get(x_30, 1); -lean_inc(x_75); -lean_inc(x_74); +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_30, 0); +x_78 = lean_ctor_get(x_30, 1); +lean_inc(x_78); +lean_inc(x_77); lean_dec(x_30); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_77); +lean_ctor_set(x_79, 1, x_78); +return x_79; } } } else { -lean_object* x_77; lean_object* x_78; +lean_object* x_80; lean_object* x_81; lean_dec(x_26); lean_dec(x_19); lean_dec(x_2); lean_dec(x_1); -x_77 = lean_ctor_get(x_29, 0); -lean_inc(x_77); +x_80 = lean_ctor_get(x_29, 0); +lean_inc(x_80); lean_dec(x_29); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_3); -return x_78; +x_81 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_81, 0, x_80); +lean_ctor_set(x_81, 1, x_3); +return x_81; } } case 7: { -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_3, 2); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 0); -lean_inc(x_80); -lean_dec(x_79); -x_81 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_80, x_1); -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_3, 2); +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +lean_dec(x_82); +x_84 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_83, x_1); +if (lean_obj_tag(x_84) == 0) { -lean_object* x_82; lean_object* x_83; -x_82 = l___private_Init_Lean_Meta_InferType_4__inferForallType___closed__1; +lean_object* x_85; lean_object* x_86; +x_85 = l___private_Init_Lean_Meta_InferType_4__inferForallType___closed__1; lean_inc(x_1); -x_83 = l_Lean_Meta_forallTelescope___rarg(x_1, x_82, x_2, x_3); -if (lean_obj_tag(x_83) == 0) -{ -lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_84 = lean_ctor_get(x_83, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_84, 2); -lean_inc(x_85); -x_86 = !lean_is_exclusive(x_83); -if (x_86 == 0) +x_86 = l_Lean_Meta_forallTelescope___rarg(x_1, x_85, x_2, x_3); +if (lean_obj_tag(x_86) == 0) { lean_object* x_87; lean_object* x_88; uint8_t x_89; -x_87 = lean_ctor_get(x_83, 0); -x_88 = lean_ctor_get(x_83, 1); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_84); +x_87 = lean_ctor_get(x_86, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_87, 2); +lean_inc(x_88); +x_89 = !lean_is_exclusive(x_86); if (x_89 == 0) { -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_84, 2); -lean_dec(x_90); -x_91 = !lean_is_exclusive(x_85); -if (x_91 == 0) +lean_object* x_90; lean_object* x_91; uint8_t x_92; +x_90 = lean_ctor_get(x_86, 0); +x_91 = lean_ctor_get(x_86, 1); +lean_dec(x_91); +x_92 = !lean_is_exclusive(x_87); +if (x_92 == 0) { -lean_object* x_92; lean_object* x_93; -x_92 = lean_ctor_get(x_85, 0); -lean_inc(x_87); -x_93 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_92, x_1, x_87); -lean_ctor_set(x_85, 0, x_93); -return x_83; +lean_object* x_93; uint8_t x_94; +x_93 = lean_ctor_get(x_87, 2); +lean_dec(x_93); +x_94 = !lean_is_exclusive(x_88); +if (x_94 == 0) +{ +lean_object* x_95; lean_object* x_96; +x_95 = lean_ctor_get(x_88, 0); +lean_inc(x_90); +x_96 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_95, x_1, x_90); +lean_ctor_set(x_88, 0, x_96); +return x_86; } 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_85, 0); -x_95 = lean_ctor_get(x_85, 1); -x_96 = lean_ctor_get(x_85, 2); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_85); -lean_inc(x_87); -x_97 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_94, x_1, x_87); -x_98 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set(x_98, 1, x_95); -lean_ctor_set(x_98, 2, x_96); -lean_ctor_set(x_84, 2, x_98); -return x_83; -} -} -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_84, 0); -x_100 = lean_ctor_get(x_84, 1); -x_101 = lean_ctor_get(x_84, 3); -x_102 = lean_ctor_get(x_84, 4); -x_103 = lean_ctor_get(x_84, 5); -lean_inc(x_103); -lean_inc(x_102); -lean_inc(x_101); +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_97 = lean_ctor_get(x_88, 0); +x_98 = lean_ctor_get(x_88, 1); +x_99 = lean_ctor_get(x_88, 2); +x_100 = lean_ctor_get(x_88, 3); lean_inc(x_100); lean_inc(x_99); -lean_dec(x_84); -x_104 = lean_ctor_get(x_85, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_85, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_85, 2); +lean_inc(x_98); +lean_inc(x_97); +lean_dec(x_88); +lean_inc(x_90); +x_101 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_97, x_1, x_90); +x_102 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_102, 0, x_101); +lean_ctor_set(x_102, 1, x_98); +lean_ctor_set(x_102, 2, x_99); +lean_ctor_set(x_102, 3, x_100); +lean_ctor_set(x_87, 2, x_102); +return x_86; +} +} +else +{ +lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_103 = lean_ctor_get(x_87, 0); +x_104 = lean_ctor_get(x_87, 1); +x_105 = lean_ctor_get(x_87, 3); +x_106 = lean_ctor_get(x_87, 4); +x_107 = lean_ctor_get(x_87, 5); +lean_inc(x_107); lean_inc(x_106); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - x_107 = x_85; +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_dec(x_87); +x_108 = lean_ctor_get(x_88, 0); +lean_inc(x_108); +x_109 = lean_ctor_get(x_88, 1); +lean_inc(x_109); +x_110 = lean_ctor_get(x_88, 2); +lean_inc(x_110); +x_111 = lean_ctor_get(x_88, 3); +lean_inc(x_111); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + x_112 = x_88; } else { - lean_dec_ref(x_85); - x_107 = lean_box(0); + lean_dec_ref(x_88); + x_112 = lean_box(0); } -lean_inc(x_87); -x_108 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_104, x_1, x_87); -if (lean_is_scalar(x_107)) { - x_109 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_90); +x_113 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_108, x_1, x_90); +if (lean_is_scalar(x_112)) { + x_114 = lean_alloc_ctor(0, 4, 0); } else { - x_109 = x_107; + x_114 = x_112; } -lean_ctor_set(x_109, 0, x_108); -lean_ctor_set(x_109, 1, x_105); -lean_ctor_set(x_109, 2, x_106); -x_110 = lean_alloc_ctor(0, 6, 0); -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); -lean_ctor_set(x_83, 1, x_110); -return x_83; +lean_ctor_set(x_114, 0, x_113); +lean_ctor_set(x_114, 1, x_109); +lean_ctor_set(x_114, 2, x_110); +lean_ctor_set(x_114, 3, x_111); +x_115 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_115, 0, x_103); +lean_ctor_set(x_115, 1, x_104); +lean_ctor_set(x_115, 2, x_114); +lean_ctor_set(x_115, 3, x_105); +lean_ctor_set(x_115, 4, x_106); +lean_ctor_set(x_115, 5, x_107); +lean_ctor_set(x_86, 1, x_115); +return x_86; } } 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; -x_111 = lean_ctor_get(x_83, 0); -lean_inc(x_111); -lean_dec(x_83); -x_112 = lean_ctor_get(x_84, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_84, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_84, 3); -lean_inc(x_114); -x_115 = lean_ctor_get(x_84, 4); -lean_inc(x_115); -x_116 = lean_ctor_get(x_84, 5); +lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; +x_116 = lean_ctor_get(x_86, 0); lean_inc(x_116); -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_117 = x_84; -} else { - lean_dec_ref(x_84); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_85, 0); +lean_dec(x_86); +x_117 = lean_ctor_get(x_87, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_87, 1); lean_inc(x_118); -x_119 = lean_ctor_get(x_85, 1); +x_119 = lean_ctor_get(x_87, 3); lean_inc(x_119); -x_120 = lean_ctor_get(x_85, 2); +x_120 = lean_ctor_get(x_87, 4); lean_inc(x_120); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - x_121 = x_85; +x_121 = lean_ctor_get(x_87, 5); +lean_inc(x_121); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + lean_ctor_release(x_87, 4); + lean_ctor_release(x_87, 5); + x_122 = x_87; } else { - lean_dec_ref(x_85); - x_121 = lean_box(0); + lean_dec_ref(x_87); + x_122 = lean_box(0); } -lean_inc(x_111); -x_122 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_118, x_1, x_111); -if (lean_is_scalar(x_121)) { - x_123 = lean_alloc_ctor(0, 3, 0); +x_123 = lean_ctor_get(x_88, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_88, 1); +lean_inc(x_124); +x_125 = lean_ctor_get(x_88, 2); +lean_inc(x_125); +x_126 = lean_ctor_get(x_88, 3); +lean_inc(x_126); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + x_127 = x_88; } else { - x_123 = x_121; + lean_dec_ref(x_88); + x_127 = lean_box(0); } -lean_ctor_set(x_123, 0, x_122); -lean_ctor_set(x_123, 1, x_119); -lean_ctor_set(x_123, 2, x_120); -if (lean_is_scalar(x_117)) { - x_124 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_116); +x_128 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_123, x_1, x_116); +if (lean_is_scalar(x_127)) { + x_129 = lean_alloc_ctor(0, 4, 0); } else { - x_124 = x_117; + x_129 = x_127; } -lean_ctor_set(x_124, 0, x_112); -lean_ctor_set(x_124, 1, x_113); -lean_ctor_set(x_124, 2, x_123); -lean_ctor_set(x_124, 3, x_114); -lean_ctor_set(x_124, 4, x_115); -lean_ctor_set(x_124, 5, x_116); -x_125 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_125, 0, x_111); -lean_ctor_set(x_125, 1, x_124); -return x_125; +lean_ctor_set(x_129, 0, x_128); +lean_ctor_set(x_129, 1, x_124); +lean_ctor_set(x_129, 2, x_125); +lean_ctor_set(x_129, 3, x_126); +if (lean_is_scalar(x_122)) { + x_130 = lean_alloc_ctor(0, 6, 0); +} else { + x_130 = x_122; +} +lean_ctor_set(x_130, 0, x_117); +lean_ctor_set(x_130, 1, x_118); +lean_ctor_set(x_130, 2, x_129); +lean_ctor_set(x_130, 3, x_119); +lean_ctor_set(x_130, 4, x_120); +lean_ctor_set(x_130, 5, x_121); +x_131 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_131, 0, x_116); +lean_ctor_set(x_131, 1, x_130); +return x_131; } } else { -uint8_t x_126; +uint8_t x_132; lean_dec(x_1); -x_126 = !lean_is_exclusive(x_83); -if (x_126 == 0) +x_132 = !lean_is_exclusive(x_86); +if (x_132 == 0) { -return x_83; +return x_86; } else { -lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_127 = lean_ctor_get(x_83, 0); -x_128 = lean_ctor_get(x_83, 1); -lean_inc(x_128); -lean_inc(x_127); -lean_dec(x_83); -x_129 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_129, 0, x_127); -lean_ctor_set(x_129, 1, x_128); -return x_129; +lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_133 = lean_ctor_get(x_86, 0); +x_134 = lean_ctor_get(x_86, 1); +lean_inc(x_134); +lean_inc(x_133); +lean_dec(x_86); +x_135 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_135, 0, x_133); +lean_ctor_set(x_135, 1, x_134); +return x_135; } } } else { -lean_object* x_130; lean_object* x_131; +lean_object* x_136; lean_object* x_137; lean_dec(x_2); lean_dec(x_1); -x_130 = lean_ctor_get(x_81, 0); -lean_inc(x_130); -lean_dec(x_81); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_3); -return x_131; +x_136 = lean_ctor_get(x_84, 0); +lean_inc(x_136); +lean_dec(x_84); +x_137 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_137, 0, x_136); +lean_ctor_set(x_137, 1, x_3); +return x_137; } } case 9: { -lean_object* x_132; lean_object* x_133; lean_object* x_134; +lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_dec(x_2); -x_132 = lean_ctor_get(x_1, 0); -lean_inc(x_132); +x_138 = lean_ctor_get(x_1, 0); +lean_inc(x_138); lean_dec(x_1); -x_133 = l_Lean_Literal_type(x_132); -lean_dec(x_132); -x_134 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_134, 0, x_133); -lean_ctor_set(x_134, 1, x_3); -return x_134; +x_139 = l_Lean_Literal_type(x_138); +lean_dec(x_138); +x_140 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_140, 0, x_139); +lean_ctor_set(x_140, 1, x_3); +return x_140; } case 10: { -lean_object* x_135; -x_135 = lean_ctor_get(x_1, 1); -lean_inc(x_135); +lean_object* x_141; +x_141 = lean_ctor_get(x_1, 1); +lean_inc(x_141); lean_dec(x_1); -x_1 = x_135; +x_1 = x_141; goto _start; } case 11: { -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_137 = lean_ctor_get(x_1, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_1, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_1, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_3, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_140, 0); -lean_inc(x_141); -lean_dec(x_140); -x_142 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_141, x_1); -if (lean_obj_tag(x_142) == 0) -{ -lean_object* x_143; -x_143 = l___private_Init_Lean_Meta_InferType_3__inferProjType(x_137, x_138, x_139, x_2, x_3); -if (lean_obj_tag(x_143) == 0) -{ -lean_object* x_144; lean_object* x_145; uint8_t x_146; -x_144 = lean_ctor_get(x_143, 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; +x_143 = lean_ctor_get(x_1, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_1, 1); lean_inc(x_144); -x_145 = lean_ctor_get(x_144, 2); +x_145 = lean_ctor_get(x_1, 2); lean_inc(x_145); -x_146 = !lean_is_exclusive(x_143); -if (x_146 == 0) -{ -lean_object* x_147; lean_object* x_148; uint8_t x_149; -x_147 = lean_ctor_get(x_143, 0); -x_148 = lean_ctor_get(x_143, 1); -lean_dec(x_148); -x_149 = !lean_is_exclusive(x_144); -if (x_149 == 0) -{ -lean_object* x_150; uint8_t x_151; -x_150 = lean_ctor_get(x_144, 2); -lean_dec(x_150); -x_151 = !lean_is_exclusive(x_145); -if (x_151 == 0) -{ -lean_object* x_152; lean_object* x_153; -x_152 = lean_ctor_get(x_145, 0); +x_146 = lean_ctor_get(x_3, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_146, 0); lean_inc(x_147); -x_153 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_152, x_1, x_147); -lean_ctor_set(x_145, 0, x_153); -return x_143; +lean_dec(x_146); +x_148 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_147, x_1); +if (lean_obj_tag(x_148) == 0) +{ +lean_object* x_149; +x_149 = l___private_Init_Lean_Meta_InferType_3__inferProjType(x_143, x_144, x_145, x_2, x_3); +if (lean_obj_tag(x_149) == 0) +{ +lean_object* x_150; lean_object* x_151; uint8_t x_152; +x_150 = lean_ctor_get(x_149, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_150, 2); +lean_inc(x_151); +x_152 = !lean_is_exclusive(x_149); +if (x_152 == 0) +{ +lean_object* x_153; lean_object* x_154; uint8_t x_155; +x_153 = lean_ctor_get(x_149, 0); +x_154 = lean_ctor_get(x_149, 1); +lean_dec(x_154); +x_155 = !lean_is_exclusive(x_150); +if (x_155 == 0) +{ +lean_object* x_156; uint8_t x_157; +x_156 = lean_ctor_get(x_150, 2); +lean_dec(x_156); +x_157 = !lean_is_exclusive(x_151); +if (x_157 == 0) +{ +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_151, 0); +lean_inc(x_153); +x_159 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_158, x_1, x_153); +lean_ctor_set(x_151, 0, x_159); +return x_149; } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_154 = lean_ctor_get(x_145, 0); -x_155 = lean_ctor_get(x_145, 1); -x_156 = lean_ctor_get(x_145, 2); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_dec(x_145); -lean_inc(x_147); -x_157 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_154, x_1, x_147); -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_157); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_156); -lean_ctor_set(x_144, 2, x_158); -return x_143; -} -} -else -{ -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_159 = lean_ctor_get(x_144, 0); -x_160 = lean_ctor_get(x_144, 1); -x_161 = lean_ctor_get(x_144, 3); -x_162 = lean_ctor_get(x_144, 4); -x_163 = lean_ctor_get(x_144, 5); +lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_160 = lean_ctor_get(x_151, 0); +x_161 = lean_ctor_get(x_151, 1); +x_162 = lean_ctor_get(x_151, 2); +x_163 = lean_ctor_get(x_151, 3); lean_inc(x_163); lean_inc(x_162); lean_inc(x_161); lean_inc(x_160); -lean_inc(x_159); -lean_dec(x_144); -x_164 = lean_ctor_get(x_145, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_145, 1); -lean_inc(x_165); -x_166 = lean_ctor_get(x_145, 2); +lean_dec(x_151); +lean_inc(x_153); +x_164 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_160, x_1, x_153); +x_165 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_165, 0, x_164); +lean_ctor_set(x_165, 1, x_161); +lean_ctor_set(x_165, 2, x_162); +lean_ctor_set(x_165, 3, x_163); +lean_ctor_set(x_150, 2, x_165); +return x_149; +} +} +else +{ +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_166 = lean_ctor_get(x_150, 0); +x_167 = lean_ctor_get(x_150, 1); +x_168 = lean_ctor_get(x_150, 3); +x_169 = lean_ctor_get(x_150, 4); +x_170 = lean_ctor_get(x_150, 5); +lean_inc(x_170); +lean_inc(x_169); +lean_inc(x_168); +lean_inc(x_167); lean_inc(x_166); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - x_167 = x_145; -} else { - lean_dec_ref(x_145); - x_167 = lean_box(0); -} -lean_inc(x_147); -x_168 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_164, x_1, x_147); -if (lean_is_scalar(x_167)) { - x_169 = lean_alloc_ctor(0, 3, 0); -} else { - x_169 = x_167; -} -lean_ctor_set(x_169, 0, x_168); -lean_ctor_set(x_169, 1, x_165); -lean_ctor_set(x_169, 2, x_166); -x_170 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_170, 0, x_159); -lean_ctor_set(x_170, 1, x_160); -lean_ctor_set(x_170, 2, x_169); -lean_ctor_set(x_170, 3, x_161); -lean_ctor_set(x_170, 4, x_162); -lean_ctor_set(x_170, 5, x_163); -lean_ctor_set(x_143, 1, x_170); -return x_143; -} -} -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_143, 0); +lean_dec(x_150); +x_171 = lean_ctor_get(x_151, 0); lean_inc(x_171); -lean_dec(x_143); -x_172 = lean_ctor_get(x_144, 0); +x_172 = lean_ctor_get(x_151, 1); lean_inc(x_172); -x_173 = lean_ctor_get(x_144, 1); +x_173 = lean_ctor_get(x_151, 2); lean_inc(x_173); -x_174 = lean_ctor_get(x_144, 3); +x_174 = lean_ctor_get(x_151, 3); lean_inc(x_174); -x_175 = lean_ctor_get(x_144, 4); -lean_inc(x_175); -x_176 = lean_ctor_get(x_144, 5); -lean_inc(x_176); -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_177 = x_144; +if (lean_is_exclusive(x_151)) { + lean_ctor_release(x_151, 0); + lean_ctor_release(x_151, 1); + lean_ctor_release(x_151, 2); + lean_ctor_release(x_151, 3); + x_175 = x_151; } else { - lean_dec_ref(x_144); - x_177 = lean_box(0); + lean_dec_ref(x_151); + x_175 = lean_box(0); } -x_178 = lean_ctor_get(x_145, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_145, 1); +lean_inc(x_153); +x_176 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_171, x_1, x_153); +if (lean_is_scalar(x_175)) { + x_177 = lean_alloc_ctor(0, 4, 0); +} else { + x_177 = x_175; +} +lean_ctor_set(x_177, 0, x_176); +lean_ctor_set(x_177, 1, x_172); +lean_ctor_set(x_177, 2, x_173); +lean_ctor_set(x_177, 3, x_174); +x_178 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_178, 0, x_166); +lean_ctor_set(x_178, 1, x_167); +lean_ctor_set(x_178, 2, x_177); +lean_ctor_set(x_178, 3, x_168); +lean_ctor_set(x_178, 4, x_169); +lean_ctor_set(x_178, 5, x_170); +lean_ctor_set(x_149, 1, x_178); +return x_149; +} +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; +x_179 = lean_ctor_get(x_149, 0); lean_inc(x_179); -x_180 = lean_ctor_get(x_145, 2); +lean_dec(x_149); +x_180 = lean_ctor_get(x_150, 0); lean_inc(x_180); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - x_181 = x_145; +x_181 = lean_ctor_get(x_150, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_150, 3); +lean_inc(x_182); +x_183 = lean_ctor_get(x_150, 4); +lean_inc(x_183); +x_184 = lean_ctor_get(x_150, 5); +lean_inc(x_184); +if (lean_is_exclusive(x_150)) { + lean_ctor_release(x_150, 0); + lean_ctor_release(x_150, 1); + lean_ctor_release(x_150, 2); + lean_ctor_release(x_150, 3); + lean_ctor_release(x_150, 4); + lean_ctor_release(x_150, 5); + x_185 = x_150; } else { - lean_dec_ref(x_145); - x_181 = lean_box(0); + lean_dec_ref(x_150); + x_185 = lean_box(0); } -lean_inc(x_171); -x_182 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_178, x_1, x_171); -if (lean_is_scalar(x_181)) { - x_183 = lean_alloc_ctor(0, 3, 0); -} else { - x_183 = x_181; -} -lean_ctor_set(x_183, 0, x_182); -lean_ctor_set(x_183, 1, x_179); -lean_ctor_set(x_183, 2, x_180); -if (lean_is_scalar(x_177)) { - x_184 = lean_alloc_ctor(0, 6, 0); -} else { - x_184 = x_177; -} -lean_ctor_set(x_184, 0, x_172); -lean_ctor_set(x_184, 1, x_173); -lean_ctor_set(x_184, 2, x_183); -lean_ctor_set(x_184, 3, x_174); -lean_ctor_set(x_184, 4, x_175); -lean_ctor_set(x_184, 5, x_176); -x_185 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_185, 0, x_171); -lean_ctor_set(x_185, 1, x_184); -return x_185; -} -} -else -{ -uint8_t x_186; -lean_dec(x_1); -x_186 = !lean_is_exclusive(x_143); -if (x_186 == 0) -{ -return x_143; -} -else -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; -x_187 = lean_ctor_get(x_143, 0); -x_188 = lean_ctor_get(x_143, 1); -lean_inc(x_188); +x_186 = lean_ctor_get(x_151, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_151, 1); lean_inc(x_187); -lean_dec(x_143); -x_189 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_189, 0, x_187); -lean_ctor_set(x_189, 1, x_188); -return x_189; +x_188 = lean_ctor_get(x_151, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_151, 3); +lean_inc(x_189); +if (lean_is_exclusive(x_151)) { + lean_ctor_release(x_151, 0); + lean_ctor_release(x_151, 1); + lean_ctor_release(x_151, 2); + lean_ctor_release(x_151, 3); + x_190 = x_151; +} else { + lean_dec_ref(x_151); + x_190 = lean_box(0); +} +lean_inc(x_179); +x_191 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_186, x_1, x_179); +if (lean_is_scalar(x_190)) { + x_192 = lean_alloc_ctor(0, 4, 0); +} else { + x_192 = x_190; +} +lean_ctor_set(x_192, 0, x_191); +lean_ctor_set(x_192, 1, x_187); +lean_ctor_set(x_192, 2, x_188); +lean_ctor_set(x_192, 3, x_189); +if (lean_is_scalar(x_185)) { + x_193 = lean_alloc_ctor(0, 6, 0); +} else { + x_193 = x_185; +} +lean_ctor_set(x_193, 0, x_180); +lean_ctor_set(x_193, 1, x_181); +lean_ctor_set(x_193, 2, x_192); +lean_ctor_set(x_193, 3, x_182); +lean_ctor_set(x_193, 4, x_183); +lean_ctor_set(x_193, 5, x_184); +x_194 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_194, 0, x_179); +lean_ctor_set(x_194, 1, x_193); +return x_194; +} +} +else +{ +uint8_t x_195; +lean_dec(x_1); +x_195 = !lean_is_exclusive(x_149); +if (x_195 == 0) +{ +return x_149; +} +else +{ +lean_object* x_196; lean_object* x_197; lean_object* x_198; +x_196 = lean_ctor_get(x_149, 0); +x_197 = lean_ctor_get(x_149, 1); +lean_inc(x_197); +lean_inc(x_196); +lean_dec(x_149); +x_198 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_198, 0, x_196); +lean_ctor_set(x_198, 1, x_197); +return x_198; } } } else { -lean_object* x_190; lean_object* x_191; -lean_dec(x_139); -lean_dec(x_138); -lean_dec(x_137); +lean_object* x_199; lean_object* x_200; +lean_dec(x_145); +lean_dec(x_144); +lean_dec(x_143); lean_dec(x_2); lean_dec(x_1); -x_190 = lean_ctor_get(x_142, 0); -lean_inc(x_190); -lean_dec(x_142); -x_191 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_191, 0, x_190); -lean_ctor_set(x_191, 1, x_3); -return x_191; +x_199 = lean_ctor_get(x_148, 0); +lean_inc(x_199); +lean_dec(x_148); +x_200 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_200, 0, x_199); +lean_ctor_set(x_200, 1, x_3); +return x_200; } } case 12: { -lean_object* x_192; lean_object* x_193; lean_object* x_194; +lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_dec(x_1); -x_192 = l_Lean_Meta_isClassQuick___main___closed__1; -x_193 = l_unreachable_x21___rarg(x_192); -x_194 = lean_apply_2(x_193, x_2, x_3); -return x_194; +x_201 = l_Lean_Meta_isClassQuick___main___closed__1; +x_202 = l_unreachable_x21___rarg(x_201); +x_203 = lean_apply_2(x_202, x_2, x_3); +return x_203; } default: { -lean_object* x_195; lean_object* x_196; lean_object* x_197; -x_195 = lean_ctor_get(x_3, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_195, 0); -lean_inc(x_196); -lean_dec(x_195); -x_197 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_196, x_1); -if (lean_obj_tag(x_197) == 0) -{ -lean_object* x_198; lean_object* x_199; -x_198 = l___private_Init_Lean_Meta_InferType_5__inferLambdaType___closed__1; -lean_inc(x_1); -x_199 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_198, x_2, x_3); -if (lean_obj_tag(x_199) == 0) -{ -lean_object* x_200; lean_object* x_201; uint8_t x_202; -x_200 = lean_ctor_get(x_199, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_200, 2); -lean_inc(x_201); -x_202 = !lean_is_exclusive(x_199); -if (x_202 == 0) -{ -lean_object* x_203; lean_object* x_204; uint8_t x_205; -x_203 = lean_ctor_get(x_199, 0); -x_204 = lean_ctor_get(x_199, 1); +lean_object* x_204; lean_object* x_205; lean_object* x_206; +x_204 = lean_ctor_get(x_3, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_204, 0); +lean_inc(x_205); lean_dec(x_204); -x_205 = !lean_is_exclusive(x_200); -if (x_205 == 0) +x_206 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_205, x_1); +if (lean_obj_tag(x_206) == 0) { -lean_object* x_206; uint8_t x_207; -x_206 = lean_ctor_get(x_200, 2); -lean_dec(x_206); -x_207 = !lean_is_exclusive(x_201); -if (x_207 == 0) +lean_object* x_207; lean_object* x_208; +x_207 = l___private_Init_Lean_Meta_InferType_5__inferLambdaType___closed__1; +lean_inc(x_1); +x_208 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_207, x_2, x_3); +if (lean_obj_tag(x_208) == 0) { -lean_object* x_208; lean_object* x_209; -x_208 = lean_ctor_get(x_201, 0); -lean_inc(x_203); -x_209 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_208, x_1, x_203); -lean_ctor_set(x_201, 0, x_209); -return x_199; -} -else -{ -lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_210 = lean_ctor_get(x_201, 0); -x_211 = lean_ctor_get(x_201, 1); -x_212 = lean_ctor_get(x_201, 2); -lean_inc(x_212); -lean_inc(x_211); +lean_object* x_209; lean_object* x_210; uint8_t x_211; +x_209 = lean_ctor_get(x_208, 1); +lean_inc(x_209); +x_210 = lean_ctor_get(x_209, 2); lean_inc(x_210); -lean_dec(x_201); -lean_inc(x_203); -x_213 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_210, x_1, x_203); -x_214 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_214, 0, x_213); -lean_ctor_set(x_214, 1, x_211); -lean_ctor_set(x_214, 2, x_212); -lean_ctor_set(x_200, 2, x_214); -return x_199; -} +x_211 = !lean_is_exclusive(x_208); +if (x_211 == 0) +{ +lean_object* x_212; lean_object* x_213; uint8_t x_214; +x_212 = lean_ctor_get(x_208, 0); +x_213 = lean_ctor_get(x_208, 1); +lean_dec(x_213); +x_214 = !lean_is_exclusive(x_209); +if (x_214 == 0) +{ +lean_object* x_215; uint8_t x_216; +x_215 = lean_ctor_get(x_209, 2); +lean_dec(x_215); +x_216 = !lean_is_exclusive(x_210); +if (x_216 == 0) +{ +lean_object* x_217; lean_object* x_218; +x_217 = lean_ctor_get(x_210, 0); +lean_inc(x_212); +x_218 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_217, x_1, x_212); +lean_ctor_set(x_210, 0, x_218); +return x_208; } else { -lean_object* x_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_215 = lean_ctor_get(x_200, 0); -x_216 = lean_ctor_get(x_200, 1); -x_217 = lean_ctor_get(x_200, 3); -x_218 = lean_ctor_get(x_200, 4); -x_219 = lean_ctor_get(x_200, 5); -lean_inc(x_219); -lean_inc(x_218); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_dec(x_200); -x_220 = lean_ctor_get(x_201, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_201, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_201, 2); +lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; +x_219 = lean_ctor_get(x_210, 0); +x_220 = lean_ctor_get(x_210, 1); +x_221 = lean_ctor_get(x_210, 2); +x_222 = lean_ctor_get(x_210, 3); lean_inc(x_222); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_223 = x_201; -} else { - lean_dec_ref(x_201); - x_223 = lean_box(0); -} -lean_inc(x_203); -x_224 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_220, x_1, x_203); -if (lean_is_scalar(x_223)) { - x_225 = lean_alloc_ctor(0, 3, 0); -} else { - x_225 = x_223; -} -lean_ctor_set(x_225, 0, x_224); -lean_ctor_set(x_225, 1, x_221); -lean_ctor_set(x_225, 2, x_222); -x_226 = lean_alloc_ctor(0, 6, 0); -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); -lean_ctor_set(x_199, 1, x_226); -return x_199; +lean_inc(x_221); +lean_inc(x_220); +lean_inc(x_219); +lean_dec(x_210); +lean_inc(x_212); +x_223 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_219, x_1, x_212); +x_224 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_224, 0, x_223); +lean_ctor_set(x_224, 1, x_220); +lean_ctor_set(x_224, 2, x_221); +lean_ctor_set(x_224, 3, x_222); +lean_ctor_set(x_209, 2, x_224); +return x_208; } } 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; -x_227 = lean_ctor_get(x_199, 0); -lean_inc(x_227); -lean_dec(x_199); -x_228 = lean_ctor_get(x_200, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_200, 1); +lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_225 = lean_ctor_get(x_209, 0); +x_226 = lean_ctor_get(x_209, 1); +x_227 = lean_ctor_get(x_209, 3); +x_228 = lean_ctor_get(x_209, 4); +x_229 = lean_ctor_get(x_209, 5); lean_inc(x_229); -x_230 = lean_ctor_get(x_200, 3); -lean_inc(x_230); -x_231 = lean_ctor_get(x_200, 4); -lean_inc(x_231); -x_232 = lean_ctor_get(x_200, 5); -lean_inc(x_232); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - lean_ctor_release(x_200, 3); - lean_ctor_release(x_200, 4); - lean_ctor_release(x_200, 5); - x_233 = x_200; -} else { - lean_dec_ref(x_200); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_201, 0); -lean_inc(x_234); -x_235 = lean_ctor_get(x_201, 1); -lean_inc(x_235); -x_236 = lean_ctor_get(x_201, 2); -lean_inc(x_236); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - x_237 = x_201; -} else { - lean_dec_ref(x_201); - x_237 = lean_box(0); -} +lean_inc(x_228); lean_inc(x_227); -x_238 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_234, x_1, x_227); -if (lean_is_scalar(x_237)) { - x_239 = lean_alloc_ctor(0, 3, 0); +lean_inc(x_226); +lean_inc(x_225); +lean_dec(x_209); +x_230 = lean_ctor_get(x_210, 0); +lean_inc(x_230); +x_231 = lean_ctor_get(x_210, 1); +lean_inc(x_231); +x_232 = lean_ctor_get(x_210, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_210, 3); +lean_inc(x_233); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + x_234 = x_210; } else { - x_239 = x_237; + lean_dec_ref(x_210); + x_234 = lean_box(0); } -lean_ctor_set(x_239, 0, x_238); -lean_ctor_set(x_239, 1, x_235); -lean_ctor_set(x_239, 2, x_236); -if (lean_is_scalar(x_233)) { - x_240 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_212); +x_235 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_230, x_1, x_212); +if (lean_is_scalar(x_234)) { + x_236 = lean_alloc_ctor(0, 4, 0); } else { - x_240 = x_233; + x_236 = x_234; } -lean_ctor_set(x_240, 0, x_228); -lean_ctor_set(x_240, 1, x_229); -lean_ctor_set(x_240, 2, x_239); -lean_ctor_set(x_240, 3, x_230); -lean_ctor_set(x_240, 4, x_231); -lean_ctor_set(x_240, 5, x_232); -x_241 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_241, 0, x_227); -lean_ctor_set(x_241, 1, x_240); -return x_241; +lean_ctor_set(x_236, 0, x_235); +lean_ctor_set(x_236, 1, x_231); +lean_ctor_set(x_236, 2, x_232); +lean_ctor_set(x_236, 3, x_233); +x_237 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_237, 0, x_225); +lean_ctor_set(x_237, 1, x_226); +lean_ctor_set(x_237, 2, x_236); +lean_ctor_set(x_237, 3, x_227); +lean_ctor_set(x_237, 4, x_228); +lean_ctor_set(x_237, 5, x_229); +lean_ctor_set(x_208, 1, x_237); +return x_208; } } else { -uint8_t x_242; -lean_dec(x_1); -x_242 = !lean_is_exclusive(x_199); -if (x_242 == 0) -{ -return x_199; -} -else -{ -lean_object* x_243; lean_object* x_244; lean_object* x_245; -x_243 = lean_ctor_get(x_199, 0); -x_244 = lean_ctor_get(x_199, 1); -lean_inc(x_244); +lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; +x_238 = lean_ctor_get(x_208, 0); +lean_inc(x_238); +lean_dec(x_208); +x_239 = lean_ctor_get(x_209, 0); +lean_inc(x_239); +x_240 = lean_ctor_get(x_209, 1); +lean_inc(x_240); +x_241 = lean_ctor_get(x_209, 3); +lean_inc(x_241); +x_242 = lean_ctor_get(x_209, 4); +lean_inc(x_242); +x_243 = lean_ctor_get(x_209, 5); lean_inc(x_243); -lean_dec(x_199); -x_245 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_245, 0, x_243); -lean_ctor_set(x_245, 1, x_244); -return x_245; +if (lean_is_exclusive(x_209)) { + lean_ctor_release(x_209, 0); + lean_ctor_release(x_209, 1); + lean_ctor_release(x_209, 2); + lean_ctor_release(x_209, 3); + lean_ctor_release(x_209, 4); + lean_ctor_release(x_209, 5); + x_244 = x_209; +} else { + lean_dec_ref(x_209); + x_244 = lean_box(0); +} +x_245 = lean_ctor_get(x_210, 0); +lean_inc(x_245); +x_246 = lean_ctor_get(x_210, 1); +lean_inc(x_246); +x_247 = lean_ctor_get(x_210, 2); +lean_inc(x_247); +x_248 = lean_ctor_get(x_210, 3); +lean_inc(x_248); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + x_249 = x_210; +} else { + lean_dec_ref(x_210); + x_249 = lean_box(0); +} +lean_inc(x_238); +x_250 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_245, x_1, x_238); +if (lean_is_scalar(x_249)) { + x_251 = lean_alloc_ctor(0, 4, 0); +} else { + x_251 = x_249; +} +lean_ctor_set(x_251, 0, x_250); +lean_ctor_set(x_251, 1, x_246); +lean_ctor_set(x_251, 2, x_247); +lean_ctor_set(x_251, 3, x_248); +if (lean_is_scalar(x_244)) { + x_252 = lean_alloc_ctor(0, 6, 0); +} else { + x_252 = x_244; +} +lean_ctor_set(x_252, 0, x_239); +lean_ctor_set(x_252, 1, x_240); +lean_ctor_set(x_252, 2, x_251); +lean_ctor_set(x_252, 3, x_241); +lean_ctor_set(x_252, 4, x_242); +lean_ctor_set(x_252, 5, x_243); +x_253 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_253, 0, x_238); +lean_ctor_set(x_253, 1, x_252); +return x_253; +} +} +else +{ +uint8_t x_254; +lean_dec(x_1); +x_254 = !lean_is_exclusive(x_208); +if (x_254 == 0) +{ +return x_208; +} +else +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_255 = lean_ctor_get(x_208, 0); +x_256 = lean_ctor_get(x_208, 1); +lean_inc(x_256); +lean_inc(x_255); +lean_dec(x_208); +x_257 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_257, 0, x_255); +lean_ctor_set(x_257, 1, x_256); +return x_257; } } } else { -lean_object* x_246; lean_object* x_247; +lean_object* x_258; lean_object* x_259; lean_dec(x_2); lean_dec(x_1); -x_246 = lean_ctor_get(x_197, 0); -lean_inc(x_246); -lean_dec(x_197); -x_247 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_247, 0, x_246); -lean_ctor_set(x_247, 1, x_3); -return x_247; +x_258 = lean_ctor_get(x_206, 0); +lean_inc(x_258); +lean_dec(x_206); +x_259 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_259, 0, x_258); +lean_ctor_set(x_259, 1, x_3); +return x_259; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/SynthInstance.c b/stage0/stdlib/Init/Lean/Meta/SynthInstance.c index 998526a2c8..2a3f95590f 100644 --- a/stage0/stdlib/Init/Lean/Meta/SynthInstance.c +++ b/stage0/stdlib/Init/Lean/Meta/SynthInstance.c @@ -21213,7 +21213,7 @@ lean_inc(x_2); x_24 = l_Lean_Meta_forallTelescopeReducing___rarg(x_20, x_23, x_2, x_21); if (lean_obj_tag(x_24) == 0) { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_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_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; x_25 = lean_ctor_get(x_24, 0); lean_inc(x_25); x_26 = lean_ctor_get(x_24, 1); @@ -21226,241 +21226,241 @@ if (lean_is_exclusive(x_24)) { lean_dec_ref(x_24); x_27 = lean_box(0); } -x_59 = lean_ctor_get(x_26, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_26, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_26, 2); +x_61 = lean_ctor_get(x_26, 0); lean_inc(x_61); -x_62 = lean_ctor_get(x_26, 3); +x_62 = lean_ctor_get(x_26, 1); lean_inc(x_62); -x_63 = lean_ctor_get(x_26, 4); +x_63 = lean_ctor_get(x_26, 2); lean_inc(x_63); -x_64 = lean_ctor_get(x_26, 5); +x_64 = lean_ctor_get(x_26, 3); lean_inc(x_64); -x_65 = lean_ctor_get(x_61, 2); +x_65 = lean_ctor_get(x_26, 4); lean_inc(x_65); -x_66 = l_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_65, x_25); -if (lean_obj_tag(x_66) == 0) +x_66 = lean_ctor_get(x_26, 5); +lean_inc(x_66); +x_67 = lean_ctor_get(x_63, 2); +lean_inc(x_67); +x_68 = l_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_67, x_25); +if (lean_obj_tag(x_68) == 0) { -uint8_t x_67; -x_67 = !lean_is_exclusive(x_26); -if (x_67 == 0) +uint8_t x_69; +x_69 = !lean_is_exclusive(x_26); +if (x_69 == 0) { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_162; lean_object* x_163; lean_object* x_175; lean_object* x_176; -x_68 = lean_ctor_get(x_26, 5); -lean_dec(x_68); -x_69 = lean_ctor_get(x_26, 4); -lean_dec(x_69); -x_70 = lean_ctor_get(x_26, 3); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_164; lean_object* x_165; lean_object* x_177; lean_object* x_178; +x_70 = lean_ctor_get(x_26, 5); lean_dec(x_70); -x_71 = lean_ctor_get(x_26, 2); +x_71 = lean_ctor_get(x_26, 4); lean_dec(x_71); -x_72 = lean_ctor_get(x_26, 1); +x_72 = lean_ctor_get(x_26, 3); lean_dec(x_72); -x_73 = lean_ctor_get(x_26, 0); +x_73 = lean_ctor_get(x_26, 2); lean_dec(x_73); -lean_inc(x_60); -x_175 = l_Lean_MetavarContext_incDepth(x_60); -lean_ctor_set(x_26, 1, x_175); +x_74 = lean_ctor_get(x_26, 1); +lean_dec(x_74); +x_75 = lean_ctor_get(x_26, 0); +lean_dec(x_75); +lean_inc(x_62); +x_177 = l_Lean_MetavarContext_incDepth(x_62); +lean_ctor_set(x_26, 1, x_177); lean_inc(x_2); lean_inc(x_25); -x_176 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_26); -if (lean_obj_tag(x_176) == 0) +x_178 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_26); +if (lean_obj_tag(x_178) == 0) { -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_214; uint8_t x_215; -x_177 = lean_ctor_get(x_176, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_176, 1); -lean_inc(x_178); -lean_dec(x_176); -x_214 = lean_ctor_get(x_178, 4); -lean_inc(x_214); -x_215 = lean_ctor_get_uint8(x_214, sizeof(void*)*1); -lean_dec(x_214); -if (x_215 == 0) +lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_216; uint8_t x_217; +x_179 = lean_ctor_get(x_178, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_178, 1); +lean_inc(x_180); +lean_dec(x_178); +x_216 = lean_ctor_get(x_180, 4); +lean_inc(x_216); +x_217 = lean_ctor_get_uint8(x_216, sizeof(void*)*1); +lean_dec(x_216); +if (x_217 == 0) { -x_179 = x_178; -goto block_213; +x_181 = x_180; +goto block_215; } else { -lean_object* x_216; lean_object* x_217; lean_object* x_218; uint8_t x_219; -x_216 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_217 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_216, x_2, x_178); -x_218 = lean_ctor_get(x_217, 0); -lean_inc(x_218); -x_219 = lean_unbox(x_218); -lean_dec(x_218); -if (x_219 == 0) -{ -lean_object* x_220; -x_220 = lean_ctor_get(x_217, 1); +lean_object* x_218; lean_object* x_219; lean_object* x_220; uint8_t x_221; +x_218 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_219 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_218, x_2, x_180); +x_220 = lean_ctor_get(x_219, 0); lean_inc(x_220); -lean_dec(x_217); -x_179 = x_220; -goto block_213; +x_221 = lean_unbox(x_220); +lean_dec(x_220); +if (x_221 == 0) +{ +lean_object* x_222; +x_222 = lean_ctor_get(x_219, 1); +lean_inc(x_222); +lean_dec(x_219); +x_181 = x_222; +goto block_215; } else { -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_221 = lean_ctor_get(x_217, 1); -lean_inc(x_221); -lean_dec(x_217); +lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; +x_223 = lean_ctor_get(x_219, 1); +lean_inc(x_223); +lean_dec(x_219); lean_inc(x_25); -x_222 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_222, 0, x_25); -x_223 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_224 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_224, 0, x_222); -lean_ctor_set(x_224, 1, x_223); -lean_inc(x_177); -x_225 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_225, 0, x_177); +x_224 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_224, 0, x_25); +x_225 = l_Lean_Meta_synthInstance_x3f___closed__9; x_226 = lean_alloc_ctor(9, 2, 0); lean_ctor_set(x_226, 0, x_224); lean_ctor_set(x_226, 1, x_225); -x_227 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_216, x_226, x_2, x_221); -x_228 = lean_ctor_get(x_227, 1); -lean_inc(x_228); -lean_dec(x_227); -x_179 = x_228; -goto block_213; +lean_inc(x_179); +x_227 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_227, 0, x_179); +x_228 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_228, 0, x_226); +lean_ctor_set(x_228, 1, x_227); +x_229 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_218, x_228, x_2, x_223); +x_230 = lean_ctor_get(x_229, 1); +lean_inc(x_230); +lean_dec(x_229); +x_181 = x_230; +goto block_215; } } -block_213: -{ -lean_object* x_180; -lean_inc(x_2); -x_180 = l_Lean_Meta_SynthInstance_main(x_177, x_15, x_2, x_179); -if (lean_obj_tag(x_180) == 0) -{ -lean_object* x_181; -lean_dec(x_22); -x_181 = lean_ctor_get(x_180, 0); -lean_inc(x_181); -if (lean_obj_tag(x_181) == 0) +block_215: { lean_object* x_182; -x_182 = lean_ctor_get(x_180, 1); -lean_inc(x_182); -lean_dec(x_180); -x_74 = x_181; -x_75 = x_182; -goto block_161; -} -else +lean_inc(x_2); +x_182 = l_Lean_Meta_SynthInstance_main(x_179, x_15, x_2, x_181); +if (lean_obj_tag(x_182) == 0) { -lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_198; uint8_t x_199; -x_183 = lean_ctor_get(x_180, 1); +lean_object* x_183; +lean_dec(x_22); +x_183 = lean_ctor_get(x_182, 0); lean_inc(x_183); -lean_dec(x_180); -x_184 = lean_ctor_get(x_181, 0); -lean_inc(x_184); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - x_185 = x_181; -} else { - lean_dec_ref(x_181); - x_185 = lean_box(0); -} -x_198 = lean_ctor_get(x_183, 4); -lean_inc(x_198); -x_199 = lean_ctor_get_uint8(x_198, sizeof(void*)*1); -lean_dec(x_198); -if (x_199 == 0) +if (lean_obj_tag(x_183) == 0) { -x_186 = x_183; -goto block_197; +lean_object* x_184; +x_184 = lean_ctor_get(x_182, 1); +lean_inc(x_184); +lean_dec(x_182); +x_76 = x_183; +x_77 = x_184; +goto block_163; } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; uint8_t x_203; -x_200 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_201 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_200, x_2, x_183); -x_202 = lean_ctor_get(x_201, 0); -lean_inc(x_202); -x_203 = lean_unbox(x_202); -lean_dec(x_202); -if (x_203 == 0) +lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_200; uint8_t x_201; +x_185 = lean_ctor_get(x_182, 1); +lean_inc(x_185); +lean_dec(x_182); +x_186 = lean_ctor_get(x_183, 0); +lean_inc(x_186); +if (lean_is_exclusive(x_183)) { + lean_ctor_release(x_183, 0); + x_187 = x_183; +} else { + lean_dec_ref(x_183); + x_187 = lean_box(0); +} +x_200 = lean_ctor_get(x_185, 4); +lean_inc(x_200); +x_201 = lean_ctor_get_uint8(x_200, sizeof(void*)*1); +lean_dec(x_200); +if (x_201 == 0) { -lean_object* x_204; -x_204 = lean_ctor_get(x_201, 1); +x_188 = x_185; +goto block_199; +} +else +{ +lean_object* x_202; lean_object* x_203; lean_object* x_204; uint8_t x_205; +x_202 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_203 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_202, x_2, x_185); +x_204 = lean_ctor_get(x_203, 0); lean_inc(x_204); -lean_dec(x_201); -x_186 = x_204; -goto block_197; +x_205 = lean_unbox(x_204); +lean_dec(x_204); +if (x_205 == 0) +{ +lean_object* x_206; +x_206 = lean_ctor_get(x_203, 1); +lean_inc(x_206); +lean_dec(x_203); +x_188 = x_206; +goto block_199; } 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; -x_205 = lean_ctor_get(x_201, 1); -lean_inc(x_205); -lean_dec(x_201); -lean_inc(x_184); -x_206 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_206, 0, x_184); -x_207 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_208 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_208, 0, x_207); -lean_ctor_set(x_208, 1, x_206); -x_209 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_200, x_208, x_2, x_205); -x_210 = lean_ctor_get(x_209, 1); -lean_inc(x_210); -lean_dec(x_209); -x_186 = x_210; -goto block_197; +lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; +x_207 = lean_ctor_get(x_203, 1); +lean_inc(x_207); +lean_dec(x_203); +lean_inc(x_186); +x_208 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_208, 0, x_186); +x_209 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_210 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_210, 0, x_209); +lean_ctor_set(x_210, 1, x_208); +x_211 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_202, x_210, x_2, x_207); +x_212 = lean_ctor_get(x_211, 1); +lean_inc(x_212); +lean_dec(x_211); +x_188 = x_212; +goto block_199; } } -block_197: +block_199: { -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; uint8_t x_192; -x_187 = l_Lean_Meta_instantiateMVars(x_184, x_2, x_186); -x_188 = lean_ctor_get(x_187, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_187, 1); -lean_inc(x_189); -lean_dec(x_187); -x_190 = l_Lean_Meta_hasAssignableMVar(x_188, x_2, x_189); -x_191 = lean_ctor_get(x_190, 0); +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; uint8_t x_194; +x_189 = l_Lean_Meta_instantiateMVars(x_186, x_2, x_188); +x_190 = lean_ctor_get(x_189, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_189, 1); lean_inc(x_191); -x_192 = lean_unbox(x_191); -lean_dec(x_191); -if (x_192 == 0) -{ -lean_object* x_193; lean_object* x_194; -x_193 = lean_ctor_get(x_190, 1); +lean_dec(x_189); +x_192 = l_Lean_Meta_hasAssignableMVar(x_190, x_2, x_191); +x_193 = lean_ctor_get(x_192, 0); lean_inc(x_193); -lean_dec(x_190); -if (lean_is_scalar(x_185)) { - x_194 = lean_alloc_ctor(1, 1, 0); -} else { - x_194 = x_185; -} -lean_ctor_set(x_194, 0, x_188); -x_74 = x_194; -x_75 = x_193; -goto block_161; -} -else +x_194 = lean_unbox(x_193); +lean_dec(x_193); +if (x_194 == 0) { lean_object* x_195; lean_object* x_196; -lean_dec(x_188); -lean_dec(x_185); -x_195 = lean_ctor_get(x_190, 1); +x_195 = lean_ctor_get(x_192, 1); lean_inc(x_195); +lean_dec(x_192); +if (lean_is_scalar(x_187)) { + x_196 = lean_alloc_ctor(1, 1, 0); +} else { + x_196 = x_187; +} +lean_ctor_set(x_196, 0, x_190); +x_76 = x_196; +x_77 = x_195; +goto block_163; +} +else +{ +lean_object* x_197; lean_object* x_198; lean_dec(x_190); -x_196 = lean_box(0); -x_74 = x_196; -x_75 = x_195; -goto block_161; +lean_dec(x_187); +x_197 = lean_ctor_get(x_192, 1); +lean_inc(x_197); +lean_dec(x_192); +x_198 = lean_box(0); +x_76 = x_198; +x_77 = x_197; +goto block_163; } } } } else { -lean_object* x_211; lean_object* x_212; +lean_object* x_213; lean_object* x_214; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -21469,20 +21469,20 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_211 = lean_ctor_get(x_180, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_180, 1); -lean_inc(x_212); -lean_dec(x_180); -x_162 = x_211; -x_163 = x_212; -goto block_174; +x_213 = lean_ctor_get(x_182, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_182, 1); +lean_inc(x_214); +lean_dec(x_182); +x_164 = x_213; +x_165 = x_214; +goto block_176; } } } else { -lean_object* x_229; lean_object* x_230; +lean_object* x_231; lean_object* x_232; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -21492,198 +21492,198 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_229 = lean_ctor_get(x_176, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_176, 1); -lean_inc(x_230); -lean_dec(x_176); -x_162 = x_229; -x_163 = x_230; -goto block_174; +x_231 = lean_ctor_get(x_178, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_178, 1); +lean_inc(x_232); +lean_dec(x_178); +x_164 = x_231; +x_165 = x_232; +goto block_176; } -block_161: +block_163: { -uint8_t x_76; -x_76 = !lean_is_exclusive(x_75); -if (x_76 == 0) +uint8_t x_78; +x_78 = !lean_is_exclusive(x_77); +if (x_78 == 0) { -lean_object* x_77; lean_object* x_78; -x_77 = lean_ctor_get(x_75, 4); -x_78 = lean_ctor_get(x_75, 1); -lean_dec(x_78); -lean_inc(x_77); -lean_ctor_set(x_75, 1, x_60); -if (lean_obj_tag(x_74) == 0) +lean_object* x_79; lean_object* x_80; +x_79 = lean_ctor_get(x_77, 4); +x_80 = lean_ctor_get(x_77, 1); +lean_dec(x_80); +lean_inc(x_79); +lean_ctor_set(x_77, 1, x_62); +if (lean_obj_tag(x_76) == 0) { -lean_dec(x_77); +lean_dec(x_79); lean_dec(x_2); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_28 = x_74; -x_29 = x_75; -goto block_58; +x_28 = x_76; +x_29 = x_77; +goto block_60; } else { -lean_object* x_79; lean_object* x_80; lean_object* x_81; uint8_t x_105; -x_79 = lean_ctor_get(x_74, 0); -lean_inc(x_79); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - x_80 = x_74; +lean_object* x_81; lean_object* x_82; lean_object* x_83; uint8_t x_107; +x_81 = lean_ctor_get(x_76, 0); +lean_inc(x_81); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + x_82 = x_76; } else { - lean_dec_ref(x_74); - x_80 = lean_box(0); + lean_dec_ref(x_76); + x_82 = lean_box(0); } -x_105 = lean_ctor_get_uint8(x_77, sizeof(void*)*1); -lean_dec(x_77); -if (x_105 == 0) +x_107 = lean_ctor_get_uint8(x_79, sizeof(void*)*1); +lean_dec(x_79); +if (x_107 == 0) { -x_81 = x_75; -goto block_104; +x_83 = x_77; +goto block_106; } else { -lean_object* x_106; lean_object* x_107; lean_object* x_108; uint8_t x_109; -x_106 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_107 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_106, x_2, x_75); -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -x_109 = lean_unbox(x_108); -lean_dec(x_108); -if (x_109 == 0) -{ -lean_object* x_110; -x_110 = lean_ctor_get(x_107, 1); +lean_object* x_108; lean_object* x_109; lean_object* x_110; uint8_t x_111; +x_108 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_109 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_108, x_2, x_77); +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_107); -x_81 = x_110; -goto block_104; +x_111 = lean_unbox(x_110); +lean_dec(x_110); +if (x_111 == 0) +{ +lean_object* x_112; +x_112 = lean_ctor_get(x_109, 1); +lean_inc(x_112); +lean_dec(x_109); +x_83 = x_112; +goto block_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; -x_111 = lean_ctor_get(x_107, 1); -lean_inc(x_111); -lean_dec(x_107); -lean_inc(x_79); -x_112 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_112, 0, x_79); -x_113 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_114 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_112); -x_115 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_106, x_114, x_2, x_111); -x_116 = lean_ctor_get(x_115, 1); -lean_inc(x_116); -lean_dec(x_115); -x_81 = x_116; -goto block_104; +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_113 = lean_ctor_get(x_109, 1); +lean_inc(x_113); +lean_dec(x_109); +lean_inc(x_81); +x_114 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_114, 0, x_81); +x_115 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_116 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_116, 0, x_115); +lean_ctor_set(x_116, 1, x_114); +x_117 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_108, x_116, x_2, x_113); +x_118 = lean_ctor_get(x_117, 1); +lean_inc(x_118); +lean_dec(x_117); +x_83 = x_118; +goto block_106; } } -block_104: +block_106: { -lean_object* x_82; +lean_object* x_84; lean_inc(x_2); -lean_inc(x_79); -x_82 = l_Lean_Meta_inferType(x_79, x_2, x_81); -if (lean_obj_tag(x_82) == 0) +lean_inc(x_81); +x_84 = l_Lean_Meta_inferType(x_81, x_2, x_83); +if (lean_obj_tag(x_84) == 0) { -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_83 = lean_ctor_get(x_82, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_82, 1); -lean_inc(x_84); -lean_dec(x_82); -x_85 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_85, 0, x_5); -lean_ctor_set(x_85, 1, x_6); -lean_ctor_set(x_85, 2, x_7); -lean_ctor_set(x_85, 3, x_8); -lean_ctor_set(x_85, 4, x_9); +lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_85 = lean_ctor_get(x_84, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_84, 1); +lean_inc(x_86); +lean_dec(x_84); +x_87 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_87, 0, x_5); +lean_ctor_set(x_87, 1, x_6); +lean_ctor_set(x_87, 2, x_7); +lean_ctor_set(x_87, 3, x_8); +lean_ctor_set(x_87, 4, x_9); lean_inc(x_25); -x_86 = l_Lean_Meta_isExprDefEq(x_25, x_83, x_85, x_84); -if (lean_obj_tag(x_86) == 0) +x_88 = l_Lean_Meta_isExprDefEq(x_25, x_85, x_87, x_86); +if (lean_obj_tag(x_88) == 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_dec(x_80); -lean_dec(x_79); -lean_dec(x_2); -x_89 = lean_ctor_get(x_86, 1); +lean_object* x_89; uint8_t x_90; +x_89 = lean_ctor_get(x_88, 0); lean_inc(x_89); -lean_dec(x_86); -x_90 = lean_box(0); -x_28 = x_90; -x_29 = x_89; -goto block_58; -} -else +x_90 = lean_unbox(x_89); +lean_dec(x_89); +if (x_90 == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_91 = lean_ctor_get(x_86, 1); -lean_inc(x_91); -lean_dec(x_86); -x_92 = l_Lean_Meta_instantiateMVars(x_79, x_2, x_91); +lean_object* x_91; lean_object* x_92; +lean_dec(x_82); +lean_dec(x_81); lean_dec(x_2); -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); -if (lean_is_scalar(x_80)) { - x_95 = lean_alloc_ctor(1, 1, 0); -} else { - x_95 = x_80; +x_91 = lean_ctor_get(x_88, 1); +lean_inc(x_91); +lean_dec(x_88); +x_92 = lean_box(0); +x_28 = x_92; +x_29 = x_91; +goto block_60; } -lean_ctor_set(x_95, 0, x_93); -x_28 = x_95; -x_29 = x_94; -goto block_58; +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_88, 1); +lean_inc(x_93); +lean_dec(x_88); +x_94 = l_Lean_Meta_instantiateMVars(x_81, x_2, x_93); +lean_dec(x_2); +x_95 = lean_ctor_get(x_94, 0); +lean_inc(x_95); +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +if (lean_is_scalar(x_82)) { + x_97 = lean_alloc_ctor(1, 1, 0); +} else { + x_97 = x_82; +} +lean_ctor_set(x_97, 0, x_95); +x_28 = x_97; +x_29 = x_96; +goto block_60; } } else { -uint8_t x_96; -lean_dec(x_80); -lean_dec(x_79); +uint8_t x_98; +lean_dec(x_82); +lean_dec(x_81); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); -x_96 = !lean_is_exclusive(x_86); -if (x_96 == 0) +x_98 = !lean_is_exclusive(x_88); +if (x_98 == 0) { -return x_86; +return x_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_86, 0); -x_98 = lean_ctor_get(x_86, 1); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_86); -x_99 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_99, 0, x_97); -lean_ctor_set(x_99, 1, x_98); -return x_99; +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_88, 0); +x_100 = lean_ctor_get(x_88, 1); +lean_inc(x_100); +lean_inc(x_99); +lean_dec(x_88); +x_101 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_101, 0, x_99); +lean_ctor_set(x_101, 1, x_100); +return x_101; } } } else { -uint8_t x_100; -lean_dec(x_80); -lean_dec(x_79); +uint8_t x_102; +lean_dec(x_82); +lean_dec(x_81); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -21692,23 +21692,23 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_100 = !lean_is_exclusive(x_82); -if (x_100 == 0) +x_102 = !lean_is_exclusive(x_84); +if (x_102 == 0) { -return x_82; +return x_84; } else { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_82, 0); -x_102 = lean_ctor_get(x_82, 1); -lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_82); -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; +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_84, 0); +x_104 = lean_ctor_get(x_84, 1); +lean_inc(x_104); +lean_inc(x_103); +lean_dec(x_84); +x_105 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_105, 0, x_103); +lean_ctor_set(x_105, 1, x_104); +return x_105; } } } @@ -21716,199 +21716,199 @@ return x_103; } 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; -x_117 = lean_ctor_get(x_75, 0); -x_118 = lean_ctor_get(x_75, 2); -x_119 = lean_ctor_get(x_75, 3); -x_120 = lean_ctor_get(x_75, 4); -x_121 = lean_ctor_get(x_75, 5); +lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_119 = lean_ctor_get(x_77, 0); +x_120 = lean_ctor_get(x_77, 2); +x_121 = lean_ctor_get(x_77, 3); +x_122 = lean_ctor_get(x_77, 4); +x_123 = lean_ctor_get(x_77, 5); +lean_inc(x_123); +lean_inc(x_122); lean_inc(x_121); lean_inc(x_120); lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_75); -lean_inc(x_120); -x_122 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_122, 0, x_117); -lean_ctor_set(x_122, 1, x_60); -lean_ctor_set(x_122, 2, x_118); -lean_ctor_set(x_122, 3, x_119); -lean_ctor_set(x_122, 4, x_120); -lean_ctor_set(x_122, 5, x_121); -if (lean_obj_tag(x_74) == 0) +lean_dec(x_77); +lean_inc(x_122); +x_124 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_124, 0, x_119); +lean_ctor_set(x_124, 1, x_62); +lean_ctor_set(x_124, 2, x_120); +lean_ctor_set(x_124, 3, x_121); +lean_ctor_set(x_124, 4, x_122); +lean_ctor_set(x_124, 5, x_123); +if (lean_obj_tag(x_76) == 0) { -lean_dec(x_120); +lean_dec(x_122); lean_dec(x_2); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_28 = x_74; -x_29 = x_122; -goto block_58; +x_28 = x_76; +x_29 = x_124; +goto block_60; } else { -lean_object* x_123; lean_object* x_124; lean_object* x_125; uint8_t x_149; -x_123 = lean_ctor_get(x_74, 0); -lean_inc(x_123); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - x_124 = x_74; +lean_object* x_125; lean_object* x_126; lean_object* x_127; uint8_t x_151; +x_125 = lean_ctor_get(x_76, 0); +lean_inc(x_125); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + x_126 = x_76; } else { - lean_dec_ref(x_74); - x_124 = lean_box(0); + lean_dec_ref(x_76); + x_126 = lean_box(0); } -x_149 = lean_ctor_get_uint8(x_120, sizeof(void*)*1); -lean_dec(x_120); -if (x_149 == 0) +x_151 = lean_ctor_get_uint8(x_122, sizeof(void*)*1); +lean_dec(x_122); +if (x_151 == 0) { -x_125 = x_122; -goto block_148; +x_127 = x_124; +goto block_150; } else { -lean_object* x_150; lean_object* x_151; lean_object* x_152; uint8_t x_153; -x_150 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_151 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_150, x_2, x_122); -x_152 = lean_ctor_get(x_151, 0); -lean_inc(x_152); -x_153 = lean_unbox(x_152); -lean_dec(x_152); -if (x_153 == 0) -{ -lean_object* x_154; -x_154 = lean_ctor_get(x_151, 1); +lean_object* x_152; lean_object* x_153; lean_object* x_154; uint8_t x_155; +x_152 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_153 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_152, x_2, x_124); +x_154 = lean_ctor_get(x_153, 0); lean_inc(x_154); -lean_dec(x_151); -x_125 = x_154; -goto block_148; +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_127 = x_156; +goto block_150; } 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; -x_155 = lean_ctor_get(x_151, 1); -lean_inc(x_155); -lean_dec(x_151); -lean_inc(x_123); -x_156 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_156, 0, x_123); -x_157 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_158 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_158, 0, x_157); -lean_ctor_set(x_158, 1, x_156); -x_159 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_150, x_158, x_2, x_155); -x_160 = lean_ctor_get(x_159, 1); -lean_inc(x_160); -lean_dec(x_159); -x_125 = x_160; -goto block_148; +lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_157 = lean_ctor_get(x_153, 1); +lean_inc(x_157); +lean_dec(x_153); +lean_inc(x_125); +x_158 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_158, 0, x_125); +x_159 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_160 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_160, 0, x_159); +lean_ctor_set(x_160, 1, x_158); +x_161 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_152, x_160, x_2, x_157); +x_162 = lean_ctor_get(x_161, 1); +lean_inc(x_162); +lean_dec(x_161); +x_127 = x_162; +goto block_150; } } -block_148: +block_150: { -lean_object* x_126; +lean_object* x_128; lean_inc(x_2); -lean_inc(x_123); -x_126 = l_Lean_Meta_inferType(x_123, x_2, x_125); -if (lean_obj_tag(x_126) == 0) +lean_inc(x_125); +x_128 = l_Lean_Meta_inferType(x_125, x_2, x_127); +if (lean_obj_tag(x_128) == 0) { -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_127 = lean_ctor_get(x_126, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_126, 1); -lean_inc(x_128); -lean_dec(x_126); -x_129 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_129, 0, x_5); -lean_ctor_set(x_129, 1, x_6); -lean_ctor_set(x_129, 2, x_7); -lean_ctor_set(x_129, 3, x_8); -lean_ctor_set(x_129, 4, x_9); +lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_129 = lean_ctor_get(x_128, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_128, 1); +lean_inc(x_130); +lean_dec(x_128); +x_131 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_131, 0, x_5); +lean_ctor_set(x_131, 1, x_6); +lean_ctor_set(x_131, 2, x_7); +lean_ctor_set(x_131, 3, x_8); +lean_ctor_set(x_131, 4, x_9); lean_inc(x_25); -x_130 = l_Lean_Meta_isExprDefEq(x_25, x_127, x_129, x_128); -if (lean_obj_tag(x_130) == 0) +x_132 = l_Lean_Meta_isExprDefEq(x_25, x_129, x_131, x_130); +if (lean_obj_tag(x_132) == 0) { -lean_object* x_131; uint8_t x_132; -x_131 = lean_ctor_get(x_130, 0); -lean_inc(x_131); -x_132 = lean_unbox(x_131); -lean_dec(x_131); -if (x_132 == 0) -{ -lean_object* x_133; lean_object* x_134; -lean_dec(x_124); -lean_dec(x_123); -lean_dec(x_2); -x_133 = lean_ctor_get(x_130, 1); +lean_object* x_133; uint8_t x_134; +x_133 = lean_ctor_get(x_132, 0); lean_inc(x_133); -lean_dec(x_130); -x_134 = lean_box(0); -x_28 = x_134; -x_29 = x_133; -goto block_58; -} -else +x_134 = lean_unbox(x_133); +lean_dec(x_133); +if (x_134 == 0) { -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_135 = lean_ctor_get(x_130, 1); -lean_inc(x_135); -lean_dec(x_130); -x_136 = l_Lean_Meta_instantiateMVars(x_123, x_2, x_135); +lean_object* x_135; lean_object* x_136; +lean_dec(x_126); +lean_dec(x_125); lean_dec(x_2); -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); -if (lean_is_scalar(x_124)) { - x_139 = lean_alloc_ctor(1, 1, 0); -} else { - x_139 = x_124; +x_135 = lean_ctor_get(x_132, 1); +lean_inc(x_135); +lean_dec(x_132); +x_136 = lean_box(0); +x_28 = x_136; +x_29 = x_135; +goto block_60; } -lean_ctor_set(x_139, 0, x_137); -x_28 = x_139; -x_29 = x_138; -goto block_58; +else +{ +lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_137 = lean_ctor_get(x_132, 1); +lean_inc(x_137); +lean_dec(x_132); +x_138 = l_Lean_Meta_instantiateMVars(x_125, x_2, x_137); +lean_dec(x_2); +x_139 = lean_ctor_get(x_138, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_138, 1); +lean_inc(x_140); +lean_dec(x_138); +if (lean_is_scalar(x_126)) { + x_141 = lean_alloc_ctor(1, 1, 0); +} else { + x_141 = x_126; +} +lean_ctor_set(x_141, 0, x_139); +x_28 = x_141; +x_29 = x_140; +goto block_60; } } else { -lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; -lean_dec(x_124); -lean_dec(x_123); +lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; +lean_dec(x_126); +lean_dec(x_125); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); -x_140 = lean_ctor_get(x_130, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_130, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - x_142 = x_130; +x_142 = lean_ctor_get(x_132, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_132, 1); +lean_inc(x_143); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + x_144 = x_132; } else { - lean_dec_ref(x_130); - x_142 = lean_box(0); + lean_dec_ref(x_132); + x_144 = lean_box(0); } -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_144)) { + x_145 = lean_alloc_ctor(1, 2, 0); } else { - x_143 = x_142; + x_145 = x_144; } -lean_ctor_set(x_143, 0, x_140); -lean_ctor_set(x_143, 1, x_141); -return x_143; +lean_ctor_set(x_145, 0, x_142); +lean_ctor_set(x_145, 1, x_143); +return x_145; } } else { -lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; -lean_dec(x_124); -lean_dec(x_123); +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +lean_dec(x_126); +lean_dec(x_125); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -21917,295 +21917,295 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -x_145 = lean_ctor_get(x_126, 1); -lean_inc(x_145); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_146 = x_126; +x_146 = lean_ctor_get(x_128, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_128, 1); +lean_inc(x_147); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_148 = x_128; } else { - lean_dec_ref(x_126); - x_146 = lean_box(0); + lean_dec_ref(x_128); + x_148 = lean_box(0); } -if (lean_is_scalar(x_146)) { - x_147 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(1, 2, 0); } else { - x_147 = x_146; + x_149 = x_148; } -lean_ctor_set(x_147, 0, x_144); -lean_ctor_set(x_147, 1, x_145); -return x_147; +lean_ctor_set(x_149, 0, x_146); +lean_ctor_set(x_149, 1, x_147); +return x_149; } } } } } -block_174: +block_176: { -uint8_t x_164; -x_164 = !lean_is_exclusive(x_163); -if (x_164 == 0) +uint8_t x_166; +x_166 = !lean_is_exclusive(x_165); +if (x_166 == 0) { -lean_object* x_165; lean_object* x_166; -x_165 = lean_ctor_get(x_163, 1); -lean_dec(x_165); -lean_ctor_set(x_163, 1, x_60); +lean_object* x_167; lean_object* x_168; +x_167 = lean_ctor_get(x_165, 1); +lean_dec(x_167); +lean_ctor_set(x_165, 1, x_62); if (lean_is_scalar(x_22)) { - x_166 = lean_alloc_ctor(1, 2, 0); + x_168 = lean_alloc_ctor(1, 2, 0); } else { - x_166 = x_22; - lean_ctor_set_tag(x_166, 1); + x_168 = x_22; + lean_ctor_set_tag(x_168, 1); } -lean_ctor_set(x_166, 0, x_162); -lean_ctor_set(x_166, 1, x_163); -return x_166; +lean_ctor_set(x_168, 0, x_164); +lean_ctor_set(x_168, 1, x_165); +return x_168; } else { -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_167 = lean_ctor_get(x_163, 0); -x_168 = lean_ctor_get(x_163, 2); -x_169 = lean_ctor_get(x_163, 3); -x_170 = lean_ctor_get(x_163, 4); -x_171 = lean_ctor_get(x_163, 5); +lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_169 = lean_ctor_get(x_165, 0); +x_170 = lean_ctor_get(x_165, 2); +x_171 = lean_ctor_get(x_165, 3); +x_172 = lean_ctor_get(x_165, 4); +x_173 = lean_ctor_get(x_165, 5); +lean_inc(x_173); +lean_inc(x_172); lean_inc(x_171); lean_inc(x_170); lean_inc(x_169); -lean_inc(x_168); -lean_inc(x_167); -lean_dec(x_163); -x_172 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_172, 0, x_167); -lean_ctor_set(x_172, 1, x_60); -lean_ctor_set(x_172, 2, x_168); -lean_ctor_set(x_172, 3, x_169); -lean_ctor_set(x_172, 4, x_170); -lean_ctor_set(x_172, 5, x_171); +lean_dec(x_165); +x_174 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_174, 0, x_169); +lean_ctor_set(x_174, 1, x_62); +lean_ctor_set(x_174, 2, x_170); +lean_ctor_set(x_174, 3, x_171); +lean_ctor_set(x_174, 4, x_172); +lean_ctor_set(x_174, 5, x_173); if (lean_is_scalar(x_22)) { - x_173 = lean_alloc_ctor(1, 2, 0); + x_175 = lean_alloc_ctor(1, 2, 0); } else { - x_173 = x_22; - lean_ctor_set_tag(x_173, 1); + x_175 = x_22; + lean_ctor_set_tag(x_175, 1); } -lean_ctor_set(x_173, 0, x_162); -lean_ctor_set(x_173, 1, x_172); -return x_173; +lean_ctor_set(x_175, 0, x_164); +lean_ctor_set(x_175, 1, x_174); +return x_175; } } } else { -lean_object* x_231; lean_object* x_232; lean_object* x_279; lean_object* x_280; lean_object* x_290; lean_object* x_291; lean_object* x_292; +lean_object* x_233; lean_object* x_234; lean_object* x_281; lean_object* x_282; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_dec(x_26); -lean_inc(x_60); -x_290 = l_Lean_MetavarContext_incDepth(x_60); -x_291 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_291, 0, x_59); -lean_ctor_set(x_291, 1, x_290); -lean_ctor_set(x_291, 2, x_61); -lean_ctor_set(x_291, 3, x_62); -lean_ctor_set(x_291, 4, x_63); -lean_ctor_set(x_291, 5, x_64); +lean_inc(x_62); +x_292 = l_Lean_MetavarContext_incDepth(x_62); +x_293 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_293, 0, x_61); +lean_ctor_set(x_293, 1, x_292); +lean_ctor_set(x_293, 2, x_63); +lean_ctor_set(x_293, 3, x_64); +lean_ctor_set(x_293, 4, x_65); +lean_ctor_set(x_293, 5, x_66); lean_inc(x_2); lean_inc(x_25); -x_292 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_291); -if (lean_obj_tag(x_292) == 0) +x_294 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_293); +if (lean_obj_tag(x_294) == 0) { -lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_330; uint8_t x_331; -x_293 = lean_ctor_get(x_292, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_292, 1); -lean_inc(x_294); -lean_dec(x_292); -x_330 = lean_ctor_get(x_294, 4); -lean_inc(x_330); -x_331 = lean_ctor_get_uint8(x_330, sizeof(void*)*1); -lean_dec(x_330); -if (x_331 == 0) +lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_332; uint8_t x_333; +x_295 = lean_ctor_get(x_294, 0); +lean_inc(x_295); +x_296 = lean_ctor_get(x_294, 1); +lean_inc(x_296); +lean_dec(x_294); +x_332 = lean_ctor_get(x_296, 4); +lean_inc(x_332); +x_333 = lean_ctor_get_uint8(x_332, sizeof(void*)*1); +lean_dec(x_332); +if (x_333 == 0) { -x_295 = x_294; -goto block_329; +x_297 = x_296; +goto block_331; } else { -lean_object* x_332; lean_object* x_333; lean_object* x_334; uint8_t x_335; -x_332 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_333 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_332, x_2, x_294); -x_334 = lean_ctor_get(x_333, 0); -lean_inc(x_334); -x_335 = lean_unbox(x_334); -lean_dec(x_334); -if (x_335 == 0) -{ -lean_object* x_336; -x_336 = lean_ctor_get(x_333, 1); +lean_object* x_334; lean_object* x_335; lean_object* x_336; uint8_t x_337; +x_334 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_335 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_334, x_2, x_296); +x_336 = lean_ctor_get(x_335, 0); lean_inc(x_336); -lean_dec(x_333); -x_295 = x_336; -goto block_329; +x_337 = lean_unbox(x_336); +lean_dec(x_336); +if (x_337 == 0) +{ +lean_object* x_338; +x_338 = lean_ctor_get(x_335, 1); +lean_inc(x_338); +lean_dec(x_335); +x_297 = x_338; +goto block_331; } else { -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_337 = lean_ctor_get(x_333, 1); -lean_inc(x_337); -lean_dec(x_333); +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; +x_339 = lean_ctor_get(x_335, 1); +lean_inc(x_339); +lean_dec(x_335); lean_inc(x_25); -x_338 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_338, 0, x_25); -x_339 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_340 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_340, 0, x_338); -lean_ctor_set(x_340, 1, x_339); -lean_inc(x_293); -x_341 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_341, 0, x_293); +x_340 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_340, 0, x_25); +x_341 = l_Lean_Meta_synthInstance_x3f___closed__9; x_342 = lean_alloc_ctor(9, 2, 0); lean_ctor_set(x_342, 0, x_340); lean_ctor_set(x_342, 1, x_341); -x_343 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_332, x_342, x_2, x_337); -x_344 = lean_ctor_get(x_343, 1); -lean_inc(x_344); -lean_dec(x_343); -x_295 = x_344; -goto block_329; +lean_inc(x_295); +x_343 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_343, 0, x_295); +x_344 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_344, 0, x_342); +lean_ctor_set(x_344, 1, x_343); +x_345 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_334, x_344, x_2, x_339); +x_346 = lean_ctor_get(x_345, 1); +lean_inc(x_346); +lean_dec(x_345); +x_297 = x_346; +goto block_331; } } -block_329: -{ -lean_object* x_296; -lean_inc(x_2); -x_296 = l_Lean_Meta_SynthInstance_main(x_293, x_15, x_2, x_295); -if (lean_obj_tag(x_296) == 0) -{ -lean_object* x_297; -lean_dec(x_22); -x_297 = lean_ctor_get(x_296, 0); -lean_inc(x_297); -if (lean_obj_tag(x_297) == 0) +block_331: { lean_object* x_298; -x_298 = lean_ctor_get(x_296, 1); -lean_inc(x_298); -lean_dec(x_296); -x_231 = x_297; -x_232 = x_298; -goto block_278; -} -else +lean_inc(x_2); +x_298 = l_Lean_Meta_SynthInstance_main(x_295, x_15, x_2, x_297); +if (lean_obj_tag(x_298) == 0) { -lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_314; uint8_t x_315; -x_299 = lean_ctor_get(x_296, 1); +lean_object* x_299; +lean_dec(x_22); +x_299 = lean_ctor_get(x_298, 0); lean_inc(x_299); -lean_dec(x_296); -x_300 = lean_ctor_get(x_297, 0); -lean_inc(x_300); -if (lean_is_exclusive(x_297)) { - lean_ctor_release(x_297, 0); - x_301 = x_297; -} else { - lean_dec_ref(x_297); - x_301 = lean_box(0); -} -x_314 = lean_ctor_get(x_299, 4); -lean_inc(x_314); -x_315 = lean_ctor_get_uint8(x_314, sizeof(void*)*1); -lean_dec(x_314); -if (x_315 == 0) +if (lean_obj_tag(x_299) == 0) { -x_302 = x_299; -goto block_313; +lean_object* x_300; +x_300 = lean_ctor_get(x_298, 1); +lean_inc(x_300); +lean_dec(x_298); +x_233 = x_299; +x_234 = x_300; +goto block_280; } else { -lean_object* x_316; lean_object* x_317; lean_object* x_318; uint8_t x_319; -x_316 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_317 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_316, x_2, x_299); -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_unbox(x_318); -lean_dec(x_318); -if (x_319 == 0) +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_316; uint8_t x_317; +x_301 = lean_ctor_get(x_298, 1); +lean_inc(x_301); +lean_dec(x_298); +x_302 = lean_ctor_get(x_299, 0); +lean_inc(x_302); +if (lean_is_exclusive(x_299)) { + lean_ctor_release(x_299, 0); + x_303 = x_299; +} else { + lean_dec_ref(x_299); + x_303 = lean_box(0); +} +x_316 = lean_ctor_get(x_301, 4); +lean_inc(x_316); +x_317 = lean_ctor_get_uint8(x_316, sizeof(void*)*1); +lean_dec(x_316); +if (x_317 == 0) { -lean_object* x_320; -x_320 = lean_ctor_get(x_317, 1); +x_304 = x_301; +goto block_315; +} +else +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; uint8_t x_321; +x_318 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_319 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_318, x_2, x_301); +x_320 = lean_ctor_get(x_319, 0); lean_inc(x_320); -lean_dec(x_317); -x_302 = x_320; -goto block_313; +x_321 = lean_unbox(x_320); +lean_dec(x_320); +if (x_321 == 0) +{ +lean_object* x_322; +x_322 = lean_ctor_get(x_319, 1); +lean_inc(x_322); +lean_dec(x_319); +x_304 = x_322; +goto block_315; } 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; -x_321 = lean_ctor_get(x_317, 1); -lean_inc(x_321); -lean_dec(x_317); -lean_inc(x_300); -x_322 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_322, 0, x_300); -x_323 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_324 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_324, 0, x_323); -lean_ctor_set(x_324, 1, x_322); -x_325 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_316, x_324, x_2, x_321); -x_326 = lean_ctor_get(x_325, 1); -lean_inc(x_326); -lean_dec(x_325); -x_302 = x_326; -goto block_313; +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_323 = lean_ctor_get(x_319, 1); +lean_inc(x_323); +lean_dec(x_319); +lean_inc(x_302); +x_324 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_324, 0, x_302); +x_325 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_326 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_326, 0, x_325); +lean_ctor_set(x_326, 1, x_324); +x_327 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_318, x_326, x_2, x_323); +x_328 = lean_ctor_get(x_327, 1); +lean_inc(x_328); +lean_dec(x_327); +x_304 = x_328; +goto block_315; } } -block_313: +block_315: { -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; uint8_t x_308; -x_303 = l_Lean_Meta_instantiateMVars(x_300, x_2, x_302); -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 = l_Lean_Meta_hasAssignableMVar(x_304, x_2, x_305); -x_307 = lean_ctor_get(x_306, 0); +lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; uint8_t x_310; +x_305 = l_Lean_Meta_instantiateMVars(x_302, x_2, x_304); +x_306 = lean_ctor_get(x_305, 0); +lean_inc(x_306); +x_307 = lean_ctor_get(x_305, 1); lean_inc(x_307); -x_308 = lean_unbox(x_307); -lean_dec(x_307); -if (x_308 == 0) -{ -lean_object* x_309; lean_object* x_310; -x_309 = lean_ctor_get(x_306, 1); +lean_dec(x_305); +x_308 = l_Lean_Meta_hasAssignableMVar(x_306, x_2, x_307); +x_309 = lean_ctor_get(x_308, 0); lean_inc(x_309); -lean_dec(x_306); -if (lean_is_scalar(x_301)) { - x_310 = lean_alloc_ctor(1, 1, 0); -} else { - x_310 = x_301; -} -lean_ctor_set(x_310, 0, x_304); -x_231 = x_310; -x_232 = x_309; -goto block_278; -} -else +x_310 = lean_unbox(x_309); +lean_dec(x_309); +if (x_310 == 0) { lean_object* x_311; lean_object* x_312; -lean_dec(x_304); -lean_dec(x_301); -x_311 = lean_ctor_get(x_306, 1); +x_311 = lean_ctor_get(x_308, 1); lean_inc(x_311); +lean_dec(x_308); +if (lean_is_scalar(x_303)) { + x_312 = lean_alloc_ctor(1, 1, 0); +} else { + x_312 = x_303; +} +lean_ctor_set(x_312, 0, x_306); +x_233 = x_312; +x_234 = x_311; +goto block_280; +} +else +{ +lean_object* x_313; lean_object* x_314; lean_dec(x_306); -x_312 = lean_box(0); -x_231 = x_312; -x_232 = x_311; -goto block_278; +lean_dec(x_303); +x_313 = lean_ctor_get(x_308, 1); +lean_inc(x_313); +lean_dec(x_308); +x_314 = lean_box(0); +x_233 = x_314; +x_234 = x_313; +goto block_280; } } } } else { -lean_object* x_327; lean_object* x_328; +lean_object* x_329; lean_object* x_330; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -22214,337 +22214,20 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_327 = lean_ctor_get(x_296, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_296, 1); -lean_inc(x_328); -lean_dec(x_296); -x_279 = x_327; -x_280 = x_328; -goto block_289; -} -} -} -else -{ -lean_object* x_345; lean_object* x_346; -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -lean_dec(x_15); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_345 = lean_ctor_get(x_292, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_292, 1); -lean_inc(x_346); -lean_dec(x_292); -x_279 = x_345; -x_280 = x_346; -goto block_289; -} -block_278: -{ -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_233 = lean_ctor_get(x_232, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_232, 2); -lean_inc(x_234); -x_235 = lean_ctor_get(x_232, 3); -lean_inc(x_235); -x_236 = lean_ctor_get(x_232, 4); -lean_inc(x_236); -x_237 = lean_ctor_get(x_232, 5); -lean_inc(x_237); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - lean_ctor_release(x_232, 1); - lean_ctor_release(x_232, 2); - lean_ctor_release(x_232, 3); - lean_ctor_release(x_232, 4); - lean_ctor_release(x_232, 5); - x_238 = x_232; -} else { - lean_dec_ref(x_232); - x_238 = lean_box(0); -} -lean_inc(x_236); -if (lean_is_scalar(x_238)) { - x_239 = lean_alloc_ctor(0, 6, 0); -} else { - x_239 = x_238; -} -lean_ctor_set(x_239, 0, x_233); -lean_ctor_set(x_239, 1, x_60); -lean_ctor_set(x_239, 2, x_234); -lean_ctor_set(x_239, 3, x_235); -lean_ctor_set(x_239, 4, x_236); -lean_ctor_set(x_239, 5, x_237); -if (lean_obj_tag(x_231) == 0) -{ -lean_dec(x_236); -lean_dec(x_2); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_28 = x_231; -x_29 = x_239; -goto block_58; -} -else -{ -lean_object* x_240; lean_object* x_241; lean_object* x_242; uint8_t x_266; -x_240 = lean_ctor_get(x_231, 0); -lean_inc(x_240); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - x_241 = x_231; -} else { - lean_dec_ref(x_231); - x_241 = lean_box(0); -} -x_266 = lean_ctor_get_uint8(x_236, sizeof(void*)*1); -lean_dec(x_236); -if (x_266 == 0) -{ -x_242 = x_239; -goto block_265; -} -else -{ -lean_object* x_267; lean_object* x_268; lean_object* x_269; uint8_t x_270; -x_267 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_268 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_267, x_2, x_239); -x_269 = lean_ctor_get(x_268, 0); -lean_inc(x_269); -x_270 = lean_unbox(x_269); -lean_dec(x_269); -if (x_270 == 0) -{ -lean_object* x_271; -x_271 = lean_ctor_get(x_268, 1); -lean_inc(x_271); -lean_dec(x_268); -x_242 = x_271; -goto block_265; -} -else -{ -lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_272 = lean_ctor_get(x_268, 1); -lean_inc(x_272); -lean_dec(x_268); -lean_inc(x_240); -x_273 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_273, 0, x_240); -x_274 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_275 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_275, 0, x_274); -lean_ctor_set(x_275, 1, x_273); -x_276 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_267, x_275, x_2, x_272); -x_277 = lean_ctor_get(x_276, 1); -lean_inc(x_277); -lean_dec(x_276); -x_242 = x_277; -goto block_265; -} -} -block_265: -{ -lean_object* x_243; -lean_inc(x_2); -lean_inc(x_240); -x_243 = l_Lean_Meta_inferType(x_240, x_2, x_242); -if (lean_obj_tag(x_243) == 0) -{ -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; -x_244 = lean_ctor_get(x_243, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_243, 1); -lean_inc(x_245); -lean_dec(x_243); -x_246 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_246, 0, x_5); -lean_ctor_set(x_246, 1, x_6); -lean_ctor_set(x_246, 2, x_7); -lean_ctor_set(x_246, 3, x_8); -lean_ctor_set(x_246, 4, x_9); -lean_inc(x_25); -x_247 = l_Lean_Meta_isExprDefEq(x_25, x_244, x_246, x_245); -if (lean_obj_tag(x_247) == 0) -{ -lean_object* x_248; uint8_t x_249; -x_248 = lean_ctor_get(x_247, 0); -lean_inc(x_248); -x_249 = lean_unbox(x_248); -lean_dec(x_248); -if (x_249 == 0) -{ -lean_object* x_250; lean_object* x_251; -lean_dec(x_241); -lean_dec(x_240); -lean_dec(x_2); -x_250 = lean_ctor_get(x_247, 1); -lean_inc(x_250); -lean_dec(x_247); -x_251 = lean_box(0); -x_28 = x_251; -x_29 = x_250; -goto block_58; -} -else -{ -lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; -x_252 = lean_ctor_get(x_247, 1); -lean_inc(x_252); -lean_dec(x_247); -x_253 = l_Lean_Meta_instantiateMVars(x_240, x_2, x_252); -lean_dec(x_2); -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); -if (lean_is_scalar(x_241)) { - x_256 = lean_alloc_ctor(1, 1, 0); -} else { - x_256 = x_241; -} -lean_ctor_set(x_256, 0, x_254); -x_28 = x_256; -x_29 = x_255; -goto block_58; -} -} -else -{ -lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; -lean_dec(x_241); -lean_dec(x_240); -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -x_257 = lean_ctor_get(x_247, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_247, 1); -lean_inc(x_258); -if (lean_is_exclusive(x_247)) { - lean_ctor_release(x_247, 0); - lean_ctor_release(x_247, 1); - 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(1, 2, 0); -} else { - x_260 = x_259; -} -lean_ctor_set(x_260, 0, x_257); -lean_ctor_set(x_260, 1, x_258); -return x_260; -} -} -else -{ -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; -lean_dec(x_241); -lean_dec(x_240); -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_261 = lean_ctor_get(x_243, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_243, 1); -lean_inc(x_262); -if (lean_is_exclusive(x_243)) { - lean_ctor_release(x_243, 0); - lean_ctor_release(x_243, 1); - x_263 = x_243; -} else { - lean_dec_ref(x_243); - x_263 = lean_box(0); -} -if (lean_is_scalar(x_263)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_263; -} -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -return x_264; -} -} -} -} -block_289: -{ -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_281 = lean_ctor_get(x_280, 0); -lean_inc(x_281); -x_282 = lean_ctor_get(x_280, 2); -lean_inc(x_282); -x_283 = lean_ctor_get(x_280, 3); -lean_inc(x_283); -x_284 = lean_ctor_get(x_280, 4); -lean_inc(x_284); -x_285 = lean_ctor_get(x_280, 5); -lean_inc(x_285); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - lean_ctor_release(x_280, 3); - lean_ctor_release(x_280, 4); - lean_ctor_release(x_280, 5); - x_286 = x_280; -} else { - lean_dec_ref(x_280); - x_286 = lean_box(0); -} -if (lean_is_scalar(x_286)) { - x_287 = lean_alloc_ctor(0, 6, 0); -} else { - x_287 = x_286; -} -lean_ctor_set(x_287, 0, x_281); -lean_ctor_set(x_287, 1, x_60); -lean_ctor_set(x_287, 2, x_282); -lean_ctor_set(x_287, 3, x_283); -lean_ctor_set(x_287, 4, x_284); -lean_ctor_set(x_287, 5, x_285); -if (lean_is_scalar(x_22)) { - x_288 = lean_alloc_ctor(1, 2, 0); -} else { - x_288 = x_22; - lean_ctor_set_tag(x_288, 1); -} -lean_ctor_set(x_288, 0, x_279); -lean_ctor_set(x_288, 1, x_287); -return x_288; +x_329 = lean_ctor_get(x_298, 0); +lean_inc(x_329); +x_330 = lean_ctor_get(x_298, 1); +lean_inc(x_330); +lean_dec(x_298); +x_281 = x_329; +x_282 = x_330; +goto block_291; } } } else { lean_object* x_347; lean_object* x_348; -lean_dec(x_64); -lean_dec(x_63); -lean_dec(x_62); -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -22554,19 +22237,336 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_347 = lean_ctor_get(x_66, 0); +x_347 = lean_ctor_get(x_294, 0); lean_inc(x_347); -lean_dec(x_66); -if (lean_is_scalar(x_22)) { - x_348 = lean_alloc_ctor(0, 2, 0); +x_348 = lean_ctor_get(x_294, 1); +lean_inc(x_348); +lean_dec(x_294); +x_281 = x_347; +x_282 = x_348; +goto block_291; +} +block_280: +{ +lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_235 = lean_ctor_get(x_234, 0); +lean_inc(x_235); +x_236 = lean_ctor_get(x_234, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_234, 3); +lean_inc(x_237); +x_238 = lean_ctor_get(x_234, 4); +lean_inc(x_238); +x_239 = lean_ctor_get(x_234, 5); +lean_inc(x_239); +if (lean_is_exclusive(x_234)) { + lean_ctor_release(x_234, 0); + lean_ctor_release(x_234, 1); + lean_ctor_release(x_234, 2); + lean_ctor_release(x_234, 3); + lean_ctor_release(x_234, 4); + lean_ctor_release(x_234, 5); + x_240 = x_234; } else { - x_348 = x_22; + lean_dec_ref(x_234); + x_240 = lean_box(0); } -lean_ctor_set(x_348, 0, x_347); -lean_ctor_set(x_348, 1, x_26); -return x_348; +lean_inc(x_238); +if (lean_is_scalar(x_240)) { + x_241 = lean_alloc_ctor(0, 6, 0); +} else { + x_241 = x_240; } -block_58: +lean_ctor_set(x_241, 0, x_235); +lean_ctor_set(x_241, 1, x_62); +lean_ctor_set(x_241, 2, x_236); +lean_ctor_set(x_241, 3, x_237); +lean_ctor_set(x_241, 4, x_238); +lean_ctor_set(x_241, 5, x_239); +if (lean_obj_tag(x_233) == 0) +{ +lean_dec(x_238); +lean_dec(x_2); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_28 = x_233; +x_29 = x_241; +goto block_60; +} +else +{ +lean_object* x_242; lean_object* x_243; lean_object* x_244; uint8_t x_268; +x_242 = lean_ctor_get(x_233, 0); +lean_inc(x_242); +if (lean_is_exclusive(x_233)) { + lean_ctor_release(x_233, 0); + x_243 = x_233; +} else { + lean_dec_ref(x_233); + x_243 = lean_box(0); +} +x_268 = lean_ctor_get_uint8(x_238, sizeof(void*)*1); +lean_dec(x_238); +if (x_268 == 0) +{ +x_244 = x_241; +goto block_267; +} +else +{ +lean_object* x_269; lean_object* x_270; lean_object* x_271; uint8_t x_272; +x_269 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_270 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_269, x_2, x_241); +x_271 = lean_ctor_get(x_270, 0); +lean_inc(x_271); +x_272 = lean_unbox(x_271); +lean_dec(x_271); +if (x_272 == 0) +{ +lean_object* x_273; +x_273 = lean_ctor_get(x_270, 1); +lean_inc(x_273); +lean_dec(x_270); +x_244 = x_273; +goto block_267; +} +else +{ +lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_274 = lean_ctor_get(x_270, 1); +lean_inc(x_274); +lean_dec(x_270); +lean_inc(x_242); +x_275 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_275, 0, x_242); +x_276 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_277 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_277, 0, x_276); +lean_ctor_set(x_277, 1, x_275); +x_278 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_269, x_277, x_2, x_274); +x_279 = lean_ctor_get(x_278, 1); +lean_inc(x_279); +lean_dec(x_278); +x_244 = x_279; +goto block_267; +} +} +block_267: +{ +lean_object* x_245; +lean_inc(x_2); +lean_inc(x_242); +x_245 = l_Lean_Meta_inferType(x_242, x_2, x_244); +if (lean_obj_tag(x_245) == 0) +{ +lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_246 = lean_ctor_get(x_245, 0); +lean_inc(x_246); +x_247 = lean_ctor_get(x_245, 1); +lean_inc(x_247); +lean_dec(x_245); +x_248 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_248, 0, x_5); +lean_ctor_set(x_248, 1, x_6); +lean_ctor_set(x_248, 2, x_7); +lean_ctor_set(x_248, 3, x_8); +lean_ctor_set(x_248, 4, x_9); +lean_inc(x_25); +x_249 = l_Lean_Meta_isExprDefEq(x_25, x_246, x_248, x_247); +if (lean_obj_tag(x_249) == 0) +{ +lean_object* x_250; uint8_t x_251; +x_250 = lean_ctor_get(x_249, 0); +lean_inc(x_250); +x_251 = lean_unbox(x_250); +lean_dec(x_250); +if (x_251 == 0) +{ +lean_object* x_252; lean_object* x_253; +lean_dec(x_243); +lean_dec(x_242); +lean_dec(x_2); +x_252 = lean_ctor_get(x_249, 1); +lean_inc(x_252); +lean_dec(x_249); +x_253 = lean_box(0); +x_28 = x_253; +x_29 = x_252; +goto block_60; +} +else +{ +lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +x_254 = lean_ctor_get(x_249, 1); +lean_inc(x_254); +lean_dec(x_249); +x_255 = l_Lean_Meta_instantiateMVars(x_242, x_2, x_254); +lean_dec(x_2); +x_256 = lean_ctor_get(x_255, 0); +lean_inc(x_256); +x_257 = lean_ctor_get(x_255, 1); +lean_inc(x_257); +lean_dec(x_255); +if (lean_is_scalar(x_243)) { + x_258 = lean_alloc_ctor(1, 1, 0); +} else { + x_258 = x_243; +} +lean_ctor_set(x_258, 0, x_256); +x_28 = x_258; +x_29 = x_257; +goto block_60; +} +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; +lean_dec(x_243); +lean_dec(x_242); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +x_259 = lean_ctor_get(x_249, 0); +lean_inc(x_259); +x_260 = lean_ctor_get(x_249, 1); +lean_inc(x_260); +if (lean_is_exclusive(x_249)) { + lean_ctor_release(x_249, 0); + lean_ctor_release(x_249, 1); + x_261 = x_249; +} else { + lean_dec_ref(x_249); + x_261 = lean_box(0); +} +if (lean_is_scalar(x_261)) { + x_262 = lean_alloc_ctor(1, 2, 0); +} else { + x_262 = x_261; +} +lean_ctor_set(x_262, 0, x_259); +lean_ctor_set(x_262, 1, x_260); +return x_262; +} +} +else +{ +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; +lean_dec(x_243); +lean_dec(x_242); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_263 = lean_ctor_get(x_245, 0); +lean_inc(x_263); +x_264 = lean_ctor_get(x_245, 1); +lean_inc(x_264); +if (lean_is_exclusive(x_245)) { + lean_ctor_release(x_245, 0); + lean_ctor_release(x_245, 1); + x_265 = x_245; +} else { + lean_dec_ref(x_245); + x_265 = lean_box(0); +} +if (lean_is_scalar(x_265)) { + x_266 = lean_alloc_ctor(1, 2, 0); +} else { + x_266 = x_265; +} +lean_ctor_set(x_266, 0, x_263); +lean_ctor_set(x_266, 1, x_264); +return x_266; +} +} +} +} +block_291: +{ +lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; +x_283 = lean_ctor_get(x_282, 0); +lean_inc(x_283); +x_284 = lean_ctor_get(x_282, 2); +lean_inc(x_284); +x_285 = lean_ctor_get(x_282, 3); +lean_inc(x_285); +x_286 = lean_ctor_get(x_282, 4); +lean_inc(x_286); +x_287 = lean_ctor_get(x_282, 5); +lean_inc(x_287); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + lean_ctor_release(x_282, 2); + lean_ctor_release(x_282, 3); + lean_ctor_release(x_282, 4); + lean_ctor_release(x_282, 5); + x_288 = x_282; +} else { + lean_dec_ref(x_282); + x_288 = lean_box(0); +} +if (lean_is_scalar(x_288)) { + x_289 = lean_alloc_ctor(0, 6, 0); +} else { + x_289 = x_288; +} +lean_ctor_set(x_289, 0, x_283); +lean_ctor_set(x_289, 1, x_62); +lean_ctor_set(x_289, 2, x_284); +lean_ctor_set(x_289, 3, x_285); +lean_ctor_set(x_289, 4, x_286); +lean_ctor_set(x_289, 5, x_287); +if (lean_is_scalar(x_22)) { + x_290 = lean_alloc_ctor(1, 2, 0); +} else { + x_290 = x_22; + lean_ctor_set_tag(x_290, 1); +} +lean_ctor_set(x_290, 0, x_281); +lean_ctor_set(x_290, 1, x_289); +return x_290; +} +} +} +else +{ +lean_object* x_349; lean_object* x_350; +lean_dec(x_66); +lean_dec(x_65); +lean_dec(x_64); +lean_dec(x_63); +lean_dec(x_62); +lean_dec(x_61); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +lean_dec(x_15); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_349 = lean_ctor_get(x_68, 0); +lean_inc(x_349); +lean_dec(x_68); +if (lean_is_scalar(x_22)) { + x_350 = lean_alloc_ctor(0, 2, 0); +} else { + x_350 = x_22; +} +lean_ctor_set(x_350, 0, x_349); +lean_ctor_set(x_350, 1, x_26); +return x_350; +} +block_60: { uint8_t x_30; x_30 = l_Lean_Expr_hasMVar(x_25); @@ -22597,107 +22597,114 @@ 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_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; x_37 = lean_ctor_get(x_32, 0); x_38 = lean_ctor_get(x_32, 1); x_39 = lean_ctor_get(x_32, 2); +x_40 = lean_ctor_get(x_32, 3); +lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_dec(x_32); lean_inc(x_28); -x_40 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_39, x_25, x_28); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_37); -lean_ctor_set(x_41, 1, x_38); -lean_ctor_set(x_41, 2, x_40); -lean_ctor_set(x_29, 2, x_41); +x_41 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_39, x_25, x_28); +x_42 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +lean_ctor_set(x_42, 3, x_40); +lean_ctor_set(x_29, 2, x_42); if (lean_is_scalar(x_27)) { - x_42 = lean_alloc_ctor(0, 2, 0); + x_43 = lean_alloc_ctor(0, 2, 0); } else { - x_42 = x_27; + x_43 = x_27; } -lean_ctor_set(x_42, 0, x_28); -lean_ctor_set(x_42, 1, x_29); -return x_42; +lean_ctor_set(x_43, 0, x_28); +lean_ctor_set(x_43, 1, x_29); +return x_43; } } 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; -x_43 = lean_ctor_get(x_29, 2); -x_44 = lean_ctor_get(x_29, 0); -x_45 = lean_ctor_get(x_29, 1); -x_46 = lean_ctor_get(x_29, 3); -x_47 = lean_ctor_get(x_29, 4); -x_48 = lean_ctor_get(x_29, 5); +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_44 = lean_ctor_get(x_29, 2); +x_45 = lean_ctor_get(x_29, 0); +x_46 = lean_ctor_get(x_29, 1); +x_47 = lean_ctor_get(x_29, 3); +x_48 = lean_ctor_get(x_29, 4); +x_49 = lean_ctor_get(x_29, 5); +lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); -lean_inc(x_46); -lean_inc(x_43); -lean_inc(x_45); lean_inc(x_44); +lean_inc(x_46); +lean_inc(x_45); lean_dec(x_29); -x_49 = lean_ctor_get(x_43, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_43, 1); +x_50 = lean_ctor_get(x_44, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_43, 2); +x_51 = lean_ctor_get(x_44, 1); lean_inc(x_51); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - lean_ctor_release(x_43, 2); - x_52 = x_43; +x_52 = lean_ctor_get(x_44, 2); +lean_inc(x_52); +x_53 = lean_ctor_get(x_44, 3); +lean_inc(x_53); +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + lean_ctor_release(x_44, 2); + lean_ctor_release(x_44, 3); + x_54 = x_44; } else { - lean_dec_ref(x_43); - x_52 = lean_box(0); + lean_dec_ref(x_44); + x_54 = lean_box(0); } lean_inc(x_28); -x_53 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_51, x_25, x_28); -if (lean_is_scalar(x_52)) { - x_54 = lean_alloc_ctor(0, 3, 0); +x_55 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_52, x_25, x_28); +if (lean_is_scalar(x_54)) { + x_56 = lean_alloc_ctor(0, 4, 0); } else { - x_54 = x_52; + x_56 = x_54; } -lean_ctor_set(x_54, 0, x_49); -lean_ctor_set(x_54, 1, x_50); -lean_ctor_set(x_54, 2, x_53); -x_55 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_55, 0, x_44); -lean_ctor_set(x_55, 1, x_45); -lean_ctor_set(x_55, 2, x_54); -lean_ctor_set(x_55, 3, x_46); -lean_ctor_set(x_55, 4, x_47); -lean_ctor_set(x_55, 5, x_48); +lean_ctor_set(x_56, 0, x_50); +lean_ctor_set(x_56, 1, x_51); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_53); +x_57 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_57, 0, x_45); +lean_ctor_set(x_57, 1, x_46); +lean_ctor_set(x_57, 2, x_56); +lean_ctor_set(x_57, 3, x_47); +lean_ctor_set(x_57, 4, x_48); +lean_ctor_set(x_57, 5, x_49); if (lean_is_scalar(x_27)) { - x_56 = lean_alloc_ctor(0, 2, 0); + x_58 = lean_alloc_ctor(0, 2, 0); } else { - x_56 = x_27; + x_58 = x_27; } -lean_ctor_set(x_56, 0, x_28); -lean_ctor_set(x_56, 1, x_55); -return x_56; +lean_ctor_set(x_58, 0, x_28); +lean_ctor_set(x_58, 1, x_57); +return x_58; } } else { -lean_object* x_57; +lean_object* x_59; lean_dec(x_25); if (lean_is_scalar(x_27)) { - x_57 = lean_alloc_ctor(0, 2, 0); + x_59 = lean_alloc_ctor(0, 2, 0); } else { - x_57 = x_27; + x_59 = x_27; } -lean_ctor_set(x_57, 0, x_28); -lean_ctor_set(x_57, 1, x_29); -return x_57; +lean_ctor_set(x_59, 0, x_28); +lean_ctor_set(x_59, 1, x_29); +return x_59; } } } else { -uint8_t x_349; +uint8_t x_351; lean_dec(x_22); lean_dec(x_2); lean_dec(x_15); @@ -22706,821 +22713,825 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_349 = !lean_is_exclusive(x_24); -if (x_349 == 0) +x_351 = !lean_is_exclusive(x_24); +if (x_351 == 0) { return x_24; } else { -lean_object* x_350; lean_object* x_351; lean_object* x_352; -x_350 = lean_ctor_get(x_24, 0); -x_351 = lean_ctor_get(x_24, 1); -lean_inc(x_351); -lean_inc(x_350); +lean_object* x_352; lean_object* x_353; lean_object* x_354; +x_352 = lean_ctor_get(x_24, 0); +x_353 = lean_ctor_get(x_24, 1); +lean_inc(x_353); +lean_inc(x_352); lean_dec(x_24); -x_352 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_352, 0, x_350); -lean_ctor_set(x_352, 1, x_351); -return x_352; +x_354 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_354, 0, x_352); +lean_ctor_set(x_354, 1, x_353); +return x_354; } } } 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; uint8_t x_359; uint8_t x_360; uint8_t x_361; uint8_t x_362; lean_object* x_363; uint8_t x_364; uint8_t 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_353 = lean_ctor_get(x_2, 0); -x_354 = lean_ctor_get(x_2, 1); -x_355 = lean_ctor_get(x_2, 2); -x_356 = lean_ctor_get(x_2, 3); -x_357 = lean_ctor_get(x_2, 4); -lean_inc(x_357); -lean_inc(x_356); -lean_inc(x_355); -lean_inc(x_354); -lean_inc(x_353); -lean_dec(x_2); -x_358 = lean_ctor_get(x_353, 0); +lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; uint8_t x_361; uint8_t x_362; uint8_t x_363; uint8_t x_364; lean_object* x_365; uint8_t x_366; uint8_t x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; +x_355 = lean_ctor_get(x_2, 0); +x_356 = lean_ctor_get(x_2, 1); +x_357 = lean_ctor_get(x_2, 2); +x_358 = lean_ctor_get(x_2, 3); +x_359 = lean_ctor_get(x_2, 4); +lean_inc(x_359); lean_inc(x_358); -x_359 = lean_ctor_get_uint8(x_353, sizeof(void*)*1 + 2); -x_360 = lean_ctor_get_uint8(x_353, sizeof(void*)*1 + 3); -x_361 = lean_ctor_get_uint8(x_353, sizeof(void*)*1 + 4); -x_362 = lean_ctor_get_uint8(x_353, sizeof(void*)*1 + 5); -x_363 = l___private_Init_Lean_Meta_SynthInstance_6__getMaxSteps(x_358); -x_364 = 1; -x_365 = 2; -x_366 = lean_alloc_ctor(0, 1, 7); -lean_ctor_set(x_366, 0, x_358); -lean_ctor_set_uint8(x_366, sizeof(void*)*1, x_364); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 1, x_364); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 2, x_359); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 3, x_360); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 4, x_361); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 5, x_362); -lean_ctor_set_uint8(x_366, sizeof(void*)*1 + 6, x_365); lean_inc(x_357); lean_inc(x_356); lean_inc(x_355); -lean_inc(x_354); -x_367 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_367, 0, x_366); -lean_ctor_set(x_367, 1, x_354); -lean_ctor_set(x_367, 2, x_355); -lean_ctor_set(x_367, 3, x_356); -lean_ctor_set(x_367, 4, x_357); -x_368 = l_Lean_Meta_instantiateMVars(x_1, x_367, x_3); -x_369 = lean_ctor_get(x_368, 0); +lean_dec(x_2); +x_360 = lean_ctor_get(x_355, 0); +lean_inc(x_360); +x_361 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 2); +x_362 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 3); +x_363 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 4); +x_364 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 5); +x_365 = l___private_Init_Lean_Meta_SynthInstance_6__getMaxSteps(x_360); +x_366 = 1; +x_367 = 2; +x_368 = lean_alloc_ctor(0, 1, 7); +lean_ctor_set(x_368, 0, x_360); +lean_ctor_set_uint8(x_368, sizeof(void*)*1, x_366); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 1, x_366); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 2, x_361); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 3, x_362); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 4, x_363); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 5, x_364); +lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 6, x_367); +lean_inc(x_359); +lean_inc(x_358); +lean_inc(x_357); +lean_inc(x_356); +x_369 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_369, 0, x_368); +lean_ctor_set(x_369, 1, x_356); +lean_ctor_set(x_369, 2, x_357); +lean_ctor_set(x_369, 3, x_358); +lean_ctor_set(x_369, 4, x_359); +x_370 = l_Lean_Meta_instantiateMVars(x_1, x_369, x_3); +x_371 = lean_ctor_get(x_370, 0); +lean_inc(x_371); +x_372 = lean_ctor_get(x_370, 1); +lean_inc(x_372); +if (lean_is_exclusive(x_370)) { + lean_ctor_release(x_370, 0); + lean_ctor_release(x_370, 1); + x_373 = x_370; +} else { + lean_dec_ref(x_370); + x_373 = lean_box(0); +} +x_374 = l___private_Init_Lean_Meta_SynthInstance_2__preprocess___closed__1; lean_inc(x_369); -x_370 = lean_ctor_get(x_368, 1); -lean_inc(x_370); -if (lean_is_exclusive(x_368)) { - lean_ctor_release(x_368, 0); - lean_ctor_release(x_368, 1); - x_371 = x_368; -} else { - lean_dec_ref(x_368); - x_371 = lean_box(0); -} -x_372 = l___private_Init_Lean_Meta_SynthInstance_2__preprocess___closed__1; -lean_inc(x_367); -x_373 = l_Lean_Meta_forallTelescopeReducing___rarg(x_369, x_372, x_367, x_370); -if (lean_obj_tag(x_373) == 0) +x_375 = l_Lean_Meta_forallTelescopeReducing___rarg(x_371, x_374, x_369, x_372); +if (lean_obj_tag(x_375) == 0) { -lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; 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; -x_374 = lean_ctor_get(x_373, 0); -lean_inc(x_374); -x_375 = lean_ctor_get(x_373, 1); -lean_inc(x_375); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_376 = x_373; -} else { - lean_dec_ref(x_373); - x_376 = lean_box(0); -} -x_397 = lean_ctor_get(x_375, 0); -lean_inc(x_397); -x_398 = lean_ctor_get(x_375, 1); -lean_inc(x_398); -x_399 = lean_ctor_get(x_375, 2); -lean_inc(x_399); -x_400 = lean_ctor_get(x_375, 3); -lean_inc(x_400); -x_401 = lean_ctor_get(x_375, 4); -lean_inc(x_401); -x_402 = lean_ctor_get(x_375, 5); -lean_inc(x_402); -x_403 = lean_ctor_get(x_399, 2); -lean_inc(x_403); -x_404 = l_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_403, x_374); -if (lean_obj_tag(x_404) == 0) -{ -lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_454; lean_object* x_455; lean_object* x_465; lean_object* x_466; lean_object* x_467; +lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; +x_376 = lean_ctor_get(x_375, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_375, 1); +lean_inc(x_377); if (lean_is_exclusive(x_375)) { lean_ctor_release(x_375, 0); lean_ctor_release(x_375, 1); - 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_405 = x_375; + x_378 = x_375; } else { lean_dec_ref(x_375); - x_405 = lean_box(0); + x_378 = lean_box(0); } -lean_inc(x_398); -x_465 = l_Lean_MetavarContext_incDepth(x_398); -if (lean_is_scalar(x_405)) { - x_466 = lean_alloc_ctor(0, 6, 0); +x_400 = lean_ctor_get(x_377, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_377, 1); +lean_inc(x_401); +x_402 = lean_ctor_get(x_377, 2); +lean_inc(x_402); +x_403 = lean_ctor_get(x_377, 3); +lean_inc(x_403); +x_404 = lean_ctor_get(x_377, 4); +lean_inc(x_404); +x_405 = lean_ctor_get(x_377, 5); +lean_inc(x_405); +x_406 = lean_ctor_get(x_402, 2); +lean_inc(x_406); +x_407 = l_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_406, x_376); +if (lean_obj_tag(x_407) == 0) +{ +lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_457; lean_object* x_458; lean_object* x_468; lean_object* x_469; lean_object* x_470; +if (lean_is_exclusive(x_377)) { + lean_ctor_release(x_377, 0); + lean_ctor_release(x_377, 1); + lean_ctor_release(x_377, 2); + lean_ctor_release(x_377, 3); + lean_ctor_release(x_377, 4); + lean_ctor_release(x_377, 5); + x_408 = x_377; } else { - x_466 = x_405; + lean_dec_ref(x_377); + x_408 = lean_box(0); } -lean_ctor_set(x_466, 0, x_397); -lean_ctor_set(x_466, 1, x_465); -lean_ctor_set(x_466, 2, x_399); -lean_ctor_set(x_466, 3, x_400); -lean_ctor_set(x_466, 4, x_401); -lean_ctor_set(x_466, 5, x_402); -lean_inc(x_367); -lean_inc(x_374); -x_467 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_374, x_367, x_466); -if (lean_obj_tag(x_467) == 0) -{ -lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_505; uint8_t x_506; -x_468 = lean_ctor_get(x_467, 0); -lean_inc(x_468); -x_469 = lean_ctor_get(x_467, 1); -lean_inc(x_469); -lean_dec(x_467); -x_505 = lean_ctor_get(x_469, 4); -lean_inc(x_505); -x_506 = lean_ctor_get_uint8(x_505, sizeof(void*)*1); -lean_dec(x_505); -if (x_506 == 0) -{ -x_470 = x_469; -goto block_504; +lean_inc(x_401); +x_468 = l_Lean_MetavarContext_incDepth(x_401); +if (lean_is_scalar(x_408)) { + x_469 = lean_alloc_ctor(0, 6, 0); +} else { + x_469 = x_408; } -else +lean_ctor_set(x_469, 0, x_400); +lean_ctor_set(x_469, 1, x_468); +lean_ctor_set(x_469, 2, x_402); +lean_ctor_set(x_469, 3, x_403); +lean_ctor_set(x_469, 4, x_404); +lean_ctor_set(x_469, 5, x_405); +lean_inc(x_369); +lean_inc(x_376); +x_470 = l___private_Init_Lean_Meta_SynthInstance_5__preprocessOutParam(x_376, x_369, x_469); +if (lean_obj_tag(x_470) == 0) { -lean_object* x_507; lean_object* x_508; lean_object* x_509; uint8_t x_510; -x_507 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_508 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_507, x_367, x_469); -x_509 = lean_ctor_get(x_508, 0); -lean_inc(x_509); -x_510 = lean_unbox(x_509); -lean_dec(x_509); -if (x_510 == 0) -{ -lean_object* x_511; -x_511 = lean_ctor_get(x_508, 1); -lean_inc(x_511); -lean_dec(x_508); -x_470 = x_511; -goto block_504; -} -else -{ -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_512 = lean_ctor_get(x_508, 1); -lean_inc(x_512); -lean_dec(x_508); -lean_inc(x_374); -x_513 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_513, 0, x_374); -x_514 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_515 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_515, 0, x_513); -lean_ctor_set(x_515, 1, x_514); -lean_inc(x_468); -x_516 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_516, 0, x_468); -x_517 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_517, 0, x_515); -lean_ctor_set(x_517, 1, x_516); -x_518 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_507, x_517, x_367, x_512); -x_519 = lean_ctor_get(x_518, 1); -lean_inc(x_519); -lean_dec(x_518); -x_470 = x_519; -goto block_504; -} -} -block_504: -{ -lean_object* x_471; -lean_inc(x_367); -x_471 = l_Lean_Meta_SynthInstance_main(x_468, x_363, x_367, x_470); -if (lean_obj_tag(x_471) == 0) -{ -lean_object* x_472; -lean_dec(x_371); -x_472 = lean_ctor_get(x_471, 0); +lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_508; uint8_t x_509; +x_471 = lean_ctor_get(x_470, 0); +lean_inc(x_471); +x_472 = lean_ctor_get(x_470, 1); lean_inc(x_472); -if (lean_obj_tag(x_472) == 0) +lean_dec(x_470); +x_508 = lean_ctor_get(x_472, 4); +lean_inc(x_508); +x_509 = lean_ctor_get_uint8(x_508, sizeof(void*)*1); +lean_dec(x_508); +if (x_509 == 0) { -lean_object* x_473; -x_473 = lean_ctor_get(x_471, 1); -lean_inc(x_473); -lean_dec(x_471); -x_406 = x_472; -x_407 = x_473; -goto block_453; +x_473 = x_472; +goto block_507; } else { -lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_489; uint8_t x_490; -x_474 = lean_ctor_get(x_471, 1); -lean_inc(x_474); -lean_dec(x_471); -x_475 = lean_ctor_get(x_472, 0); +lean_object* x_510; lean_object* x_511; lean_object* x_512; uint8_t x_513; +x_510 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_511 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_510, x_369, x_472); +x_512 = lean_ctor_get(x_511, 0); +lean_inc(x_512); +x_513 = lean_unbox(x_512); +lean_dec(x_512); +if (x_513 == 0) +{ +lean_object* x_514; +x_514 = lean_ctor_get(x_511, 1); +lean_inc(x_514); +lean_dec(x_511); +x_473 = x_514; +goto block_507; +} +else +{ +lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; +x_515 = lean_ctor_get(x_511, 1); +lean_inc(x_515); +lean_dec(x_511); +lean_inc(x_376); +x_516 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_516, 0, x_376); +x_517 = l_Lean_Meta_synthInstance_x3f___closed__9; +x_518 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_518, 0, x_516); +lean_ctor_set(x_518, 1, x_517); +lean_inc(x_471); +x_519 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_519, 0, x_471); +x_520 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_520, 0, x_518); +lean_ctor_set(x_520, 1, x_519); +x_521 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_510, x_520, x_369, x_515); +x_522 = lean_ctor_get(x_521, 1); +lean_inc(x_522); +lean_dec(x_521); +x_473 = x_522; +goto block_507; +} +} +block_507: +{ +lean_object* x_474; +lean_inc(x_369); +x_474 = l_Lean_Meta_SynthInstance_main(x_471, x_365, x_369, x_473); +if (lean_obj_tag(x_474) == 0) +{ +lean_object* x_475; +lean_dec(x_373); +x_475 = lean_ctor_get(x_474, 0); lean_inc(x_475); -if (lean_is_exclusive(x_472)) { - lean_ctor_release(x_472, 0); - x_476 = x_472; +if (lean_obj_tag(x_475) == 0) +{ +lean_object* x_476; +x_476 = lean_ctor_get(x_474, 1); +lean_inc(x_476); +lean_dec(x_474); +x_409 = x_475; +x_410 = x_476; +goto block_456; +} +else +{ +lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_492; uint8_t x_493; +x_477 = lean_ctor_get(x_474, 1); +lean_inc(x_477); +lean_dec(x_474); +x_478 = lean_ctor_get(x_475, 0); +lean_inc(x_478); +if (lean_is_exclusive(x_475)) { + lean_ctor_release(x_475, 0); + x_479 = x_475; } else { - lean_dec_ref(x_472); - x_476 = lean_box(0); + lean_dec_ref(x_475); + x_479 = lean_box(0); } -x_489 = lean_ctor_get(x_474, 4); -lean_inc(x_489); -x_490 = lean_ctor_get_uint8(x_489, sizeof(void*)*1); -lean_dec(x_489); -if (x_490 == 0) -{ -x_477 = x_474; -goto block_488; -} -else -{ -lean_object* x_491; lean_object* x_492; lean_object* x_493; uint8_t x_494; -x_491 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_492 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_491, x_367, x_474); -x_493 = lean_ctor_get(x_492, 0); -lean_inc(x_493); -x_494 = lean_unbox(x_493); -lean_dec(x_493); -if (x_494 == 0) -{ -lean_object* x_495; -x_495 = lean_ctor_get(x_492, 1); -lean_inc(x_495); +x_492 = lean_ctor_get(x_477, 4); +lean_inc(x_492); +x_493 = lean_ctor_get_uint8(x_492, sizeof(void*)*1); lean_dec(x_492); -x_477 = x_495; -goto block_488; +if (x_493 == 0) +{ +x_480 = x_477; +goto block_491; } 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; -x_496 = lean_ctor_get(x_492, 1); +lean_object* x_494; lean_object* x_495; lean_object* x_496; uint8_t x_497; +x_494 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_495 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_494, x_369, x_477); +x_496 = lean_ctor_get(x_495, 0); lean_inc(x_496); -lean_dec(x_492); -lean_inc(x_475); -x_497 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_497, 0, x_475); -x_498 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_499 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_499, 0, x_498); -lean_ctor_set(x_499, 1, x_497); -x_500 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_491, x_499, x_367, x_496); -x_501 = lean_ctor_get(x_500, 1); -lean_inc(x_501); -lean_dec(x_500); -x_477 = x_501; -goto block_488; -} -} -block_488: +x_497 = lean_unbox(x_496); +lean_dec(x_496); +if (x_497 == 0) { -lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; uint8_t x_483; -x_478 = l_Lean_Meta_instantiateMVars(x_475, x_367, x_477); -x_479 = lean_ctor_get(x_478, 0); -lean_inc(x_479); -x_480 = lean_ctor_get(x_478, 1); -lean_inc(x_480); -lean_dec(x_478); -x_481 = l_Lean_Meta_hasAssignableMVar(x_479, x_367, x_480); +lean_object* x_498; +x_498 = lean_ctor_get(x_495, 1); +lean_inc(x_498); +lean_dec(x_495); +x_480 = x_498; +goto block_491; +} +else +{ +lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; +x_499 = lean_ctor_get(x_495, 1); +lean_inc(x_499); +lean_dec(x_495); +lean_inc(x_478); +x_500 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_500, 0, x_478); +x_501 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_502 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_502, 0, x_501); +lean_ctor_set(x_502, 1, x_500); +x_503 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_494, x_502, x_369, x_499); +x_504 = lean_ctor_get(x_503, 1); +lean_inc(x_504); +lean_dec(x_503); +x_480 = x_504; +goto block_491; +} +} +block_491: +{ +lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; uint8_t x_486; +x_481 = l_Lean_Meta_instantiateMVars(x_478, x_369, x_480); x_482 = lean_ctor_get(x_481, 0); lean_inc(x_482); -x_483 = lean_unbox(x_482); +x_483 = lean_ctor_get(x_481, 1); +lean_inc(x_483); +lean_dec(x_481); +x_484 = l_Lean_Meta_hasAssignableMVar(x_482, x_369, x_483); +x_485 = lean_ctor_get(x_484, 0); +lean_inc(x_485); +x_486 = lean_unbox(x_485); +lean_dec(x_485); +if (x_486 == 0) +{ +lean_object* x_487; lean_object* x_488; +x_487 = lean_ctor_get(x_484, 1); +lean_inc(x_487); +lean_dec(x_484); +if (lean_is_scalar(x_479)) { + x_488 = lean_alloc_ctor(1, 1, 0); +} else { + x_488 = x_479; +} +lean_ctor_set(x_488, 0, x_482); +x_409 = x_488; +x_410 = x_487; +goto block_456; +} +else +{ +lean_object* x_489; lean_object* x_490; lean_dec(x_482); -if (x_483 == 0) -{ -lean_object* x_484; lean_object* x_485; -x_484 = lean_ctor_get(x_481, 1); -lean_inc(x_484); -lean_dec(x_481); -if (lean_is_scalar(x_476)) { - x_485 = lean_alloc_ctor(1, 1, 0); -} else { - x_485 = x_476; -} -lean_ctor_set(x_485, 0, x_479); -x_406 = x_485; -x_407 = x_484; -goto block_453; -} -else -{ -lean_object* x_486; lean_object* x_487; lean_dec(x_479); -lean_dec(x_476); -x_486 = lean_ctor_get(x_481, 1); -lean_inc(x_486); -lean_dec(x_481); -x_487 = lean_box(0); -x_406 = x_487; -x_407 = x_486; -goto block_453; +x_489 = lean_ctor_get(x_484, 1); +lean_inc(x_489); +lean_dec(x_484); +x_490 = lean_box(0); +x_409 = x_490; +x_410 = x_489; +goto block_456; } } } } else { -lean_object* x_502; lean_object* x_503; +lean_object* x_505; lean_object* x_506; +lean_dec(x_378); lean_dec(x_376); -lean_dec(x_374); -lean_dec(x_367); +lean_dec(x_369); +lean_dec(x_359); +lean_dec(x_358); lean_dec(x_357); lean_dec(x_356); lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_502 = lean_ctor_get(x_471, 0); -lean_inc(x_502); -x_503 = lean_ctor_get(x_471, 1); -lean_inc(x_503); -lean_dec(x_471); -x_454 = x_502; -x_455 = x_503; -goto block_464; +x_505 = lean_ctor_get(x_474, 0); +lean_inc(x_505); +x_506 = lean_ctor_get(x_474, 1); +lean_inc(x_506); +lean_dec(x_474); +x_457 = x_505; +x_458 = x_506; +goto block_467; } } } else { -lean_object* x_520; lean_object* x_521; +lean_object* x_523; lean_object* x_524; +lean_dec(x_378); lean_dec(x_376); -lean_dec(x_374); -lean_dec(x_367); -lean_dec(x_363); +lean_dec(x_369); +lean_dec(x_365); +lean_dec(x_359); +lean_dec(x_358); lean_dec(x_357); lean_dec(x_356); lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_520 = lean_ctor_get(x_467, 0); -lean_inc(x_520); -x_521 = lean_ctor_get(x_467, 1); -lean_inc(x_521); -lean_dec(x_467); -x_454 = x_520; -x_455 = x_521; -goto block_464; +x_523 = lean_ctor_get(x_470, 0); +lean_inc(x_523); +x_524 = lean_ctor_get(x_470, 1); +lean_inc(x_524); +lean_dec(x_470); +x_457 = x_523; +x_458 = x_524; +goto block_467; } -block_453: +block_456: { -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_408 = lean_ctor_get(x_407, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_407, 2); -lean_inc(x_409); -x_410 = lean_ctor_get(x_407, 3); -lean_inc(x_410); -x_411 = lean_ctor_get(x_407, 4); +lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; +x_411 = lean_ctor_get(x_410, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_407, 5); +x_412 = lean_ctor_get(x_410, 2); lean_inc(x_412); -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_413 = x_407; -} else { - lean_dec_ref(x_407); - x_413 = lean_box(0); -} -lean_inc(x_411); -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 6, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_408); -lean_ctor_set(x_414, 1, x_398); -lean_ctor_set(x_414, 2, x_409); -lean_ctor_set(x_414, 3, x_410); -lean_ctor_set(x_414, 4, x_411); -lean_ctor_set(x_414, 5, x_412); -if (lean_obj_tag(x_406) == 0) -{ -lean_dec(x_411); -lean_dec(x_367); -lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_377 = x_406; -x_378 = x_414; -goto block_396; -} -else -{ -lean_object* x_415; lean_object* x_416; lean_object* x_417; uint8_t x_441; -x_415 = lean_ctor_get(x_406, 0); +x_413 = lean_ctor_get(x_410, 3); +lean_inc(x_413); +x_414 = lean_ctor_get(x_410, 4); +lean_inc(x_414); +x_415 = lean_ctor_get(x_410, 5); lean_inc(x_415); -if (lean_is_exclusive(x_406)) { - lean_ctor_release(x_406, 0); - x_416 = x_406; +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + lean_ctor_release(x_410, 5); + x_416 = x_410; } else { - lean_dec_ref(x_406); + lean_dec_ref(x_410); x_416 = lean_box(0); } -x_441 = lean_ctor_get_uint8(x_411, sizeof(void*)*1); -lean_dec(x_411); -if (x_441 == 0) -{ -x_417 = x_414; -goto block_440; -} -else -{ -lean_object* x_442; lean_object* x_443; lean_object* x_444; uint8_t x_445; -x_442 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_443 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_442, x_367, x_414); -x_444 = lean_ctor_get(x_443, 0); -lean_inc(x_444); -x_445 = lean_unbox(x_444); -lean_dec(x_444); -if (x_445 == 0) -{ -lean_object* x_446; -x_446 = lean_ctor_get(x_443, 1); -lean_inc(x_446); -lean_dec(x_443); -x_417 = x_446; -goto block_440; -} -else -{ -lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; -x_447 = lean_ctor_get(x_443, 1); -lean_inc(x_447); -lean_dec(x_443); -lean_inc(x_415); -x_448 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_448, 0, x_415); -x_449 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_450 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_450, 0, x_449); -lean_ctor_set(x_450, 1, x_448); -x_451 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_442, x_450, x_367, x_447); -x_452 = lean_ctor_get(x_451, 1); -lean_inc(x_452); -lean_dec(x_451); -x_417 = x_452; -goto block_440; -} -} -block_440: -{ -lean_object* x_418; -lean_inc(x_367); -lean_inc(x_415); -x_418 = l_Lean_Meta_inferType(x_415, x_367, x_417); -if (lean_obj_tag(x_418) == 0) -{ -lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; -x_419 = lean_ctor_get(x_418, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_418, 1); -lean_inc(x_420); -lean_dec(x_418); -x_421 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_421, 0, x_353); -lean_ctor_set(x_421, 1, x_354); -lean_ctor_set(x_421, 2, x_355); -lean_ctor_set(x_421, 3, x_356); -lean_ctor_set(x_421, 4, x_357); -lean_inc(x_374); -x_422 = l_Lean_Meta_isExprDefEq(x_374, x_419, x_421, x_420); -if (lean_obj_tag(x_422) == 0) -{ -lean_object* x_423; uint8_t x_424; -x_423 = lean_ctor_get(x_422, 0); -lean_inc(x_423); -x_424 = lean_unbox(x_423); -lean_dec(x_423); -if (x_424 == 0) -{ -lean_object* x_425; lean_object* x_426; -lean_dec(x_416); -lean_dec(x_415); -lean_dec(x_367); -x_425 = lean_ctor_get(x_422, 1); -lean_inc(x_425); -lean_dec(x_422); -x_426 = lean_box(0); -x_377 = x_426; -x_378 = x_425; -goto block_396; -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_427 = lean_ctor_get(x_422, 1); -lean_inc(x_427); -lean_dec(x_422); -x_428 = l_Lean_Meta_instantiateMVars(x_415, x_367, x_427); -lean_dec(x_367); -x_429 = lean_ctor_get(x_428, 0); -lean_inc(x_429); -x_430 = lean_ctor_get(x_428, 1); -lean_inc(x_430); -lean_dec(x_428); +lean_inc(x_414); if (lean_is_scalar(x_416)) { - x_431 = lean_alloc_ctor(1, 1, 0); + x_417 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_416; + x_417 = x_416; } -lean_ctor_set(x_431, 0, x_429); -x_377 = x_431; -x_378 = x_430; -goto block_396; -} -} -else +lean_ctor_set(x_417, 0, x_411); +lean_ctor_set(x_417, 1, x_401); +lean_ctor_set(x_417, 2, x_412); +lean_ctor_set(x_417, 3, x_413); +lean_ctor_set(x_417, 4, x_414); +lean_ctor_set(x_417, 5, x_415); +if (lean_obj_tag(x_409) == 0) { -lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -lean_dec(x_416); -lean_dec(x_415); -lean_dec(x_376); -lean_dec(x_374); -lean_dec(x_367); -x_432 = lean_ctor_get(x_422, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_422, 1); -lean_inc(x_433); -if (lean_is_exclusive(x_422)) { - lean_ctor_release(x_422, 0); - lean_ctor_release(x_422, 1); - x_434 = x_422; -} else { - lean_dec_ref(x_422); - x_434 = lean_box(0); -} -if (lean_is_scalar(x_434)) { - x_435 = lean_alloc_ctor(1, 2, 0); -} else { - x_435 = x_434; -} -lean_ctor_set(x_435, 0, x_432); -lean_ctor_set(x_435, 1, x_433); -return x_435; -} -} -else -{ -lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; -lean_dec(x_416); -lean_dec(x_415); -lean_dec(x_376); -lean_dec(x_374); -lean_dec(x_367); +lean_dec(x_414); +lean_dec(x_369); +lean_dec(x_359); +lean_dec(x_358); lean_dec(x_357); lean_dec(x_356); lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_436 = lean_ctor_get(x_418, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_418, 1); -lean_inc(x_437); -if (lean_is_exclusive(x_418)) { - lean_ctor_release(x_418, 0); - lean_ctor_release(x_418, 1); - x_438 = x_418; -} else { - lean_dec_ref(x_418); - x_438 = lean_box(0); +x_379 = x_409; +x_380 = x_417; +goto block_399; } -if (lean_is_scalar(x_438)) { - x_439 = lean_alloc_ctor(1, 2, 0); -} else { - x_439 = x_438; -} -lean_ctor_set(x_439, 0, x_436); -lean_ctor_set(x_439, 1, x_437); -return x_439; -} -} -} -} -block_464: +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; -x_456 = lean_ctor_get(x_455, 0); -lean_inc(x_456); -x_457 = lean_ctor_get(x_455, 2); -lean_inc(x_457); -x_458 = lean_ctor_get(x_455, 3); -lean_inc(x_458); -x_459 = lean_ctor_get(x_455, 4); -lean_inc(x_459); -x_460 = lean_ctor_get(x_455, 5); -lean_inc(x_460); -if (lean_is_exclusive(x_455)) { - lean_ctor_release(x_455, 0); - lean_ctor_release(x_455, 1); - lean_ctor_release(x_455, 2); - lean_ctor_release(x_455, 3); - lean_ctor_release(x_455, 4); - lean_ctor_release(x_455, 5); - x_461 = x_455; +lean_object* x_418; lean_object* x_419; lean_object* x_420; uint8_t x_444; +x_418 = lean_ctor_get(x_409, 0); +lean_inc(x_418); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + x_419 = x_409; } else { - lean_dec_ref(x_455); - x_461 = lean_box(0); + lean_dec_ref(x_409); + x_419 = lean_box(0); } -if (lean_is_scalar(x_461)) { - x_462 = lean_alloc_ctor(0, 6, 0); +x_444 = lean_ctor_get_uint8(x_414, sizeof(void*)*1); +lean_dec(x_414); +if (x_444 == 0) +{ +x_420 = x_417; +goto block_443; +} +else +{ +lean_object* x_445; lean_object* x_446; lean_object* x_447; uint8_t x_448; +x_445 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_446 = l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_445, x_369, x_417); +x_447 = lean_ctor_get(x_446, 0); +lean_inc(x_447); +x_448 = lean_unbox(x_447); +lean_dec(x_447); +if (x_448 == 0) +{ +lean_object* x_449; +x_449 = lean_ctor_get(x_446, 1); +lean_inc(x_449); +lean_dec(x_446); +x_420 = x_449; +goto block_443; +} +else +{ +lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_450 = lean_ctor_get(x_446, 1); +lean_inc(x_450); +lean_dec(x_446); +lean_inc(x_418); +x_451 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_451, 0, x_418); +x_452 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_453 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_453, 0, x_452); +lean_ctor_set(x_453, 1, x_451); +x_454 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_445, x_453, x_369, x_450); +x_455 = lean_ctor_get(x_454, 1); +lean_inc(x_455); +lean_dec(x_454); +x_420 = x_455; +goto block_443; +} +} +block_443: +{ +lean_object* x_421; +lean_inc(x_369); +lean_inc(x_418); +x_421 = l_Lean_Meta_inferType(x_418, x_369, x_420); +if (lean_obj_tag(x_421) == 0) +{ +lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; +x_422 = lean_ctor_get(x_421, 0); +lean_inc(x_422); +x_423 = lean_ctor_get(x_421, 1); +lean_inc(x_423); +lean_dec(x_421); +x_424 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_424, 0, x_355); +lean_ctor_set(x_424, 1, x_356); +lean_ctor_set(x_424, 2, x_357); +lean_ctor_set(x_424, 3, x_358); +lean_ctor_set(x_424, 4, x_359); +lean_inc(x_376); +x_425 = l_Lean_Meta_isExprDefEq(x_376, x_422, x_424, x_423); +if (lean_obj_tag(x_425) == 0) +{ +lean_object* x_426; uint8_t x_427; +x_426 = lean_ctor_get(x_425, 0); +lean_inc(x_426); +x_427 = lean_unbox(x_426); +lean_dec(x_426); +if (x_427 == 0) +{ +lean_object* x_428; lean_object* x_429; +lean_dec(x_419); +lean_dec(x_418); +lean_dec(x_369); +x_428 = lean_ctor_get(x_425, 1); +lean_inc(x_428); +lean_dec(x_425); +x_429 = lean_box(0); +x_379 = x_429; +x_380 = x_428; +goto block_399; +} +else +{ +lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; +x_430 = lean_ctor_get(x_425, 1); +lean_inc(x_430); +lean_dec(x_425); +x_431 = l_Lean_Meta_instantiateMVars(x_418, x_369, x_430); +lean_dec(x_369); +x_432 = lean_ctor_get(x_431, 0); +lean_inc(x_432); +x_433 = lean_ctor_get(x_431, 1); +lean_inc(x_433); +lean_dec(x_431); +if (lean_is_scalar(x_419)) { + x_434 = lean_alloc_ctor(1, 1, 0); } else { - x_462 = x_461; + x_434 = x_419; } -lean_ctor_set(x_462, 0, x_456); -lean_ctor_set(x_462, 1, x_398); -lean_ctor_set(x_462, 2, x_457); -lean_ctor_set(x_462, 3, x_458); -lean_ctor_set(x_462, 4, x_459); -lean_ctor_set(x_462, 5, x_460); -if (lean_is_scalar(x_371)) { - x_463 = lean_alloc_ctor(1, 2, 0); -} else { - x_463 = x_371; - lean_ctor_set_tag(x_463, 1); -} -lean_ctor_set(x_463, 0, x_454); -lean_ctor_set(x_463, 1, x_462); -return x_463; +lean_ctor_set(x_434, 0, x_432); +x_379 = x_434; +x_380 = x_433; +goto block_399; } } else { -lean_object* x_522; lean_object* x_523; +lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; +lean_dec(x_419); +lean_dec(x_418); +lean_dec(x_378); +lean_dec(x_376); +lean_dec(x_369); +x_435 = lean_ctor_get(x_425, 0); +lean_inc(x_435); +x_436 = lean_ctor_get(x_425, 1); +lean_inc(x_436); +if (lean_is_exclusive(x_425)) { + lean_ctor_release(x_425, 0); + lean_ctor_release(x_425, 1); + x_437 = x_425; +} else { + lean_dec_ref(x_425); + x_437 = lean_box(0); +} +if (lean_is_scalar(x_437)) { + x_438 = lean_alloc_ctor(1, 2, 0); +} else { + x_438 = x_437; +} +lean_ctor_set(x_438, 0, x_435); +lean_ctor_set(x_438, 1, x_436); +return x_438; +} +} +else +{ +lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; +lean_dec(x_419); +lean_dec(x_418); +lean_dec(x_378); +lean_dec(x_376); +lean_dec(x_369); +lean_dec(x_359); +lean_dec(x_358); +lean_dec(x_357); +lean_dec(x_356); +lean_dec(x_355); +x_439 = lean_ctor_get(x_421, 0); +lean_inc(x_439); +x_440 = lean_ctor_get(x_421, 1); +lean_inc(x_440); +if (lean_is_exclusive(x_421)) { + lean_ctor_release(x_421, 0); + lean_ctor_release(x_421, 1); + x_441 = x_421; +} else { + lean_dec_ref(x_421); + x_441 = lean_box(0); +} +if (lean_is_scalar(x_441)) { + x_442 = lean_alloc_ctor(1, 2, 0); +} else { + x_442 = x_441; +} +lean_ctor_set(x_442, 0, x_439); +lean_ctor_set(x_442, 1, x_440); +return x_442; +} +} +} +} +block_467: +{ +lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_459 = lean_ctor_get(x_458, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_458, 2); +lean_inc(x_460); +x_461 = lean_ctor_get(x_458, 3); +lean_inc(x_461); +x_462 = lean_ctor_get(x_458, 4); +lean_inc(x_462); +x_463 = lean_ctor_get(x_458, 5); +lean_inc(x_463); +if (lean_is_exclusive(x_458)) { + lean_ctor_release(x_458, 0); + lean_ctor_release(x_458, 1); + lean_ctor_release(x_458, 2); + lean_ctor_release(x_458, 3); + lean_ctor_release(x_458, 4); + lean_ctor_release(x_458, 5); + x_464 = x_458; +} else { + lean_dec_ref(x_458); + x_464 = lean_box(0); +} +if (lean_is_scalar(x_464)) { + x_465 = lean_alloc_ctor(0, 6, 0); +} else { + x_465 = x_464; +} +lean_ctor_set(x_465, 0, x_459); +lean_ctor_set(x_465, 1, x_401); +lean_ctor_set(x_465, 2, x_460); +lean_ctor_set(x_465, 3, x_461); +lean_ctor_set(x_465, 4, x_462); +lean_ctor_set(x_465, 5, x_463); +if (lean_is_scalar(x_373)) { + x_466 = lean_alloc_ctor(1, 2, 0); +} else { + x_466 = x_373; + lean_ctor_set_tag(x_466, 1); +} +lean_ctor_set(x_466, 0, x_457); +lean_ctor_set(x_466, 1, x_465); +return x_466; +} +} +else +{ +lean_object* x_525; lean_object* x_526; +lean_dec(x_405); +lean_dec(x_404); +lean_dec(x_403); lean_dec(x_402); lean_dec(x_401); lean_dec(x_400); -lean_dec(x_399); -lean_dec(x_398); -lean_dec(x_397); +lean_dec(x_378); lean_dec(x_376); -lean_dec(x_374); -lean_dec(x_367); -lean_dec(x_363); +lean_dec(x_369); +lean_dec(x_365); +lean_dec(x_359); +lean_dec(x_358); lean_dec(x_357); lean_dec(x_356); lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_522 = lean_ctor_get(x_404, 0); -lean_inc(x_522); -lean_dec(x_404); -if (lean_is_scalar(x_371)) { - x_523 = lean_alloc_ctor(0, 2, 0); +x_525 = lean_ctor_get(x_407, 0); +lean_inc(x_525); +lean_dec(x_407); +if (lean_is_scalar(x_373)) { + x_526 = lean_alloc_ctor(0, 2, 0); } else { - x_523 = x_371; + x_526 = x_373; } -lean_ctor_set(x_523, 0, x_522); -lean_ctor_set(x_523, 1, x_375); -return x_523; +lean_ctor_set(x_526, 0, x_525); +lean_ctor_set(x_526, 1, x_377); +return x_526; } -block_396: +block_399: { -uint8_t x_379; -x_379 = l_Lean_Expr_hasMVar(x_374); -if (x_379 == 0) +uint8_t x_381; +x_381 = l_Lean_Expr_hasMVar(x_376); +if (x_381 == 0) { -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_380 = lean_ctor_get(x_378, 2); -lean_inc(x_380); -x_381 = lean_ctor_get(x_378, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_378, 1); +lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; +x_382 = lean_ctor_get(x_380, 2); lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 3); +x_383 = lean_ctor_get(x_380, 0); lean_inc(x_383); -x_384 = lean_ctor_get(x_378, 4); +x_384 = lean_ctor_get(x_380, 1); lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 5); +x_385 = lean_ctor_get(x_380, 3); 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); - lean_ctor_release(x_378, 5); - x_386 = x_378; -} else { - lean_dec_ref(x_378); - x_386 = lean_box(0); -} -x_387 = lean_ctor_get(x_380, 0); +x_386 = lean_ctor_get(x_380, 4); +lean_inc(x_386); +x_387 = lean_ctor_get(x_380, 5); 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); if (lean_is_exclusive(x_380)) { lean_ctor_release(x_380, 0); lean_ctor_release(x_380, 1); lean_ctor_release(x_380, 2); - x_390 = x_380; + lean_ctor_release(x_380, 3); + lean_ctor_release(x_380, 4); + lean_ctor_release(x_380, 5); + x_388 = x_380; } else { lean_dec_ref(x_380); - x_390 = lean_box(0); + x_388 = lean_box(0); } -lean_inc(x_377); -x_391 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_389, x_374, x_377); -if (lean_is_scalar(x_390)) { - x_392 = lean_alloc_ctor(0, 3, 0); +x_389 = lean_ctor_get(x_382, 0); +lean_inc(x_389); +x_390 = lean_ctor_get(x_382, 1); +lean_inc(x_390); +x_391 = lean_ctor_get(x_382, 2); +lean_inc(x_391); +x_392 = lean_ctor_get(x_382, 3); +lean_inc(x_392); +if (lean_is_exclusive(x_382)) { + lean_ctor_release(x_382, 0); + lean_ctor_release(x_382, 1); + lean_ctor_release(x_382, 2); + lean_ctor_release(x_382, 3); + x_393 = x_382; } else { - x_392 = x_390; + lean_dec_ref(x_382); + x_393 = lean_box(0); } -lean_ctor_set(x_392, 0, x_387); -lean_ctor_set(x_392, 1, x_388); -lean_ctor_set(x_392, 2, x_391); -if (lean_is_scalar(x_386)) { - x_393 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_379); +x_394 = l_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_391, x_376, x_379); +if (lean_is_scalar(x_393)) { + x_395 = lean_alloc_ctor(0, 4, 0); } else { - x_393 = x_386; + x_395 = x_393; } -lean_ctor_set(x_393, 0, x_381); -lean_ctor_set(x_393, 1, x_382); -lean_ctor_set(x_393, 2, x_392); -lean_ctor_set(x_393, 3, x_383); -lean_ctor_set(x_393, 4, x_384); -lean_ctor_set(x_393, 5, x_385); -if (lean_is_scalar(x_376)) { - x_394 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_395, 0, x_389); +lean_ctor_set(x_395, 1, x_390); +lean_ctor_set(x_395, 2, x_394); +lean_ctor_set(x_395, 3, x_392); +if (lean_is_scalar(x_388)) { + x_396 = lean_alloc_ctor(0, 6, 0); } else { - x_394 = x_376; + x_396 = x_388; } -lean_ctor_set(x_394, 0, x_377); -lean_ctor_set(x_394, 1, x_393); -return x_394; +lean_ctor_set(x_396, 0, x_383); +lean_ctor_set(x_396, 1, x_384); +lean_ctor_set(x_396, 2, x_395); +lean_ctor_set(x_396, 3, x_385); +lean_ctor_set(x_396, 4, x_386); +lean_ctor_set(x_396, 5, x_387); +if (lean_is_scalar(x_378)) { + x_397 = lean_alloc_ctor(0, 2, 0); +} else { + x_397 = x_378; +} +lean_ctor_set(x_397, 0, x_379); +lean_ctor_set(x_397, 1, x_396); +return x_397; } else { -lean_object* x_395; -lean_dec(x_374); -if (lean_is_scalar(x_376)) { - x_395 = lean_alloc_ctor(0, 2, 0); +lean_object* x_398; +lean_dec(x_376); +if (lean_is_scalar(x_378)) { + x_398 = lean_alloc_ctor(0, 2, 0); } else { - x_395 = x_376; + x_398 = x_378; } -lean_ctor_set(x_395, 0, x_377); -lean_ctor_set(x_395, 1, x_378); -return x_395; +lean_ctor_set(x_398, 0, x_379); +lean_ctor_set(x_398, 1, x_380); +return x_398; } } } else { -lean_object* x_524; lean_object* x_525; lean_object* x_526; lean_object* x_527; -lean_dec(x_371); -lean_dec(x_367); -lean_dec(x_363); +lean_object* x_527; lean_object* x_528; lean_object* x_529; lean_object* x_530; +lean_dec(x_373); +lean_dec(x_369); +lean_dec(x_365); +lean_dec(x_359); +lean_dec(x_358); lean_dec(x_357); lean_dec(x_356); lean_dec(x_355); -lean_dec(x_354); -lean_dec(x_353); -x_524 = lean_ctor_get(x_373, 0); -lean_inc(x_524); -x_525 = lean_ctor_get(x_373, 1); -lean_inc(x_525); -if (lean_is_exclusive(x_373)) { - lean_ctor_release(x_373, 0); - lean_ctor_release(x_373, 1); - x_526 = x_373; +x_527 = lean_ctor_get(x_375, 0); +lean_inc(x_527); +x_528 = lean_ctor_get(x_375, 1); +lean_inc(x_528); +if (lean_is_exclusive(x_375)) { + lean_ctor_release(x_375, 0); + lean_ctor_release(x_375, 1); + x_529 = x_375; } else { - lean_dec_ref(x_373); - x_526 = lean_box(0); + lean_dec_ref(x_375); + x_529 = lean_box(0); } -if (lean_is_scalar(x_526)) { - x_527 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_529)) { + x_530 = lean_alloc_ctor(1, 2, 0); } else { - x_527 = x_526; + x_530 = x_529; } -lean_ctor_set(x_527, 0, x_524); -lean_ctor_set(x_527, 1, x_525); -return x_527; +lean_ctor_set(x_530, 0, x_527); +lean_ctor_set(x_530, 1, x_528); +return x_530; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Cases.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Cases.c index 0ec264746b..200fbfcd07 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Cases.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Cases.c @@ -69,6 +69,7 @@ lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_Tactic_Ca uint8_t l_Lean_Expr_isApp(lean_object*); lean_object* l___private_Init_Lean_Meta_Tactic_Cases_2__withNewIndexEqsAux___main___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__8(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appFn_x21(lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); extern lean_object* l_Lean_Name_inhabited; @@ -78,6 +79,7 @@ extern lean_object* l_Lean_Expr_getAppArgs___closed__1; lean_object* l_PersistentArray_anyM___at___private_Init_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__42___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__35(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_9__unifyEqs___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); lean_object* l_Nat_anyAux___main___at___private_Init_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__3___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__2___boxed(lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -227,7 +229,6 @@ lean_object* l_Lean_Meta_checkNotAssigned(lean_object*, lean_object*, lean_objec lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); uint8_t lean_expr_eqv(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Tactic_Cases_3__withNewIndexEqs(lean_object*); -lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_Cases_cases___lambda__1___closed__4; uint8_t l_PersistentArray_anyM___at___private_Init_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); @@ -11133,180 +11134,200 @@ return x_19; } else { -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_20 = lean_unsigned_to_nat(0u); -x_21 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_20); -x_22 = lean_unsigned_to_nat(1u); -x_23 = lean_nat_sub(x_21, x_22); -x_24 = lean_nat_sub(x_23, x_22); -lean_dec(x_23); -x_25 = l_Lean_Expr_getRevArg_x21___main(x_10, x_24); -x_26 = lean_unsigned_to_nat(2u); -x_27 = lean_nat_sub(x_21, x_26); -lean_dec(x_21); -x_28 = lean_nat_sub(x_27, x_22); -lean_dec(x_27); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_10, x_28); +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_20 = l_Lean_Expr_appFn_x21(x_10); +x_21 = l_Lean_Expr_appArg_x21(x_20); +lean_dec(x_20); +x_22 = l_Lean_Expr_appArg_x21(x_10); lean_dec(x_10); lean_inc(x_8); +lean_inc(x_22); +lean_inc(x_21); +x_23 = l_Lean_Meta_isExprDefEq(x_21, x_22, x_8, x_9); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; uint8_t x_25; +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +x_25 = lean_unbox(x_24); +lean_dec(x_24); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_23, 1); +lean_inc(x_26); +lean_dec(x_23); +lean_inc(x_8); +x_27 = l_Lean_Meta_whnf(x_21, x_8, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +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_inc(x_25); -x_30 = l_Lean_Meta_isExprDefEq(x_25, x_29, x_8, x_9); +lean_dec(x_27); +lean_inc(x_8); +x_30 = l_Lean_Meta_whnf(x_22, x_8, x_29); if (lean_obj_tag(x_30) == 0) { -lean_object* x_31; uint8_t x_32; +lean_object* x_31; lean_object* x_32; lean_object* x_33; x_31 = lean_ctor_get(x_30, 0); lean_inc(x_31); -x_32 = lean_unbox(x_31); -lean_dec(x_31); -if (x_32 == 0) -{ -lean_object* x_33; lean_object* x_34; -x_33 = lean_ctor_get(x_30, 1); -lean_inc(x_33); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); lean_dec(x_30); -lean_inc(x_8); -x_34 = l_Lean_Meta_whnf(x_25, x_8, x_33); -if (lean_obj_tag(x_34) == 0) +if (lean_obj_tag(x_28) == 1) { -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); -lean_inc(x_8); -x_37 = l_Lean_Meta_whnf(x_29, x_8, x_36); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_37, 1); -lean_inc(x_39); -lean_dec(x_37); -if (lean_obj_tag(x_35) == 1) -{ -switch (lean_obj_tag(x_38)) { +switch (lean_obj_tag(x_31)) { case 0: { -uint8_t x_79; uint8_t x_80; lean_object* x_81; -lean_dec(x_38); -lean_dec(x_35); -x_79 = 0; -x_80 = 1; -x_81 = l_Lean_Meta_substCore(x_1, x_2, x_79, x_80, x_8, x_39); -if (lean_obj_tag(x_81) == 0) +uint8_t x_73; uint8_t x_74; lean_object* x_75; +lean_dec(x_31); +lean_dec(x_28); +x_73 = 0; +x_74 = 1; +x_75 = l_Lean_Meta_substCore(x_1, x_2, x_73, x_74, x_8, x_32); +if (lean_obj_tag(x_75) == 0) { -lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_82 = lean_ctor_get(x_81, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_81, 1); -lean_inc(x_83); -lean_dec(x_81); -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_86 = x_4; -x_87 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__2(x_84, x_20, x_86); -x_88 = x_87; -x_89 = l_Lean_Meta_FVarSubst_compose(x_84, x_5); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_85); -lean_ctor_set(x_90, 1, x_88); -lean_ctor_set(x_90, 2, x_89); -x_91 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_91, 0, x_90); -lean_ctor_set(x_91, 1, x_6); -x_92 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_91, x_8, x_83); +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_75, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_75, 1); +lean_inc(x_77); +lean_dec(x_75); +x_78 = lean_ctor_get(x_76, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_76, 1); +lean_inc(x_79); +lean_dec(x_76); +x_80 = x_4; +x_81 = lean_unsigned_to_nat(0u); +x_82 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__2(x_78, x_81, x_80); +x_83 = x_82; +x_84 = l_Lean_Meta_FVarSubst_compose(x_78, x_5); +x_85 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_85, 0, x_79); +lean_ctor_set(x_85, 1, x_83); +lean_ctor_set(x_85, 2, x_84); +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_85); +lean_ctor_set(x_86, 1, x_6); +x_87 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_86, x_8, x_77); lean_dec(x_8); -return x_92; +return x_87; } else { -uint8_t x_93; +uint8_t x_88; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_93 = !lean_is_exclusive(x_81); -if (x_93 == 0) +x_88 = !lean_is_exclusive(x_75); +if (x_88 == 0) { -return x_81; +return x_75; } else { -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_81, 0); -x_95 = lean_ctor_get(x_81, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_81); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -return x_96; +lean_object* x_89; lean_object* x_90; lean_object* x_91; +x_89 = lean_ctor_get(x_75, 0); +x_90 = lean_ctor_get(x_75, 1); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_75); +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; } } } case 1: { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_35, 0); +lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_92 = lean_ctor_get(x_28, 0); +lean_inc(x_92); +lean_dec(x_28); +x_93 = lean_ctor_get(x_31, 0); +lean_inc(x_93); +lean_dec(x_31); +lean_inc(x_8); +x_94 = l_Lean_Meta_getLocalDecl(x_92, x_8, x_32); +if (lean_obj_tag(x_94) == 0) +{ +lean_object* x_95; lean_object* x_96; +x_95 = lean_ctor_get(x_94, 1); +lean_inc(x_95); +lean_dec(x_94); +lean_inc(x_8); +x_96 = l_Lean_Meta_getLocalDecl(x_93, x_8, x_95); +if (lean_obj_tag(x_96) == 0) +{ +lean_object* x_97; uint8_t x_98; uint8_t x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_96, 1); lean_inc(x_97); -lean_dec(x_35); -x_98 = lean_ctor_get(x_38, 0); -lean_inc(x_98); -lean_dec(x_38); -lean_inc(x_8); -x_99 = l_Lean_Meta_getLocalDecl(x_97, x_8, x_39); -if (lean_obj_tag(x_99) == 0) +lean_dec(x_96); +x_98 = 0; +x_99 = 1; +x_100 = l_Lean_Meta_substCore(x_1, x_2, x_98, x_99, x_8, x_97); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_100; lean_object* x_101; -x_100 = lean_ctor_get(x_99, 1); -lean_inc(x_100); -lean_dec(x_99); -lean_inc(x_8); -x_101 = l_Lean_Meta_getLocalDecl(x_98, x_8, x_100); -if (lean_obj_tag(x_101) == 0) -{ -lean_object* x_102; uint8_t x_103; uint8_t x_104; lean_object* x_105; -x_102 = lean_ctor_get(x_101, 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_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_ctor_get(x_101, 0); +lean_inc(x_103); +x_104 = lean_ctor_get(x_101, 1); +lean_inc(x_104); lean_dec(x_101); -x_103 = 0; -x_104 = 1; -x_105 = l_Lean_Meta_substCore(x_1, x_2, x_103, x_104, x_8, x_102); -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; -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_ctor_get(x_106, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_106, 1); -lean_inc(x_109); -lean_dec(x_106); -x_110 = x_4; -x_111 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__3(x_108, x_20, x_110); -x_112 = x_111; -x_113 = l_Lean_Meta_FVarSubst_compose(x_108, x_5); -x_114 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_114, 0, x_109); -lean_ctor_set(x_114, 1, x_112); -lean_ctor_set(x_114, 2, x_113); -x_115 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_115, 0, x_114); -lean_ctor_set(x_115, 1, x_6); -x_116 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_115, x_8, x_107); +x_105 = x_4; +x_106 = lean_unsigned_to_nat(0u); +x_107 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__3(x_103, x_106, x_105); +x_108 = x_107; +x_109 = l_Lean_Meta_FVarSubst_compose(x_103, x_5); +x_110 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_110, 0, x_104); +lean_ctor_set(x_110, 1, x_108); +lean_ctor_set(x_110, 2, x_109); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_6); +x_112 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_111, x_8, x_102); lean_dec(x_8); +return x_112; +} +else +{ +uint8_t x_113; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_113 = !lean_is_exclusive(x_100); +if (x_113 == 0) +{ +return x_100; +} +else +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_100, 0); +x_115 = lean_ctor_get(x_100, 1); +lean_inc(x_115); +lean_inc(x_114); +lean_dec(x_100); +x_116 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_116, 0, x_114); +lean_ctor_set(x_116, 1, x_115); return x_116; } +} +} else { uint8_t x_117; @@ -11314,19 +11335,21 @@ lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_117 = !lean_is_exclusive(x_105); +lean_dec(x_2); +lean_dec(x_1); +x_117 = !lean_is_exclusive(x_96); if (x_117 == 0) { -return x_105; +return x_96; } else { lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_118 = lean_ctor_get(x_105, 0); -x_119 = lean_ctor_get(x_105, 1); +x_118 = lean_ctor_get(x_96, 0); +x_119 = lean_ctor_get(x_96, 1); lean_inc(x_119); lean_inc(x_118); -lean_dec(x_105); +lean_dec(x_96); x_120 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_120, 0, x_118); lean_ctor_set(x_120, 1, x_119); @@ -11337,25 +11360,26 @@ return x_120; else { uint8_t x_121; +lean_dec(x_93); 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_121 = !lean_is_exclusive(x_101); +x_121 = !lean_is_exclusive(x_94); if (x_121 == 0) { -return x_101; +return x_94; } else { lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_101, 0); -x_123 = lean_ctor_get(x_101, 1); +x_122 = lean_ctor_get(x_94, 0); +x_123 = lean_ctor_get(x_94, 1); lean_inc(x_123); lean_inc(x_122); -lean_dec(x_101); +lean_dec(x_94); x_124 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_124, 0, x_122); lean_ctor_set(x_124, 1, x_123); @@ -11363,258 +11387,232 @@ return x_124; } } } -else -{ -uint8_t x_125; -lean_dec(x_98); -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_125 = !lean_is_exclusive(x_99); -if (x_125 == 0) -{ -return x_99; -} -else -{ -lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_126 = lean_ctor_get(x_99, 0); -x_127 = lean_ctor_get(x_99, 1); -lean_inc(x_127); -lean_inc(x_126); -lean_dec(x_99); -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; -} -} -} case 2: { -uint8_t x_129; uint8_t x_130; lean_object* x_131; -lean_dec(x_38); -lean_dec(x_35); -x_129 = 0; -x_130 = 1; -x_131 = l_Lean_Meta_substCore(x_1, x_2, x_129, x_130, x_8, x_39); -if (lean_obj_tag(x_131) == 0) +uint8_t x_125; uint8_t x_126; lean_object* x_127; +lean_dec(x_31); +lean_dec(x_28); +x_125 = 0; +x_126 = 1; +x_127 = l_Lean_Meta_substCore(x_1, x_2, x_125, x_126, x_8, x_32); +if (lean_obj_tag(x_127) == 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; -x_132 = lean_ctor_get(x_131, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_131, 1); -lean_inc(x_133); -lean_dec(x_131); -x_134 = lean_ctor_get(x_132, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_132, 1); -lean_inc(x_135); -lean_dec(x_132); -x_136 = x_4; -x_137 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__4(x_134, x_20, x_136); -x_138 = x_137; -x_139 = l_Lean_Meta_FVarSubst_compose(x_134, x_5); -x_140 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_140, 0, x_135); -lean_ctor_set(x_140, 1, x_138); -lean_ctor_set(x_140, 2, x_139); -x_141 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_6); -x_142 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_141, x_8, x_133); +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_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_ctor_get(x_128, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_128, 1); +lean_inc(x_131); +lean_dec(x_128); +x_132 = x_4; +x_133 = lean_unsigned_to_nat(0u); +x_134 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__4(x_130, x_133, x_132); +x_135 = x_134; +x_136 = l_Lean_Meta_FVarSubst_compose(x_130, x_5); +x_137 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_137, 0, x_131); +lean_ctor_set(x_137, 1, x_135); +lean_ctor_set(x_137, 2, x_136); +x_138 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_6); +x_139 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_138, x_8, x_129); lean_dec(x_8); -return x_142; +return x_139; } else { -uint8_t x_143; +uint8_t x_140; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_143 = !lean_is_exclusive(x_131); -if (x_143 == 0) +x_140 = !lean_is_exclusive(x_127); +if (x_140 == 0) { -return x_131; +return x_127; } else { -lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_144 = lean_ctor_get(x_131, 0); -x_145 = lean_ctor_get(x_131, 1); -lean_inc(x_145); -lean_inc(x_144); -lean_dec(x_131); -x_146 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_146, 0, x_144); -lean_ctor_set(x_146, 1, x_145); -return x_146; +lean_object* x_141; lean_object* x_142; lean_object* x_143; +x_141 = lean_ctor_get(x_127, 0); +x_142 = lean_ctor_get(x_127, 1); +lean_inc(x_142); +lean_inc(x_141); +lean_dec(x_127); +x_143 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_143, 0, x_141); +lean_ctor_set(x_143, 1, x_142); +return x_143; } } } case 3: { -uint8_t x_147; uint8_t x_148; lean_object* x_149; -lean_dec(x_38); -lean_dec(x_35); -x_147 = 0; -x_148 = 1; -x_149 = l_Lean_Meta_substCore(x_1, x_2, x_147, x_148, x_8, x_39); -if (lean_obj_tag(x_149) == 0) +uint8_t x_144; uint8_t x_145; lean_object* x_146; +lean_dec(x_31); +lean_dec(x_28); +x_144 = 0; +x_145 = 1; +x_146 = l_Lean_Meta_substCore(x_1, x_2, x_144, x_145, x_8, x_32); +if (lean_obj_tag(x_146) == 0) { -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_150 = lean_ctor_get(x_149, 0); +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_147 = lean_ctor_get(x_146, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_146, 1); +lean_inc(x_148); +lean_dec(x_146); +x_149 = lean_ctor_get(x_147, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_147, 1); lean_inc(x_150); -x_151 = lean_ctor_get(x_149, 1); -lean_inc(x_151); -lean_dec(x_149); -x_152 = lean_ctor_get(x_150, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_150, 1); -lean_inc(x_153); -lean_dec(x_150); -x_154 = x_4; -x_155 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__5(x_152, x_20, x_154); -x_156 = x_155; -x_157 = l_Lean_Meta_FVarSubst_compose(x_152, x_5); -x_158 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_158, 0, x_153); -lean_ctor_set(x_158, 1, x_156); -lean_ctor_set(x_158, 2, x_157); -x_159 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_159, 0, x_158); -lean_ctor_set(x_159, 1, x_6); -x_160 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_159, x_8, x_151); +lean_dec(x_147); +x_151 = x_4; +x_152 = lean_unsigned_to_nat(0u); +x_153 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__5(x_149, x_152, x_151); +x_154 = x_153; +x_155 = l_Lean_Meta_FVarSubst_compose(x_149, x_5); +x_156 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_156, 0, x_150); +lean_ctor_set(x_156, 1, x_154); +lean_ctor_set(x_156, 2, x_155); +x_157 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_157, 0, x_156); +lean_ctor_set(x_157, 1, x_6); +x_158 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_157, x_8, x_148); lean_dec(x_8); -return x_160; +return x_158; } else { -uint8_t x_161; +uint8_t x_159; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_161 = !lean_is_exclusive(x_149); -if (x_161 == 0) +x_159 = !lean_is_exclusive(x_146); +if (x_159 == 0) { -return x_149; +return x_146; } else { -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_149, 0); -x_163 = lean_ctor_get(x_149, 1); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_149); -x_164 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_164, 0, x_162); -lean_ctor_set(x_164, 1, x_163); -return x_164; +lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_160 = lean_ctor_get(x_146, 0); +x_161 = lean_ctor_get(x_146, 1); +lean_inc(x_161); +lean_inc(x_160); +lean_dec(x_146); +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; } } } case 4: { -uint8_t x_165; uint8_t x_166; lean_object* x_167; -lean_dec(x_38); -lean_dec(x_35); -x_165 = 0; -x_166 = 1; -x_167 = l_Lean_Meta_substCore(x_1, x_2, x_165, x_166, x_8, x_39); -if (lean_obj_tag(x_167) == 0) +uint8_t x_163; uint8_t x_164; lean_object* x_165; +lean_dec(x_31); +lean_dec(x_28); +x_163 = 0; +x_164 = 1; +x_165 = l_Lean_Meta_substCore(x_1, x_2, x_163, x_164, x_8, x_32); +if (lean_obj_tag(x_165) == 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; -x_168 = lean_ctor_get(x_167, 0); +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_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, 0); lean_inc(x_168); -x_169 = lean_ctor_get(x_167, 1); +x_169 = lean_ctor_get(x_166, 1); lean_inc(x_169); -lean_dec(x_167); -x_170 = lean_ctor_get(x_168, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_168, 1); -lean_inc(x_171); -lean_dec(x_168); -x_172 = x_4; -x_173 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__6(x_170, x_20, x_172); -x_174 = x_173; -x_175 = l_Lean_Meta_FVarSubst_compose(x_170, x_5); -x_176 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_176, 0, x_171); -lean_ctor_set(x_176, 1, x_174); -lean_ctor_set(x_176, 2, x_175); -x_177 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_177, 0, x_176); -lean_ctor_set(x_177, 1, x_6); -x_178 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_177, x_8, x_169); +lean_dec(x_166); +x_170 = x_4; +x_171 = lean_unsigned_to_nat(0u); +x_172 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__6(x_168, x_171, x_170); +x_173 = x_172; +x_174 = l_Lean_Meta_FVarSubst_compose(x_168, x_5); +x_175 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_175, 0, x_169); +lean_ctor_set(x_175, 1, x_173); +lean_ctor_set(x_175, 2, x_174); +x_176 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_176, 0, x_175); +lean_ctor_set(x_176, 1, x_6); +x_177 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_176, x_8, x_167); lean_dec(x_8); -return x_178; +return x_177; } else { -uint8_t x_179; +uint8_t x_178; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_179 = !lean_is_exclusive(x_167); -if (x_179 == 0) +x_178 = !lean_is_exclusive(x_165); +if (x_178 == 0) { -return x_167; +return x_165; } else { -lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_180 = lean_ctor_get(x_167, 0); -x_181 = lean_ctor_get(x_167, 1); -lean_inc(x_181); +lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_179 = lean_ctor_get(x_165, 0); +x_180 = lean_ctor_get(x_165, 1); lean_inc(x_180); -lean_dec(x_167); -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; +lean_inc(x_179); +lean_dec(x_165); +x_181 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_181, 0, x_179); +lean_ctor_set(x_181, 1, x_180); +return x_181; } } } case 5: { -uint8_t x_183; uint8_t x_184; lean_object* x_185; -lean_dec(x_38); -lean_dec(x_35); -x_183 = 0; -x_184 = 1; -x_185 = l_Lean_Meta_substCore(x_1, x_2, x_183, x_184, x_8, x_39); -if (lean_obj_tag(x_185) == 0) +uint8_t x_182; uint8_t x_183; lean_object* x_184; +lean_dec(x_31); +lean_dec(x_28); +x_182 = 0; +x_183 = 1; +x_184 = l_Lean_Meta_substCore(x_1, x_2, x_182, x_183, x_8, x_32); +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; -x_186 = lean_ctor_get(x_185, 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; +x_185 = lean_ctor_get(x_184, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_184, 1); lean_inc(x_186); -x_187 = lean_ctor_get(x_185, 1); +lean_dec(x_184); +x_187 = lean_ctor_get(x_185, 0); lean_inc(x_187); -lean_dec(x_185); -x_188 = lean_ctor_get(x_186, 0); +x_188 = lean_ctor_get(x_185, 1); lean_inc(x_188); -x_189 = lean_ctor_get(x_186, 1); -lean_inc(x_189); -lean_dec(x_186); -x_190 = x_4; -x_191 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__7(x_188, x_20, x_190); +lean_dec(x_185); +x_189 = x_4; +x_190 = lean_unsigned_to_nat(0u); +x_191 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__7(x_187, x_190, x_189); x_192 = x_191; -x_193 = l_Lean_Meta_FVarSubst_compose(x_188, x_5); +x_193 = l_Lean_Meta_FVarSubst_compose(x_187, x_5); x_194 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_194, 0, x_189); +lean_ctor_set(x_194, 0, x_188); lean_ctor_set(x_194, 1, x_192); lean_ctor_set(x_194, 2, x_193); x_195 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_195, 0, x_194); lean_ctor_set(x_195, 1, x_6); -x_196 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_195, x_8, x_187); +x_196 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_195, x_8, x_186); lean_dec(x_8); return x_196; } @@ -11625,19 +11623,19 @@ lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_197 = !lean_is_exclusive(x_185); +x_197 = !lean_is_exclusive(x_184); if (x_197 == 0) { -return x_185; +return x_184; } else { lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_198 = lean_ctor_get(x_185, 0); -x_199 = lean_ctor_get(x_185, 1); +x_198 = lean_ctor_get(x_184, 0); +x_199 = lean_ctor_get(x_184, 1); lean_inc(x_199); lean_inc(x_198); -lean_dec(x_185); +lean_dec(x_184); x_200 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_200, 0, x_198); lean_ctor_set(x_200, 1, x_199); @@ -11648,14 +11646,14 @@ return x_200; case 6: { uint8_t x_201; uint8_t x_202; lean_object* x_203; -lean_dec(x_38); -lean_dec(x_35); +lean_dec(x_31); +lean_dec(x_28); x_201 = 0; x_202 = 1; -x_203 = l_Lean_Meta_substCore(x_1, x_2, x_201, x_202, x_8, x_39); +x_203 = l_Lean_Meta_substCore(x_1, x_2, x_201, x_202, x_8, x_32); if (lean_obj_tag(x_203) == 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_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_204 = lean_ctor_get(x_203, 0); lean_inc(x_204); x_205 = lean_ctor_get(x_203, 1); @@ -11667,422 +11665,429 @@ x_207 = lean_ctor_get(x_204, 1); lean_inc(x_207); lean_dec(x_204); x_208 = x_4; -x_209 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__8(x_206, x_20, x_208); -x_210 = x_209; -x_211 = l_Lean_Meta_FVarSubst_compose(x_206, x_5); -x_212 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_212, 0, x_207); -lean_ctor_set(x_212, 1, x_210); -lean_ctor_set(x_212, 2, x_211); -x_213 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_213, 0, x_212); -lean_ctor_set(x_213, 1, x_6); -x_214 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_213, x_8, x_205); +x_209 = lean_unsigned_to_nat(0u); +x_210 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__8(x_206, x_209, x_208); +x_211 = x_210; +x_212 = l_Lean_Meta_FVarSubst_compose(x_206, x_5); +x_213 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_213, 0, x_207); +lean_ctor_set(x_213, 1, x_211); +lean_ctor_set(x_213, 2, x_212); +x_214 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_214, 0, x_213); +lean_ctor_set(x_214, 1, x_6); +x_215 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_214, x_8, x_205); lean_dec(x_8); -return x_214; +return x_215; } else { -uint8_t x_215; +uint8_t x_216; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_215 = !lean_is_exclusive(x_203); -if (x_215 == 0) +x_216 = !lean_is_exclusive(x_203); +if (x_216 == 0) { return x_203; } else { -lean_object* x_216; lean_object* x_217; lean_object* x_218; -x_216 = lean_ctor_get(x_203, 0); -x_217 = lean_ctor_get(x_203, 1); +lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_217 = lean_ctor_get(x_203, 0); +x_218 = lean_ctor_get(x_203, 1); +lean_inc(x_218); lean_inc(x_217); -lean_inc(x_216); lean_dec(x_203); -x_218 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_218, 0, x_216); -lean_ctor_set(x_218, 1, x_217); -return x_218; +x_219 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_219, 0, x_217); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } case 7: { -uint8_t x_219; uint8_t x_220; lean_object* x_221; -lean_dec(x_38); -lean_dec(x_35); -x_219 = 0; -x_220 = 1; -x_221 = l_Lean_Meta_substCore(x_1, x_2, x_219, x_220, x_8, x_39); -if (lean_obj_tag(x_221) == 0) +uint8_t x_220; uint8_t x_221; lean_object* x_222; +lean_dec(x_31); +lean_dec(x_28); +x_220 = 0; +x_221 = 1; +x_222 = l_Lean_Meta_substCore(x_1, x_2, x_220, x_221, x_8, x_32); +if (lean_obj_tag(x_222) == 0) { -lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_222 = lean_ctor_get(x_221, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_221, 1); +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_223 = lean_ctor_get(x_222, 0); lean_inc(x_223); -lean_dec(x_221); -x_224 = lean_ctor_get(x_222, 0); +x_224 = lean_ctor_get(x_222, 1); lean_inc(x_224); -x_225 = lean_ctor_get(x_222, 1); -lean_inc(x_225); lean_dec(x_222); -x_226 = x_4; -x_227 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__9(x_224, x_20, x_226); -x_228 = x_227; -x_229 = l_Lean_Meta_FVarSubst_compose(x_224, x_5); -x_230 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_230, 0, x_225); -lean_ctor_set(x_230, 1, x_228); -lean_ctor_set(x_230, 2, x_229); -x_231 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_231, 0, x_230); -lean_ctor_set(x_231, 1, x_6); -x_232 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_231, x_8, x_223); +x_225 = lean_ctor_get(x_223, 0); +lean_inc(x_225); +x_226 = lean_ctor_get(x_223, 1); +lean_inc(x_226); +lean_dec(x_223); +x_227 = x_4; +x_228 = lean_unsigned_to_nat(0u); +x_229 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__9(x_225, x_228, x_227); +x_230 = x_229; +x_231 = l_Lean_Meta_FVarSubst_compose(x_225, x_5); +x_232 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_232, 0, x_226); +lean_ctor_set(x_232, 1, x_230); +lean_ctor_set(x_232, 2, x_231); +x_233 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_233, 0, x_232); +lean_ctor_set(x_233, 1, x_6); +x_234 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_233, x_8, x_224); lean_dec(x_8); -return x_232; +return x_234; } else { -uint8_t x_233; +uint8_t x_235; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_233 = !lean_is_exclusive(x_221); -if (x_233 == 0) +x_235 = !lean_is_exclusive(x_222); +if (x_235 == 0) { -return x_221; +return x_222; } else { -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_221, 0); -x_235 = lean_ctor_get(x_221, 1); -lean_inc(x_235); -lean_inc(x_234); -lean_dec(x_221); -x_236 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_236, 0, x_234); -lean_ctor_set(x_236, 1, x_235); -return x_236; +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_222, 0); +x_237 = lean_ctor_get(x_222, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_222); +x_238 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_238, 0, x_236); +lean_ctor_set(x_238, 1, x_237); +return x_238; } } } case 8: { -uint8_t x_237; uint8_t x_238; lean_object* x_239; -lean_dec(x_38); -lean_dec(x_35); -x_237 = 0; -x_238 = 1; -x_239 = l_Lean_Meta_substCore(x_1, x_2, x_237, x_238, x_8, x_39); -if (lean_obj_tag(x_239) == 0) +uint8_t x_239; uint8_t x_240; lean_object* x_241; +lean_dec(x_31); +lean_dec(x_28); +x_239 = 0; +x_240 = 1; +x_241 = l_Lean_Meta_substCore(x_1, x_2, x_239, x_240, x_8, x_32); +if (lean_obj_tag(x_241) == 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; -x_240 = lean_ctor_get(x_239, 0); -lean_inc(x_240); -x_241 = lean_ctor_get(x_239, 1); -lean_inc(x_241); -lean_dec(x_239); -x_242 = lean_ctor_get(x_240, 0); +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_242 = lean_ctor_get(x_241, 0); lean_inc(x_242); -x_243 = lean_ctor_get(x_240, 1); +x_243 = lean_ctor_get(x_241, 1); lean_inc(x_243); -lean_dec(x_240); -x_244 = x_4; -x_245 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__10(x_242, x_20, x_244); -x_246 = x_245; -x_247 = l_Lean_Meta_FVarSubst_compose(x_242, x_5); -x_248 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_248, 0, x_243); -lean_ctor_set(x_248, 1, x_246); -lean_ctor_set(x_248, 2, x_247); -x_249 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_249, 0, x_248); -lean_ctor_set(x_249, 1, x_6); -x_250 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_249, x_8, x_241); +lean_dec(x_241); +x_244 = lean_ctor_get(x_242, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_242, 1); +lean_inc(x_245); +lean_dec(x_242); +x_246 = x_4; +x_247 = lean_unsigned_to_nat(0u); +x_248 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__10(x_244, x_247, x_246); +x_249 = x_248; +x_250 = l_Lean_Meta_FVarSubst_compose(x_244, x_5); +x_251 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_251, 0, x_245); +lean_ctor_set(x_251, 1, x_249); +lean_ctor_set(x_251, 2, x_250); +x_252 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_252, 0, x_251); +lean_ctor_set(x_252, 1, x_6); +x_253 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_252, x_8, x_243); lean_dec(x_8); -return x_250; +return x_253; } else { -uint8_t x_251; +uint8_t x_254; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_251 = !lean_is_exclusive(x_239); -if (x_251 == 0) +x_254 = !lean_is_exclusive(x_241); +if (x_254 == 0) { -return x_239; +return x_241; } else { -lean_object* x_252; lean_object* x_253; lean_object* x_254; -x_252 = lean_ctor_get(x_239, 0); -x_253 = lean_ctor_get(x_239, 1); -lean_inc(x_253); -lean_inc(x_252); -lean_dec(x_239); -x_254 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_254, 0, x_252); -lean_ctor_set(x_254, 1, x_253); -return x_254; +lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_255 = lean_ctor_get(x_241, 0); +x_256 = lean_ctor_get(x_241, 1); +lean_inc(x_256); +lean_inc(x_255); +lean_dec(x_241); +x_257 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_257, 0, x_255); +lean_ctor_set(x_257, 1, x_256); +return x_257; } } } case 9: { -uint8_t x_255; uint8_t x_256; lean_object* x_257; -lean_dec(x_38); -lean_dec(x_35); -x_255 = 0; -x_256 = 1; -x_257 = l_Lean_Meta_substCore(x_1, x_2, x_255, x_256, x_8, x_39); -if (lean_obj_tag(x_257) == 0) +uint8_t x_258; uint8_t x_259; lean_object* x_260; +lean_dec(x_31); +lean_dec(x_28); +x_258 = 0; +x_259 = 1; +x_260 = l_Lean_Meta_substCore(x_1, x_2, x_258, x_259, x_8, x_32); +if (lean_obj_tag(x_260) == 0) { -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_258 = lean_ctor_get(x_257, 0); -lean_inc(x_258); -x_259 = lean_ctor_get(x_257, 1); -lean_inc(x_259); -lean_dec(x_257); -x_260 = lean_ctor_get(x_258, 0); -lean_inc(x_260); -x_261 = lean_ctor_get(x_258, 1); +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_260, 0); lean_inc(x_261); -lean_dec(x_258); -x_262 = x_4; -x_263 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__11(x_260, x_20, x_262); -x_264 = x_263; -x_265 = l_Lean_Meta_FVarSubst_compose(x_260, x_5); -x_266 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_266, 0, x_261); -lean_ctor_set(x_266, 1, x_264); -lean_ctor_set(x_266, 2, x_265); -x_267 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_267, 0, x_266); -lean_ctor_set(x_267, 1, x_6); -x_268 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_267, x_8, x_259); +x_262 = lean_ctor_get(x_260, 1); +lean_inc(x_262); +lean_dec(x_260); +x_263 = lean_ctor_get(x_261, 0); +lean_inc(x_263); +x_264 = lean_ctor_get(x_261, 1); +lean_inc(x_264); +lean_dec(x_261); +x_265 = x_4; +x_266 = lean_unsigned_to_nat(0u); +x_267 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__11(x_263, x_266, x_265); +x_268 = x_267; +x_269 = l_Lean_Meta_FVarSubst_compose(x_263, x_5); +x_270 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_270, 0, x_264); +lean_ctor_set(x_270, 1, x_268); +lean_ctor_set(x_270, 2, x_269); +x_271 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_271, 0, x_270); +lean_ctor_set(x_271, 1, x_6); +x_272 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_271, x_8, x_262); lean_dec(x_8); -return x_268; +return x_272; } else { -uint8_t x_269; +uint8_t x_273; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_269 = !lean_is_exclusive(x_257); -if (x_269 == 0) +x_273 = !lean_is_exclusive(x_260); +if (x_273 == 0) { -return x_257; +return x_260; } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_270 = lean_ctor_get(x_257, 0); -x_271 = lean_ctor_get(x_257, 1); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_257); -x_272 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_272, 0, x_270); -lean_ctor_set(x_272, 1, x_271); -return x_272; +lean_object* x_274; lean_object* x_275; lean_object* x_276; +x_274 = lean_ctor_get(x_260, 0); +x_275 = lean_ctor_get(x_260, 1); +lean_inc(x_275); +lean_inc(x_274); +lean_dec(x_260); +x_276 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_276, 0, x_274); +lean_ctor_set(x_276, 1, x_275); +return x_276; } } } case 10: { -uint8_t x_273; uint8_t x_274; lean_object* x_275; -lean_dec(x_38); -lean_dec(x_35); -x_273 = 0; -x_274 = 1; -x_275 = l_Lean_Meta_substCore(x_1, x_2, x_273, x_274, x_8, x_39); -if (lean_obj_tag(x_275) == 0) +uint8_t x_277; uint8_t x_278; lean_object* x_279; +lean_dec(x_31); +lean_dec(x_28); +x_277 = 0; +x_278 = 1; +x_279 = l_Lean_Meta_substCore(x_1, x_2, x_277, x_278, x_8, x_32); +if (lean_obj_tag(x_279) == 0) { -lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = lean_ctor_get(x_276, 0); -lean_inc(x_278); -x_279 = lean_ctor_get(x_276, 1); -lean_inc(x_279); -lean_dec(x_276); -x_280 = x_4; -x_281 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__12(x_278, x_20, x_280); -x_282 = x_281; -x_283 = l_Lean_Meta_FVarSubst_compose(x_278, x_5); -x_284 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_284, 0, x_279); -lean_ctor_set(x_284, 1, x_282); -lean_ctor_set(x_284, 2, x_283); -x_285 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_285, 0, x_284); -lean_ctor_set(x_285, 1, x_6); -x_286 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_285, x_8, x_277); +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_279, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_279, 1); +lean_inc(x_281); +lean_dec(x_279); +x_282 = lean_ctor_get(x_280, 0); +lean_inc(x_282); +x_283 = lean_ctor_get(x_280, 1); +lean_inc(x_283); +lean_dec(x_280); +x_284 = x_4; +x_285 = lean_unsigned_to_nat(0u); +x_286 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__12(x_282, x_285, x_284); +x_287 = x_286; +x_288 = l_Lean_Meta_FVarSubst_compose(x_282, x_5); +x_289 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_289, 0, x_283); +lean_ctor_set(x_289, 1, x_287); +lean_ctor_set(x_289, 2, x_288); +x_290 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_290, 0, x_289); +lean_ctor_set(x_290, 1, x_6); +x_291 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_290, x_8, x_281); lean_dec(x_8); -return x_286; +return x_291; } else { -uint8_t x_287; +uint8_t x_292; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_287 = !lean_is_exclusive(x_275); -if (x_287 == 0) +x_292 = !lean_is_exclusive(x_279); +if (x_292 == 0) { -return x_275; +return x_279; } else { -lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_288 = lean_ctor_get(x_275, 0); -x_289 = lean_ctor_get(x_275, 1); -lean_inc(x_289); -lean_inc(x_288); -lean_dec(x_275); -x_290 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_290, 0, x_288); -lean_ctor_set(x_290, 1, x_289); -return x_290; +lean_object* x_293; lean_object* x_294; lean_object* x_295; +x_293 = lean_ctor_get(x_279, 0); +x_294 = lean_ctor_get(x_279, 1); +lean_inc(x_294); +lean_inc(x_293); +lean_dec(x_279); +x_295 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_295, 0, x_293); +lean_ctor_set(x_295, 1, x_294); +return x_295; } } } case 11: { -uint8_t x_291; uint8_t x_292; lean_object* x_293; -lean_dec(x_38); -lean_dec(x_35); -x_291 = 0; -x_292 = 1; -x_293 = l_Lean_Meta_substCore(x_1, x_2, x_291, x_292, x_8, x_39); -if (lean_obj_tag(x_293) == 0) +uint8_t x_296; uint8_t x_297; lean_object* x_298; +lean_dec(x_31); +lean_dec(x_28); +x_296 = 0; +x_297 = 1; +x_298 = l_Lean_Meta_substCore(x_1, x_2, x_296, x_297, x_8, x_32); +if (lean_obj_tag(x_298) == 0) { -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_294 = lean_ctor_get(x_293, 0); -lean_inc(x_294); -x_295 = lean_ctor_get(x_293, 1); -lean_inc(x_295); -lean_dec(x_293); -x_296 = lean_ctor_get(x_294, 0); -lean_inc(x_296); -x_297 = lean_ctor_get(x_294, 1); -lean_inc(x_297); -lean_dec(x_294); -x_298 = x_4; -x_299 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__13(x_296, x_20, x_298); -x_300 = x_299; -x_301 = l_Lean_Meta_FVarSubst_compose(x_296, x_5); -x_302 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_302, 0, x_297); -lean_ctor_set(x_302, 1, x_300); -lean_ctor_set(x_302, 2, x_301); -x_303 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_303, 0, x_302); -lean_ctor_set(x_303, 1, x_6); -x_304 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_303, x_8, x_295); +lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +x_299 = lean_ctor_get(x_298, 0); +lean_inc(x_299); +x_300 = lean_ctor_get(x_298, 1); +lean_inc(x_300); +lean_dec(x_298); +x_301 = lean_ctor_get(x_299, 0); +lean_inc(x_301); +x_302 = lean_ctor_get(x_299, 1); +lean_inc(x_302); +lean_dec(x_299); +x_303 = x_4; +x_304 = lean_unsigned_to_nat(0u); +x_305 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__13(x_301, x_304, x_303); +x_306 = x_305; +x_307 = l_Lean_Meta_FVarSubst_compose(x_301, x_5); +x_308 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_308, 0, x_302); +lean_ctor_set(x_308, 1, x_306); +lean_ctor_set(x_308, 2, x_307); +x_309 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_309, 0, x_308); +lean_ctor_set(x_309, 1, x_6); +x_310 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_309, x_8, x_300); lean_dec(x_8); -return x_304; +return x_310; } else { -uint8_t x_305; +uint8_t x_311; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_305 = !lean_is_exclusive(x_293); -if (x_305 == 0) +x_311 = !lean_is_exclusive(x_298); +if (x_311 == 0) { -return x_293; +return x_298; } else { -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_293, 0); -x_307 = lean_ctor_get(x_293, 1); -lean_inc(x_307); -lean_inc(x_306); -lean_dec(x_293); -x_308 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_308, 0, x_306); -lean_ctor_set(x_308, 1, x_307); -return x_308; +lean_object* x_312; lean_object* x_313; lean_object* x_314; +x_312 = lean_ctor_get(x_298, 0); +x_313 = lean_ctor_get(x_298, 1); +lean_inc(x_313); +lean_inc(x_312); +lean_dec(x_298); +x_314 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_314, 0, x_312); +lean_ctor_set(x_314, 1, x_313); +return x_314; } } } default: { -uint8_t x_309; uint8_t x_310; lean_object* x_311; -lean_dec(x_38); -lean_dec(x_35); -x_309 = 0; -x_310 = 1; -x_311 = l_Lean_Meta_substCore(x_1, x_2, x_309, x_310, x_8, x_39); -if (lean_obj_tag(x_311) == 0) +uint8_t x_315; uint8_t x_316; lean_object* x_317; +lean_dec(x_31); +lean_dec(x_28); +x_315 = 0; +x_316 = 1; +x_317 = l_Lean_Meta_substCore(x_1, x_2, x_315, x_316, x_8, x_32); +if (lean_obj_tag(x_317) == 0) { -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_312 = lean_ctor_get(x_311, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_311, 1); -lean_inc(x_313); -lean_dec(x_311); -x_314 = lean_ctor_get(x_312, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_312, 1); -lean_inc(x_315); -lean_dec(x_312); -x_316 = x_4; -x_317 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__14(x_314, x_20, x_316); -x_318 = x_317; -x_319 = l_Lean_Meta_FVarSubst_compose(x_314, x_5); -x_320 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_320, 0, x_315); -lean_ctor_set(x_320, 1, x_318); -lean_ctor_set(x_320, 2, x_319); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_320); -lean_ctor_set(x_321, 1, x_6); -x_322 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_321, x_8, x_313); +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_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_ctor_get(x_318, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_318, 1); +lean_inc(x_321); +lean_dec(x_318); +x_322 = x_4; +x_323 = lean_unsigned_to_nat(0u); +x_324 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__14(x_320, x_323, x_322); +x_325 = x_324; +x_326 = l_Lean_Meta_FVarSubst_compose(x_320, x_5); +x_327 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_327, 0, x_321); +lean_ctor_set(x_327, 1, x_325); +lean_ctor_set(x_327, 2, x_326); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_327); +lean_ctor_set(x_328, 1, x_6); +x_329 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_328, x_8, x_319); lean_dec(x_8); -return x_322; +return x_329; } else { -uint8_t x_323; +uint8_t x_330; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_323 = !lean_is_exclusive(x_311); -if (x_323 == 0) +x_330 = !lean_is_exclusive(x_317); +if (x_330 == 0) { -return x_311; +return x_317; } else { -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_311, 0); -x_325 = lean_ctor_get(x_311, 1); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_311); -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; +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_317, 0); +x_332 = lean_ctor_get(x_317, 1); +lean_inc(x_332); +lean_inc(x_331); +lean_dec(x_317); +x_333 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_333, 0, x_331); +lean_ctor_set(x_333, 1, x_332); +return x_333; } } } @@ -12090,167 +12095,168 @@ return x_326; } else { -lean_object* x_327; -lean_dec(x_35); -x_327 = lean_box(0); -x_40 = x_327; -goto block_78; +lean_object* x_334; +lean_dec(x_28); +x_334 = lean_box(0); +x_33 = x_334; +goto block_72; } -block_78: +block_72: { -lean_dec(x_40); -if (lean_obj_tag(x_38) == 1) +lean_dec(x_33); +if (lean_obj_tag(x_31) == 1) { -uint8_t x_41; uint8_t x_42; lean_object* x_43; -lean_dec(x_38); -x_41 = 0; -x_42 = 1; -x_43 = l_Lean_Meta_substCore(x_1, x_2, x_41, x_42, x_8, x_39); -if (lean_obj_tag(x_43) == 0) +uint8_t x_34; uint8_t x_35; lean_object* x_36; +lean_dec(x_31); +x_34 = 0; +x_35 = 1; +x_36 = l_Lean_Meta_substCore(x_1, x_2, x_34, x_35, x_8, x_32); +if (lean_obj_tag(x_36) == 0) { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -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 = x_4; -x_49 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__1(x_46, x_20, x_48); -x_50 = x_49; -x_51 = l_Lean_Meta_FVarSubst_compose(x_46, x_5); -x_52 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_52, 0, x_47); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, 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_6); -x_54 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_53, x_8, x_45); +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_37 = lean_ctor_get(x_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_ctor_get(x_37, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_37, 1); +lean_inc(x_40); +lean_dec(x_37); +x_41 = x_4; +x_42 = lean_unsigned_to_nat(0u); +x_43 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__1(x_39, x_42, x_41); +x_44 = x_43; +x_45 = l_Lean_Meta_FVarSubst_compose(x_39, x_5); +x_46 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_46, 0, x_40); +lean_ctor_set(x_46, 1, x_44); +lean_ctor_set(x_46, 2, 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_6); +x_48 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_47, x_8, x_38); lean_dec(x_8); -return x_54; +return x_48; } else { +uint8_t x_49; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_49 = !lean_is_exclusive(x_36); +if (x_49 == 0) +{ +return x_36; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_36, 0); +x_51 = lean_ctor_get(x_36, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_36); +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +} +else +{ +lean_object* x_53; +lean_dec(x_31); +x_53 = l_Lean_Meta_injectionCore(x_1, x_2, x_8, x_32); +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_54; +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +if (lean_obj_tag(x_54) == 0) +{ uint8_t x_55; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_55 = !lean_is_exclusive(x_43); +x_55 = !lean_is_exclusive(x_53); if (x_55 == 0) { -return x_43; +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_53, 0); +lean_dec(x_56); +x_57 = lean_box(0); +lean_ctor_set(x_53, 0, x_57); +return x_53; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_43, 0); -x_57 = lean_ctor_get(x_43, 1); -lean_inc(x_57); -lean_inc(x_56); -lean_dec(x_43); -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* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_53, 1); +lean_inc(x_58); +lean_dec(x_53); +x_59 = lean_box(0); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_58); +return x_60; } } else { -lean_object* x_59; -lean_dec(x_38); -x_59 = l_Lean_Meta_injectionCore(x_1, x_2, x_8, x_39); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 0) -{ -uint8_t x_61; -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_61 = !lean_is_exclusive(x_59); -if (x_61 == 0) -{ -lean_object* x_62; lean_object* x_63; -x_62 = lean_ctor_get(x_59, 0); -lean_dec(x_62); -x_63 = lean_box(0); -lean_ctor_set(x_59, 0, x_63); -return x_59; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_59, 1); -lean_inc(x_64); -lean_dec(x_59); -x_65 = lean_box(0); +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_61 = lean_ctor_get(x_53, 1); +lean_inc(x_61); +lean_dec(x_53); +x_62 = lean_ctor_get(x_54, 0); +lean_inc(x_62); +x_63 = lean_ctor_get(x_54, 1); +lean_inc(x_63); +lean_dec(x_54); +x_64 = lean_nat_add(x_3, x_63); +lean_dec(x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_62); +lean_ctor_set(x_65, 1, x_4); +lean_ctor_set(x_65, 2, x_5); x_66 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_64); -return x_66; +lean_ctor_set(x_66, 1, x_6); +x_67 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_64, x_66, x_8, x_61); +lean_dec(x_8); +lean_dec(x_64); +return x_67; } } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_67 = lean_ctor_get(x_59, 1); -lean_inc(x_67); -lean_dec(x_59); -x_68 = lean_ctor_get(x_60, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_60, 1); +uint8_t x_68; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_68 = !lean_is_exclusive(x_53); +if (x_68 == 0) +{ +return x_53; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_53, 0); +x_70 = lean_ctor_get(x_53, 1); +lean_inc(x_70); lean_inc(x_69); -lean_dec(x_60); -x_70 = lean_nat_add(x_3, x_69); -lean_dec(x_69); -x_71 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_4); -lean_ctor_set(x_71, 2, x_5); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_6); -x_73 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_70, x_72, x_8, x_67); -lean_dec(x_8); -lean_dec(x_70); -return x_73; -} -} -else -{ -uint8_t x_74; -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_74 = !lean_is_exclusive(x_59); -if (x_74 == 0) -{ -return x_59; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_59, 0); -x_76 = lean_ctor_get(x_59, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_59); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; +lean_dec(x_53); +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; } } } @@ -12258,335 +12264,330 @@ return x_77; } else { -uint8_t x_328; -lean_dec(x_35); +uint8_t x_335; +lean_dec(x_28); 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_328 = !lean_is_exclusive(x_37); -if (x_328 == 0) -{ -return x_37; -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_329 = lean_ctor_get(x_37, 0); -x_330 = lean_ctor_get(x_37, 1); -lean_inc(x_330); -lean_inc(x_329); -lean_dec(x_37); -x_331 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_331, 0, x_329); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} -} -} -else -{ -uint8_t x_332; -lean_dec(x_29); -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_332 = !lean_is_exclusive(x_34); -if (x_332 == 0) -{ -return x_34; -} -else -{ -lean_object* x_333; lean_object* x_334; lean_object* x_335; -x_333 = lean_ctor_get(x_34, 0); -x_334 = lean_ctor_get(x_34, 1); -lean_inc(x_334); -lean_inc(x_333); -lean_dec(x_34); -x_335 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_335, 0, x_333); -lean_ctor_set(x_335, 1, x_334); -return x_335; -} -} -} -else -{ -lean_object* x_336; lean_object* x_337; -lean_dec(x_29); -lean_dec(x_25); -x_336 = lean_ctor_get(x_30, 1); -lean_inc(x_336); -lean_dec(x_30); -x_337 = l_Lean_Meta_clear(x_1, x_2, x_8, x_336); -if (lean_obj_tag(x_337) == 0) -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; -x_338 = lean_ctor_get(x_337, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_337, 1); -lean_inc(x_339); -lean_dec(x_337); -x_340 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_340, 0, x_338); -lean_ctor_set(x_340, 1, x_4); -lean_ctor_set(x_340, 2, x_5); -x_341 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_341, 0, x_340); -lean_ctor_set(x_341, 1, x_6); -x_342 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_341, x_8, x_339); -lean_dec(x_8); -return x_342; -} -else -{ -uint8_t x_343; -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_343 = !lean_is_exclusive(x_337); -if (x_343 == 0) -{ -return x_337; -} -else -{ -lean_object* x_344; lean_object* x_345; lean_object* x_346; -x_344 = lean_ctor_get(x_337, 0); -x_345 = lean_ctor_get(x_337, 1); -lean_inc(x_345); -lean_inc(x_344); -lean_dec(x_337); -x_346 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_346, 0, x_344); -lean_ctor_set(x_346, 1, x_345); -return x_346; -} -} -} -} -else -{ -uint8_t x_347; -lean_dec(x_29); -lean_dec(x_25); -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_347 = !lean_is_exclusive(x_30); -if (x_347 == 0) +x_335 = !lean_is_exclusive(x_30); +if (x_335 == 0) { return x_30; } else { -lean_object* x_348; lean_object* x_349; lean_object* x_350; -x_348 = lean_ctor_get(x_30, 0); -x_349 = lean_ctor_get(x_30, 1); -lean_inc(x_349); -lean_inc(x_348); +lean_object* x_336; lean_object* x_337; lean_object* x_338; +x_336 = lean_ctor_get(x_30, 0); +x_337 = lean_ctor_get(x_30, 1); +lean_inc(x_337); +lean_inc(x_336); lean_dec(x_30); -x_350 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_350, 0, x_348); -lean_ctor_set(x_350, 1, x_349); -return x_350; +x_338 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_338, 0, x_336); +lean_ctor_set(x_338, 1, x_337); +return x_338; +} +} +} +else +{ +uint8_t x_339; +lean_dec(x_22); +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_339 = !lean_is_exclusive(x_27); +if (x_339 == 0) +{ +return x_27; +} +else +{ +lean_object* x_340; lean_object* x_341; lean_object* x_342; +x_340 = lean_ctor_get(x_27, 0); +x_341 = lean_ctor_get(x_27, 1); +lean_inc(x_341); +lean_inc(x_340); +lean_dec(x_27); +x_342 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_342, 0, x_340); +lean_ctor_set(x_342, 1, x_341); +return x_342; +} +} +} +else +{ +lean_object* x_343; lean_object* x_344; +lean_dec(x_22); +lean_dec(x_21); +x_343 = lean_ctor_get(x_23, 1); +lean_inc(x_343); +lean_dec(x_23); +x_344 = l_Lean_Meta_clear(x_1, x_2, x_8, x_343); +if (lean_obj_tag(x_344) == 0) +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; +x_345 = lean_ctor_get(x_344, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_344, 1); +lean_inc(x_346); +lean_dec(x_344); +x_347 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_347, 0, x_345); +lean_ctor_set(x_347, 1, x_4); +lean_ctor_set(x_347, 2, x_5); +x_348 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_348, 0, x_347); +lean_ctor_set(x_348, 1, x_6); +x_349 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_3, x_348, x_8, x_346); +lean_dec(x_8); +return x_349; +} +else +{ +uint8_t x_350; +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_350 = !lean_is_exclusive(x_344); +if (x_350 == 0) +{ +return x_344; +} +else +{ +lean_object* x_351; lean_object* x_352; lean_object* x_353; +x_351 = lean_ctor_get(x_344, 0); +x_352 = lean_ctor_get(x_344, 1); +lean_inc(x_352); +lean_inc(x_351); +lean_dec(x_344); +x_353 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_353, 0, x_351); +lean_ctor_set(x_353, 1, x_352); +return x_353; } } } } else { -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; -x_351 = lean_unsigned_to_nat(0u); -x_352 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_351); -x_353 = lean_unsigned_to_nat(1u); -x_354 = lean_nat_sub(x_352, x_353); -x_355 = lean_nat_sub(x_354, x_353); -lean_dec(x_354); -x_356 = l_Lean_Expr_getRevArg_x21___main(x_10, x_355); -x_357 = lean_nat_sub(x_352, x_12); -lean_dec(x_352); -x_358 = lean_nat_sub(x_357, x_353); -lean_dec(x_357); -x_359 = l_Lean_Expr_getRevArg_x21___main(x_10, x_358); +uint8_t x_354; +lean_dec(x_22); +lean_dec(x_21); +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_354 = !lean_is_exclusive(x_23); +if (x_354 == 0) +{ +return x_23; +} +else +{ +lean_object* x_355; lean_object* x_356; lean_object* x_357; +x_355 = lean_ctor_get(x_23, 0); +x_356 = lean_ctor_get(x_23, 1); +lean_inc(x_356); +lean_inc(x_355); +lean_dec(x_23); +x_357 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_357, 0, x_355); +lean_ctor_set(x_357, 1, x_356); +return x_357; +} +} +} +} +else +{ +lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; +x_358 = l_Lean_Expr_appFn_x21(x_10); +x_359 = l_Lean_Expr_appFn_x21(x_358); +lean_dec(x_358); +x_360 = l_Lean_Expr_appArg_x21(x_359); +lean_dec(x_359); +x_361 = l_Lean_Expr_appArg_x21(x_10); lean_dec(x_10); lean_inc(x_2); -x_360 = l_Lean_mkFVar(x_2); +x_362 = l_Lean_mkFVar(x_2); lean_inc(x_8); -x_361 = l_Lean_Meta_mkEqOfHEq(x_360, x_8, x_9); -if (lean_obj_tag(x_361) == 0) +x_363 = l_Lean_Meta_mkEqOfHEq(x_362, x_8, x_9); +if (lean_obj_tag(x_363) == 0) { -lean_object* x_362; lean_object* x_363; lean_object* x_364; -x_362 = lean_ctor_get(x_361, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_361, 1); -lean_inc(x_363); -lean_dec(x_361); -lean_inc(x_8); -x_364 = l_Lean_Meta_mkEq(x_356, x_359, x_8, x_363); -if (lean_obj_tag(x_364) == 0) -{ -lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; -x_365 = lean_ctor_get(x_364, 0); +lean_object* x_364; lean_object* x_365; lean_object* x_366; +x_364 = lean_ctor_get(x_363, 0); +lean_inc(x_364); +x_365 = lean_ctor_get(x_363, 1); lean_inc(x_365); -x_366 = lean_ctor_get(x_364, 1); -lean_inc(x_366); -lean_dec(x_364); -x_367 = l_Lean_LocalDecl_userName(x_7); -x_368 = l_Lean_Meta_assert(x_1, x_367, x_365, x_362, x_8, x_366); -if (lean_obj_tag(x_368) == 0) +lean_dec(x_363); +lean_inc(x_8); +x_366 = l_Lean_Meta_mkEq(x_360, x_361, x_8, x_365); +if (lean_obj_tag(x_366) == 0) { -lean_object* x_369; lean_object* x_370; lean_object* x_371; -x_369 = lean_ctor_get(x_368, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_368, 1); -lean_inc(x_370); -lean_dec(x_368); -x_371 = l_Lean_Meta_clear(x_369, x_2, x_8, x_370); -if (lean_obj_tag(x_371) == 0) +lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; +x_367 = lean_ctor_get(x_366, 0); +lean_inc(x_367); +x_368 = lean_ctor_get(x_366, 1); +lean_inc(x_368); +lean_dec(x_366); +x_369 = l_Lean_LocalDecl_userName(x_7); +x_370 = l_Lean_Meta_assert(x_1, x_369, x_367, x_364, x_8, x_368); +if (lean_obj_tag(x_370) == 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; -x_372 = lean_ctor_get(x_371, 0); +lean_object* x_371; lean_object* x_372; lean_object* x_373; +x_371 = lean_ctor_get(x_370, 0); +lean_inc(x_371); +x_372 = lean_ctor_get(x_370, 1); lean_inc(x_372); -x_373 = lean_ctor_get(x_371, 1); -lean_inc(x_373); -lean_dec(x_371); -x_374 = lean_nat_add(x_3, x_353); -x_375 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_375, 0, x_372); -lean_ctor_set(x_375, 1, x_4); -lean_ctor_set(x_375, 2, x_5); -x_376 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_376, 0, x_375); -lean_ctor_set(x_376, 1, x_6); -x_377 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_374, x_376, x_8, x_373); +lean_dec(x_370); +x_373 = l_Lean_Meta_clear(x_371, x_2, x_8, x_372); +if (lean_obj_tag(x_373) == 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; +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_unsigned_to_nat(1u); +x_377 = lean_nat_add(x_3, x_376); +x_378 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_378, 0, x_374); +lean_ctor_set(x_378, 1, x_4); +lean_ctor_set(x_378, 2, x_5); +x_379 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_379, 0, x_378); +lean_ctor_set(x_379, 1, x_6); +x_380 = l___private_Init_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main(x_377, x_379, x_8, x_375); lean_dec(x_8); -lean_dec(x_374); -return x_377; +lean_dec(x_377); +return x_380; } else { -uint8_t x_378; +uint8_t x_381; lean_dec(x_8); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_378 = !lean_is_exclusive(x_371); -if (x_378 == 0) +x_381 = !lean_is_exclusive(x_373); +if (x_381 == 0) { -return x_371; +return x_373; } else { -lean_object* x_379; lean_object* x_380; lean_object* x_381; -x_379 = lean_ctor_get(x_371, 0); -x_380 = lean_ctor_get(x_371, 1); -lean_inc(x_380); -lean_inc(x_379); -lean_dec(x_371); -x_381 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_381, 0, x_379); -lean_ctor_set(x_381, 1, x_380); -return x_381; -} -} -} -else -{ -uint8_t x_382; -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_382 = !lean_is_exclusive(x_368); -if (x_382 == 0) -{ -return x_368; -} -else -{ -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_368, 0); -x_384 = lean_ctor_get(x_368, 1); -lean_inc(x_384); +lean_object* x_382; lean_object* x_383; lean_object* x_384; +x_382 = lean_ctor_get(x_373, 0); +x_383 = lean_ctor_get(x_373, 1); lean_inc(x_383); -lean_dec(x_368); -x_385 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_385, 0, x_383); -lean_ctor_set(x_385, 1, x_384); -return x_385; +lean_inc(x_382); +lean_dec(x_373); +x_384 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_384, 0, x_382); +lean_ctor_set(x_384, 1, x_383); +return x_384; } } } else { -uint8_t x_386; -lean_dec(x_362); +uint8_t x_385; 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_386 = !lean_is_exclusive(x_364); -if (x_386 == 0) +x_385 = !lean_is_exclusive(x_370); +if (x_385 == 0) { -return x_364; +return x_370; } else { -lean_object* x_387; lean_object* x_388; lean_object* x_389; -x_387 = lean_ctor_get(x_364, 0); -x_388 = lean_ctor_get(x_364, 1); -lean_inc(x_388); +lean_object* x_386; lean_object* x_387; lean_object* x_388; +x_386 = lean_ctor_get(x_370, 0); +x_387 = lean_ctor_get(x_370, 1); lean_inc(x_387); -lean_dec(x_364); -x_389 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_389, 0, x_387); -lean_ctor_set(x_389, 1, x_388); -return x_389; +lean_inc(x_386); +lean_dec(x_370); +x_388 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_388, 0, x_386); +lean_ctor_set(x_388, 1, x_387); +return x_388; } } } else { -uint8_t x_390; -lean_dec(x_359); -lean_dec(x_356); +uint8_t x_389; +lean_dec(x_364); 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_390 = !lean_is_exclusive(x_361); -if (x_390 == 0) +x_389 = !lean_is_exclusive(x_366); +if (x_389 == 0) { -return x_361; +return x_366; } else { -lean_object* x_391; lean_object* x_392; lean_object* x_393; -x_391 = lean_ctor_get(x_361, 0); -x_392 = lean_ctor_get(x_361, 1); -lean_inc(x_392); +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_366, 0); +x_391 = lean_ctor_get(x_366, 1); lean_inc(x_391); +lean_inc(x_390); +lean_dec(x_366); +x_392 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_392, 0, x_390); +lean_ctor_set(x_392, 1, x_391); +return x_392; +} +} +} +else +{ +uint8_t x_393; lean_dec(x_361); -x_393 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_393, 0, x_391); -lean_ctor_set(x_393, 1, x_392); -return x_393; +lean_dec(x_360); +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_393 = !lean_is_exclusive(x_363); +if (x_393 == 0) +{ +return x_363; +} +else +{ +lean_object* x_394; lean_object* x_395; lean_object* x_396; +x_394 = lean_ctor_get(x_363, 0); +x_395 = lean_ctor_get(x_363, 1); +lean_inc(x_395); +lean_inc(x_394); +lean_dec(x_363); +x_396 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_396, 0, x_394); +lean_ctor_set(x_396, 1, x_395); +return x_396; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Injection.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Injection.c index f4496b25ad..75904ec37b 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Injection.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Injection.c @@ -29,8 +29,10 @@ lean_object* lean_environment_find(lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarTag(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*); extern lean_object* l_Lean_WHNF_toCtorIfLit___closed__5; +lean_object* l_Lean_Expr_appFn_x21(lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); lean_object* l_Lean_Meta_checkNotAssigned___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Meta_injectionIntro(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -62,7 +64,6 @@ lean_object* l_Lean_Meta_injectionCore___lambda__1(lean_object*, lean_object*, l lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_injection___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); lean_object* l_Lean_Meta_injectionCore___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -436,360 +437,396 @@ return x_18; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_19 = lean_unsigned_to_nat(0u); -x_20 = l_Lean_Expr_getAppNumArgsAux___main(x_12, x_19); -x_21 = lean_unsigned_to_nat(1u); -x_22 = lean_nat_sub(x_20, x_21); -x_23 = lean_nat_sub(x_22, x_21); -lean_dec(x_22); -x_24 = l_Lean_Expr_getRevArg_x21___main(x_12, x_23); -x_25 = lean_unsigned_to_nat(2u); -x_26 = lean_nat_sub(x_20, x_25); -lean_dec(x_20); -x_27 = lean_nat_sub(x_26, x_21); -lean_dec(x_26); -x_28 = l_Lean_Expr_getRevArg_x21___main(x_12, x_27); +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = l_Lean_Expr_appFn_x21(x_12); +x_20 = l_Lean_Expr_appArg_x21(x_19); +lean_dec(x_19); +x_21 = l_Lean_Expr_appArg_x21(x_12); lean_dec(x_12); lean_inc(x_5); -x_29 = l_Lean_Meta_whnf(x_24, x_5, x_13); -if (lean_obj_tag(x_29) == 0) +x_22 = l_Lean_Meta_whnf(x_20, x_5, x_13); +if (lean_obj_tag(x_22) == 0) { -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); lean_inc(x_5); -x_32 = l_Lean_Meta_whnf(x_28, x_5, x_31); +x_25 = l_Lean_Meta_whnf(x_21, x_5, x_24); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +lean_inc(x_3); +x_28 = l_Lean_Meta_getMVarType(x_3, x_5, x_27); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_Meta_constructorApp_x3f(x_23, x_5, x_30); +lean_dec(x_23); +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 = l_Lean_Meta_constructorApp_x3f(x_26, x_5, x_33); +lean_dec(x_26); if (lean_obj_tag(x_32) == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); +lean_object* x_35; lean_object* x_36; lean_object* x_37; +lean_dec(x_29); +lean_dec(x_1); +x_35 = lean_ctor_get(x_34, 1); +lean_inc(x_35); +lean_dec(x_34); +x_36 = l_Lean_Meta_injectionCore___lambda__1___closed__5; +x_37 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_36, x_5, x_35); +lean_dec(x_5); +return x_37; +} +else +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_34, 0); +lean_inc(x_38); +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_dec(x_32); -lean_inc(x_3); -x_35 = l_Lean_Meta_getMVarType(x_3, x_5, x_34); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -lean_dec(x_35); -x_38 = l_Lean_Meta_constructorApp_x3f(x_30, x_5, x_37); -lean_dec(x_30); -x_39 = lean_ctor_get(x_38, 0); +lean_dec(x_29); +lean_dec(x_1); +x_39 = lean_ctor_get(x_34, 1); 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_constructorApp_x3f(x_33, x_5, x_40); -lean_dec(x_33); -if (lean_obj_tag(x_39) == 0) +lean_dec(x_34); +x_40 = l_Lean_Meta_injectionCore___lambda__1___closed__5; +x_41 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_40, x_5, x_39); +lean_dec(x_5); +return x_41; +} +else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; -lean_dec(x_36); -lean_dec(x_1); -x_42 = lean_ctor_get(x_41, 1); +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_34, 1); lean_inc(x_42); -lean_dec(x_41); -x_43 = l_Lean_Meta_injectionCore___lambda__1___closed__5; -x_44 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_43, x_5, x_42); -lean_dec(x_5); -return x_44; -} -else -{ -lean_object* x_45; -x_45 = lean_ctor_get(x_41, 0); -lean_inc(x_45); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_1); -x_46 = lean_ctor_get(x_41, 1); -lean_inc(x_46); -lean_dec(x_41); -x_47 = l_Lean_Meta_injectionCore___lambda__1___closed__5; -x_48 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_47, x_5, x_46); -lean_dec(x_5); -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_41, 1); -lean_inc(x_49); -lean_dec(x_41); -x_50 = lean_ctor_get(x_39, 0); -lean_inc(x_50); -lean_dec(x_39); -x_51 = lean_ctor_get(x_45, 0); -lean_inc(x_51); -lean_dec(x_45); +lean_dec(x_34); +x_43 = lean_ctor_get(x_32, 0); +lean_inc(x_43); +lean_dec(x_32); +x_44 = lean_ctor_get(x_38, 0); +lean_inc(x_44); +lean_dec(x_38); lean_inc(x_1); -x_52 = l_Lean_mkFVar(x_1); +x_45 = l_Lean_mkFVar(x_1); lean_inc(x_5); -x_53 = l_Lean_Meta_mkNoConfusion(x_36, x_52, x_5, x_49); -if (lean_obj_tag(x_53) == 0) +x_46 = l_Lean_Meta_mkNoConfusion(x_29, x_45, x_5, x_42); +if (lean_obj_tag(x_46) == 0) { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -x_54 = lean_ctor_get(x_53, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_53, 1); -lean_inc(x_55); -lean_dec(x_53); -x_56 = lean_ctor_get(x_50, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -lean_dec(x_56); -x_58 = lean_ctor_get(x_51, 0); -lean_inc(x_58); +lean_object* x_47; 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_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_43, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_49, 0); +lean_inc(x_50); +lean_dec(x_49); +x_51 = lean_ctor_get(x_44, 0); +lean_inc(x_51); +lean_dec(x_44); +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); lean_dec(x_51); -x_59 = lean_ctor_get(x_58, 0); -lean_inc(x_59); -lean_dec(x_58); -x_60 = lean_name_eq(x_57, x_59); -lean_dec(x_59); -lean_dec(x_57); -if (x_60 == 0) -{ -lean_object* x_61; +x_53 = lean_name_eq(x_50, x_52); +lean_dec(x_52); lean_dec(x_50); +if (x_53 == 0) +{ +lean_object* x_54; +lean_dec(x_43); lean_dec(x_2); lean_dec(x_1); -x_61 = l_Lean_Meta_assignExprMVar(x_3, x_54, x_5, x_55); +x_54 = l_Lean_Meta_assignExprMVar(x_3, x_47, x_5, x_48); lean_dec(x_5); -if (lean_obj_tag(x_61) == 0) +if (lean_obj_tag(x_54) == 0) { -uint8_t x_62; -x_62 = !lean_is_exclusive(x_61); -if (x_62 == 0) +uint8_t x_55; +x_55 = !lean_is_exclusive(x_54); +if (x_55 == 0) { -lean_object* x_63; lean_object* x_64; -x_63 = lean_ctor_get(x_61, 0); -lean_dec(x_63); -x_64 = lean_box(0); -lean_ctor_set(x_61, 0, x_64); -return x_61; +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_54, 0); +lean_dec(x_56); +x_57 = lean_box(0); +lean_ctor_set(x_54, 0, x_57); +return x_54; } else { -lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_61, 1); -lean_inc(x_65); -lean_dec(x_61); -x_66 = lean_box(0); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_66); -lean_ctor_set(x_67, 1, x_65); -return x_67; +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_54, 1); +lean_inc(x_58); +lean_dec(x_54); +x_59 = lean_box(0); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_58); +return x_60; } } else { -uint8_t x_68; -x_68 = !lean_is_exclusive(x_61); -if (x_68 == 0) +uint8_t x_61; +x_61 = !lean_is_exclusive(x_54); +if (x_61 == 0) { -return x_61; +return x_54; } else { -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_61, 0); -x_70 = lean_ctor_get(x_61, 1); -lean_inc(x_70); +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_54, 0); +x_63 = lean_ctor_get(x_54, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_54); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} +} +else +{ +lean_object* x_65; +lean_inc(x_5); +lean_inc(x_47); +x_65 = l_Lean_Meta_inferType(x_47, x_5, x_48); +if (lean_obj_tag(x_65) == 0) +{ +lean_object* x_66; lean_object* x_67; lean_object* 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); +lean_inc(x_5); +x_68 = l_Lean_Meta_whnf(x_66, x_5, x_67); +if (lean_obj_tag(x_68) == 0) +{ +lean_object* x_69; +x_69 = lean_ctor_get(x_68, 0); lean_inc(x_69); -lean_dec(x_61); -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 +if (lean_obj_tag(x_69) == 7) { -lean_object* x_72; -lean_inc(x_5); -lean_inc(x_54); -x_72 = l_Lean_Meta_inferType(x_54, x_5, x_55); -if (lean_obj_tag(x_72) == 0) -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -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); -lean_inc(x_5); -x_75 = l_Lean_Meta_whnf(x_73, x_5, x_74); -if (lean_obj_tag(x_75) == 0) -{ -lean_object* x_76; -x_76 = lean_ctor_get(x_75, 0); -lean_inc(x_76); -if (lean_obj_tag(x_76) == 7) -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_dec(x_2); -x_77 = lean_ctor_get(x_75, 1); -lean_inc(x_77); -lean_dec(x_75); -x_78 = lean_ctor_get(x_76, 1); -lean_inc(x_78); -lean_dec(x_76); -x_79 = l_Lean_Expr_headBeta(x_78); +x_70 = lean_ctor_get(x_68, 1); +lean_inc(x_70); +lean_dec(x_68); +x_71 = lean_ctor_get(x_69, 1); +lean_inc(x_71); +lean_dec(x_69); +x_72 = l_Lean_Expr_headBeta(x_71); lean_inc(x_3); -x_80 = l_Lean_Meta_getMVarTag(x_3, x_5, x_77); -if (lean_obj_tag(x_80) == 0) +x_73 = l_Lean_Meta_getMVarTag(x_3, x_5, x_70); +if (lean_obj_tag(x_73) == 0) { -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; lean_object* x_88; -x_81 = lean_ctor_get(x_80, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_80, 1); -lean_inc(x_82); -lean_dec(x_80); -x_83 = 2; +lean_object* x_74; lean_object* x_75; uint8_t x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_74 = lean_ctor_get(x_73, 0); +lean_inc(x_74); +x_75 = lean_ctor_get(x_73, 1); +lean_inc(x_75); +lean_dec(x_73); +x_76 = 2; lean_inc(x_5); -x_84 = l_Lean_Meta_mkFreshExprMVar(x_79, x_81, x_83, x_5, x_82); -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); -lean_inc(x_85); -x_87 = l_Lean_mkApp(x_54, x_85); -x_88 = l_Lean_Meta_assignExprMVar(x_3, x_87, x_5, x_86); -if (lean_obj_tag(x_88) == 0) +x_77 = l_Lean_Meta_mkFreshExprMVar(x_72, x_74, x_76, x_5, x_75); +x_78 = lean_ctor_get(x_77, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_77, 1); +lean_inc(x_79); +lean_dec(x_77); +lean_inc(x_78); +x_80 = l_Lean_mkApp(x_47, x_78); +x_81 = l_Lean_Meta_assignExprMVar(x_3, x_80, x_5, x_79); +if (lean_obj_tag(x_81) == 0) { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_88, 1); -lean_inc(x_89); -lean_dec(x_88); -x_90 = l_Lean_Expr_mvarId_x21(x_85); -lean_dec(x_85); -x_91 = l_Lean_Meta_tryClear(x_90, x_1, x_5, x_89); +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_81, 1); +lean_inc(x_82); +lean_dec(x_81); +x_83 = l_Lean_Expr_mvarId_x21(x_78); +lean_dec(x_78); +x_84 = l_Lean_Meta_tryClear(x_83, x_1, x_5, x_82); lean_dec(x_5); -if (lean_obj_tag(x_91) == 0) +if (lean_obj_tag(x_84) == 0) { -uint8_t x_92; -x_92 = !lean_is_exclusive(x_91); -if (x_92 == 0) +uint8_t x_85; +x_85 = !lean_is_exclusive(x_84); +if (x_85 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_91, 0); -x_94 = lean_ctor_get(x_50, 4); -lean_inc(x_94); -lean_dec(x_50); -x_95 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_95, 0, x_93); -lean_ctor_set(x_95, 1, x_94); -lean_ctor_set(x_91, 0, x_95); -return x_91; +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_84, 0); +x_87 = lean_ctor_get(x_43, 4); +lean_inc(x_87); +lean_dec(x_43); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +lean_ctor_set(x_84, 0, x_88); +return x_84; } 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_91, 0); -x_97 = lean_ctor_get(x_91, 1); -lean_inc(x_97); +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_84, 0); +x_90 = lean_ctor_get(x_84, 1); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_84); +x_91 = lean_ctor_get(x_43, 4); +lean_inc(x_91); +lean_dec(x_43); +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_89); +lean_ctor_set(x_92, 1, x_91); +x_93 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_90); +return x_93; +} +} +else +{ +uint8_t x_94; +lean_dec(x_43); +x_94 = !lean_is_exclusive(x_84); +if (x_94 == 0) +{ +return x_84; +} +else +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_84, 0); +x_96 = lean_ctor_get(x_84, 1); lean_inc(x_96); -lean_dec(x_91); -x_98 = lean_ctor_get(x_50, 4); -lean_inc(x_98); -lean_dec(x_50); -x_99 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_98); -x_100 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_100, 0, x_99); -lean_ctor_set(x_100, 1, x_97); -return x_100; -} -} -else -{ -uint8_t x_101; -lean_dec(x_50); -x_101 = !lean_is_exclusive(x_91); -if (x_101 == 0) -{ -return x_91; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_91, 0); -x_103 = lean_ctor_get(x_91, 1); -lean_inc(x_103); -lean_inc(x_102); -lean_dec(x_91); -x_104 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_104, 0, x_102); -lean_ctor_set(x_104, 1, x_103); -return x_104; +lean_inc(x_95); +lean_dec(x_84); +x_97 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_97, 0, x_95); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } else { -uint8_t x_105; -lean_dec(x_85); -lean_dec(x_50); +uint8_t x_98; +lean_dec(x_78); +lean_dec(x_43); lean_dec(x_5); lean_dec(x_1); -x_105 = !lean_is_exclusive(x_88); -if (x_105 == 0) +x_98 = !lean_is_exclusive(x_81); +if (x_98 == 0) { -return x_88; +return x_81; +} +else +{ +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_81, 0); +x_100 = lean_ctor_get(x_81, 1); +lean_inc(x_100); +lean_inc(x_99); +lean_dec(x_81); +x_101 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_101, 0, x_99); +lean_ctor_set(x_101, 1, x_100); +return x_101; +} +} +} +else +{ +uint8_t x_102; +lean_dec(x_72); +lean_dec(x_47); +lean_dec(x_43); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_1); +x_102 = !lean_is_exclusive(x_73); +if (x_102 == 0) +{ +return x_73; +} +else +{ +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_73, 0); +x_104 = lean_ctor_get(x_73, 1); +lean_inc(x_104); +lean_inc(x_103); +lean_dec(x_73); +x_105 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_105, 0, x_103); +lean_ctor_set(x_105, 1, x_104); +return x_105; +} +} } else { lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_88, 0); -x_107 = lean_ctor_get(x_88, 1); -lean_inc(x_107); +lean_dec(x_69); +lean_dec(x_47); +lean_dec(x_43); +lean_dec(x_1); +x_106 = lean_ctor_get(x_68, 1); lean_inc(x_106); -lean_dec(x_88); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_106); -lean_ctor_set(x_108, 1, x_107); +lean_dec(x_68); +x_107 = l_Lean_Meta_injectionCore___lambda__1___closed__8; +x_108 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_107, x_5, x_106); +lean_dec(x_5); return x_108; } } -} else { uint8_t x_109; -lean_dec(x_79); -lean_dec(x_54); -lean_dec(x_50); +lean_dec(x_47); +lean_dec(x_43); lean_dec(x_5); lean_dec(x_3); +lean_dec(x_2); lean_dec(x_1); -x_109 = !lean_is_exclusive(x_80); +x_109 = !lean_is_exclusive(x_68); if (x_109 == 0) { -return x_80; +return x_68; } else { lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_80, 0); -x_111 = lean_ctor_get(x_80, 1); +x_110 = lean_ctor_get(x_68, 0); +x_111 = lean_ctor_get(x_68, 1); lean_inc(x_111); lean_inc(x_110); -lean_dec(x_80); +lean_dec(x_68); x_112 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_112, 0, x_110); lean_ctor_set(x_112, 1, x_111); @@ -799,247 +836,202 @@ return x_112; } else { -lean_object* x_113; lean_object* x_114; lean_object* x_115; -lean_dec(x_76); -lean_dec(x_54); -lean_dec(x_50); -lean_dec(x_1); -x_113 = lean_ctor_get(x_75, 1); -lean_inc(x_113); -lean_dec(x_75); -x_114 = l_Lean_Meta_injectionCore___lambda__1___closed__8; -x_115 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_114, x_5, x_113); -lean_dec(x_5); -return x_115; -} -} -else -{ -uint8_t x_116; -lean_dec(x_54); -lean_dec(x_50); +uint8_t x_113; +lean_dec(x_47); +lean_dec(x_43); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_116 = !lean_is_exclusive(x_75); -if (x_116 == 0) +x_113 = !lean_is_exclusive(x_65); +if (x_113 == 0) { -return x_75; +return x_65; } else { -lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_117 = lean_ctor_get(x_75, 0); -x_118 = lean_ctor_get(x_75, 1); +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_65, 0); +x_115 = lean_ctor_get(x_65, 1); +lean_inc(x_115); +lean_inc(x_114); +lean_dec(x_65); +x_116 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_116, 0, x_114); +lean_ctor_set(x_116, 1, x_115); +return x_116; +} +} +} +} +else +{ +uint8_t x_117; +lean_dec(x_44); +lean_dec(x_43); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_117 = !lean_is_exclusive(x_46); +if (x_117 == 0) +{ +return x_46; +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_46, 0); +x_119 = lean_ctor_get(x_46, 1); +lean_inc(x_119); lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_75); -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; +lean_dec(x_46); +x_120 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_120, 0, x_118); +lean_ctor_set(x_120, 1, x_119); +return x_120; +} +} } } } else { -uint8_t x_120; -lean_dec(x_54); -lean_dec(x_50); +uint8_t x_121; +lean_dec(x_26); +lean_dec(x_23); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_120 = !lean_is_exclusive(x_72); -if (x_120 == 0) +x_121 = !lean_is_exclusive(x_28); +if (x_121 == 0) { -return x_72; +return x_28; } else { -lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_121 = lean_ctor_get(x_72, 0); -x_122 = lean_ctor_get(x_72, 1); +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_28, 0); +x_123 = lean_ctor_get(x_28, 1); +lean_inc(x_123); lean_inc(x_122); -lean_inc(x_121); -lean_dec(x_72); -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_51); -lean_dec(x_50); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_124 = !lean_is_exclusive(x_53); -if (x_124 == 0) -{ -return x_53; -} -else -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; -x_125 = lean_ctor_get(x_53, 0); -x_126 = lean_ctor_get(x_53, 1); -lean_inc(x_126); -lean_inc(x_125); -lean_dec(x_53); -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_33); -lean_dec(x_30); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_128 = !lean_is_exclusive(x_35); -if (x_128 == 0) -{ -return x_35; -} -else -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_129 = lean_ctor_get(x_35, 0); -x_130 = lean_ctor_get(x_35, 1); -lean_inc(x_130); -lean_inc(x_129); -lean_dec(x_35); -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; -} -} -} -else -{ -uint8_t x_132; -lean_dec(x_30); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_132 = !lean_is_exclusive(x_32); -if (x_132 == 0) -{ -return x_32; -} -else -{ -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_32, 0); -x_134 = lean_ctor_get(x_32, 1); -lean_inc(x_134); -lean_inc(x_133); -lean_dec(x_32); -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 -{ -uint8_t x_136; lean_dec(x_28); +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_23); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_136 = !lean_is_exclusive(x_29); -if (x_136 == 0) +x_125 = !lean_is_exclusive(x_25); +if (x_125 == 0) { -return x_29; +return x_25; } else { -lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_137 = lean_ctor_get(x_29, 0); -x_138 = lean_ctor_get(x_29, 1); -lean_inc(x_138); -lean_inc(x_137); -lean_dec(x_29); -x_139 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_139, 0, x_137); -lean_ctor_set(x_139, 1, x_138); -return x_139; +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_25, 0); +x_127 = lean_ctor_get(x_25, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_25); +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_21); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_129 = !lean_is_exclusive(x_22); +if (x_129 == 0) +{ +return x_22; +} +else +{ +lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_130 = lean_ctor_get(x_22, 0); +x_131 = lean_ctor_get(x_22, 1); +lean_inc(x_131); +lean_inc(x_130); +lean_dec(x_22); +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_140; +uint8_t x_133; lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_140 = !lean_is_exclusive(x_11); -if (x_140 == 0) +x_133 = !lean_is_exclusive(x_11); +if (x_133 == 0) { return x_11; } else { -lean_object* x_141; lean_object* x_142; lean_object* x_143; -x_141 = lean_ctor_get(x_11, 0); -x_142 = lean_ctor_get(x_11, 1); -lean_inc(x_142); -lean_inc(x_141); +lean_object* x_134; lean_object* x_135; lean_object* x_136; +x_134 = lean_ctor_get(x_11, 0); +x_135 = lean_ctor_get(x_11, 1); +lean_inc(x_135); +lean_inc(x_134); lean_dec(x_11); -x_143 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_143, 0, x_141); -lean_ctor_set(x_143, 1, x_142); -return x_143; +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_144; +uint8_t x_137; lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_144 = !lean_is_exclusive(x_7); -if (x_144 == 0) +x_137 = !lean_is_exclusive(x_7); +if (x_137 == 0) { return x_7; } else { -lean_object* x_145; lean_object* x_146; lean_object* x_147; -x_145 = lean_ctor_get(x_7, 0); -x_146 = lean_ctor_get(x_7, 1); -lean_inc(x_146); -lean_inc(x_145); +lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_138 = lean_ctor_get(x_7, 0); +x_139 = lean_ctor_get(x_7, 1); +lean_inc(x_139); +lean_inc(x_138); lean_dec(x_7); -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_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; } } } @@ -1171,485 +1163,473 @@ return x_7; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_free_object(x_7); -x_15 = lean_unsigned_to_nat(0u); -x_16 = l_Lean_Expr_getAppNumArgsAux___main(x_9, x_15); -x_17 = lean_unsigned_to_nat(1u); -x_18 = lean_nat_sub(x_16, x_17); -x_19 = lean_nat_sub(x_18, x_17); -lean_dec(x_18); -x_20 = l_Lean_Expr_getRevArg_x21___main(x_9, x_19); -x_21 = lean_nat_sub(x_16, x_12); +x_15 = l_Lean_Expr_appFn_x21(x_9); +x_16 = l_Lean_Expr_appFn_x21(x_15); +lean_dec(x_15); +x_17 = l_Lean_Expr_appArg_x21(x_16); lean_dec(x_16); -x_22 = lean_nat_sub(x_21, x_17); -lean_dec(x_21); -x_23 = l_Lean_Expr_getRevArg_x21___main(x_9, x_22); +x_18 = l_Lean_Expr_appArg_x21(x_9); lean_dec(x_9); lean_inc(x_1); -x_24 = l_Lean_mkFVar(x_1); +x_19 = l_Lean_mkFVar(x_1); lean_inc(x_4); -x_25 = l_Lean_Meta_mkEqOfHEq(x_24, x_4, x_10); -if (lean_obj_tag(x_25) == 0) +x_20 = l_Lean_Meta_mkEqOfHEq(x_19, x_4, x_10); +if (lean_obj_tag(x_20) == 0) { -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -lean_inc(x_4); -x_28 = l_Lean_Meta_mkEq(x_20, x_23, x_4, x_27); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = l_Lean_LocalDecl_userName(x_3); -x_32 = l_Lean_Meta_assert(x_2, x_31, x_29, x_26, x_4, x_30); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Lean_Meta_clear(x_33, x_1, x_4, x_34); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_object* x_39; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -lean_dec(x_35); -x_38 = 0; -x_39 = l_Lean_Meta_intro1(x_36, x_38, x_4, x_37); -lean_dec(x_4); -if (lean_obj_tag(x_39) == 0) -{ -uint8_t x_40; -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) -{ -return x_39; -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_39, 0); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_39); -x_43 = lean_alloc_ctor(0, 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; -x_44 = !lean_is_exclusive(x_39); -if (x_44 == 0) -{ -return x_39; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_39, 0); -x_46 = lean_ctor_get(x_39, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_39); -x_47 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_47, 0, x_45); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -} -else -{ -uint8_t x_48; -lean_dec(x_4); -x_48 = !lean_is_exclusive(x_35); -if (x_48 == 0) -{ -return x_35; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_35, 0); -x_50 = lean_ctor_get(x_35, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_35); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -else -{ -uint8_t x_52; -lean_dec(x_4); -lean_dec(x_1); -x_52 = !lean_is_exclusive(x_32); -if (x_52 == 0) -{ -return x_32; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_32, 0); -x_54 = lean_ctor_get(x_32, 1); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_32); -x_55 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -return x_55; -} -} -} -else -{ -uint8_t x_56; -lean_dec(x_26); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_56 = !lean_is_exclusive(x_28); -if (x_56 == 0) -{ -return x_28; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_28, 0); -x_58 = lean_ctor_get(x_28, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_28); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -return x_59; -} -} -} -else -{ -uint8_t x_60; -lean_dec(x_23); +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); lean_dec(x_20); +lean_inc(x_4); +x_23 = l_Lean_Meta_mkEq(x_17, x_18, x_4, 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; +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 = l_Lean_LocalDecl_userName(x_3); +x_27 = l_Lean_Meta_assert(x_2, x_26, x_24, x_21, x_4, x_25); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +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 = l_Lean_Meta_clear(x_28, x_1, x_4, x_29); +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_31; lean_object* x_32; uint8_t x_33; lean_object* x_34; +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); +lean_dec(x_30); +x_33 = 0; +x_34 = l_Lean_Meta_intro1(x_31, x_33, x_4, x_32); +lean_dec(x_4); +if (lean_obj_tag(x_34) == 0) +{ +uint8_t x_35; +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(0, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +else +{ +uint8_t x_39; +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 +{ +uint8_t x_43; +lean_dec(x_4); +x_43 = !lean_is_exclusive(x_30); +if (x_43 == 0) +{ +return x_30; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_30, 0); +x_45 = lean_ctor_get(x_30, 1); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_30); +x_46 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_46, 0, x_44); +lean_ctor_set(x_46, 1, x_45); +return x_46; +} +} +} +else +{ +uint8_t x_47; +lean_dec(x_4); +lean_dec(x_1); +x_47 = !lean_is_exclusive(x_27); +if (x_47 == 0) +{ +return x_27; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_27, 0); +x_49 = lean_ctor_get(x_27, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_27); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +else +{ +uint8_t x_51; +lean_dec(x_21); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_60 = !lean_is_exclusive(x_25); -if (x_60 == 0) +x_51 = !lean_is_exclusive(x_23); +if (x_51 == 0) { -return x_25; +return x_23; } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_25, 0); -x_62 = lean_ctor_get(x_25, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_25); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_23, 0); +x_53 = lean_ctor_get(x_23, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_23); +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 { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_64 = lean_ctor_get(x_7, 0); -x_65 = lean_ctor_get(x_7, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_7); -x_66 = l_Lean_Expr_heq_x3f___closed__2; -x_67 = lean_unsigned_to_nat(4u); -x_68 = l_Lean_Expr_isAppOfArity___main(x_64, x_66, x_67); -if (x_68 == 0) -{ -lean_object* x_69; lean_object* x_70; -lean_dec(x_64); +uint8_t x_55; +lean_dec(x_18); +lean_dec(x_17); lean_dec(x_4); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_1); -lean_ctor_set(x_69, 1, x_2); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_65); -return x_70; +lean_dec(x_2); +lean_dec(x_1); +x_55 = !lean_is_exclusive(x_20); +if (x_55 == 0) +{ +return x_20; } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_71 = lean_unsigned_to_nat(0u); -x_72 = l_Lean_Expr_getAppNumArgsAux___main(x_64, x_71); -x_73 = lean_unsigned_to_nat(1u); -x_74 = lean_nat_sub(x_72, x_73); -x_75 = lean_nat_sub(x_74, x_73); -lean_dec(x_74); -x_76 = l_Lean_Expr_getRevArg_x21___main(x_64, x_75); -x_77 = lean_nat_sub(x_72, x_67); -lean_dec(x_72); -x_78 = lean_nat_sub(x_77, x_73); -lean_dec(x_77); -x_79 = l_Lean_Expr_getRevArg_x21___main(x_64, x_78); -lean_dec(x_64); +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_20, 0); +x_57 = lean_ctor_get(x_20, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_20); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); +return x_58; +} +} +} +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_59 = lean_ctor_get(x_7, 0); +x_60 = lean_ctor_get(x_7, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_7); +x_61 = l_Lean_Expr_heq_x3f___closed__2; +x_62 = lean_unsigned_to_nat(4u); +x_63 = l_Lean_Expr_isAppOfArity___main(x_59, x_61, x_62); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; +lean_dec(x_59); +lean_dec(x_4); +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_alloc_ctor(0, 2, 0); +lean_ctor_set(x_65, 0, x_64); +lean_ctor_set(x_65, 1, x_60); +return x_65; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_66 = l_Lean_Expr_appFn_x21(x_59); +x_67 = l_Lean_Expr_appFn_x21(x_66); +lean_dec(x_66); +x_68 = l_Lean_Expr_appArg_x21(x_67); +lean_dec(x_67); +x_69 = l_Lean_Expr_appArg_x21(x_59); +lean_dec(x_59); lean_inc(x_1); -x_80 = l_Lean_mkFVar(x_1); +x_70 = l_Lean_mkFVar(x_1); lean_inc(x_4); -x_81 = l_Lean_Meta_mkEqOfHEq(x_80, x_4, x_65); +x_71 = l_Lean_Meta_mkEqOfHEq(x_70, x_4, x_60); +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); +lean_inc(x_4); +x_74 = l_Lean_Meta_mkEq(x_68, x_69, x_4, x_73); +if (lean_obj_tag(x_74) == 0) +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +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 = l_Lean_LocalDecl_userName(x_3); +x_78 = l_Lean_Meta_assert(x_2, x_77, x_75, x_72, x_4, x_76); +if (lean_obj_tag(x_78) == 0) +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_78, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_78, 1); +lean_inc(x_80); +lean_dec(x_78); +x_81 = l_Lean_Meta_clear(x_79, x_1, x_4, x_80); if (lean_obj_tag(x_81) == 0) { -lean_object* x_82; lean_object* x_83; lean_object* x_84; +lean_object* x_82; lean_object* x_83; uint8_t x_84; lean_object* x_85; 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); -lean_inc(x_4); -x_84 = l_Lean_Meta_mkEq(x_76, x_79, x_4, x_83); -if (lean_obj_tag(x_84) == 0) +x_84 = 0; +x_85 = l_Lean_Meta_intro1(x_82, x_84, x_4, x_83); +lean_dec(x_4); +if (lean_obj_tag(x_85) == 0) { -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_84, 1); +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; +x_86 = lean_ctor_get(x_85, 0); lean_inc(x_86); -lean_dec(x_84); -x_87 = l_Lean_LocalDecl_userName(x_3); -x_88 = l_Lean_Meta_assert(x_2, x_87, x_85, x_82, x_4, x_86); -if (lean_obj_tag(x_88) == 0) +x_87 = lean_ctor_get(x_85, 1); +lean_inc(x_87); +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_88 = x_85; +} else { + lean_dec_ref(x_85); + x_88 = lean_box(0); +} +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 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_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_88, 1); +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_90 = lean_ctor_get(x_85, 0); lean_inc(x_90); -lean_dec(x_88); -x_91 = l_Lean_Meta_clear(x_89, x_1, x_4, x_90); -if (lean_obj_tag(x_91) == 0) -{ -lean_object* x_92; lean_object* x_93; uint8_t x_94; lean_object* x_95; -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 = 0; -x_95 = l_Lean_Meta_intro1(x_92, x_94, x_4, x_93); -lean_dec(x_4); -if (lean_obj_tag(x_95) == 0) -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_96 = lean_ctor_get(x_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; +x_91 = lean_ctor_get(x_85, 1); +lean_inc(x_91); +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_92 = x_85; } else { - lean_dec_ref(x_95); - x_98 = lean_box(0); + lean_dec_ref(x_85); + x_92 = lean_box(0); } -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_92)) { + x_93 = lean_alloc_ctor(1, 2, 0); } else { - x_99 = x_98; + x_93 = x_92; } -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -return x_99; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_100 = lean_ctor_get(x_95, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_95, 1); -lean_inc(x_101); -if (lean_is_exclusive(x_95)) { - lean_ctor_release(x_95, 0); - lean_ctor_release(x_95, 1); - x_102 = x_95; -} else { - lean_dec_ref(x_95); - x_102 = lean_box(0); -} -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(1, 2, 0); -} else { - x_103 = x_102; -} -lean_ctor_set(x_103, 0, x_100); -lean_ctor_set(x_103, 1, x_101); -return x_103; +lean_ctor_set(x_93, 0, x_90); +lean_ctor_set(x_93, 1, x_91); +return x_93; } } else { -lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_dec(x_4); -x_104 = lean_ctor_get(x_91, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_91, 1); -lean_inc(x_105); -if (lean_is_exclusive(x_91)) { - lean_ctor_release(x_91, 0); - lean_ctor_release(x_91, 1); - x_106 = x_91; -} else { - lean_dec_ref(x_91); - x_106 = lean_box(0); -} -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(1, 2, 0); -} else { - x_107 = x_106; -} -lean_ctor_set(x_107, 0, x_104); -lean_ctor_set(x_107, 1, x_105); -return x_107; -} -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -lean_dec(x_4); -lean_dec(x_1); -x_108 = lean_ctor_get(x_88, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_88, 1); -lean_inc(x_109); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_110 = x_88; -} else { - lean_dec_ref(x_88); - 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_object* x_113; lean_object* x_114; lean_object* x_115; -lean_dec(x_82); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_112 = lean_ctor_get(x_84, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_84, 1); -lean_inc(x_113); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_114 = x_84; -} else { - lean_dec_ref(x_84); - 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 -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -lean_dec(x_79); -lean_dec(x_76); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_116 = lean_ctor_get(x_81, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_81, 1); -lean_inc(x_117); +x_94 = lean_ctor_get(x_81, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_81, 1); +lean_inc(x_95); if (lean_is_exclusive(x_81)) { lean_ctor_release(x_81, 0); lean_ctor_release(x_81, 1); - x_118 = x_81; + x_96 = x_81; } else { lean_dec_ref(x_81); - x_118 = lean_box(0); + x_96 = lean_box(0); } -if (lean_is_scalar(x_118)) { - x_119 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_96)) { + x_97 = lean_alloc_ctor(1, 2, 0); } else { - x_119 = x_118; + x_97 = x_96; } -lean_ctor_set(x_119, 0, x_116); -lean_ctor_set(x_119, 1, x_117); -return x_119; +lean_ctor_set(x_97, 0, x_94); +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_4); +lean_dec(x_1); +x_98 = lean_ctor_get(x_78, 0); +lean_inc(x_98); +x_99 = lean_ctor_get(x_78, 1); +lean_inc(x_99); +if (lean_is_exclusive(x_78)) { + lean_ctor_release(x_78, 0); + lean_ctor_release(x_78, 1); + x_100 = x_78; +} else { + lean_dec_ref(x_78); + 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_dec(x_72); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_102 = lean_ctor_get(x_74, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_74, 1); +lean_inc(x_103); +if (lean_is_exclusive(x_74)) { + lean_ctor_release(x_74, 0); + lean_ctor_release(x_74, 1); + x_104 = x_74; +} else { + lean_dec_ref(x_74); + x_104 = lean_box(0); +} +if (lean_is_scalar(x_104)) { + x_105 = lean_alloc_ctor(1, 2, 0); +} else { + x_105 = x_104; +} +lean_ctor_set(x_105, 0, x_102); +lean_ctor_set(x_105, 1, x_103); +return x_105; +} +} +else +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; +lean_dec(x_69); +lean_dec(x_68); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_106 = lean_ctor_get(x_71, 0); +lean_inc(x_106); +x_107 = lean_ctor_get(x_71, 1); +lean_inc(x_107); +if (lean_is_exclusive(x_71)) { + lean_ctor_release(x_71, 0); + lean_ctor_release(x_71, 1); + x_108 = x_71; +} else { + lean_dec_ref(x_71); + x_108 = lean_box(0); +} +if (lean_is_scalar(x_108)) { + x_109 = lean_alloc_ctor(1, 2, 0); +} else { + x_109 = x_108; +} +lean_ctor_set(x_109, 0, x_106); +lean_ctor_set(x_109, 1, x_107); +return x_109; } } } } else { -uint8_t x_120; +uint8_t x_110; lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_120 = !lean_is_exclusive(x_7); -if (x_120 == 0) +x_110 = !lean_is_exclusive(x_7); +if (x_110 == 0) { return x_7; } else { -lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_121 = lean_ctor_get(x_7, 0); -x_122 = lean_ctor_get(x_7, 1); -lean_inc(x_122); -lean_inc(x_121); +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_7, 0); +x_112 = lean_ctor_get(x_7, 1); +lean_inc(x_112); +lean_inc(x_111); lean_dec(x_7); -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; +x_113 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_113, 0, x_111); +lean_ctor_set(x_113, 1, x_112); +return x_113; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Intro.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Intro.c index f6cb2edce6..7a6a70ceb6 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Intro.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Intro.c @@ -1049,82 +1049,89 @@ return x_37; } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; +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_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_46); -lean_ctor_set(x_48, 1, x_47); -lean_ctor_set(x_48, 2, x_31); -lean_ctor_set(x_38, 2, x_48); +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; } } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_49 = lean_ctor_get(x_38, 0); -x_50 = lean_ctor_get(x_38, 1); -x_51 = lean_ctor_get(x_38, 3); -x_52 = lean_ctor_get(x_38, 4); -x_53 = lean_ctor_get(x_38, 5); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +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_inc(x_51); lean_inc(x_50); -lean_inc(x_49); lean_dec(x_38); -x_54 = lean_ctor_get(x_39, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_39, 1); +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); - x_56 = x_39; + lean_ctor_release(x_39, 3); + x_58 = x_39; } else { lean_dec_ref(x_39); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 4, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_54); -lean_ctor_set(x_57, 1, x_55); -lean_ctor_set(x_57, 2, x_31); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_49); -lean_ctor_set(x_58, 1, x_50); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_51); -lean_ctor_set(x_58, 4, x_52); -lean_ctor_set(x_58, 5, x_53); -lean_ctor_set(x_37, 1, 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_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; } } 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; -x_59 = lean_ctor_get(x_37, 0); -lean_inc(x_59); -lean_dec(x_37); -x_60 = lean_ctor_get(x_38, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_38, 1); +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); -x_62 = lean_ctor_get(x_38, 3); +lean_dec(x_37); +x_62 = lean_ctor_get(x_38, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_38, 4); +x_63 = lean_ctor_get(x_38, 1); lean_inc(x_63); -x_64 = lean_ctor_get(x_38, 5); +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); @@ -1132,1900 +1139,1999 @@ if (lean_is_exclusive(x_38)) { lean_ctor_release(x_38, 3); lean_ctor_release(x_38, 4); lean_ctor_release(x_38, 5); - x_65 = x_38; + x_67 = x_38; } else { lean_dec_ref(x_38); - x_65 = lean_box(0); + x_67 = lean_box(0); } -x_66 = lean_ctor_get(x_39, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_39, 1); -lean_inc(x_67); +x_68 = lean_ctor_get(x_39, 0); +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); - x_68 = x_39; + lean_ctor_release(x_39, 3); + x_71 = x_39; } else { lean_dec_ref(x_39); - x_68 = lean_box(0); + x_71 = lean_box(0); } -if (lean_is_scalar(x_68)) { - x_69 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_71)) { + x_72 = lean_alloc_ctor(0, 4, 0); } else { - x_69 = x_68; + x_72 = x_71; } -lean_ctor_set(x_69, 0, x_66); -lean_ctor_set(x_69, 1, x_67); -lean_ctor_set(x_69, 2, x_31); -if (lean_is_scalar(x_65)) { - x_70 = lean_alloc_ctor(0, 6, 0); +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_70 = x_65; + x_73 = x_67; } -lean_ctor_set(x_70, 0, x_60); -lean_ctor_set(x_70, 1, x_61); -lean_ctor_set(x_70, 2, x_69); -lean_ctor_set(x_70, 3, x_62); -lean_ctor_set(x_70, 4, x_63); -lean_ctor_set(x_70, 5, x_64); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_59); -lean_ctor_set(x_71, 1, x_70); -return x_71; +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; } } else { -lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_72 = lean_ctor_get(x_37, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_72, 2); -lean_inc(x_73); -x_74 = !lean_is_exclusive(x_37); -if (x_74 == 0) -{ -lean_object* x_75; uint8_t x_76; +lean_object* x_75; lean_object* x_76; uint8_t x_77; x_75 = lean_ctor_get(x_37, 1); -lean_dec(x_75); -x_76 = !lean_is_exclusive(x_72); -if (x_76 == 0) +lean_inc(x_75); +x_76 = lean_ctor_get(x_75, 2); +lean_inc(x_76); +x_77 = !lean_is_exclusive(x_37); +if (x_77 == 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_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_79; -x_79 = lean_ctor_get(x_73, 2); -lean_dec(x_79); -lean_ctor_set(x_73, 2, x_31); +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_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_73, 0); -x_81 = lean_ctor_get(x_73, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_73); -x_82 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -lean_ctor_set(x_82, 2, x_31); -lean_ctor_set(x_72, 2, x_82); -return x_37; -} -} -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; -x_83 = lean_ctor_get(x_72, 0); -x_84 = lean_ctor_get(x_72, 1); -x_85 = lean_ctor_get(x_72, 3); -x_86 = lean_ctor_get(x_72, 4); -x_87 = lean_ctor_get(x_72, 5); -lean_inc(x_87); -lean_inc(x_86); +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_72); -x_88 = lean_ctor_get(x_73, 0); -lean_inc(x_88); -x_89 = lean_ctor_get(x_73, 1); -lean_inc(x_89); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - x_90 = x_73; -} else { - lean_dec_ref(x_73); - x_90 = lean_box(0); -} -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 3, 0); -} else { - x_91 = x_90; -} -lean_ctor_set(x_91, 0, x_88); -lean_ctor_set(x_91, 1, x_89); -lean_ctor_set(x_91, 2, x_31); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_83); -lean_ctor_set(x_92, 1, x_84); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_85); -lean_ctor_set(x_92, 4, x_86); -lean_ctor_set(x_92, 5, x_87); -lean_ctor_set(x_37, 1, x_92); +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_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; -x_93 = lean_ctor_get(x_37, 0); +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_87 = lean_ctor_get(x_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); -lean_dec(x_37); -x_94 = lean_ctor_get(x_72, 0); +x_94 = lean_ctor_get(x_76, 3); lean_inc(x_94); -x_95 = lean_ctor_get(x_72, 1); -lean_inc(x_95); -x_96 = lean_ctor_get(x_72, 3); -lean_inc(x_96); -x_97 = lean_ctor_get(x_72, 4); -lean_inc(x_97); -x_98 = lean_ctor_get(x_72, 5); +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; +} else { + lean_dec_ref(x_76); + 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_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); -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_99 = x_72; -} else { - lean_dec_ref(x_72); - x_99 = lean_box(0); -} -x_100 = lean_ctor_get(x_73, 0); +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_73, 1); +x_101 = lean_ctor_get(x_75, 3); lean_inc(x_101); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - x_102 = x_73; +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; } else { - lean_dec_ref(x_73); - x_102 = lean_box(0); + lean_dec_ref(x_75); + x_104 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 3, 0); +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 { - x_103 = x_102; + lean_dec_ref(x_76); + x_108 = lean_box(0); } -lean_ctor_set(x_103, 0, x_100); -lean_ctor_set(x_103, 1, x_101); -lean_ctor_set(x_103, 2, x_31); -if (lean_is_scalar(x_99)) { - x_104 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_108)) { + x_109 = lean_alloc_ctor(0, 4, 0); } else { - x_104 = x_99; + x_109 = x_108; } -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); -x_105 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_105, 0, x_93); -lean_ctor_set(x_105, 1, x_104); -return x_105; +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_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_6, 0); -x_107 = lean_ctor_get(x_6, 1); -x_108 = lean_ctor_get(x_6, 2); -x_109 = lean_ctor_get(x_6, 3); -x_110 = lean_ctor_get(x_6, 4); -lean_inc(x_110); -lean_inc(x_109); -lean_inc(x_108); -lean_inc(x_107); -lean_inc(x_106); -lean_dec(x_6); -x_111 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_111, 0, x_25); -lean_ctor_set(x_111, 1, x_13); -x_112 = lean_array_push(x_108, x_111); -x_113 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_113, 0, x_106); -lean_ctor_set(x_113, 1, x_107); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_109); -lean_ctor_set(x_113, 4, x_110); -x_114 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_113, x_24); -if (lean_obj_tag(x_114) == 0) -{ -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_115 = lean_ctor_get(x_114, 1); -lean_inc(x_115); -x_116 = lean_ctor_get(x_115, 2); +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); -x_117 = lean_ctor_get(x_114, 0); -lean_inc(x_117); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_118 = x_114; -} else { - lean_dec_ref(x_114); - x_118 = lean_box(0); -} -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_115, 3); +lean_inc(x_115); +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_115, 4); +x_122 = lean_ctor_get(x_121, 2); lean_inc(x_122); -x_123 = lean_ctor_get(x_115, 5); +x_123 = lean_ctor_get(x_120, 0); lean_inc(x_123); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - lean_ctor_release(x_115, 2); - lean_ctor_release(x_115, 3); - lean_ctor_release(x_115, 4); - lean_ctor_release(x_115, 5); - x_124 = x_115; +if (lean_is_exclusive(x_120)) { + lean_ctor_release(x_120, 0); + lean_ctor_release(x_120, 1); + x_124 = x_120; } else { - lean_dec_ref(x_115); + lean_dec_ref(x_120); x_124 = lean_box(0); } -x_125 = lean_ctor_get(x_116, 0); +x_125 = lean_ctor_get(x_121, 0); lean_inc(x_125); -x_126 = lean_ctor_get(x_116, 1); +x_126 = lean_ctor_get(x_121, 1); lean_inc(x_126); -if (lean_is_exclusive(x_116)) { - lean_ctor_release(x_116, 0); - lean_ctor_release(x_116, 1); - lean_ctor_release(x_116, 2); - x_127 = x_116; +x_127 = lean_ctor_get(x_121, 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; } else { - lean_dec_ref(x_116); - x_127 = lean_box(0); + lean_dec_ref(x_121); + x_130 = lean_box(0); } -if (lean_is_scalar(x_127)) { - x_128 = lean_alloc_ctor(0, 3, 0); -} else { - x_128 = x_127; -} -lean_ctor_set(x_128, 0, x_125); -lean_ctor_set(x_128, 1, x_126); -lean_ctor_set(x_128, 2, x_31); -if (lean_is_scalar(x_124)) { - x_129 = lean_alloc_ctor(0, 6, 0); -} else { - x_129 = x_124; -} -lean_ctor_set(x_129, 0, x_119); -lean_ctor_set(x_129, 1, x_120); -lean_ctor_set(x_129, 2, x_128); -lean_ctor_set(x_129, 3, x_121); -lean_ctor_set(x_129, 4, x_122); -lean_ctor_set(x_129, 5, x_123); -if (lean_is_scalar(x_118)) { - x_130 = lean_alloc_ctor(0, 2, 0); -} else { - x_130 = x_118; -} -lean_ctor_set(x_130, 0, x_117); -lean_ctor_set(x_130, 1, x_129); -return x_130; -} -else -{ -lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_131 = lean_ctor_get(x_114, 1); +x_131 = lean_ctor_get(x_122, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_131, 2); +x_132 = lean_ctor_get(x_122, 1); lean_inc(x_132); -x_133 = lean_ctor_get(x_114, 0); +x_133 = lean_ctor_get(x_122, 3); lean_inc(x_133); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_134 = x_114; +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; } else { - lean_dec_ref(x_114); + lean_dec_ref(x_122); x_134 = lean_box(0); } -x_135 = lean_ctor_get(x_131, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_131, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_131, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_131, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_131, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - lean_ctor_release(x_131, 4); - lean_ctor_release(x_131, 5); - x_140 = x_131; -} else { - lean_dec_ref(x_131); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_132, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_132, 1); -lean_inc(x_142); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - x_143 = x_132; -} else { - lean_dec_ref(x_132); - x_143 = lean_box(0); -} -if (lean_is_scalar(x_143)) { - x_144 = lean_alloc_ctor(0, 3, 0); -} else { - x_144 = x_143; -} -lean_ctor_set(x_144, 0, x_141); -lean_ctor_set(x_144, 1, x_142); -lean_ctor_set(x_144, 2, x_31); -if (lean_is_scalar(x_140)) { - x_145 = lean_alloc_ctor(0, 6, 0); -} else { - x_145 = x_140; -} -lean_ctor_set(x_145, 0, x_135); -lean_ctor_set(x_145, 1, x_136); -lean_ctor_set(x_145, 2, x_144); -lean_ctor_set(x_145, 3, x_137); -lean_ctor_set(x_145, 4, x_138); -lean_ctor_set(x_145, 5, x_139); if (lean_is_scalar(x_134)) { - x_146 = lean_alloc_ctor(1, 2, 0); + x_135 = lean_alloc_ctor(0, 4, 0); } else { - x_146 = x_134; + x_135 = x_134; } -lean_ctor_set(x_146, 0, x_133); -lean_ctor_set(x_146, 1, x_145); -return x_146; +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); +if (lean_is_scalar(x_124)) { + x_137 = lean_alloc_ctor(0, 2, 0); +} else { + x_137 = x_124; +} +lean_ctor_set(x_137, 0, x_123); +lean_ctor_set(x_137, 1, x_136); +return x_137; +} +else +{ +lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; +x_138 = lean_ctor_get(x_120, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_138, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_120, 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); +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; +} else { + lean_dec_ref(x_138); + x_147 = 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; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 4, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_148); +lean_ctor_set(x_152, 1, x_149); +lean_ctor_set(x_152, 2, x_31); +lean_ctor_set(x_152, 3, x_150); +if (lean_is_scalar(x_147)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_147; +} +lean_ctor_set(x_153, 0, x_142); +lean_ctor_set(x_153, 1, x_143); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_144); +lean_ctor_set(x_153, 4, x_145); +lean_ctor_set(x_153, 5, x_146); +if (lean_is_scalar(x_141)) { + x_154 = lean_alloc_ctor(1, 2, 0); +} else { + x_154 = x_141; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; } } } 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; -x_147 = lean_ctor_get(x_29, 0); -x_148 = lean_ctor_get(x_29, 1); -x_149 = lean_ctor_get(x_29, 2); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_dec(x_29); -x_150 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_151 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_24, 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_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); 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; + x_166 = x_6; } else { lean_dec_ref(x_6); - x_157 = lean_box(0); + x_166 = lean_box(0); } -x_158 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_158, 0, x_25); -lean_ctor_set(x_158, 1, x_13); -x_159 = lean_array_push(x_154, x_158); -if (lean_is_scalar(x_157)) { - x_160 = lean_alloc_ctor(0, 5, 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); } else { - x_160 = x_157; + x_169 = x_166; } -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_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_160, x_24); -if (lean_obj_tag(x_161) == 0) +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_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_161, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_162, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_161, 0); -lean_inc(x_164); -if (lean_is_exclusive(x_161)) { - lean_ctor_release(x_161, 0); - lean_ctor_release(x_161, 1); - x_165 = x_161; -} else { - lean_dec_ref(x_161); - x_165 = lean_box(0); -} -x_166 = lean_ctor_get(x_162, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_162, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_162, 3); -lean_inc(x_168); -x_169 = lean_ctor_get(x_162, 4); -lean_inc(x_169); -x_170 = lean_ctor_get(x_162, 5); -lean_inc(x_170); -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_171 = x_162; -} else { - lean_dec_ref(x_162); - x_171 = lean_box(0); -} -x_172 = lean_ctor_get(x_163, 0); +lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; 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_163, 1); +x_173 = lean_ctor_get(x_170, 0); lean_inc(x_173); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - x_174 = x_163; +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_163); + lean_dec_ref(x_170); x_174 = lean_box(0); } -if (lean_is_scalar(x_174)) { - x_175 = lean_alloc_ctor(0, 3, 0); -} else { - x_175 = x_174; -} -lean_ctor_set(x_175, 0, x_172); -lean_ctor_set(x_175, 1, x_173); -lean_ctor_set(x_175, 2, x_149); -if (lean_is_scalar(x_171)) { - x_176 = lean_alloc_ctor(0, 6, 0); -} else { - x_176 = x_171; -} -lean_ctor_set(x_176, 0, x_166); -lean_ctor_set(x_176, 1, x_167); -lean_ctor_set(x_176, 2, x_175); -lean_ctor_set(x_176, 3, x_168); -lean_ctor_set(x_176, 4, x_169); -lean_ctor_set(x_176, 5, x_170); -if (lean_is_scalar(x_165)) { - x_177 = lean_alloc_ctor(0, 2, 0); -} else { - x_177 = x_165; -} -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; lean_object* x_193; -x_178 = lean_ctor_get(x_161, 1); +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_178, 2); +x_179 = lean_ctor_get(x_171, 5); lean_inc(x_179); -x_180 = lean_ctor_get(x_161, 0); -lean_inc(x_180); -if (lean_is_exclusive(x_161)) { - lean_ctor_release(x_161, 0); - lean_ctor_release(x_161, 1); - x_181 = x_161; +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_161); - x_181 = lean_box(0); + lean_dec_ref(x_171); + x_180 = lean_box(0); } -x_182 = lean_ctor_get(x_178, 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_178, 1); +x_183 = lean_ctor_get(x_172, 3); 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; +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_178); - x_187 = lean_box(0); + lean_dec_ref(x_172); + x_184 = lean_box(0); } -x_188 = lean_ctor_get(x_179, 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; +} +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_inc(x_188); -x_189 = lean_ctor_get(x_179, 1); +x_189 = lean_ctor_get(x_188, 2); lean_inc(x_189); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - x_190 = x_179; +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; } else { - lean_dec_ref(x_179); - x_190 = lean_box(0); + lean_dec_ref(x_170); + x_191 = lean_box(0); } -if (lean_is_scalar(x_190)) { - x_191 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_194); +x_195 = lean_ctor_get(x_188, 4); +lean_inc(x_195); +x_196 = lean_ctor_get(x_188, 5); +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 { - x_191 = x_190; + lean_dec_ref(x_188); + x_197 = lean_box(0); } -lean_ctor_set(x_191, 0, x_188); -lean_ctor_set(x_191, 1, x_189); -lean_ctor_set(x_191, 2, x_149); -if (lean_is_scalar(x_187)) { - x_192 = lean_alloc_ctor(0, 6, 0); +x_198 = lean_ctor_get(x_189, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_189, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_189, 3); +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; } else { - x_192 = x_187; + lean_dec_ref(x_189); + x_201 = lean_box(0); } -lean_ctor_set(x_192, 0, x_182); -lean_ctor_set(x_192, 1, x_183); -lean_ctor_set(x_192, 2, x_191); -lean_ctor_set(x_192, 3, x_184); -lean_ctor_set(x_192, 4, x_185); -lean_ctor_set(x_192, 5, x_186); -if (lean_is_scalar(x_181)) { - x_193 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_201)) { + x_202 = lean_alloc_ctor(0, 4, 0); } else { - x_193 = x_181; + x_202 = x_201; } -lean_ctor_set(x_193, 0, x_180); -lean_ctor_set(x_193, 1, x_192); -return x_193; +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); +} 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_191)) { + x_204 = lean_alloc_ctor(1, 2, 0); +} else { + x_204 = x_191; +} +lean_ctor_set(x_204, 0, x_190); +lean_ctor_set(x_204, 1, x_203); +return x_204; } } } 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; 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_194 = lean_ctor_get(x_24, 2); -x_195 = lean_ctor_get(x_24, 0); -x_196 = lean_ctor_get(x_24, 1); -x_197 = lean_ctor_get(x_24, 3); -x_198 = lean_ctor_get(x_24, 4); -x_199 = lean_ctor_get(x_24, 5); -lean_inc(x_199); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_194); -lean_inc(x_196); -lean_inc(x_195); -lean_dec(x_24); -x_200 = lean_ctor_get(x_194, 0); -lean_inc(x_200); -x_201 = lean_ctor_get(x_194, 1); -lean_inc(x_201); -x_202 = lean_ctor_get(x_194, 2); -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); - x_203 = x_194; -} else { - lean_dec_ref(x_194); - x_203 = lean_box(0); -} -x_204 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_203)) { - x_205 = lean_alloc_ctor(0, 3, 0); -} else { - x_205 = x_203; -} -lean_ctor_set(x_205, 0, x_200); -lean_ctor_set(x_205, 1, x_201); -lean_ctor_set(x_205, 2, x_204); -x_206 = lean_alloc_ctor(0, 6, 0); -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); -x_207 = lean_ctor_get(x_6, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_6, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_6, 2); -lean_inc(x_209); -x_210 = lean_ctor_get(x_6, 3); +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); -x_211 = lean_ctor_get(x_6, 4); +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_212 = x_6; + x_224 = x_6; } else { lean_dec_ref(x_6); - x_212 = lean_box(0); + x_224 = lean_box(0); } -x_213 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_213, 0, x_25); -lean_ctor_set(x_213, 1, x_13); -x_214 = lean_array_push(x_209, x_213); -if (lean_is_scalar(x_212)) { - x_215 = lean_alloc_ctor(0, 5, 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_215 = x_212; + x_227 = x_224; } -lean_ctor_set(x_215, 0, x_207); -lean_ctor_set(x_215, 1, x_208); -lean_ctor_set(x_215, 2, x_214); -lean_ctor_set(x_215, 3, x_210); -lean_ctor_set(x_215, 4, x_211); -x_216 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_27, x_215, x_206); -if (lean_obj_tag(x_216) == 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_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_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_217 = lean_ctor_get(x_216, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_217, 2); -lean_inc(x_218); -x_219 = lean_ctor_get(x_216, 0); -lean_inc(x_219); -if (lean_is_exclusive(x_216)) { - lean_ctor_release(x_216, 0); - lean_ctor_release(x_216, 1); - x_220 = x_216; +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_216); - x_220 = lean_box(0); + lean_dec_ref(x_228); + x_232 = lean_box(0); } -x_221 = lean_ctor_get(x_217, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_217, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_217, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_217, 4); -lean_inc(x_224); -x_225 = lean_ctor_get(x_217, 5); -lean_inc(x_225); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - lean_ctor_release(x_217, 2); - lean_ctor_release(x_217, 3); - lean_ctor_release(x_217, 4); - lean_ctor_release(x_217, 5); - x_226 = x_217; +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_217); - x_226 = lean_box(0); + lean_dec_ref(x_229); + x_238 = lean_box(0); } -x_227 = lean_ctor_get(x_218, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_218, 1); -lean_inc(x_228); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - x_229 = x_218; +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_218); - x_229 = lean_box(0); + lean_dec_ref(x_230); + x_242 = lean_box(0); } -if (lean_is_scalar(x_229)) { - x_230 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_242)) { + x_243 = lean_alloc_ctor(0, 4, 0); } else { - x_230 = x_229; + x_243 = x_242; } -lean_ctor_set(x_230, 0, x_227); -lean_ctor_set(x_230, 1, x_228); -lean_ctor_set(x_230, 2, x_202); -if (lean_is_scalar(x_226)) { - x_231 = lean_alloc_ctor(0, 6, 0); +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_231 = x_226; + x_244 = x_238; } -lean_ctor_set(x_231, 0, x_221); -lean_ctor_set(x_231, 1, x_222); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_223); -lean_ctor_set(x_231, 4, x_224); -lean_ctor_set(x_231, 5, x_225); -if (lean_is_scalar(x_220)) { - x_232 = lean_alloc_ctor(0, 2, 0); +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_232 = x_220; + x_245 = x_232; } -lean_ctor_set(x_232, 0, x_219); -lean_ctor_set(x_232, 1, x_231); -return 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_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; -x_233 = lean_ctor_get(x_216, 1); -lean_inc(x_233); -x_234 = lean_ctor_get(x_233, 2); -lean_inc(x_234); -x_235 = lean_ctor_get(x_216, 0); -lean_inc(x_235); -if (lean_is_exclusive(x_216)) { - lean_ctor_release(x_216, 0); - lean_ctor_release(x_216, 1); - x_236 = x_216; +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_216); - x_236 = lean_box(0); + lean_dec_ref(x_228); + x_249 = lean_box(0); } -x_237 = lean_ctor_get(x_233, 0); -lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); -lean_inc(x_238); -x_239 = lean_ctor_get(x_233, 3); -lean_inc(x_239); -x_240 = lean_ctor_get(x_233, 4); -lean_inc(x_240); -x_241 = lean_ctor_get(x_233, 5); -lean_inc(x_241); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - lean_ctor_release(x_233, 2); - lean_ctor_release(x_233, 3); - lean_ctor_release(x_233, 4); - lean_ctor_release(x_233, 5); - x_242 = x_233; +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_233); - x_242 = lean_box(0); + lean_dec_ref(x_246); + x_255 = lean_box(0); } -x_243 = lean_ctor_get(x_234, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_234, 1); -lean_inc(x_244); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - lean_ctor_release(x_234, 2); - x_245 = x_234; +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_234); - x_245 = lean_box(0); + lean_dec_ref(x_247); + x_259 = lean_box(0); } -if (lean_is_scalar(x_245)) { - x_246 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_259)) { + x_260 = lean_alloc_ctor(0, 4, 0); } else { - x_246 = x_245; + x_260 = x_259; } -lean_ctor_set(x_246, 0, x_243); -lean_ctor_set(x_246, 1, x_244); -lean_ctor_set(x_246, 2, x_202); -if (lean_is_scalar(x_242)) { - x_247 = lean_alloc_ctor(0, 6, 0); +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_247 = x_242; + x_261 = x_255; } -lean_ctor_set(x_247, 0, x_237); -lean_ctor_set(x_247, 1, x_238); -lean_ctor_set(x_247, 2, x_246); -lean_ctor_set(x_247, 3, x_239); -lean_ctor_set(x_247, 4, x_240); -lean_ctor_set(x_247, 5, x_241); -if (lean_is_scalar(x_236)) { - x_248 = lean_alloc_ctor(1, 2, 0); +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_248 = x_236; + x_262 = x_249; } -lean_ctor_set(x_248, 0, x_235); -lean_ctor_set(x_248, 1, x_247); -return x_248; +lean_ctor_set(x_262, 0, x_248); +lean_ctor_set(x_262, 1, x_261); +return x_262; } } } default: { -lean_object* x_249; lean_object* x_250; -x_249 = lean_ctor_get(x_18, 1); -lean_inc(x_249); +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_18, 1); +lean_inc(x_263); lean_dec(x_18); lean_inc(x_6); -x_250 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_249); -if (lean_obj_tag(x_250) == 0) +x_264 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_263); +if (lean_obj_tag(x_264) == 0) { -lean_object* x_251; -x_251 = lean_ctor_get(x_250, 0); -lean_inc(x_251); -if (lean_obj_tag(x_251) == 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_252; lean_object* x_253; lean_object* x_254; +lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_dec(x_13); -x_252 = lean_ctor_get(x_250, 1); -lean_inc(x_252); -lean_dec(x_250); -x_253 = lean_unsigned_to_nat(1u); -x_254 = lean_nat_add(x_5, x_253); +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); lean_dec(x_5); -x_5 = x_254; -x_7 = x_252; +x_5 = x_268; +x_7 = x_266; goto _start; } else { -lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; uint8_t x_260; -x_256 = lean_ctor_get(x_250, 1); -lean_inc(x_256); -lean_dec(x_250); -x_257 = lean_ctor_get(x_251, 0); -lean_inc(x_257); -lean_dec(x_251); -x_258 = lean_unsigned_to_nat(1u); -x_259 = lean_nat_add(x_5, x_258); -lean_dec(x_5); -x_260 = !lean_is_exclusive(x_256); -if (x_260 == 0) -{ -lean_object* x_261; uint8_t x_262; -x_261 = lean_ctor_get(x_256, 2); -x_262 = !lean_is_exclusive(x_261); -if (x_262 == 0) -{ -lean_object* x_263; lean_object* x_264; uint8_t x_265; -x_263 = lean_ctor_get(x_261, 2); -x_264 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_261, 2, x_264); -x_265 = !lean_is_exclusive(x_6); -if (x_265 == 0) -{ -lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; -x_266 = lean_ctor_get(x_6, 2); -x_267 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_267, 0, x_257); -lean_ctor_set(x_267, 1, x_13); -x_268 = lean_array_push(x_266, x_267); -lean_ctor_set(x_6, 2, x_268); -x_269 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_259, x_6, x_256); -if (lean_obj_tag(x_269) == 0) -{ -lean_object* x_270; lean_object* x_271; uint8_t x_272; -x_270 = lean_ctor_get(x_269, 1); +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); -x_271 = lean_ctor_get(x_270, 2); +lean_dec(x_264); +x_271 = lean_ctor_get(x_265, 0); lean_inc(x_271); -x_272 = !lean_is_exclusive(x_269); -if (x_272 == 0) -{ -lean_object* x_273; uint8_t x_274; -x_273 = lean_ctor_get(x_269, 1); -lean_dec(x_273); +lean_dec(x_265); +x_272 = lean_unsigned_to_nat(1u); +x_273 = lean_nat_add(x_5, x_272); +lean_dec(x_5); x_274 = !lean_is_exclusive(x_270); if (x_274 == 0) { lean_object* x_275; uint8_t x_276; x_275 = lean_ctor_get(x_270, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_271); +x_276 = !lean_is_exclusive(x_275); if (x_276 == 0) { -lean_object* x_277; -x_277 = lean_ctor_get(x_271, 2); -lean_dec(x_277); -lean_ctor_set(x_271, 2, x_263); -return x_269; -} -else +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_278; lean_object* x_279; lean_object* x_280; -x_278 = lean_ctor_get(x_271, 0); -x_279 = lean_ctor_get(x_271, 1); -lean_inc(x_279); -lean_inc(x_278); -lean_dec(x_271); -x_280 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_280, 0, x_278); -lean_ctor_set(x_280, 1, x_279); -lean_ctor_set(x_280, 2, x_263); -lean_ctor_set(x_270, 2, x_280); -return x_269; -} -} -else +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_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_281 = lean_ctor_get(x_270, 0); -x_282 = lean_ctor_get(x_270, 1); -x_283 = lean_ctor_get(x_270, 3); -x_284 = lean_ctor_get(x_270, 4); -x_285 = lean_ctor_get(x_270, 5); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_283, 1); lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_inc(x_281); -lean_dec(x_270); -x_286 = lean_ctor_get(x_271, 0); -lean_inc(x_286); -x_287 = lean_ctor_get(x_271, 1); -lean_inc(x_287); -if (lean_is_exclusive(x_271)) { - lean_ctor_release(x_271, 0); - lean_ctor_release(x_271, 1); - lean_ctor_release(x_271, 2); - x_288 = x_271; -} else { - lean_dec_ref(x_271); - x_288 = lean_box(0); -} -if (lean_is_scalar(x_288)) { - x_289 = lean_alloc_ctor(0, 3, 0); -} else { - x_289 = x_288; -} -lean_ctor_set(x_289, 0, x_286); -lean_ctor_set(x_289, 1, x_287); -lean_ctor_set(x_289, 2, x_263); -x_290 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_290, 0, x_281); -lean_ctor_set(x_290, 1, x_282); -lean_ctor_set(x_290, 2, x_289); -lean_ctor_set(x_290, 3, x_283); -lean_ctor_set(x_290, 4, x_284); -lean_ctor_set(x_290, 5, x_285); -lean_ctor_set(x_269, 1, x_290); -return x_269; -} +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_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; -x_291 = lean_ctor_get(x_269, 0); -lean_inc(x_291); -lean_dec(x_269); -x_292 = lean_ctor_get(x_270, 0); -lean_inc(x_292); -x_293 = lean_ctor_get(x_270, 1); -lean_inc(x_293); -x_294 = lean_ctor_get(x_270, 3); +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); -x_295 = lean_ctor_get(x_270, 4); -lean_inc(x_295); -x_296 = lean_ctor_get(x_270, 5); -lean_inc(x_296); -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_297 = x_270; -} else { - lean_dec_ref(x_270); - x_297 = lean_box(0); +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; } -x_298 = lean_ctor_get(x_271, 0); -lean_inc(x_298); -x_299 = lean_ctor_get(x_271, 1); +} +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); -if (lean_is_exclusive(x_271)) { - lean_ctor_release(x_271, 0); - lean_ctor_release(x_271, 1); - lean_ctor_release(x_271, 2); - x_300 = x_271; +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_inc(x_302); +x_303 = lean_ctor_get(x_285, 3); +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_271); - x_300 = lean_box(0); + lean_dec_ref(x_285); + x_304 = lean_box(0); } -if (lean_is_scalar(x_300)) { - x_301 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_304)) { + x_305 = lean_alloc_ctor(0, 4, 0); } else { - x_301 = x_300; + x_305 = x_304; } -lean_ctor_set(x_301, 0, x_298); -lean_ctor_set(x_301, 1, x_299); -lean_ctor_set(x_301, 2, x_263); -if (lean_is_scalar(x_297)) { - x_302 = lean_alloc_ctor(0, 6, 0); -} else { - x_302 = x_297; -} -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); -x_303 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_303, 0, x_291); -lean_ctor_set(x_303, 1, x_302); -return x_303; +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_304; lean_object* x_305; uint8_t x_306; -x_304 = lean_ctor_get(x_269, 1); -lean_inc(x_304); -x_305 = lean_ctor_get(x_304, 2); -lean_inc(x_305); -x_306 = !lean_is_exclusive(x_269); -if (x_306 == 0) -{ -lean_object* x_307; uint8_t x_308; -x_307 = lean_ctor_get(x_269, 1); -lean_dec(x_307); -x_308 = !lean_is_exclusive(x_304); -if (x_308 == 0) -{ -lean_object* x_309; uint8_t x_310; -x_309 = lean_ctor_get(x_304, 2); -lean_dec(x_309); -x_310 = !lean_is_exclusive(x_305); -if (x_310 == 0) -{ -lean_object* x_311; -x_311 = lean_ctor_get(x_305, 2); -lean_dec(x_311); -lean_ctor_set(x_305, 2, x_263); -return x_269; -} -else -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_312 = lean_ctor_get(x_305, 0); -x_313 = lean_ctor_get(x_305, 1); -lean_inc(x_313); +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_inc(x_312); -lean_dec(x_305); -x_314 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_314, 0, x_312); -lean_ctor_set(x_314, 1, x_313); -lean_ctor_set(x_314, 2, x_263); -lean_ctor_set(x_304, 2, x_314); -return x_269; +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); } -} -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; -x_315 = lean_ctor_get(x_304, 0); -x_316 = lean_ctor_get(x_304, 1); -x_317 = lean_ctor_get(x_304, 3); -x_318 = lean_ctor_get(x_304, 4); -x_319 = lean_ctor_get(x_304, 5); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); +x_314 = lean_ctor_get(x_285, 0); +lean_inc(x_314); +x_315 = lean_ctor_get(x_285, 1); lean_inc(x_315); -lean_dec(x_304); -x_320 = lean_ctor_get(x_305, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_305, 1); +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); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - x_322 = x_305; -} else { - lean_dec_ref(x_305); - x_322 = lean_box(0); -} -if (lean_is_scalar(x_322)) { - x_323 = lean_alloc_ctor(0, 3, 0); -} else { - x_323 = x_322; -} -lean_ctor_set(x_323, 0, x_320); -lean_ctor_set(x_323, 1, x_321); -lean_ctor_set(x_323, 2, x_263); -x_324 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_324, 0, x_315); -lean_ctor_set(x_324, 1, x_316); -lean_ctor_set(x_324, 2, x_323); -lean_ctor_set(x_324, 3, x_317); -lean_ctor_set(x_324, 4, x_318); -lean_ctor_set(x_324, 5, x_319); -lean_ctor_set(x_269, 1, x_324); -return x_269; -} +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_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; -x_325 = lean_ctor_get(x_269, 0); -lean_inc(x_325); -lean_dec(x_269); -x_326 = lean_ctor_get(x_304, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_304, 1); -lean_inc(x_327); -x_328 = lean_ctor_get(x_304, 3); -lean_inc(x_328); -x_329 = lean_ctor_get(x_304, 4); -lean_inc(x_329); -x_330 = lean_ctor_get(x_304, 5); +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); -if (lean_is_exclusive(x_304)) { - lean_ctor_release(x_304, 0); - lean_ctor_release(x_304, 1); - lean_ctor_release(x_304, 2); - lean_ctor_release(x_304, 3); - lean_ctor_release(x_304, 4); - lean_ctor_release(x_304, 5); - x_331 = x_304; -} else { - lean_dec_ref(x_304); - x_331 = lean_box(0); -} -x_332 = lean_ctor_get(x_305, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_305, 1); -lean_inc(x_333); -if (lean_is_exclusive(x_305)) { - lean_ctor_release(x_305, 0); - lean_ctor_release(x_305, 1); - lean_ctor_release(x_305, 2); - x_334 = x_305; -} else { - lean_dec_ref(x_305); - x_334 = lean_box(0); -} -if (lean_is_scalar(x_334)) { - x_335 = lean_alloc_ctor(0, 3, 0); -} else { - x_335 = x_334; -} -lean_ctor_set(x_335, 0, x_332); -lean_ctor_set(x_335, 1, x_333); -lean_ctor_set(x_335, 2, x_263); -if (lean_is_scalar(x_331)) { - x_336 = lean_alloc_ctor(0, 6, 0); -} else { - x_336 = x_331; -} -lean_ctor_set(x_336, 0, x_326); -lean_ctor_set(x_336, 1, x_327); -lean_ctor_set(x_336, 2, x_335); -lean_ctor_set(x_336, 3, x_328); -lean_ctor_set(x_336, 4, x_329); -lean_ctor_set(x_336, 5, x_330); -x_337 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_337, 0, x_325); -lean_ctor_set(x_337, 1, x_336); -return x_337; -} +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_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_338 = lean_ctor_get(x_6, 0); -x_339 = lean_ctor_get(x_6, 1); -x_340 = lean_ctor_get(x_6, 2); -x_341 = lean_ctor_get(x_6, 3); -x_342 = lean_ctor_get(x_6, 4); -lean_inc(x_342); -lean_inc(x_341); -lean_inc(x_340); -lean_inc(x_339); +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); -lean_dec(x_6); -x_343 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_343, 0, x_257); -lean_ctor_set(x_343, 1, x_13); -x_344 = lean_array_push(x_340, x_343); -x_345 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_345, 0, x_338); -lean_ctor_set(x_345, 1, x_339); -lean_ctor_set(x_345, 2, x_344); -lean_ctor_set(x_345, 3, x_341); -lean_ctor_set(x_345, 4, x_342); -x_346 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_259, x_345, x_256); -if (lean_obj_tag(x_346) == 0) -{ -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_347 = lean_ctor_get(x_346, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_347, 2); -lean_inc(x_348); -x_349 = lean_ctor_get(x_346, 0); -lean_inc(x_349); -if (lean_is_exclusive(x_346)) { - lean_ctor_release(x_346, 0); - lean_ctor_release(x_346, 1); - x_350 = x_346; +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_346); + 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_347, 0); +x_351 = lean_ctor_get(x_322, 0); lean_inc(x_351); -x_352 = lean_ctor_get(x_347, 1); +x_352 = lean_ctor_get(x_322, 1); lean_inc(x_352); -x_353 = lean_ctor_get(x_347, 3); +x_353 = lean_ctor_get(x_322, 3); lean_inc(x_353); -x_354 = lean_ctor_get(x_347, 4); -lean_inc(x_354); -x_355 = lean_ctor_get(x_347, 5); -lean_inc(x_355); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - lean_ctor_release(x_347, 2); - lean_ctor_release(x_347, 3); - lean_ctor_release(x_347, 4); - lean_ctor_release(x_347, 5); - x_356 = x_347; +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_347); - x_356 = lean_box(0); + lean_dec_ref(x_322); + x_354 = lean_box(0); } -x_357 = lean_ctor_get(x_348, 0); -lean_inc(x_357); -x_358 = lean_ctor_get(x_348, 1); -lean_inc(x_358); -if (lean_is_exclusive(x_348)) { - lean_ctor_release(x_348, 0); - lean_ctor_release(x_348, 1); - lean_ctor_release(x_348, 2); - x_359 = x_348; +if (lean_is_scalar(x_354)) { + x_355 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_348); - x_359 = lean_box(0); + x_355 = x_354; } -if (lean_is_scalar(x_359)) { - x_360 = lean_alloc_ctor(0, 3, 0); -} else { - x_360 = x_359; -} -lean_ctor_set(x_360, 0, x_357); -lean_ctor_set(x_360, 1, x_358); -lean_ctor_set(x_360, 2, x_263); -if (lean_is_scalar(x_356)) { - x_361 = lean_alloc_ctor(0, 6, 0); -} else { - x_361 = x_356; -} -lean_ctor_set(x_361, 0, x_351); -lean_ctor_set(x_361, 1, x_352); -lean_ctor_set(x_361, 2, x_360); -lean_ctor_set(x_361, 3, x_353); -lean_ctor_set(x_361, 4, x_354); -lean_ctor_set(x_361, 5, x_355); +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_362 = lean_alloc_ctor(0, 2, 0); + x_356 = lean_alloc_ctor(0, 6, 0); } else { - x_362 = x_350; + 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; +} } -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; 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_363 = lean_ctor_get(x_346, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_363, 2); -lean_inc(x_364); -x_365 = lean_ctor_get(x_346, 0); -lean_inc(x_365); -if (lean_is_exclusive(x_346)) { - lean_ctor_release(x_346, 0); - lean_ctor_release(x_346, 1); - x_366 = x_346; -} else { - lean_dec_ref(x_346); - x_366 = lean_box(0); -} -x_367 = lean_ctor_get(x_363, 0); +lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; +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_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) +{ +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_363, 1); +x_368 = lean_ctor_get(x_367, 2); lean_inc(x_368); -x_369 = lean_ctor_get(x_363, 3); +x_369 = lean_ctor_get(x_366, 0); lean_inc(x_369); -x_370 = lean_ctor_get(x_363, 4); -lean_inc(x_370); -x_371 = lean_ctor_get(x_363, 5); +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); -if (lean_is_exclusive(x_363)) { - lean_ctor_release(x_363, 0); - lean_ctor_release(x_363, 1); - lean_ctor_release(x_363, 2); - lean_ctor_release(x_363, 3); - lean_ctor_release(x_363, 4); - lean_ctor_release(x_363, 5); - x_372 = x_363; -} else { - lean_dec_ref(x_363); - x_372 = lean_box(0); -} -x_373 = lean_ctor_get(x_364, 0); +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_364, 1); +x_374 = lean_ctor_get(x_367, 4); lean_inc(x_374); -if (lean_is_exclusive(x_364)) { - lean_ctor_release(x_364, 0); - lean_ctor_release(x_364, 1); - lean_ctor_release(x_364, 2); - x_375 = x_364; +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_364); - x_375 = lean_box(0); + lean_dec_ref(x_367); + x_376 = lean_box(0); } -if (lean_is_scalar(x_375)) { - x_376 = lean_alloc_ctor(0, 3, 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 { - x_376 = x_375; + lean_dec_ref(x_368); + x_380 = lean_box(0); } -lean_ctor_set(x_376, 0, x_373); -lean_ctor_set(x_376, 1, x_374); -lean_ctor_set(x_376, 2, x_263); -if (lean_is_scalar(x_372)) { - x_377 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_380)) { + x_381 = lean_alloc_ctor(0, 4, 0); } else { - x_377 = x_372; + x_381 = x_380; } -lean_ctor_set(x_377, 0, x_367); -lean_ctor_set(x_377, 1, x_368); -lean_ctor_set(x_377, 2, x_376); -lean_ctor_set(x_377, 3, x_369); -lean_ctor_set(x_377, 4, x_370); -lean_ctor_set(x_377, 5, x_371); -if (lean_is_scalar(x_366)) { - x_378 = lean_alloc_ctor(1, 2, 0); +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_378 = x_366; -} -lean_ctor_set(x_378, 0, x_365); -lean_ctor_set(x_378, 1, x_377); -return x_378; + 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; } 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_392; lean_object* x_393; -x_379 = lean_ctor_get(x_261, 0); -x_380 = lean_ctor_get(x_261, 1); -x_381 = lean_ctor_get(x_261, 2); -lean_inc(x_381); -lean_inc(x_380); -lean_inc(x_379); -lean_dec(x_261); -x_382 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_383 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_383, 0, x_379); -lean_ctor_set(x_383, 1, x_380); -lean_ctor_set(x_383, 2, x_382); -lean_ctor_set(x_256, 2, x_383); -x_384 = lean_ctor_get(x_6, 0); +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_6, 1); +x_385 = lean_ctor_get(x_384, 2); lean_inc(x_385); -x_386 = lean_ctor_get(x_6, 2); +x_386 = lean_ctor_get(x_366, 0); lean_inc(x_386); -x_387 = lean_ctor_get(x_6, 3); -lean_inc(x_387); -x_388 = lean_ctor_get(x_6, 4); +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); +} +x_388 = lean_ctor_get(x_384, 0); lean_inc(x_388); -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_389 = x_6; +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_6); - x_389 = lean_box(0); + lean_dec_ref(x_384); + x_393 = lean_box(0); } -x_390 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_390, 0, x_257); -lean_ctor_set(x_390, 1, x_13); -x_391 = lean_array_push(x_386, x_390); -if (lean_is_scalar(x_389)) { - x_392 = lean_alloc_ctor(0, 5, 0); -} else { - x_392 = x_389; -} -lean_ctor_set(x_392, 0, x_384); -lean_ctor_set(x_392, 1, x_385); -lean_ctor_set(x_392, 2, x_391); -lean_ctor_set(x_392, 3, x_387); -lean_ctor_set(x_392, 4, x_388); -x_393 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_259, x_392, x_256); -if (lean_obj_tag(x_393) == 0) -{ -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_394 = lean_ctor_get(x_393, 1); +x_394 = lean_ctor_get(x_385, 0); lean_inc(x_394); -x_395 = lean_ctor_get(x_394, 2); +x_395 = lean_ctor_get(x_385, 1); lean_inc(x_395); -x_396 = lean_ctor_get(x_393, 0); +x_396 = lean_ctor_get(x_385, 3); lean_inc(x_396); -if (lean_is_exclusive(x_393)) { - lean_ctor_release(x_393, 0); - lean_ctor_release(x_393, 1); - x_397 = 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); + x_397 = x_385; } else { - lean_dec_ref(x_393); + lean_dec_ref(x_385); x_397 = lean_box(0); } -x_398 = lean_ctor_get(x_394, 0); -lean_inc(x_398); -x_399 = lean_ctor_get(x_394, 1); -lean_inc(x_399); -x_400 = lean_ctor_get(x_394, 3); -lean_inc(x_400); -x_401 = lean_ctor_get(x_394, 4); -lean_inc(x_401); -x_402 = lean_ctor_get(x_394, 5); -lean_inc(x_402); -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); - lean_ctor_release(x_394, 5); - x_403 = x_394; -} else { - lean_dec_ref(x_394); - x_403 = lean_box(0); -} -x_404 = lean_ctor_get(x_395, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_395, 1); -lean_inc(x_405); -if (lean_is_exclusive(x_395)) { - lean_ctor_release(x_395, 0); - lean_ctor_release(x_395, 1); - lean_ctor_release(x_395, 2); - x_406 = x_395; -} else { - lean_dec_ref(x_395); - x_406 = lean_box(0); -} -if (lean_is_scalar(x_406)) { - x_407 = lean_alloc_ctor(0, 3, 0); -} else { - x_407 = x_406; -} -lean_ctor_set(x_407, 0, x_404); -lean_ctor_set(x_407, 1, x_405); -lean_ctor_set(x_407, 2, x_381); -if (lean_is_scalar(x_403)) { - x_408 = lean_alloc_ctor(0, 6, 0); -} else { - x_408 = x_403; -} -lean_ctor_set(x_408, 0, x_398); -lean_ctor_set(x_408, 1, x_399); -lean_ctor_set(x_408, 2, x_407); -lean_ctor_set(x_408, 3, x_400); -lean_ctor_set(x_408, 4, x_401); -lean_ctor_set(x_408, 5, x_402); if (lean_is_scalar(x_397)) { - x_409 = lean_alloc_ctor(0, 2, 0); + x_398 = lean_alloc_ctor(0, 4, 0); } else { - x_409 = x_397; + x_398 = x_397; +} +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); +} else { + x_399 = x_393; +} +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); +} else { + x_400 = x_387; +} +lean_ctor_set(x_400, 0, x_386); +lean_ctor_set(x_400, 1, x_399); +return x_400; +} } -lean_ctor_set(x_409, 0, x_396); -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_393, 1); +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_410, 2); +x_411 = lean_ctor_get(x_6, 4); lean_inc(x_411); -x_412 = lean_ctor_get(x_393, 0); -lean_inc(x_412); -if (lean_is_exclusive(x_393)) { - lean_ctor_release(x_393, 0); - lean_ctor_release(x_393, 1); - x_413 = x_393; -} else { - lean_dec_ref(x_393); - x_413 = lean_box(0); -} -x_414 = lean_ctor_get(x_410, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_410, 1); -lean_inc(x_415); -x_416 = lean_ctor_get(x_410, 3); -lean_inc(x_416); -x_417 = lean_ctor_get(x_410, 4); -lean_inc(x_417); -x_418 = lean_ctor_get(x_410, 5); -lean_inc(x_418); -if (lean_is_exclusive(x_410)) { - lean_ctor_release(x_410, 0); - lean_ctor_release(x_410, 1); - lean_ctor_release(x_410, 2); - lean_ctor_release(x_410, 3); - lean_ctor_release(x_410, 4); - lean_ctor_release(x_410, 5); - x_419 = x_410; -} else { - lean_dec_ref(x_410); - x_419 = lean_box(0); -} -x_420 = lean_ctor_get(x_411, 0); -lean_inc(x_420); -x_421 = lean_ctor_get(x_411, 1); -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); - x_422 = x_411; -} else { - lean_dec_ref(x_411); - x_422 = lean_box(0); -} -if (lean_is_scalar(x_422)) { - x_423 = lean_alloc_ctor(0, 3, 0); -} else { - x_423 = x_422; -} -lean_ctor_set(x_423, 0, x_420); -lean_ctor_set(x_423, 1, x_421); -lean_ctor_set(x_423, 2, x_381); -if (lean_is_scalar(x_419)) { - x_424 = lean_alloc_ctor(0, 6, 0); -} else { - x_424 = x_419; -} -lean_ctor_set(x_424, 0, x_414); -lean_ctor_set(x_424, 1, x_415); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_416); -lean_ctor_set(x_424, 4, x_417); -lean_ctor_set(x_424, 5, x_418); -if (lean_is_scalar(x_413)) { - x_425 = lean_alloc_ctor(1, 2, 0); -} else { - x_425 = x_413; -} -lean_ctor_set(x_425, 0, x_412); -lean_ctor_set(x_425, 1, x_424); -return x_425; -} -} -} -else -{ -lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; 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_426 = lean_ctor_get(x_256, 2); -x_427 = lean_ctor_get(x_256, 0); -x_428 = lean_ctor_get(x_256, 1); -x_429 = lean_ctor_get(x_256, 3); -x_430 = lean_ctor_get(x_256, 4); -x_431 = lean_ctor_get(x_256, 5); -lean_inc(x_431); -lean_inc(x_430); -lean_inc(x_429); -lean_inc(x_426); -lean_inc(x_428); -lean_inc(x_427); -lean_dec(x_256); -x_432 = lean_ctor_get(x_426, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_426, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_426, 2); -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); - x_435 = x_426; -} else { - lean_dec_ref(x_426); - x_435 = lean_box(0); -} -x_436 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_435)) { - x_437 = lean_alloc_ctor(0, 3, 0); -} else { - x_437 = x_435; -} -lean_ctor_set(x_437, 0, x_432); -lean_ctor_set(x_437, 1, x_433); -lean_ctor_set(x_437, 2, x_436); -x_438 = lean_alloc_ctor(0, 6, 0); -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); -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; + x_412 = x_6; } else { lean_dec_ref(x_6); - x_444 = lean_box(0); + x_412 = lean_box(0); } -x_445 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_445, 0, x_257); -lean_ctor_set(x_445, 1, x_13); -x_446 = lean_array_push(x_441, x_445); -if (lean_is_scalar(x_444)) { - x_447 = lean_alloc_ctor(0, 5, 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); } else { - x_447 = x_444; + x_415 = x_412; } -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_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_259, x_447, x_438); -if (lean_obj_tag(x_448) == 0) +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_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_449 = lean_ctor_get(x_448, 1); -lean_inc(x_449); -x_450 = lean_ctor_get(x_449, 2); -lean_inc(x_450); -x_451 = lean_ctor_get(x_448, 0); -lean_inc(x_451); -if (lean_is_exclusive(x_448)) { - lean_ctor_release(x_448, 0); - lean_ctor_release(x_448, 1); - x_452 = x_448; +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_448); - x_452 = lean_box(0); + lean_dec_ref(x_416); + x_420 = lean_box(0); } -x_453 = lean_ctor_get(x_449, 0); -lean_inc(x_453); -x_454 = lean_ctor_get(x_449, 1); -lean_inc(x_454); -x_455 = lean_ctor_get(x_449, 3); -lean_inc(x_455); -x_456 = lean_ctor_get(x_449, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_434); + x_443 = 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; +} else { + lean_dec_ref(x_435); + x_447 = lean_box(0); +} +if (lean_is_scalar(x_447)) { + x_448 = lean_alloc_ctor(0, 4, 0); +} else { + x_448 = x_447; +} +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); +} else { + x_449 = x_443; +} +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); +} else { + x_450 = x_437; +} +lean_ctor_set(x_450, 0, x_436); +lean_ctor_set(x_450, 1, x_449); +return x_450; +} +} +} +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); -x_457 = lean_ctor_get(x_449, 5); +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); -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); - lean_ctor_release(x_449, 4); - lean_ctor_release(x_449, 5); - x_458 = x_449; -} else { - lean_dec_ref(x_449); - x_458 = lean_box(0); -} -x_459 = lean_ctor_get(x_450, 0); +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_450, 1); +x_460 = lean_ctor_get(x_451, 3); lean_inc(x_460); -if (lean_is_exclusive(x_450)) { - lean_ctor_release(x_450, 0); - lean_ctor_release(x_450, 1); - lean_ctor_release(x_450, 2); - x_461 = x_450; +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; } else { - lean_dec_ref(x_450); + lean_dec_ref(x_451); x_461 = lean_box(0); } +x_462 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_461)) { - x_462 = lean_alloc_ctor(0, 3, 0); + x_463 = lean_alloc_ctor(0, 4, 0); } else { - x_462 = x_461; + x_463 = x_461; } -lean_ctor_set(x_462, 0, x_459); -lean_ctor_set(x_462, 1, x_460); -lean_ctor_set(x_462, 2, x_434); -if (lean_is_scalar(x_458)) { - x_463 = lean_alloc_ctor(0, 6, 0); -} else { - x_463 = x_458; -} -lean_ctor_set(x_463, 0, x_453); -lean_ctor_set(x_463, 1, x_454); +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_455); -lean_ctor_set(x_463, 4, x_456); -lean_ctor_set(x_463, 5, x_457); -if (lean_is_scalar(x_452)) { - x_464 = lean_alloc_ctor(0, 2, 0); -} else { - x_464 = x_452; -} -lean_ctor_set(x_464, 0, x_451); -lean_ctor_set(x_464, 1, x_463); -return x_464; -} -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; -x_465 = lean_ctor_get(x_448, 1); +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_465, 2); +x_466 = lean_ctor_get(x_6, 1); lean_inc(x_466); -x_467 = lean_ctor_get(x_448, 0); +x_467 = lean_ctor_get(x_6, 2); lean_inc(x_467); -if (lean_is_exclusive(x_448)) { - lean_ctor_release(x_448, 0); - lean_ctor_release(x_448, 1); - x_468 = x_448; -} else { - lean_dec_ref(x_448); - x_468 = lean_box(0); -} -x_469 = lean_ctor_get(x_465, 0); +x_468 = lean_ctor_get(x_6, 3); +lean_inc(x_468); +x_469 = lean_ctor_get(x_6, 4); lean_inc(x_469); -x_470 = lean_ctor_get(x_465, 1); -lean_inc(x_470); -x_471 = lean_ctor_get(x_465, 3); -lean_inc(x_471); -x_472 = lean_ctor_get(x_465, 4); -lean_inc(x_472); -x_473 = lean_ctor_get(x_465, 5); -lean_inc(x_473); -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); - lean_ctor_release(x_465, 4); - lean_ctor_release(x_465, 5); - x_474 = x_465; +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; } else { - lean_dec_ref(x_465); - x_474 = lean_box(0); + lean_dec_ref(x_6); + x_470 = lean_box(0); } -x_475 = lean_ctor_get(x_466, 0); +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); +} else { + x_473 = x_470; +} +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_466, 1); +x_476 = lean_ctor_get(x_475, 2); lean_inc(x_476); -if (lean_is_exclusive(x_466)) { - lean_ctor_release(x_466, 0); - lean_ctor_release(x_466, 1); - lean_ctor_release(x_466, 2); - x_477 = x_466; +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; } else { - lean_dec_ref(x_466); - x_477 = lean_box(0); + lean_dec_ref(x_474); + x_478 = lean_box(0); } -if (lean_is_scalar(x_477)) { - x_478 = lean_alloc_ctor(0, 3, 0); +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 { - x_478 = x_477; + lean_dec_ref(x_475); + x_484 = lean_box(0); } -lean_ctor_set(x_478, 0, x_475); -lean_ctor_set(x_478, 1, x_476); -lean_ctor_set(x_478, 2, x_434); -if (lean_is_scalar(x_474)) { - x_479 = lean_alloc_ctor(0, 6, 0); +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 { - x_479 = x_474; + lean_dec_ref(x_476); + x_488 = lean_box(0); } -lean_ctor_set(x_479, 0, x_469); -lean_ctor_set(x_479, 1, x_470); -lean_ctor_set(x_479, 2, x_478); -lean_ctor_set(x_479, 3, x_471); -lean_ctor_set(x_479, 4, x_472); -lean_ctor_set(x_479, 5, x_473); -if (lean_is_scalar(x_468)) { - x_480 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_488)) { + x_489 = lean_alloc_ctor(0, 4, 0); } else { - x_480 = x_468; + x_489 = x_488; } -lean_ctor_set(x_480, 0, x_467); -lean_ctor_set(x_480, 1, x_479); -return x_480; +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_481; +uint8_t x_509; 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_481 = !lean_is_exclusive(x_250); -if (x_481 == 0) +x_509 = !lean_is_exclusive(x_264); +if (x_509 == 0) { -return x_250; +return x_264; } else { -lean_object* x_482; lean_object* x_483; lean_object* x_484; -x_482 = lean_ctor_get(x_250, 0); -x_483 = lean_ctor_get(x_250, 1); -lean_inc(x_483); -lean_inc(x_482); -lean_dec(x_250); -x_484 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_484, 0, x_482); -lean_ctor_set(x_484, 1, x_483); -return x_484; +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; } } } @@ -3033,7 +3139,7 @@ return x_484; } else { -uint8_t x_485; +uint8_t x_513; lean_dec(x_17); lean_dec(x_13); lean_dec(x_6); @@ -3041,52 +3147,52 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_485 = !lean_is_exclusive(x_18); -if (x_485 == 0) +x_513 = !lean_is_exclusive(x_18); +if (x_513 == 0) { return x_18; } else { -lean_object* x_486; lean_object* x_487; lean_object* x_488; -x_486 = lean_ctor_get(x_18, 0); -x_487 = lean_ctor_get(x_18, 1); -lean_inc(x_487); -lean_inc(x_486); +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_dec(x_18); -x_488 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_488, 0, x_486); -lean_ctor_set(x_488, 1, x_487); -return x_488; +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; } } } else { -uint8_t x_489; +uint8_t x_517; 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_489 = !lean_is_exclusive(x_14); -if (x_489 == 0) +x_517 = !lean_is_exclusive(x_14); +if (x_517 == 0) { return x_14; } else { -lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_490 = lean_ctor_get(x_14, 0); -x_491 = lean_ctor_get(x_14, 1); -lean_inc(x_491); -lean_inc(x_490); +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_dec(x_14); -x_492 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_492, 0, x_490); -lean_ctor_set(x_492, 1, x_491); -return x_492; +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; } } } @@ -3266,82 +3372,89 @@ return x_45; } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; +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_56 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -lean_ctor_set(x_56, 2, x_39); -lean_ctor_set(x_46, 2, x_56); +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; } } 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; -x_57 = lean_ctor_get(x_46, 0); -x_58 = lean_ctor_get(x_46, 1); -x_59 = lean_ctor_get(x_46, 3); -x_60 = lean_ctor_get(x_46, 4); -x_61 = lean_ctor_get(x_46, 5); +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_inc(x_59); lean_inc(x_58); -lean_inc(x_57); lean_dec(x_46); -x_62 = lean_ctor_get(x_47, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_47, 1); +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); - x_64 = x_47; + lean_ctor_release(x_47, 3); + x_66 = x_47; } else { lean_dec_ref(x_47); - x_64 = lean_box(0); + x_66 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 4, 0); } else { - x_65 = x_64; + x_67 = x_66; } -lean_ctor_set(x_65, 0, x_62); -lean_ctor_set(x_65, 1, x_63); -lean_ctor_set(x_65, 2, x_39); -x_66 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_66, 0, x_57); -lean_ctor_set(x_66, 1, x_58); -lean_ctor_set(x_66, 2, x_65); -lean_ctor_set(x_66, 3, x_59); -lean_ctor_set(x_66, 4, x_60); -lean_ctor_set(x_66, 5, x_61); -lean_ctor_set(x_45, 1, x_66); +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; } } 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; -x_67 = lean_ctor_get(x_45, 0); -lean_inc(x_67); -lean_dec(x_45); -x_68 = lean_ctor_get(x_46, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_46, 1); +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); -x_70 = lean_ctor_get(x_46, 3); +lean_dec(x_45); +x_70 = lean_ctor_get(x_46, 0); lean_inc(x_70); -x_71 = lean_ctor_get(x_46, 4); +x_71 = lean_ctor_get(x_46, 1); lean_inc(x_71); -x_72 = lean_ctor_get(x_46, 5); +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); @@ -3349,1877 +3462,1976 @@ if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 3); lean_ctor_release(x_46, 4); lean_ctor_release(x_46, 5); - x_73 = x_46; + x_75 = x_46; } else { lean_dec_ref(x_46); - x_73 = lean_box(0); + x_75 = lean_box(0); } -x_74 = lean_ctor_get(x_47, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_47, 1); -lean_inc(x_75); +x_76 = lean_ctor_get(x_47, 0); +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); - x_76 = x_47; + lean_ctor_release(x_47, 3); + x_79 = x_47; } else { lean_dec_ref(x_47); - x_76 = lean_box(0); + x_79 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 4, 0); } else { - x_77 = x_76; + x_80 = x_79; } -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_75); -lean_ctor_set(x_77, 2, x_39); -if (lean_is_scalar(x_73)) { - x_78 = lean_alloc_ctor(0, 6, 0); +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_78 = x_73; + x_81 = x_75; } -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); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_67); -lean_ctor_set(x_79, 1, x_78); -return x_79; +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; } } else { -lean_object* x_80; lean_object* x_81; uint8_t x_82; -x_80 = lean_ctor_get(x_45, 1); -lean_inc(x_80); -x_81 = lean_ctor_get(x_80, 2); -lean_inc(x_81); -x_82 = !lean_is_exclusive(x_45); -if (x_82 == 0) -{ -lean_object* x_83; uint8_t x_84; +lean_object* x_83; lean_object* x_84; uint8_t x_85; x_83 = lean_ctor_get(x_45, 1); -lean_dec(x_83); -x_84 = !lean_is_exclusive(x_80); -if (x_84 == 0) +lean_inc(x_83); +x_84 = lean_ctor_get(x_83, 2); +lean_inc(x_84); +x_85 = !lean_is_exclusive(x_45); +if (x_85 == 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_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_87; -x_87 = lean_ctor_get(x_81, 2); -lean_dec(x_87); -lean_ctor_set(x_81, 2, x_39); +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_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_81, 0); -x_89 = lean_ctor_get(x_81, 1); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_81); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_88); -lean_ctor_set(x_90, 1, x_89); -lean_ctor_set(x_90, 2, x_39); -lean_ctor_set(x_80, 2, x_90); -return x_45; -} -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_91 = lean_ctor_get(x_80, 0); -x_92 = lean_ctor_get(x_80, 1); -x_93 = lean_ctor_get(x_80, 3); -x_94 = lean_ctor_get(x_80, 4); -x_95 = lean_ctor_get(x_80, 5); -lean_inc(x_95); -lean_inc(x_94); +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_80); -x_96 = lean_ctor_get(x_81, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_81, 1); -lean_inc(x_97); -if (lean_is_exclusive(x_81)) { - lean_ctor_release(x_81, 0); - lean_ctor_release(x_81, 1); - lean_ctor_release(x_81, 2); - x_98 = x_81; -} else { - lean_dec_ref(x_81); - x_98 = lean_box(0); -} -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 3, 0); -} else { - x_99 = x_98; -} -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -lean_ctor_set(x_99, 2, x_39); -x_100 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_100, 0, x_91); -lean_ctor_set(x_100, 1, x_92); -lean_ctor_set(x_100, 2, x_99); -lean_ctor_set(x_100, 3, x_93); -lean_ctor_set(x_100, 4, x_94); -lean_ctor_set(x_100, 5, x_95); -lean_ctor_set(x_45, 1, x_100); +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_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_101 = lean_ctor_get(x_45, 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; +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); -lean_dec(x_45); -x_102 = lean_ctor_get(x_80, 0); +x_102 = lean_ctor_get(x_84, 3); lean_inc(x_102); -x_103 = lean_ctor_get(x_80, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_80, 3); -lean_inc(x_104); -x_105 = lean_ctor_get(x_80, 4); -lean_inc(x_105); -x_106 = lean_ctor_get(x_80, 5); +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; +} else { + lean_dec_ref(x_84); + x_103 = lean_box(0); +} +if (lean_is_scalar(x_103)) { + x_104 = lean_alloc_ctor(0, 4, 0); +} else { + x_104 = x_103; +} +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); -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_107 = x_80; -} else { - lean_dec_ref(x_80); - x_107 = lean_box(0); -} -x_108 = lean_ctor_get(x_81, 0); +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_81, 1); +x_109 = lean_ctor_get(x_83, 3); 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); - x_110 = x_81; +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; } else { - lean_dec_ref(x_81); - x_110 = lean_box(0); + lean_dec_ref(x_83); + x_112 = lean_box(0); } -if (lean_is_scalar(x_110)) { - x_111 = lean_alloc_ctor(0, 3, 0); +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 { - x_111 = x_110; + lean_dec_ref(x_84); + x_116 = lean_box(0); } -lean_ctor_set(x_111, 0, x_108); -lean_ctor_set(x_111, 1, x_109); -lean_ctor_set(x_111, 2, x_39); -if (lean_is_scalar(x_107)) { - x_112 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_116)) { + x_117 = lean_alloc_ctor(0, 4, 0); } else { - x_112 = x_107; + x_117 = x_116; } -lean_ctor_set(x_112, 0, x_102); -lean_ctor_set(x_112, 1, x_103); -lean_ctor_set(x_112, 2, x_111); -lean_ctor_set(x_112, 3, x_104); -lean_ctor_set(x_112, 4, x_105); -lean_ctor_set(x_112, 5, x_106); -x_113 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_113, 0, x_101); -lean_ctor_set(x_113, 1, x_112); -return x_113; +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_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_114 = lean_ctor_get(x_12, 0); -x_115 = lean_ctor_get(x_12, 1); -x_116 = lean_ctor_get(x_12, 2); -x_117 = lean_ctor_get(x_12, 3); -x_118 = lean_ctor_get(x_12, 4); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_dec(x_12); -x_119 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_119, 0, x_33); -lean_ctor_set(x_119, 1, x_21); -x_120 = lean_array_push(x_116, x_119); -x_121 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_121, 0, x_114); -lean_ctor_set(x_121, 1, x_115); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_117); -lean_ctor_set(x_121, 4, x_118); -x_122 = l_Lean_Meta_withNewLocalInstances___main___at_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_121, x_32); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_123 = lean_ctor_get(x_122, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_123, 2); +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); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_126 = x_122; -} else { - lean_dec_ref(x_122); - x_126 = lean_box(0); -} -x_127 = lean_ctor_get(x_123, 0); -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_123); +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_123, 4); +x_130 = lean_ctor_get(x_129, 2); lean_inc(x_130); -x_131 = lean_ctor_get(x_123, 5); +x_131 = lean_ctor_get(x_128, 0); 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_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_132 = x_128; } else { - lean_dec_ref(x_123); + lean_dec_ref(x_128); x_132 = lean_box(0); } -x_133 = lean_ctor_get(x_124, 0); +x_133 = lean_ctor_get(x_129, 0); lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 1); +x_134 = lean_ctor_get(x_129, 1); 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); - x_135 = x_124; +x_135 = lean_ctor_get(x_129, 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; } else { - lean_dec_ref(x_124); - x_135 = lean_box(0); + lean_dec_ref(x_129); + x_138 = lean_box(0); } -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 3, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_133); -lean_ctor_set(x_136, 1, x_134); -lean_ctor_set(x_136, 2, x_39); -if (lean_is_scalar(x_132)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_132; -} -lean_ctor_set(x_137, 0, x_127); -lean_ctor_set(x_137, 1, x_128); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_129); -lean_ctor_set(x_137, 4, x_130); -lean_ctor_set(x_137, 5, x_131); -if (lean_is_scalar(x_126)) { - x_138 = lean_alloc_ctor(0, 2, 0); -} else { - x_138 = x_126; -} -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; lean_object* x_154; -x_139 = lean_ctor_get(x_122, 1); +x_139 = lean_ctor_get(x_130, 0); lean_inc(x_139); -x_140 = lean_ctor_get(x_139, 2); +x_140 = lean_ctor_get(x_130, 1); lean_inc(x_140); -x_141 = lean_ctor_get(x_122, 0); +x_141 = lean_ctor_get(x_130, 3); lean_inc(x_141); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_142 = x_122; +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; } else { - lean_dec_ref(x_122); + lean_dec_ref(x_130); x_142 = lean_box(0); } -x_143 = lean_ctor_get(x_139, 0); -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; -} else { - lean_dec_ref(x_139); - x_148 = 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); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - lean_ctor_release(x_140, 2); - x_151 = x_140; -} else { - lean_dec_ref(x_140); - x_151 = lean_box(0); -} -if (lean_is_scalar(x_151)) { - x_152 = lean_alloc_ctor(0, 3, 0); -} else { - x_152 = x_151; -} -lean_ctor_set(x_152, 0, x_149); -lean_ctor_set(x_152, 1, x_150); -lean_ctor_set(x_152, 2, x_39); -if (lean_is_scalar(x_148)) { - x_153 = lean_alloc_ctor(0, 6, 0); -} else { - x_153 = x_148; -} -lean_ctor_set(x_153, 0, x_143); -lean_ctor_set(x_153, 1, x_144); -lean_ctor_set(x_153, 2, x_152); -lean_ctor_set(x_153, 3, x_145); -lean_ctor_set(x_153, 4, x_146); -lean_ctor_set(x_153, 5, x_147); if (lean_is_scalar(x_142)) { - x_154 = lean_alloc_ctor(1, 2, 0); + x_143 = lean_alloc_ctor(0, 4, 0); } else { - x_154 = x_142; + x_143 = x_142; } -lean_ctor_set(x_154, 0, x_141); -lean_ctor_set(x_154, 1, x_153); -return x_154; +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); +if (lean_is_scalar(x_132)) { + x_145 = lean_alloc_ctor(0, 2, 0); +} else { + x_145 = x_132; +} +lean_ctor_set(x_145, 0, x_131); +lean_ctor_set(x_145, 1, x_144); +return x_145; +} +else +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_146 = lean_ctor_get(x_128, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_146, 2); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 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); +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; +} else { + lean_dec_ref(x_146); + x_155 = 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; +} else { + lean_dec_ref(x_147); + x_159 = 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_39); +lean_ctor_set(x_160, 3, x_158); +if (lean_is_scalar(x_155)) { + x_161 = lean_alloc_ctor(0, 6, 0); +} else { + x_161 = x_155; +} +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_162, 0, x_148); +lean_ctor_set(x_162, 1, x_161); +return x_162; } } } 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; -x_155 = lean_ctor_get(x_37, 0); -x_156 = lean_ctor_get(x_37, 1); -x_157 = lean_ctor_get(x_37, 2); -lean_inc(x_157); -lean_inc(x_156); -lean_inc(x_155); -lean_dec(x_37); -x_158 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_159 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_159, 0, x_155); -lean_ctor_set(x_159, 1, x_156); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_32, 2, x_159); -x_160 = lean_ctor_get(x_12, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 1); -lean_inc(x_161); -x_162 = lean_ctor_get(x_12, 2); -lean_inc(x_162); -x_163 = lean_ctor_get(x_12, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_12, 4); +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); 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_165 = x_12; + x_174 = x_12; } else { lean_dec_ref(x_12); - x_165 = lean_box(0); + x_174 = lean_box(0); } -x_166 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_166, 0, x_33); -lean_ctor_set(x_166, 1, x_21); -x_167 = lean_array_push(x_162, x_166); -if (lean_is_scalar(x_165)) { - x_168 = lean_alloc_ctor(0, 5, 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); } else { - x_168 = x_165; + x_177 = x_174; } -lean_ctor_set(x_168, 0, x_160); -lean_ctor_set(x_168, 1, x_161); -lean_ctor_set(x_168, 2, x_167); -lean_ctor_set(x_168, 3, x_163); -lean_ctor_set(x_168, 4, x_164); -x_169 = 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_168, x_32); -if (lean_obj_tag(x_169) == 0) +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_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_170 = lean_ctor_get(x_169, 1); -lean_inc(x_170); -x_171 = lean_ctor_get(x_170, 2); -lean_inc(x_171); -x_172 = lean_ctor_get(x_169, 0); -lean_inc(x_172); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - x_173 = x_169; -} else { - lean_dec_ref(x_169); - x_173 = lean_box(0); -} -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -x_176 = lean_ctor_get(x_170, 3); -lean_inc(x_176); -x_177 = lean_ctor_get(x_170, 4); -lean_inc(x_177); -x_178 = lean_ctor_get(x_170, 5); -lean_inc(x_178); -if (lean_is_exclusive(x_170)) { - lean_ctor_release(x_170, 0); - lean_ctor_release(x_170, 1); - lean_ctor_release(x_170, 2); - lean_ctor_release(x_170, 3); - lean_ctor_release(x_170, 4); - lean_ctor_release(x_170, 5); - x_179 = x_170; -} else { - lean_dec_ref(x_170); - x_179 = lean_box(0); -} -x_180 = lean_ctor_get(x_171, 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_171, 1); +x_181 = lean_ctor_get(x_178, 0); lean_inc(x_181); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - lean_ctor_release(x_171, 2); - x_182 = x_171; +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_171); + lean_dec_ref(x_178); x_182 = lean_box(0); } -if (lean_is_scalar(x_182)) { - x_183 = lean_alloc_ctor(0, 3, 0); -} else { - x_183 = x_182; -} -lean_ctor_set(x_183, 0, x_180); -lean_ctor_set(x_183, 1, x_181); -lean_ctor_set(x_183, 2, x_157); -if (lean_is_scalar(x_179)) { - x_184 = lean_alloc_ctor(0, 6, 0); -} else { - x_184 = x_179; -} -lean_ctor_set(x_184, 0, x_174); -lean_ctor_set(x_184, 1, x_175); -lean_ctor_set(x_184, 2, x_183); -lean_ctor_set(x_184, 3, x_176); -lean_ctor_set(x_184, 4, x_177); -lean_ctor_set(x_184, 5, x_178); -if (lean_is_scalar(x_173)) { - x_185 = lean_alloc_ctor(0, 2, 0); -} else { - x_185 = x_173; -} -lean_ctor_set(x_185, 0, x_172); -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; -x_186 = lean_ctor_get(x_169, 1); +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_186, 2); +x_187 = lean_ctor_get(x_179, 5); lean_inc(x_187); -x_188 = lean_ctor_get(x_169, 0); -lean_inc(x_188); -if (lean_is_exclusive(x_169)) { - lean_ctor_release(x_169, 0); - lean_ctor_release(x_169, 1); - x_189 = x_169; +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_169); - x_189 = lean_box(0); + lean_dec_ref(x_179); + x_188 = lean_box(0); } -x_190 = lean_ctor_get(x_186, 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_186, 1); +x_191 = lean_ctor_get(x_180, 3); lean_inc(x_191); -x_192 = lean_ctor_get(x_186, 3); -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_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; +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_186); - x_195 = lean_box(0); + lean_dec_ref(x_180); + x_192 = lean_box(0); } -x_196 = lean_ctor_get(x_187, 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; +} +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_inc(x_196); -x_197 = lean_ctor_get(x_187, 1); +x_197 = lean_ctor_get(x_196, 2); lean_inc(x_197); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - x_198 = x_187; +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; } else { - lean_dec_ref(x_187); - x_198 = lean_box(0); + lean_dec_ref(x_178); + x_199 = lean_box(0); } -if (lean_is_scalar(x_198)) { - x_199 = lean_alloc_ctor(0, 3, 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); +lean_inc(x_202); +x_203 = lean_ctor_get(x_196, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_196, 5); +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 { - x_199 = x_198; + lean_dec_ref(x_196); + x_205 = lean_box(0); } -lean_ctor_set(x_199, 0, x_196); -lean_ctor_set(x_199, 1, x_197); -lean_ctor_set(x_199, 2, x_157); -if (lean_is_scalar(x_195)) { - x_200 = lean_alloc_ctor(0, 6, 0); +x_206 = lean_ctor_get(x_197, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_197, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_197, 3); +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; } else { - x_200 = x_195; + lean_dec_ref(x_197); + x_209 = lean_box(0); } -lean_ctor_set(x_200, 0, x_190); -lean_ctor_set(x_200, 1, x_191); -lean_ctor_set(x_200, 2, x_199); -lean_ctor_set(x_200, 3, x_192); -lean_ctor_set(x_200, 4, x_193); -lean_ctor_set(x_200, 5, x_194); -if (lean_is_scalar(x_189)) { - x_201 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_209)) { + x_210 = lean_alloc_ctor(0, 4, 0); } else { - x_201 = x_189; + x_210 = x_209; } -lean_ctor_set(x_201, 0, x_188); -lean_ctor_set(x_201, 1, x_200); -return x_201; +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); +} else { + x_211 = x_205; +} +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_212, 0, x_198); +lean_ctor_set(x_212, 1, x_211); +return x_212; } } } 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; -x_202 = lean_ctor_get(x_32, 2); -x_203 = lean_ctor_get(x_32, 0); -x_204 = lean_ctor_get(x_32, 1); -x_205 = lean_ctor_get(x_32, 3); -x_206 = lean_ctor_get(x_32, 4); -x_207 = lean_ctor_get(x_32, 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_32); -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); -if (lean_is_exclusive(x_202)) { - lean_ctor_release(x_202, 0); - lean_ctor_release(x_202, 1); - lean_ctor_release(x_202, 2); - x_211 = x_202; -} else { - lean_dec_ref(x_202); - x_211 = lean_box(0); -} -x_212 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_211)) { - x_213 = lean_alloc_ctor(0, 3, 0); -} else { - x_213 = x_211; -} -lean_ctor_set(x_213, 0, x_208); -lean_ctor_set(x_213, 1, x_209); -lean_ctor_set(x_213, 2, x_212); -x_214 = 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); -x_215 = lean_ctor_get(x_12, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_12, 1); -lean_inc(x_216); -x_217 = lean_ctor_get(x_12, 2); -lean_inc(x_217); -x_218 = lean_ctor_get(x_12, 3); +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); -x_219 = lean_ctor_get(x_12, 4); +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_220 = x_12; + x_232 = x_12; } else { lean_dec_ref(x_12); - x_220 = lean_box(0); + x_232 = lean_box(0); } -x_221 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_221, 0, x_33); -lean_ctor_set(x_221, 1, x_21); -x_222 = lean_array_push(x_217, x_221); -if (lean_is_scalar(x_220)) { - x_223 = lean_alloc_ctor(0, 5, 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_223 = x_220; + x_235 = x_232; } -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_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_223, x_214); -if (lean_obj_tag(x_224) == 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_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_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_225 = lean_ctor_get(x_224, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_225, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_224, 0); -lean_inc(x_227); -if (lean_is_exclusive(x_224)) { - lean_ctor_release(x_224, 0); - lean_ctor_release(x_224, 1); - x_228 = x_224; +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_224); - x_228 = lean_box(0); + lean_dec_ref(x_236); + x_240 = lean_box(0); } -x_229 = lean_ctor_get(x_225, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_225, 1); -lean_inc(x_230); -x_231 = lean_ctor_get(x_225, 3); -lean_inc(x_231); -x_232 = lean_ctor_get(x_225, 4); -lean_inc(x_232); -x_233 = lean_ctor_get(x_225, 5); -lean_inc(x_233); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - lean_ctor_release(x_225, 2); - lean_ctor_release(x_225, 3); - lean_ctor_release(x_225, 4); - lean_ctor_release(x_225, 5); - x_234 = x_225; +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_225); - x_234 = lean_box(0); + lean_dec_ref(x_237); + x_246 = lean_box(0); } -x_235 = lean_ctor_get(x_226, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_226, 1); -lean_inc(x_236); -if (lean_is_exclusive(x_226)) { - lean_ctor_release(x_226, 0); - lean_ctor_release(x_226, 1); - lean_ctor_release(x_226, 2); - x_237 = x_226; +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_226); - x_237 = lean_box(0); + lean_dec_ref(x_238); + x_250 = lean_box(0); } -if (lean_is_scalar(x_237)) { - x_238 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_250)) { + x_251 = lean_alloc_ctor(0, 4, 0); } else { - x_238 = x_237; + x_251 = x_250; } -lean_ctor_set(x_238, 0, x_235); -lean_ctor_set(x_238, 1, x_236); -lean_ctor_set(x_238, 2, x_210); -if (lean_is_scalar(x_234)) { - x_239 = lean_alloc_ctor(0, 6, 0); +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_239 = x_234; + x_252 = x_246; } -lean_ctor_set(x_239, 0, x_229); -lean_ctor_set(x_239, 1, x_230); -lean_ctor_set(x_239, 2, x_238); -lean_ctor_set(x_239, 3, x_231); -lean_ctor_set(x_239, 4, x_232); -lean_ctor_set(x_239, 5, x_233); -if (lean_is_scalar(x_228)) { - x_240 = lean_alloc_ctor(0, 2, 0); +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_240 = x_228; + x_253 = x_240; } -lean_ctor_set(x_240, 0, x_227); -lean_ctor_set(x_240, 1, x_239); -return 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_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; -x_241 = lean_ctor_get(x_224, 1); -lean_inc(x_241); -x_242 = lean_ctor_get(x_241, 2); -lean_inc(x_242); -x_243 = lean_ctor_get(x_224, 0); -lean_inc(x_243); -if (lean_is_exclusive(x_224)) { - lean_ctor_release(x_224, 0); - lean_ctor_release(x_224, 1); - x_244 = x_224; +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_224); - x_244 = lean_box(0); + lean_dec_ref(x_236); + x_257 = lean_box(0); } -x_245 = lean_ctor_get(x_241, 0); -lean_inc(x_245); -x_246 = lean_ctor_get(x_241, 1); -lean_inc(x_246); -x_247 = lean_ctor_get(x_241, 3); -lean_inc(x_247); -x_248 = lean_ctor_get(x_241, 4); -lean_inc(x_248); -x_249 = lean_ctor_get(x_241, 5); -lean_inc(x_249); -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_250 = x_241; +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_241); - x_250 = lean_box(0); + lean_dec_ref(x_254); + x_263 = lean_box(0); } -x_251 = lean_ctor_get(x_242, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_242, 1); -lean_inc(x_252); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - lean_ctor_release(x_242, 2); - x_253 = x_242; +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_242); - x_253 = lean_box(0); + lean_dec_ref(x_255); + x_267 = lean_box(0); } -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_267)) { + x_268 = lean_alloc_ctor(0, 4, 0); } else { - x_254 = x_253; + x_268 = x_267; } -lean_ctor_set(x_254, 0, x_251); -lean_ctor_set(x_254, 1, x_252); -lean_ctor_set(x_254, 2, x_210); -if (lean_is_scalar(x_250)) { - x_255 = lean_alloc_ctor(0, 6, 0); +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_255 = x_250; + x_269 = x_263; } -lean_ctor_set(x_255, 0, x_245); -lean_ctor_set(x_255, 1, x_246); -lean_ctor_set(x_255, 2, x_254); -lean_ctor_set(x_255, 3, x_247); -lean_ctor_set(x_255, 4, x_248); -lean_ctor_set(x_255, 5, x_249); -if (lean_is_scalar(x_244)) { - x_256 = lean_alloc_ctor(1, 2, 0); +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_256 = x_244; + x_270 = x_257; } -lean_ctor_set(x_256, 0, x_243); -lean_ctor_set(x_256, 1, x_255); -return x_256; +lean_ctor_set(x_270, 0, x_256); +lean_ctor_set(x_270, 1, x_269); +return x_270; } } } default: { -lean_object* x_257; lean_object* x_258; -x_257 = lean_ctor_get(x_26, 1); -lean_inc(x_257); +lean_object* x_271; lean_object* x_272; +x_271 = lean_ctor_get(x_26, 1); +lean_inc(x_271); lean_dec(x_26); lean_inc(x_12); -x_258 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_257); -if (lean_obj_tag(x_258) == 0) +x_272 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_271); +if (lean_obj_tag(x_272) == 0) { -lean_object* x_259; -x_259 = lean_ctor_get(x_258, 0); -lean_inc(x_259); -if (lean_obj_tag(x_259) == 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_260; lean_object* x_261; lean_object* x_262; +lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_dec(x_21); -x_260 = lean_ctor_get(x_258, 1); -lean_inc(x_260); -lean_dec(x_258); -x_261 = lean_unsigned_to_nat(1u); -x_262 = lean_nat_add(x_11, x_261); +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); lean_dec(x_11); -x_11 = x_262; -x_13 = x_260; +x_11 = x_276; +x_13 = x_274; goto _start; } else { -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; -x_264 = lean_ctor_get(x_258, 1); -lean_inc(x_264); -lean_dec(x_258); -x_265 = lean_ctor_get(x_259, 0); -lean_inc(x_265); -lean_dec(x_259); -x_266 = lean_unsigned_to_nat(1u); -x_267 = lean_nat_add(x_11, x_266); -lean_dec(x_11); -x_268 = !lean_is_exclusive(x_264); -if (x_268 == 0) -{ -lean_object* x_269; uint8_t x_270; -x_269 = lean_ctor_get(x_264, 2); -x_270 = !lean_is_exclusive(x_269); -if (x_270 == 0) -{ -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_269, 2); -x_272 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_269, 2, x_272); -x_273 = !lean_is_exclusive(x_12); -if (x_273 == 0) -{ -lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_274 = lean_ctor_get(x_12, 2); -x_275 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_275, 0, x_265); -lean_ctor_set(x_275, 1, x_21); -x_276 = lean_array_push(x_274, x_275); -lean_ctor_set(x_12, 2, x_276); -x_277 = 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_267, x_12, x_264); -if (lean_obj_tag(x_277) == 0) -{ -lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_277, 1); +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); -x_279 = lean_ctor_get(x_278, 2); +lean_dec(x_272); +x_279 = lean_ctor_get(x_273, 0); lean_inc(x_279); -x_280 = !lean_is_exclusive(x_277); -if (x_280 == 0) -{ -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_277, 1); -lean_dec(x_281); +lean_dec(x_273); +x_280 = lean_unsigned_to_nat(1u); +x_281 = lean_nat_add(x_11, x_280); +lean_dec(x_11); x_282 = !lean_is_exclusive(x_278); if (x_282 == 0) { lean_object* x_283; uint8_t x_284; x_283 = lean_ctor_get(x_278, 2); -lean_dec(x_283); -x_284 = !lean_is_exclusive(x_279); +x_284 = !lean_is_exclusive(x_283); if (x_284 == 0) { -lean_object* x_285; -x_285 = lean_ctor_get(x_279, 2); -lean_dec(x_285); -lean_ctor_set(x_279, 2, x_271); -return x_277; -} -else +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_286; lean_object* x_287; lean_object* x_288; -x_286 = lean_ctor_get(x_279, 0); -x_287 = lean_ctor_get(x_279, 1); -lean_inc(x_287); -lean_inc(x_286); -lean_dec(x_279); -x_288 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_288, 0, x_286); -lean_ctor_set(x_288, 1, x_287); -lean_ctor_set(x_288, 2, x_271); -lean_ctor_set(x_278, 2, x_288); -return x_277; -} -} -else +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_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; -x_289 = lean_ctor_get(x_278, 0); -x_290 = lean_ctor_get(x_278, 1); -x_291 = lean_ctor_get(x_278, 3); -x_292 = lean_ctor_get(x_278, 4); -x_293 = lean_ctor_get(x_278, 5); -lean_inc(x_293); +lean_object* x_292; lean_object* x_293; uint8_t x_294; +x_292 = lean_ctor_get(x_291, 1); lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); -lean_dec(x_278); -x_294 = lean_ctor_get(x_279, 0); -lean_inc(x_294); -x_295 = lean_ctor_get(x_279, 1); -lean_inc(x_295); -if (lean_is_exclusive(x_279)) { - lean_ctor_release(x_279, 0); - lean_ctor_release(x_279, 1); - lean_ctor_release(x_279, 2); - x_296 = x_279; -} else { - lean_dec_ref(x_279); - x_296 = lean_box(0); -} -if (lean_is_scalar(x_296)) { - x_297 = lean_alloc_ctor(0, 3, 0); -} else { - x_297 = x_296; -} -lean_ctor_set(x_297, 0, x_294); -lean_ctor_set(x_297, 1, x_295); -lean_ctor_set(x_297, 2, x_271); -x_298 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_298, 0, x_289); -lean_ctor_set(x_298, 1, x_290); -lean_ctor_set(x_298, 2, x_297); -lean_ctor_set(x_298, 3, x_291); -lean_ctor_set(x_298, 4, x_292); -lean_ctor_set(x_298, 5, x_293); -lean_ctor_set(x_277, 1, x_298); -return x_277; -} +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_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; -x_299 = lean_ctor_get(x_277, 0); -lean_inc(x_299); -lean_dec(x_277); -x_300 = lean_ctor_get(x_278, 0); -lean_inc(x_300); -x_301 = lean_ctor_get(x_278, 1); -lean_inc(x_301); -x_302 = lean_ctor_get(x_278, 3); +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); -x_303 = lean_ctor_get(x_278, 4); -lean_inc(x_303); -x_304 = lean_ctor_get(x_278, 5); -lean_inc(x_304); -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_305 = x_278; -} else { - lean_dec_ref(x_278); - x_305 = lean_box(0); +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; } -x_306 = lean_ctor_get(x_279, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_279, 1); +} +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); -if (lean_is_exclusive(x_279)) { - lean_ctor_release(x_279, 0); - lean_ctor_release(x_279, 1); - lean_ctor_release(x_279, 2); - x_308 = x_279; +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_inc(x_310); +x_311 = lean_ctor_get(x_293, 3); +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_279); - x_308 = lean_box(0); + lean_dec_ref(x_293); + x_312 = lean_box(0); } -if (lean_is_scalar(x_308)) { - x_309 = lean_alloc_ctor(0, 3, 0); +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 4, 0); } else { - x_309 = x_308; + x_313 = x_312; } -lean_ctor_set(x_309, 0, x_306); -lean_ctor_set(x_309, 1, x_307); -lean_ctor_set(x_309, 2, x_271); -if (lean_is_scalar(x_305)) { - x_310 = lean_alloc_ctor(0, 6, 0); -} else { - x_310 = x_305; -} -lean_ctor_set(x_310, 0, x_300); -lean_ctor_set(x_310, 1, x_301); -lean_ctor_set(x_310, 2, x_309); -lean_ctor_set(x_310, 3, x_302); -lean_ctor_set(x_310, 4, x_303); -lean_ctor_set(x_310, 5, x_304); -x_311 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_311, 0, x_299); -lean_ctor_set(x_311, 1, x_310); -return x_311; +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_312; lean_object* x_313; uint8_t x_314; -x_312 = lean_ctor_get(x_277, 1); -lean_inc(x_312); -x_313 = lean_ctor_get(x_312, 2); -lean_inc(x_313); -x_314 = !lean_is_exclusive(x_277); -if (x_314 == 0) -{ -lean_object* x_315; uint8_t x_316; -x_315 = lean_ctor_get(x_277, 1); -lean_dec(x_315); -x_316 = !lean_is_exclusive(x_312); -if (x_316 == 0) -{ -lean_object* x_317; uint8_t x_318; -x_317 = lean_ctor_get(x_312, 2); -lean_dec(x_317); -x_318 = !lean_is_exclusive(x_313); -if (x_318 == 0) -{ -lean_object* x_319; -x_319 = lean_ctor_get(x_313, 2); -lean_dec(x_319); -lean_ctor_set(x_313, 2, x_271); -return x_277; -} -else -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; -x_320 = lean_ctor_get(x_313, 0); -x_321 = lean_ctor_get(x_313, 1); -lean_inc(x_321); +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_inc(x_320); -lean_dec(x_313); -x_322 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_322, 0, x_320); -lean_ctor_set(x_322, 1, x_321); -lean_ctor_set(x_322, 2, x_271); -lean_ctor_set(x_312, 2, x_322); -return x_277; +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); } -} -else -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; -x_323 = lean_ctor_get(x_312, 0); -x_324 = lean_ctor_get(x_312, 1); -x_325 = lean_ctor_get(x_312, 3); -x_326 = lean_ctor_get(x_312, 4); -x_327 = lean_ctor_get(x_312, 5); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); +x_322 = lean_ctor_get(x_293, 0); +lean_inc(x_322); +x_323 = lean_ctor_get(x_293, 1); lean_inc(x_323); -lean_dec(x_312); -x_328 = lean_ctor_get(x_313, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_313, 1); +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); -if (lean_is_exclusive(x_313)) { - lean_ctor_release(x_313, 0); - lean_ctor_release(x_313, 1); - lean_ctor_release(x_313, 2); - x_330 = x_313; -} else { - lean_dec_ref(x_313); - x_330 = lean_box(0); -} -if (lean_is_scalar(x_330)) { - x_331 = lean_alloc_ctor(0, 3, 0); -} else { - x_331 = x_330; -} -lean_ctor_set(x_331, 0, x_328); -lean_ctor_set(x_331, 1, x_329); -lean_ctor_set(x_331, 2, x_271); -x_332 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_332, 0, x_323); -lean_ctor_set(x_332, 1, x_324); -lean_ctor_set(x_332, 2, x_331); -lean_ctor_set(x_332, 3, x_325); -lean_ctor_set(x_332, 4, x_326); -lean_ctor_set(x_332, 5, x_327); -lean_ctor_set(x_277, 1, x_332); -return x_277; -} +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_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_333 = lean_ctor_get(x_277, 0); -lean_inc(x_333); -lean_dec(x_277); -x_334 = lean_ctor_get(x_312, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_312, 1); -lean_inc(x_335); -x_336 = lean_ctor_get(x_312, 3); -lean_inc(x_336); -x_337 = lean_ctor_get(x_312, 4); -lean_inc(x_337); -x_338 = lean_ctor_get(x_312, 5); +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); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - lean_ctor_release(x_312, 2); - lean_ctor_release(x_312, 3); - lean_ctor_release(x_312, 4); - lean_ctor_release(x_312, 5); - x_339 = x_312; -} else { - lean_dec_ref(x_312); - x_339 = lean_box(0); -} -x_340 = lean_ctor_get(x_313, 0); -lean_inc(x_340); -x_341 = lean_ctor_get(x_313, 1); -lean_inc(x_341); -if (lean_is_exclusive(x_313)) { - lean_ctor_release(x_313, 0); - lean_ctor_release(x_313, 1); - lean_ctor_release(x_313, 2); - x_342 = x_313; -} else { - lean_dec_ref(x_313); - x_342 = lean_box(0); -} -if (lean_is_scalar(x_342)) { - x_343 = lean_alloc_ctor(0, 3, 0); -} else { - x_343 = x_342; -} -lean_ctor_set(x_343, 0, x_340); -lean_ctor_set(x_343, 1, x_341); -lean_ctor_set(x_343, 2, x_271); -if (lean_is_scalar(x_339)) { - x_344 = lean_alloc_ctor(0, 6, 0); -} else { - x_344 = x_339; -} -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); -x_345 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_345, 0, x_333); -lean_ctor_set(x_345, 1, x_344); -return x_345; -} +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_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_346 = lean_ctor_get(x_12, 0); -x_347 = lean_ctor_get(x_12, 1); -x_348 = lean_ctor_get(x_12, 2); -x_349 = lean_ctor_get(x_12, 3); -x_350 = lean_ctor_get(x_12, 4); -lean_inc(x_350); -lean_inc(x_349); -lean_inc(x_348); -lean_inc(x_347); +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); -lean_dec(x_12); -x_351 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_351, 0, x_265); -lean_ctor_set(x_351, 1, x_21); -x_352 = lean_array_push(x_348, x_351); -x_353 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_353, 0, x_346); -lean_ctor_set(x_353, 1, x_347); -lean_ctor_set(x_353, 2, x_352); -lean_ctor_set(x_353, 3, x_349); -lean_ctor_set(x_353, 4, x_350); -x_354 = 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_267, x_353, x_264); -if (lean_obj_tag(x_354) == 0) -{ -lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; -x_355 = lean_ctor_get(x_354, 1); -lean_inc(x_355); -x_356 = lean_ctor_get(x_355, 2); -lean_inc(x_356); -x_357 = lean_ctor_get(x_354, 0); -lean_inc(x_357); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - x_358 = x_354; +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_354); + 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_355, 0); +x_359 = lean_ctor_get(x_330, 0); lean_inc(x_359); -x_360 = lean_ctor_get(x_355, 1); +x_360 = lean_ctor_get(x_330, 1); lean_inc(x_360); -x_361 = lean_ctor_get(x_355, 3); +x_361 = lean_ctor_get(x_330, 3); lean_inc(x_361); -x_362 = lean_ctor_get(x_355, 4); -lean_inc(x_362); -x_363 = lean_ctor_get(x_355, 5); -lean_inc(x_363); -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); - lean_ctor_release(x_355, 4); - lean_ctor_release(x_355, 5); - x_364 = x_355; +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_355); - x_364 = lean_box(0); + lean_dec_ref(x_330); + x_362 = lean_box(0); } -x_365 = lean_ctor_get(x_356, 0); -lean_inc(x_365); -x_366 = lean_ctor_get(x_356, 1); -lean_inc(x_366); -if (lean_is_exclusive(x_356)) { - lean_ctor_release(x_356, 0); - lean_ctor_release(x_356, 1); - lean_ctor_release(x_356, 2); - x_367 = x_356; +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 4, 0); } else { - lean_dec_ref(x_356); - x_367 = lean_box(0); + x_363 = x_362; } -if (lean_is_scalar(x_367)) { - x_368 = lean_alloc_ctor(0, 3, 0); -} else { - x_368 = x_367; -} -lean_ctor_set(x_368, 0, x_365); -lean_ctor_set(x_368, 1, x_366); -lean_ctor_set(x_368, 2, x_271); -if (lean_is_scalar(x_364)) { - x_369 = lean_alloc_ctor(0, 6, 0); -} else { - x_369 = x_364; -} -lean_ctor_set(x_369, 0, x_359); -lean_ctor_set(x_369, 1, x_360); -lean_ctor_set(x_369, 2, x_368); -lean_ctor_set(x_369, 3, x_361); -lean_ctor_set(x_369, 4, x_362); -lean_ctor_set(x_369, 5, x_363); +lean_ctor_set(x_363, 0, x_359); +lean_ctor_set(x_363, 1, x_360); +lean_ctor_set(x_363, 2, x_285); +lean_ctor_set(x_363, 3, x_361); if (lean_is_scalar(x_358)) { - x_370 = lean_alloc_ctor(0, 2, 0); + x_364 = lean_alloc_ctor(0, 6, 0); } else { - x_370 = x_358; + 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; +} } -lean_ctor_set(x_370, 0, x_357); -lean_ctor_set(x_370, 1, x_369); -return x_370; } else { -lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; -x_371 = lean_ctor_get(x_354, 1); -lean_inc(x_371); -x_372 = lean_ctor_get(x_371, 2); -lean_inc(x_372); -x_373 = lean_ctor_get(x_354, 0); -lean_inc(x_373); -if (lean_is_exclusive(x_354)) { - lean_ctor_release(x_354, 0); - lean_ctor_release(x_354, 1); - x_374 = x_354; -} else { - lean_dec_ref(x_354); - x_374 = lean_box(0); -} -x_375 = lean_ctor_get(x_371, 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; +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_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) +{ +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_371, 1); +x_376 = lean_ctor_get(x_375, 2); lean_inc(x_376); -x_377 = lean_ctor_get(x_371, 3); +x_377 = lean_ctor_get(x_374, 0); lean_inc(x_377); -x_378 = lean_ctor_get(x_371, 4); -lean_inc(x_378); -x_379 = lean_ctor_get(x_371, 5); +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); -if (lean_is_exclusive(x_371)) { - lean_ctor_release(x_371, 0); - lean_ctor_release(x_371, 1); - lean_ctor_release(x_371, 2); - lean_ctor_release(x_371, 3); - lean_ctor_release(x_371, 4); - lean_ctor_release(x_371, 5); - x_380 = x_371; -} else { - lean_dec_ref(x_371); - x_380 = lean_box(0); -} -x_381 = lean_ctor_get(x_372, 0); +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_372, 1); +x_382 = lean_ctor_get(x_375, 4); lean_inc(x_382); -if (lean_is_exclusive(x_372)) { - lean_ctor_release(x_372, 0); - lean_ctor_release(x_372, 1); - lean_ctor_release(x_372, 2); - x_383 = x_372; +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_372); - x_383 = lean_box(0); + lean_dec_ref(x_375); + x_384 = lean_box(0); } -if (lean_is_scalar(x_383)) { - x_384 = lean_alloc_ctor(0, 3, 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 { - x_384 = x_383; + lean_dec_ref(x_376); + x_388 = lean_box(0); } -lean_ctor_set(x_384, 0, x_381); -lean_ctor_set(x_384, 1, x_382); -lean_ctor_set(x_384, 2, x_271); -if (lean_is_scalar(x_380)) { - x_385 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_388)) { + x_389 = lean_alloc_ctor(0, 4, 0); } else { - x_385 = x_380; + x_389 = x_388; } -lean_ctor_set(x_385, 0, x_375); -lean_ctor_set(x_385, 1, x_376); -lean_ctor_set(x_385, 2, x_384); -lean_ctor_set(x_385, 3, x_377); -lean_ctor_set(x_385, 4, x_378); -lean_ctor_set(x_385, 5, x_379); -if (lean_is_scalar(x_374)) { - x_386 = lean_alloc_ctor(1, 2, 0); +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_386 = x_374; -} -lean_ctor_set(x_386, 0, x_373); -lean_ctor_set(x_386, 1, x_385); -return x_386; + 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; } 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_400; lean_object* x_401; -x_387 = lean_ctor_get(x_269, 0); -x_388 = lean_ctor_get(x_269, 1); -x_389 = lean_ctor_get(x_269, 2); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_387); -lean_dec(x_269); -x_390 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_391 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_391, 0, x_387); -lean_ctor_set(x_391, 1, x_388); -lean_ctor_set(x_391, 2, x_390); -lean_ctor_set(x_264, 2, x_391); -x_392 = lean_ctor_get(x_12, 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_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_12, 1); +x_393 = lean_ctor_get(x_392, 2); lean_inc(x_393); -x_394 = lean_ctor_get(x_12, 2); +x_394 = lean_ctor_get(x_374, 0); lean_inc(x_394); -x_395 = lean_ctor_get(x_12, 3); -lean_inc(x_395); -x_396 = lean_ctor_get(x_12, 4); +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); +} +x_396 = lean_ctor_get(x_392, 0); lean_inc(x_396); -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_397 = x_12; +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_12); - x_397 = lean_box(0); + lean_dec_ref(x_392); + x_401 = lean_box(0); } -x_398 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_398, 0, x_265); -lean_ctor_set(x_398, 1, x_21); -x_399 = lean_array_push(x_394, x_398); -if (lean_is_scalar(x_397)) { - x_400 = lean_alloc_ctor(0, 5, 0); -} else { - x_400 = x_397; -} -lean_ctor_set(x_400, 0, x_392); -lean_ctor_set(x_400, 1, x_393); -lean_ctor_set(x_400, 2, x_399); -lean_ctor_set(x_400, 3, x_395); -lean_ctor_set(x_400, 4, x_396); -x_401 = 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_267, x_400, x_264); -if (lean_obj_tag(x_401) == 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; lean_object* x_417; -x_402 = lean_ctor_get(x_401, 1); +x_402 = lean_ctor_get(x_393, 0); lean_inc(x_402); -x_403 = lean_ctor_get(x_402, 2); +x_403 = lean_ctor_get(x_393, 1); lean_inc(x_403); -x_404 = lean_ctor_get(x_401, 0); +x_404 = lean_ctor_get(x_393, 3); lean_inc(x_404); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - x_405 = 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); + x_405 = x_393; } else { - lean_dec_ref(x_401); + lean_dec_ref(x_393); x_405 = lean_box(0); } -x_406 = lean_ctor_get(x_402, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_402, 1); -lean_inc(x_407); -x_408 = lean_ctor_get(x_402, 3); -lean_inc(x_408); -x_409 = lean_ctor_get(x_402, 4); -lean_inc(x_409); -x_410 = lean_ctor_get(x_402, 5); -lean_inc(x_410); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - lean_ctor_release(x_402, 2); - lean_ctor_release(x_402, 3); - lean_ctor_release(x_402, 4); - lean_ctor_release(x_402, 5); - x_411 = x_402; -} else { - lean_dec_ref(x_402); - x_411 = lean_box(0); -} -x_412 = lean_ctor_get(x_403, 0); -lean_inc(x_412); -x_413 = lean_ctor_get(x_403, 1); -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); - x_414 = x_403; -} else { - lean_dec_ref(x_403); - x_414 = lean_box(0); -} -if (lean_is_scalar(x_414)) { - x_415 = lean_alloc_ctor(0, 3, 0); -} else { - x_415 = x_414; -} -lean_ctor_set(x_415, 0, x_412); -lean_ctor_set(x_415, 1, x_413); -lean_ctor_set(x_415, 2, x_389); -if (lean_is_scalar(x_411)) { - x_416 = lean_alloc_ctor(0, 6, 0); -} else { - x_416 = x_411; -} -lean_ctor_set(x_416, 0, x_406); -lean_ctor_set(x_416, 1, x_407); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_408); -lean_ctor_set(x_416, 4, x_409); -lean_ctor_set(x_416, 5, x_410); if (lean_is_scalar(x_405)) { - x_417 = lean_alloc_ctor(0, 2, 0); + x_406 = lean_alloc_ctor(0, 4, 0); } else { - x_417 = x_405; + x_406 = x_405; +} +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); +} else { + x_407 = x_401; +} +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); +} else { + x_408 = x_395; +} +lean_ctor_set(x_408, 0, x_394); +lean_ctor_set(x_408, 1, x_407); +return x_408; +} } -lean_ctor_set(x_417, 0, x_404); -lean_ctor_set(x_417, 1, x_416); -return x_417; } else { -lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; -x_418 = lean_ctor_get(x_401, 1); +lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; +x_409 = lean_ctor_get(x_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_418, 2); +x_419 = lean_ctor_get(x_12, 4); lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 0); -lean_inc(x_420); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - x_421 = x_401; -} else { - lean_dec_ref(x_401); - 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); -if (lean_is_exclusive(x_419)) { - lean_ctor_release(x_419, 0); - lean_ctor_release(x_419, 1); - lean_ctor_release(x_419, 2); - x_430 = x_419; -} else { - lean_dec_ref(x_419); - x_430 = lean_box(0); -} -if (lean_is_scalar(x_430)) { - x_431 = lean_alloc_ctor(0, 3, 0); -} else { - x_431 = x_430; -} -lean_ctor_set(x_431, 0, x_428); -lean_ctor_set(x_431, 1, x_429); -lean_ctor_set(x_431, 2, x_389); -if (lean_is_scalar(x_427)) { - x_432 = lean_alloc_ctor(0, 6, 0); -} else { - x_432 = x_427; -} -lean_ctor_set(x_432, 0, x_422); -lean_ctor_set(x_432, 1, x_423); -lean_ctor_set(x_432, 2, x_431); -lean_ctor_set(x_432, 3, x_424); -lean_ctor_set(x_432, 4, x_425); -lean_ctor_set(x_432, 5, x_426); -if (lean_is_scalar(x_421)) { - x_433 = lean_alloc_ctor(1, 2, 0); -} else { - x_433 = x_421; -} -lean_ctor_set(x_433, 0, x_420); -lean_ctor_set(x_433, 1, x_432); -return x_433; -} -} -} -else -{ -lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; 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_434 = lean_ctor_get(x_264, 2); -x_435 = lean_ctor_get(x_264, 0); -x_436 = lean_ctor_get(x_264, 1); -x_437 = lean_ctor_get(x_264, 3); -x_438 = lean_ctor_get(x_264, 4); -x_439 = lean_ctor_get(x_264, 5); -lean_inc(x_439); -lean_inc(x_438); -lean_inc(x_437); -lean_inc(x_434); -lean_inc(x_436); -lean_inc(x_435); -lean_dec(x_264); -x_440 = lean_ctor_get(x_434, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_434, 1); -lean_inc(x_441); -x_442 = lean_ctor_get(x_434, 2); -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); - x_443 = x_434; -} else { - lean_dec_ref(x_434); - x_443 = lean_box(0); -} -x_444 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_443)) { - x_445 = lean_alloc_ctor(0, 3, 0); -} else { - x_445 = x_443; -} -lean_ctor_set(x_445, 0, x_440); -lean_ctor_set(x_445, 1, x_441); -lean_ctor_set(x_445, 2, x_444); -x_446 = lean_alloc_ctor(0, 6, 0); -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); -x_447 = lean_ctor_get(x_12, 0); -lean_inc(x_447); -x_448 = lean_ctor_get(x_12, 1); -lean_inc(x_448); -x_449 = lean_ctor_get(x_12, 2); -lean_inc(x_449); -x_450 = lean_ctor_get(x_12, 3); -lean_inc(x_450); -x_451 = lean_ctor_get(x_12, 4); -lean_inc(x_451); 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_452 = x_12; + x_420 = x_12; } else { lean_dec_ref(x_12); - x_452 = lean_box(0); + x_420 = lean_box(0); } -x_453 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_453, 0, x_265); -lean_ctor_set(x_453, 1, x_21); -x_454 = lean_array_push(x_449, x_453); -if (lean_is_scalar(x_452)) { - x_455 = lean_alloc_ctor(0, 5, 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); } else { - x_455 = x_452; + x_423 = x_420; } -lean_ctor_set(x_455, 0, x_447); -lean_ctor_set(x_455, 1, x_448); -lean_ctor_set(x_455, 2, x_454); -lean_ctor_set(x_455, 3, x_450); -lean_ctor_set(x_455, 4, x_451); -x_456 = l_Lean_Meta_withNewLocalInstances___main___at_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_267, x_455, x_446); -if (lean_obj_tag(x_456) == 0) +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_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; -x_457 = lean_ctor_get(x_456, 1); -lean_inc(x_457); -x_458 = lean_ctor_get(x_457, 2); -lean_inc(x_458); -x_459 = lean_ctor_get(x_456, 0); -lean_inc(x_459); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - x_460 = x_456; +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_456); - x_460 = lean_box(0); + lean_dec_ref(x_424); + x_428 = lean_box(0); } -x_461 = lean_ctor_get(x_457, 0); -lean_inc(x_461); -x_462 = lean_ctor_get(x_457, 1); -lean_inc(x_462); -x_463 = lean_ctor_get(x_457, 3); -lean_inc(x_463); -x_464 = lean_ctor_get(x_457, 4); +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; +} +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); +} +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; +} else { + lean_dec_ref(x_442); + x_451 = 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; +} else { + lean_dec_ref(x_443); + x_455 = lean_box(0); +} +if (lean_is_scalar(x_455)) { + x_456 = lean_alloc_ctor(0, 4, 0); +} else { + x_456 = x_455; +} +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); +} else { + x_457 = x_451; +} +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); +} else { + x_458 = x_445; +} +lean_ctor_set(x_458, 0, x_444); +lean_ctor_set(x_458, 1, x_457); +return x_458; +} +} +} +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); -x_465 = lean_ctor_get(x_457, 5); +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); -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); - lean_ctor_release(x_457, 4); - lean_ctor_release(x_457, 5); - x_466 = x_457; -} else { - lean_dec_ref(x_457); - x_466 = lean_box(0); -} -x_467 = lean_ctor_get(x_458, 0); +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_458, 1); +x_468 = lean_ctor_get(x_459, 3); lean_inc(x_468); -if (lean_is_exclusive(x_458)) { - lean_ctor_release(x_458, 0); - lean_ctor_release(x_458, 1); - lean_ctor_release(x_458, 2); - x_469 = x_458; +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; } else { - lean_dec_ref(x_458); + lean_dec_ref(x_459); x_469 = lean_box(0); } +x_470 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; if (lean_is_scalar(x_469)) { - x_470 = lean_alloc_ctor(0, 3, 0); + x_471 = lean_alloc_ctor(0, 4, 0); } else { - x_470 = x_469; + x_471 = x_469; } -lean_ctor_set(x_470, 0, x_467); -lean_ctor_set(x_470, 1, x_468); -lean_ctor_set(x_470, 2, x_442); -if (lean_is_scalar(x_466)) { - x_471 = lean_alloc_ctor(0, 6, 0); -} else { - x_471 = x_466; -} -lean_ctor_set(x_471, 0, x_461); -lean_ctor_set(x_471, 1, x_462); +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_463); -lean_ctor_set(x_471, 4, x_464); -lean_ctor_set(x_471, 5, x_465); -if (lean_is_scalar(x_460)) { - x_472 = lean_alloc_ctor(0, 2, 0); -} else { - x_472 = x_460; -} -lean_ctor_set(x_472, 0, x_459); -lean_ctor_set(x_472, 1, x_471); -return x_472; -} -else -{ -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_473 = lean_ctor_get(x_456, 1); +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_473, 2); +x_474 = lean_ctor_get(x_12, 1); lean_inc(x_474); -x_475 = lean_ctor_get(x_456, 0); +x_475 = lean_ctor_get(x_12, 2); lean_inc(x_475); -if (lean_is_exclusive(x_456)) { - lean_ctor_release(x_456, 0); - lean_ctor_release(x_456, 1); - x_476 = x_456; -} else { - lean_dec_ref(x_456); - x_476 = lean_box(0); -} -x_477 = lean_ctor_get(x_473, 0); +x_476 = lean_ctor_get(x_12, 3); +lean_inc(x_476); +x_477 = lean_ctor_get(x_12, 4); lean_inc(x_477); -x_478 = lean_ctor_get(x_473, 1); -lean_inc(x_478); -x_479 = lean_ctor_get(x_473, 3); -lean_inc(x_479); -x_480 = lean_ctor_get(x_473, 4); -lean_inc(x_480); -x_481 = lean_ctor_get(x_473, 5); -lean_inc(x_481); -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); - lean_ctor_release(x_473, 4); - lean_ctor_release(x_473, 5); - x_482 = x_473; +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; } else { - lean_dec_ref(x_473); - x_482 = lean_box(0); + lean_dec_ref(x_12); + x_478 = lean_box(0); } -x_483 = lean_ctor_get(x_474, 0); +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); +} else { + x_481 = x_478; +} +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_474, 1); +x_484 = lean_ctor_get(x_483, 2); lean_inc(x_484); -if (lean_is_exclusive(x_474)) { - lean_ctor_release(x_474, 0); - lean_ctor_release(x_474, 1); - lean_ctor_release(x_474, 2); - x_485 = x_474; +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; } else { - lean_dec_ref(x_474); - x_485 = lean_box(0); + lean_dec_ref(x_482); + x_486 = lean_box(0); } -if (lean_is_scalar(x_485)) { - x_486 = lean_alloc_ctor(0, 3, 0); +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 { - x_486 = x_485; + lean_dec_ref(x_483); + x_492 = lean_box(0); } -lean_ctor_set(x_486, 0, x_483); -lean_ctor_set(x_486, 1, x_484); -lean_ctor_set(x_486, 2, x_442); -if (lean_is_scalar(x_482)) { - x_487 = lean_alloc_ctor(0, 6, 0); +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 { - x_487 = x_482; + lean_dec_ref(x_484); + x_496 = lean_box(0); } -lean_ctor_set(x_487, 0, x_477); -lean_ctor_set(x_487, 1, x_478); -lean_ctor_set(x_487, 2, x_486); -lean_ctor_set(x_487, 3, x_479); -lean_ctor_set(x_487, 4, x_480); -lean_ctor_set(x_487, 5, x_481); -if (lean_is_scalar(x_476)) { - x_488 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_496)) { + x_497 = lean_alloc_ctor(0, 4, 0); } else { - x_488 = x_476; + x_497 = x_496; } -lean_ctor_set(x_488, 0, x_475); -lean_ctor_set(x_488, 1, x_487); -return x_488; +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_489; +uint8_t x_517; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -5229,23 +5441,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_489 = !lean_is_exclusive(x_258); -if (x_489 == 0) +x_517 = !lean_is_exclusive(x_272); +if (x_517 == 0) { -return x_258; +return x_272; } else { -lean_object* x_490; lean_object* x_491; lean_object* x_492; -x_490 = lean_ctor_get(x_258, 0); -x_491 = lean_ctor_get(x_258, 1); -lean_inc(x_491); -lean_inc(x_490); -lean_dec(x_258); -x_492 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_492, 0, x_490); -lean_ctor_set(x_492, 1, x_491); -return x_492; +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; } } } @@ -5253,7 +5465,7 @@ return x_492; } else { -uint8_t x_493; +uint8_t x_521; lean_dec(x_25); lean_dec(x_21); lean_dec(x_12); @@ -5264,29 +5476,29 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_493 = !lean_is_exclusive(x_26); -if (x_493 == 0) +x_521 = !lean_is_exclusive(x_26); +if (x_521 == 0) { return x_26; } else { -lean_object* x_494; lean_object* x_495; lean_object* x_496; -x_494 = lean_ctor_get(x_26, 0); -x_495 = lean_ctor_get(x_26, 1); -lean_inc(x_495); -lean_inc(x_494); +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_dec(x_26); -x_496 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_496, 0, x_494); -lean_ctor_set(x_496, 1, x_495); -return x_496; +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; } } } else { -uint8_t x_497; +uint8_t x_525; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -5296,23 +5508,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_497 = !lean_is_exclusive(x_22); -if (x_497 == 0) +x_525 = !lean_is_exclusive(x_22); +if (x_525 == 0) { return x_22; } else { -lean_object* x_498; lean_object* x_499; lean_object* x_500; -x_498 = lean_ctor_get(x_22, 0); -x_499 = lean_ctor_get(x_22, 1); -lean_inc(x_499); -lean_inc(x_498); +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_dec(x_22); -x_500 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_500, 0, x_498); -lean_ctor_set(x_500, 1, x_499); -return x_500; +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; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Rewrite.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Rewrite.c index a990d4f683..eabb697f9a 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Rewrite.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Rewrite.c @@ -24,6 +24,7 @@ lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__11; lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__8; lean_object* l_Lean_Meta_isTypeCorrect(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__17; lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__4; lean_object* l_Lean_Meta_checkNotAssigned___boxed(lean_object*, lean_object*, lean_object*, lean_object*); @@ -31,11 +32,9 @@ lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__9; lean_object* l_Lean_Meta_postprocessAppMVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__6; lean_object* l_Lean_Meta_mkEqRefl(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_rewriteCore___closed__1; lean_object* l_Lean_Meta_rewriteCore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_filterMAux___main___at_Lean_Meta_apply___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_mkEqSymm(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_iff_x3f___closed__2; lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__2; @@ -55,7 +54,6 @@ lean_object* l_Lean_Meta_throwTacticEx___rarg(lean_object*, lean_object*, lean_o lean_object* l_Lean_Meta_rewriteCore___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__3; uint8_t l_Lean_Expr_isMVar(lean_object*); -lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); lean_object* l_Lean_Meta_rewriteCore___lambda__1___closed__14; lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); @@ -337,382 +335,407 @@ 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; -x_32 = l_Lean_Expr_getAppNumArgsAux___main(x_21, x_22); -x_33 = lean_nat_sub(x_32, x_22); -x_34 = lean_unsigned_to_nat(1u); -x_35 = lean_nat_sub(x_33, x_34); +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_32 = l_Lean_Expr_appFn_x21(x_21); +x_33 = l_Lean_Expr_appFn_x21(x_32); +x_34 = l_Lean_Expr_appArg_x21(x_33); lean_dec(x_33); -x_36 = l_Lean_Expr_getRevArg_x21___main(x_21, x_35); -x_37 = lean_nat_sub(x_32, x_34); -x_38 = lean_nat_sub(x_37, x_34); -lean_dec(x_37); -x_39 = l_Lean_Expr_getRevArg_x21___main(x_21, x_38); -x_40 = lean_nat_sub(x_32, x_25); +x_35 = l_Lean_Expr_appArg_x21(x_32); lean_dec(x_32); -x_41 = lean_nat_sub(x_40, x_34); -lean_dec(x_40); -x_42 = l_Lean_Expr_getRevArg_x21___main(x_21, x_41); +x_36 = l_Lean_Expr_appArg_x21(x_21); lean_dec(x_21); if (x_4 == 0) { -lean_object* x_43; uint8_t x_44; -x_43 = l_Lean_Expr_getAppFn___main(x_39); -x_44 = l_Lean_Expr_isMVar(x_43); +lean_object* x_37; uint8_t x_38; +x_37 = l_Lean_Expr_getAppFn___main(x_35); +x_38 = l_Lean_Expr_isMVar(x_37); +lean_dec(x_37); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_39 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_18); +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +lean_inc(x_8); +lean_inc(x_40); +x_42 = l_Lean_Meta_kabstract(x_40, x_35, x_6, x_8, x_41); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_108; +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_108 = l_Lean_Expr_hasLooseBVars(x_43); +if (x_108 == 0) +{ +lean_object* x_109; lean_object* x_110; uint8_t x_111; lean_dec(x_43); -if (x_44 == 0) -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_45 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_18); -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_8); -lean_inc(x_46); -x_48 = l_Lean_Meta_kabstract(x_46, x_39, x_6, x_8, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_114; -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_114 = l_Lean_Expr_hasLooseBVars(x_49); -if (x_114 == 0) -{ -lean_object* x_115; lean_object* x_116; uint8_t x_117; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_42); +lean_dec(x_40); lean_dec(x_36); +lean_dec(x_34); lean_dec(x_23); lean_dec(x_20); lean_dec(x_19); -x_115 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; -x_116 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_115, x_8, x_50); +x_109 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; +x_110 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_109, x_8, x_44); lean_dec(x_8); -x_117 = !lean_is_exclusive(x_116); -if (x_117 == 0) +x_111 = !lean_is_exclusive(x_110); +if (x_111 == 0) { -return x_116; +return x_110; } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_118 = lean_ctor_get(x_116, 0); -x_119 = lean_ctor_get(x_116, 1); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_116); -x_120 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_120, 0, x_118); -lean_ctor_set(x_120, 1, x_119); -return x_120; +lean_object* x_112; lean_object* x_113; lean_object* x_114; +x_112 = lean_ctor_get(x_110, 0); +x_113 = lean_ctor_get(x_110, 1); +lean_inc(x_113); +lean_inc(x_112); +lean_dec(x_110); +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 { -x_51 = x_50; -goto block_113; +x_45 = x_44; +goto block_107; } -block_113: +block_107: { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_52 = lean_expr_instantiate1(x_49, x_42); -lean_dec(x_42); -x_53 = l_Lean_Meta_instantiateMVars(x_52, x_8, x_51); -x_54 = lean_ctor_get(x_53, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_53, 1); -lean_inc(x_55); -lean_dec(x_53); +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_46 = lean_expr_instantiate1(x_43, x_36); +lean_dec(x_36); +x_47 = l_Lean_Meta_instantiateMVars(x_46, x_8, x_45); +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_8); -lean_inc_n(x_46, 2); -x_56 = l_Lean_Meta_mkEq(x_46, x_46, x_8, x_55); -if (lean_obj_tag(x_56) == 0) +lean_inc_n(x_40, 2); +x_50 = l_Lean_Meta_mkEq(x_40, x_40, x_8, x_49); +if (lean_obj_tag(x_50) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; lean_object* x_98; lean_object* x_99; uint8_t x_100; -x_57 = lean_ctor_get(x_56, 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_object* x_57; lean_object* x_58; lean_object* x_92; lean_object* x_93; uint8_t x_94; +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 = l_Lean_Expr_appFn_x21(x_51); +lean_dec(x_51); +x_54 = l_Lean_mkApp(x_53, x_43); +x_55 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; +x_56 = 0; +x_57 = l_Lean_mkLambda(x_55, x_56, x_34, x_54); +lean_inc(x_8); lean_inc(x_57); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -lean_dec(x_56); -x_59 = l_Lean_Expr_appFn_x21(x_57); -lean_dec(x_57); -x_60 = l_Lean_mkApp(x_59, x_49); -x_61 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; -x_62 = 0; -x_63 = l_Lean_mkLambda(x_61, x_62, x_36, x_60); -lean_inc(x_8); -lean_inc(x_63); -x_98 = l_Lean_Meta_isTypeCorrect(x_63, x_8, x_58); -x_99 = lean_ctor_get(x_98, 0); -lean_inc(x_99); -x_100 = lean_unbox(x_99); -lean_dec(x_99); -if (x_100 == 0) +x_92 = l_Lean_Meta_isTypeCorrect(x_57, x_8, x_52); +x_93 = lean_ctor_get(x_92, 0); +lean_inc(x_93); +x_94 = lean_unbox(x_93); +lean_dec(x_93); +if (x_94 == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; uint8_t x_104; -lean_dec(x_63); -lean_dec(x_54); -lean_dec(x_46); +lean_object* x_95; lean_object* x_96; lean_object* x_97; uint8_t x_98; +lean_dec(x_57); +lean_dec(x_48); +lean_dec(x_40); lean_dec(x_23); lean_dec(x_20); lean_dec(x_19); -x_101 = lean_ctor_get(x_98, 1); -lean_inc(x_101); -lean_dec(x_98); -x_102 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; -x_103 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_102, x_8, x_101); +x_95 = lean_ctor_get(x_92, 1); +lean_inc(x_95); +lean_dec(x_92); +x_96 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; +x_97 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_96, x_8, x_95); lean_dec(x_8); -x_104 = !lean_is_exclusive(x_103); -if (x_104 == 0) +x_98 = !lean_is_exclusive(x_97); +if (x_98 == 0) { -return x_103; +return x_97; } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_105 = lean_ctor_get(x_103, 0); -x_106 = lean_ctor_get(x_103, 1); -lean_inc(x_106); -lean_inc(x_105); -lean_dec(x_103); -x_107 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_107, 0, x_105); -lean_ctor_set(x_107, 1, x_106); -return x_107; +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_97, 0); +x_100 = lean_ctor_get(x_97, 1); +lean_inc(x_100); +lean_inc(x_99); +lean_dec(x_97); +x_101 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_101, 0, x_99); +lean_ctor_set(x_101, 1, x_100); +return x_101; } } else { -lean_object* x_108; -x_108 = lean_ctor_get(x_98, 1); -lean_inc(x_108); -lean_dec(x_98); -x_64 = x_108; -goto block_97; +lean_object* x_102; +x_102 = lean_ctor_get(x_92, 1); +lean_inc(x_102); +lean_dec(x_92); +x_58 = x_102; +goto block_91; } -block_97: +block_91: { -lean_object* x_65; +lean_object* x_59; lean_inc(x_8); -x_65 = l_Lean_Meta_mkEqRefl(x_46, x_8, x_64); +x_59 = l_Lean_Meta_mkEqRefl(x_40, x_8, 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_inc(x_60); +x_61 = lean_ctor_get(x_59, 1); +lean_inc(x_61); +lean_dec(x_59); +lean_inc(x_8); +x_62 = l_Lean_Meta_mkEqNDRec(x_57, x_60, x_23, x_8, x_61); +if (lean_obj_tag(x_62) == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; +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); +lean_inc(x_8); +x_65 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_64); +lean_dec(x_20); if (lean_obj_tag(x_65) == 0) { -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_65, 0); +lean_object* x_66; lean_object* x_67; uint8_t x_68; +x_66 = lean_ctor_get(x_65, 1); lean_inc(x_66); -x_67 = lean_ctor_get(x_65, 1); -lean_inc(x_67); lean_dec(x_65); -lean_inc(x_8); -x_68 = l_Lean_Meta_mkEqNDRec(x_63, x_66, x_23, x_8, x_67); -if (lean_obj_tag(x_68) == 0) -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_68, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_68, 1); -lean_inc(x_70); -lean_dec(x_68); -lean_inc(x_8); -x_71 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_70); -lean_dec(x_20); -if (lean_obj_tag(x_71) == 0) -{ -lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_72 = lean_ctor_get(x_71, 1); -lean_inc(x_72); -lean_dec(x_71); -x_73 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_72); +x_67 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_66); lean_dec(x_8); -x_74 = !lean_is_exclusive(x_73); -if (x_74 == 0) +x_68 = !lean_is_exclusive(x_67); +if (x_68 == 0) { -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_75 = lean_ctor_get(x_73, 0); -x_76 = l_Array_toList___rarg(x_75); -lean_dec(x_75); -x_77 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_76); -x_78 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_78, 0, x_54); -lean_ctor_set(x_78, 1, x_69); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_73, 0, x_78); -return x_73; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_79 = lean_ctor_get(x_73, 0); -x_80 = lean_ctor_get(x_73, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_73); -x_81 = l_Array_toList___rarg(x_79); -lean_dec(x_79); -x_82 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_81); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_54); -lean_ctor_set(x_83, 1, x_69); -lean_ctor_set(x_83, 2, x_82); -x_84 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_84, 0, x_83); -lean_ctor_set(x_84, 1, x_80); -return x_84; -} -} -else -{ -uint8_t x_85; +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_69 = lean_ctor_get(x_67, 0); +x_70 = l_Array_toList___rarg(x_69); lean_dec(x_69); -lean_dec(x_54); -lean_dec(x_19); -lean_dec(x_8); -x_85 = !lean_is_exclusive(x_71); -if (x_85 == 0) -{ -return x_71; +x_71 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_70); +x_72 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_72, 0, x_48); +lean_ctor_set(x_72, 1, x_63); +lean_ctor_set(x_72, 2, x_71); +lean_ctor_set(x_67, 0, x_72); +return x_67; } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_71, 0); -x_87 = lean_ctor_get(x_71, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_71); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_73 = lean_ctor_get(x_67, 0); +x_74 = lean_ctor_get(x_67, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_67); +x_75 = l_Array_toList___rarg(x_73); +lean_dec(x_73); +x_76 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_75); +x_77 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_77, 0, x_48); +lean_ctor_set(x_77, 1, x_63); +lean_ctor_set(x_77, 2, x_76); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_77); +lean_ctor_set(x_78, 1, x_74); +return x_78; } } else { -uint8_t x_89; -lean_dec(x_54); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_68); -if (x_89 == 0) -{ -return x_68; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_68, 0); -x_91 = lean_ctor_get(x_68, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_68); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -else -{ -uint8_t x_93; +uint8_t x_79; lean_dec(x_63); -lean_dec(x_54); -lean_dec(x_23); -lean_dec(x_20); +lean_dec(x_48); lean_dec(x_19); lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_93 = !lean_is_exclusive(x_65); -if (x_93 == 0) +x_79 = !lean_is_exclusive(x_65); +if (x_79 == 0) { return x_65; } else { -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_65, 0); -x_95 = lean_ctor_get(x_65, 1); -lean_inc(x_95); -lean_inc(x_94); +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_65, 0); +x_81 = lean_ctor_get(x_65, 1); +lean_inc(x_81); +lean_inc(x_80); lean_dec(x_65); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -return x_96; -} +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_109; -lean_dec(x_54); -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_36); +uint8_t x_83; +lean_dec(x_48); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_83 = !lean_is_exclusive(x_62); +if (x_83 == 0) +{ +return x_62; +} +else +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_84 = lean_ctor_get(x_62, 0); +x_85 = lean_ctor_get(x_62, 1); +lean_inc(x_85); +lean_inc(x_84); +lean_dec(x_62); +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; +} +} +} +else +{ +uint8_t x_87; +lean_dec(x_57); +lean_dec(x_48); lean_dec(x_23); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_109 = !lean_is_exclusive(x_56); -if (x_109 == 0) +x_87 = !lean_is_exclusive(x_59); +if (x_87 == 0) { -return x_56; +return x_59; } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_56, 0); -x_111 = lean_ctor_get(x_56, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_56); -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; +lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_88 = lean_ctor_get(x_59, 0); +x_89 = lean_ctor_get(x_59, 1); +lean_inc(x_89); +lean_inc(x_88); +lean_dec(x_59); +x_90 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_90, 0, x_88); +lean_ctor_set(x_90, 1, x_89); +return x_90; } } } } else { -uint8_t x_121; -lean_dec(x_46); +uint8_t x_103; +lean_dec(x_48); +lean_dec(x_43); +lean_dec(x_40); +lean_dec(x_34); +lean_dec(x_23); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_103 = !lean_is_exclusive(x_50); +if (x_103 == 0) +{ +return x_50; +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_50, 0); +x_105 = lean_ctor_get(x_50, 1); +lean_inc(x_105); +lean_inc(x_104); +lean_dec(x_50); +x_106 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_106, 0, x_104); +lean_ctor_set(x_106, 1, x_105); +return x_106; +} +} +} +} +else +{ +uint8_t x_115; +lean_dec(x_40); +lean_dec(x_36); +lean_dec(x_34); +lean_dec(x_23); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_115 = !lean_is_exclusive(x_42); +if (x_115 == 0) +{ +return x_42; +} +else +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_42, 0); +x_117 = lean_ctor_get(x_42, 1); +lean_inc(x_117); +lean_inc(x_116); lean_dec(x_42); +x_118 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_118, 0, x_116); +lean_ctor_set(x_118, 1, x_117); +return x_118; +} +} +} +else +{ +lean_object* x_119; lean_object* x_120; uint8_t x_121; lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_34); lean_dec(x_23); lean_dec(x_20); lean_dec(x_19); +lean_dec(x_5); +x_119 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; +x_120 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_119, x_8, x_18); lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_121 = !lean_is_exclusive(x_48); +x_121 = !lean_is_exclusive(x_120); if (x_121 == 0) { -return x_48; +return x_120; } else { lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_48, 0); -x_123 = lean_ctor_get(x_48, 1); +x_122 = lean_ctor_get(x_120, 0); +x_123 = lean_ctor_get(x_120, 1); lean_inc(x_123); lean_inc(x_122); -lean_dec(x_48); +lean_dec(x_120); x_124 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_124, 0, x_122); lean_ctor_set(x_124, 1, x_123); @@ -722,523 +745,490 @@ return x_124; } else { -lean_object* x_125; lean_object* x_126; uint8_t x_127; -lean_dec(x_42); -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_23); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_5); -x_125 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; -x_126 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_125, x_8, x_18); -lean_dec(x_8); -x_127 = !lean_is_exclusive(x_126); -if (x_127 == 0) +lean_object* x_125; +lean_inc(x_8); +x_125 = l_Lean_Meta_mkEqSymm(x_23, x_8, x_18); +if (lean_obj_tag(x_125) == 0) { -return x_126; +lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_210; +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_8); +lean_inc(x_35); +lean_inc(x_36); +x_210 = l_Lean_Meta_mkEq(x_36, x_35, x_8, x_127); +if (lean_obj_tag(x_210) == 0) +{ +lean_object* x_211; lean_object* x_212; uint8_t x_213; +x_211 = lean_ctor_get(x_210, 1); +lean_inc(x_211); +lean_dec(x_210); +x_212 = l_Lean_Expr_getAppFn___main(x_36); +x_213 = l_Lean_Expr_isMVar(x_212); +lean_dec(x_212); +if (x_213 == 0) +{ +x_128 = x_211; +goto block_209; } else { -lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_128 = lean_ctor_get(x_126, 0); -x_129 = lean_ctor_get(x_126, 1); -lean_inc(x_129); -lean_inc(x_128); +lean_object* x_214; lean_object* x_215; uint8_t x_216; lean_dec(x_126); -x_130 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_130, 0, x_128); -lean_ctor_set(x_130, 1, x_129); -return x_130; -} -} -} -else -{ -lean_object* x_131; -lean_inc(x_8); -x_131 = l_Lean_Meta_mkEqSymm(x_23, x_8, x_18); -if (lean_obj_tag(x_131) == 0) -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_216; -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); -lean_inc(x_8); -lean_inc(x_39); -lean_inc(x_42); -x_216 = l_Lean_Meta_mkEq(x_42, x_39, x_8, x_133); -if (lean_obj_tag(x_216) == 0) -{ -lean_object* x_217; lean_object* x_218; uint8_t x_219; -x_217 = lean_ctor_get(x_216, 1); -lean_inc(x_217); -lean_dec(x_216); -x_218 = l_Lean_Expr_getAppFn___main(x_42); -x_219 = l_Lean_Expr_isMVar(x_218); -lean_dec(x_218); -if (x_219 == 0) -{ -x_134 = x_217; -goto block_215; -} -else -{ -lean_object* x_220; lean_object* x_221; uint8_t x_222; -lean_dec(x_132); -lean_dec(x_42); -lean_dec(x_39); lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_34); lean_dec(x_20); lean_dec(x_19); lean_dec(x_5); -x_220 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; -x_221 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_220, x_8, x_217); +x_214 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; +x_215 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_214, x_8, x_211); lean_dec(x_8); -x_222 = !lean_is_exclusive(x_221); -if (x_222 == 0) +x_216 = !lean_is_exclusive(x_215); +if (x_216 == 0) { -return x_221; +return x_215; } else { -lean_object* x_223; lean_object* x_224; lean_object* x_225; -x_223 = lean_ctor_get(x_221, 0); -x_224 = lean_ctor_get(x_221, 1); -lean_inc(x_224); -lean_inc(x_223); -lean_dec(x_221); -x_225 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_225, 0, x_223); -lean_ctor_set(x_225, 1, x_224); -return x_225; +lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_217 = lean_ctor_get(x_215, 0); +x_218 = lean_ctor_get(x_215, 1); +lean_inc(x_218); +lean_inc(x_217); +lean_dec(x_215); +x_219 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_219, 0, x_217); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } else { -uint8_t x_226; -lean_dec(x_132); -lean_dec(x_42); -lean_dec(x_39); +uint8_t x_220; +lean_dec(x_126); lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_34); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_226 = !lean_is_exclusive(x_216); -if (x_226 == 0) +x_220 = !lean_is_exclusive(x_210); +if (x_220 == 0) { -return x_216; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_216, 0); -x_228 = lean_ctor_get(x_216, 1); -lean_inc(x_228); -lean_inc(x_227); -lean_dec(x_216); -x_229 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_229, 0, x_227); -lean_ctor_set(x_229, 1, x_228); -return x_229; -} -} -block_215: -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_135 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_134); -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); -lean_inc(x_8); -lean_inc(x_136); -x_138 = l_Lean_Meta_kabstract(x_136, x_42, x_6, x_8, x_137); -if (lean_obj_tag(x_138) == 0) -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; uint8_t x_204; -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_204 = l_Lean_Expr_hasLooseBVars(x_139); -if (x_204 == 0) -{ -lean_object* x_205; lean_object* x_206; uint8_t x_207; -lean_dec(x_139); -lean_dec(x_136); -lean_dec(x_132); -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_20); -lean_dec(x_19); -x_205 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; -x_206 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_205, x_8, x_140); -lean_dec(x_8); -x_207 = !lean_is_exclusive(x_206); -if (x_207 == 0) -{ -return x_206; -} -else -{ -lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_208 = lean_ctor_get(x_206, 0); -x_209 = lean_ctor_get(x_206, 1); -lean_inc(x_209); -lean_inc(x_208); -lean_dec(x_206); -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 { -x_141 = x_140; -goto block_203; +lean_object* x_221; lean_object* x_222; lean_object* x_223; +x_221 = lean_ctor_get(x_210, 0); +x_222 = lean_ctor_get(x_210, 1); +lean_inc(x_222); +lean_inc(x_221); +lean_dec(x_210); +x_223 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_223, 0, x_221); +lean_ctor_set(x_223, 1, x_222); +return x_223; } -block_203: +} +block_209: { -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; -x_142 = lean_expr_instantiate1(x_139, x_39); -lean_dec(x_39); -x_143 = l_Lean_Meta_instantiateMVars(x_142, x_8, x_141); -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_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_129 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_128); +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_8); -lean_inc_n(x_136, 2); -x_146 = l_Lean_Meta_mkEq(x_136, x_136, x_8, x_145); -if (lean_obj_tag(x_146) == 0) +lean_inc(x_130); +x_132 = l_Lean_Meta_kabstract(x_130, x_36, x_6, x_8, x_131); +if (lean_obj_tag(x_132) == 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; lean_object* x_153; lean_object* x_154; lean_object* x_188; lean_object* x_189; uint8_t x_190; -x_147 = lean_ctor_get(x_146, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_146, 1); -lean_inc(x_148); -lean_dec(x_146); -x_149 = l_Lean_Expr_appFn_x21(x_147); -lean_dec(x_147); -x_150 = l_Lean_mkApp(x_149, x_139); -x_151 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; -x_152 = 0; -x_153 = l_Lean_mkLambda(x_151, x_152, x_36, x_150); -lean_inc(x_8); -lean_inc(x_153); -x_188 = l_Lean_Meta_isTypeCorrect(x_153, x_8, x_148); -x_189 = lean_ctor_get(x_188, 0); -lean_inc(x_189); -x_190 = lean_unbox(x_189); -lean_dec(x_189); -if (x_190 == 0) -{ -lean_object* x_191; lean_object* x_192; lean_object* x_193; uint8_t x_194; -lean_dec(x_153); -lean_dec(x_144); -lean_dec(x_136); +lean_object* x_133; lean_object* x_134; lean_object* x_135; uint8_t x_198; +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_198 = l_Lean_Expr_hasLooseBVars(x_133); +if (x_198 == 0) +{ +lean_object* x_199; lean_object* x_200; uint8_t x_201; +lean_dec(x_133); +lean_dec(x_130); +lean_dec(x_126); +lean_dec(x_35); +lean_dec(x_34); lean_dec(x_20); lean_dec(x_19); -x_191 = lean_ctor_get(x_188, 1); -lean_inc(x_191); -lean_dec(x_188); -x_192 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; -x_193 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_192, x_8, x_191); +x_199 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; +x_200 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_199, x_8, x_134); lean_dec(x_8); -x_194 = !lean_is_exclusive(x_193); -if (x_194 == 0) +x_201 = !lean_is_exclusive(x_200); +if (x_201 == 0) { -return x_193; +return x_200; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; -x_195 = lean_ctor_get(x_193, 0); -x_196 = lean_ctor_get(x_193, 1); -lean_inc(x_196); -lean_inc(x_195); -lean_dec(x_193); -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; +lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_202 = lean_ctor_get(x_200, 0); +x_203 = lean_ctor_get(x_200, 1); +lean_inc(x_203); +lean_inc(x_202); +lean_dec(x_200); +x_204 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_204, 0, x_202); +lean_ctor_set(x_204, 1, x_203); +return x_204; } } else { -lean_object* x_198; -x_198 = lean_ctor_get(x_188, 1); -lean_inc(x_198); -lean_dec(x_188); -x_154 = x_198; -goto block_187; +x_135 = x_134; +goto block_197; } -block_187: +block_197: { -lean_object* x_155; +lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_136 = lean_expr_instantiate1(x_133, x_35); +lean_dec(x_35); +x_137 = l_Lean_Meta_instantiateMVars(x_136, x_8, x_135); +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_8); -x_155 = l_Lean_Meta_mkEqRefl(x_136, x_8, x_154); +lean_inc_n(x_130, 2); +x_140 = l_Lean_Meta_mkEq(x_130, x_130, x_8, x_139); +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; lean_object* x_147; lean_object* x_148; lean_object* x_182; lean_object* x_183; uint8_t x_184; +x_141 = lean_ctor_get(x_140, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_140, 1); +lean_inc(x_142); +lean_dec(x_140); +x_143 = l_Lean_Expr_appFn_x21(x_141); +lean_dec(x_141); +x_144 = l_Lean_mkApp(x_143, x_133); +x_145 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; +x_146 = 0; +x_147 = l_Lean_mkLambda(x_145, x_146, x_34, x_144); +lean_inc(x_8); +lean_inc(x_147); +x_182 = l_Lean_Meta_isTypeCorrect(x_147, x_8, x_142); +x_183 = lean_ctor_get(x_182, 0); +lean_inc(x_183); +x_184 = lean_unbox(x_183); +lean_dec(x_183); +if (x_184 == 0) +{ +lean_object* x_185; lean_object* x_186; lean_object* x_187; uint8_t x_188; +lean_dec(x_147); +lean_dec(x_138); +lean_dec(x_130); +lean_dec(x_126); +lean_dec(x_20); +lean_dec(x_19); +x_185 = lean_ctor_get(x_182, 1); +lean_inc(x_185); +lean_dec(x_182); +x_186 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; +x_187 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_186, x_8, x_185); +lean_dec(x_8); +x_188 = !lean_is_exclusive(x_187); +if (x_188 == 0) +{ +return x_187; +} +else +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_187, 0); +x_190 = lean_ctor_get(x_187, 1); +lean_inc(x_190); +lean_inc(x_189); +lean_dec(x_187); +x_191 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_191, 0, x_189); +lean_ctor_set(x_191, 1, x_190); +return x_191; +} +} +else +{ +lean_object* x_192; +x_192 = lean_ctor_get(x_182, 1); +lean_inc(x_192); +lean_dec(x_182); +x_148 = x_192; +goto block_181; +} +block_181: +{ +lean_object* x_149; +lean_inc(x_8); +x_149 = l_Lean_Meta_mkEqRefl(x_130, x_8, x_148); +if (lean_obj_tag(x_149) == 0) +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; +x_150 = lean_ctor_get(x_149, 0); +lean_inc(x_150); +x_151 = lean_ctor_get(x_149, 1); +lean_inc(x_151); +lean_dec(x_149); +lean_inc(x_8); +x_152 = l_Lean_Meta_mkEqNDRec(x_147, x_150, x_126, x_8, x_151); +if (lean_obj_tag(x_152) == 0) +{ +lean_object* x_153; lean_object* x_154; lean_object* x_155; +x_153 = lean_ctor_get(x_152, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_152, 1); +lean_inc(x_154); +lean_dec(x_152); +lean_inc(x_8); +x_155 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_154); +lean_dec(x_20); 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, 0); +lean_object* x_156; lean_object* x_157; uint8_t x_158; +x_156 = lean_ctor_get(x_155, 1); lean_inc(x_156); -x_157 = lean_ctor_get(x_155, 1); -lean_inc(x_157); lean_dec(x_155); -lean_inc(x_8); -x_158 = l_Lean_Meta_mkEqNDRec(x_153, x_156, x_132, x_8, x_157); -if (lean_obj_tag(x_158) == 0) -{ -lean_object* x_159; lean_object* x_160; lean_object* x_161; -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); -lean_inc(x_8); -x_161 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_160); -lean_dec(x_20); -if (lean_obj_tag(x_161) == 0) -{ -lean_object* x_162; lean_object* x_163; uint8_t x_164; -x_162 = lean_ctor_get(x_161, 1); -lean_inc(x_162); -lean_dec(x_161); -x_163 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_162); +x_157 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_156); lean_dec(x_8); -x_164 = !lean_is_exclusive(x_163); -if (x_164 == 0) +x_158 = !lean_is_exclusive(x_157); +if (x_158 == 0) { -lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_165 = lean_ctor_get(x_163, 0); -x_166 = l_Array_toList___rarg(x_165); -lean_dec(x_165); -x_167 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_166); -x_168 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_168, 0, x_144); -lean_ctor_set(x_168, 1, x_159); -lean_ctor_set(x_168, 2, x_167); -lean_ctor_set(x_163, 0, x_168); -return x_163; -} -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; -x_169 = lean_ctor_get(x_163, 0); -x_170 = lean_ctor_get(x_163, 1); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_163); -x_171 = l_Array_toList___rarg(x_169); -lean_dec(x_169); -x_172 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_171); -x_173 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_173, 0, x_144); -lean_ctor_set(x_173, 1, x_159); -lean_ctor_set(x_173, 2, x_172); -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_173); -lean_ctor_set(x_174, 1, x_170); -return x_174; -} -} -else -{ -uint8_t x_175; +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_159 = lean_ctor_get(x_157, 0); +x_160 = l_Array_toList___rarg(x_159); lean_dec(x_159); -lean_dec(x_144); -lean_dec(x_19); -lean_dec(x_8); -x_175 = !lean_is_exclusive(x_161); -if (x_175 == 0) -{ -return x_161; +x_161 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_160); +x_162 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_162, 0, x_138); +lean_ctor_set(x_162, 1, x_153); +lean_ctor_set(x_162, 2, x_161); +lean_ctor_set(x_157, 0, x_162); +return x_157; } else { -lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_176 = lean_ctor_get(x_161, 0); -x_177 = lean_ctor_get(x_161, 1); -lean_inc(x_177); -lean_inc(x_176); -lean_dec(x_161); -x_178 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_178, 0, x_176); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} +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_163 = lean_ctor_get(x_157, 0); +x_164 = lean_ctor_get(x_157, 1); +lean_inc(x_164); +lean_inc(x_163); +lean_dec(x_157); +x_165 = l_Array_toList___rarg(x_163); +lean_dec(x_163); +x_166 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_165); +x_167 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_167, 0, x_138); +lean_ctor_set(x_167, 1, x_153); +lean_ctor_set(x_167, 2, x_166); +x_168 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_168, 0, x_167); +lean_ctor_set(x_168, 1, x_164); +return x_168; } } else { -uint8_t x_179; -lean_dec(x_144); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_179 = !lean_is_exclusive(x_158); -if (x_179 == 0) -{ -return x_158; -} -else -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_180 = lean_ctor_get(x_158, 0); -x_181 = lean_ctor_get(x_158, 1); -lean_inc(x_181); -lean_inc(x_180); -lean_dec(x_158); -x_182 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_182, 0, x_180); -lean_ctor_set(x_182, 1, x_181); -return x_182; -} -} -} -else -{ -uint8_t x_183; +uint8_t x_169; lean_dec(x_153); -lean_dec(x_144); -lean_dec(x_132); -lean_dec(x_20); +lean_dec(x_138); lean_dec(x_19); lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_183 = !lean_is_exclusive(x_155); -if (x_183 == 0) +x_169 = !lean_is_exclusive(x_155); +if (x_169 == 0) { return x_155; } else { -lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_184 = lean_ctor_get(x_155, 0); -x_185 = lean_ctor_get(x_155, 1); -lean_inc(x_185); -lean_inc(x_184); +lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_170 = lean_ctor_get(x_155, 0); +x_171 = lean_ctor_get(x_155, 1); +lean_inc(x_171); +lean_inc(x_170); lean_dec(x_155); -x_186 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_186, 0, x_184); -lean_ctor_set(x_186, 1, x_185); -return x_186; -} +x_172 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_172, 0, x_170); +lean_ctor_set(x_172, 1, x_171); +return x_172; } } } else { -uint8_t x_199; -lean_dec(x_144); -lean_dec(x_139); -lean_dec(x_136); -lean_dec(x_132); -lean_dec(x_36); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_199 = !lean_is_exclusive(x_146); -if (x_199 == 0) -{ -return x_146; -} -else -{ -lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_200 = lean_ctor_get(x_146, 0); -x_201 = lean_ctor_get(x_146, 1); -lean_inc(x_201); -lean_inc(x_200); -lean_dec(x_146); -x_202 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_202, 0, x_200); -lean_ctor_set(x_202, 1, x_201); -return x_202; -} -} -} -} -else -{ -uint8_t x_211; -lean_dec(x_136); -lean_dec(x_132); -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_211 = !lean_is_exclusive(x_138); -if (x_211 == 0) -{ -return x_138; -} -else -{ -lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_212 = lean_ctor_get(x_138, 0); -x_213 = lean_ctor_get(x_138, 1); -lean_inc(x_213); -lean_inc(x_212); +uint8_t x_173; lean_dec(x_138); -x_214 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_214, 0, x_212); -lean_ctor_set(x_214, 1, x_213); -return x_214; +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_173 = !lean_is_exclusive(x_152); +if (x_173 == 0) +{ +return x_152; +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_152, 0); +x_175 = lean_ctor_get(x_152, 1); +lean_inc(x_175); +lean_inc(x_174); +lean_dec(x_152); +x_176 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_176, 0, x_174); +lean_ctor_set(x_176, 1, x_175); +return x_176; +} +} +} +else +{ +uint8_t x_177; +lean_dec(x_147); +lean_dec(x_138); +lean_dec(x_126); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_177 = !lean_is_exclusive(x_149); +if (x_177 == 0) +{ +return x_149; +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_149, 0); +x_179 = lean_ctor_get(x_149, 1); +lean_inc(x_179); +lean_inc(x_178); +lean_dec(x_149); +x_180 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_180, 0, x_178); +lean_ctor_set(x_180, 1, x_179); +return x_180; } } } } else { -uint8_t x_230; -lean_dec(x_42); -lean_dec(x_39); +uint8_t x_193; +lean_dec(x_138); +lean_dec(x_133); +lean_dec(x_130); +lean_dec(x_126); +lean_dec(x_34); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_193 = !lean_is_exclusive(x_140); +if (x_193 == 0) +{ +return x_140; +} +else +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_140, 0); +x_195 = lean_ctor_get(x_140, 1); +lean_inc(x_195); +lean_inc(x_194); +lean_dec(x_140); +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_205; +lean_dec(x_130); +lean_dec(x_126); +lean_dec(x_35); +lean_dec(x_34); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_205 = !lean_is_exclusive(x_132); +if (x_205 == 0) +{ +return x_132; +} +else +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_206 = lean_ctor_get(x_132, 0); +x_207 = lean_ctor_get(x_132, 1); +lean_inc(x_207); +lean_inc(x_206); +lean_dec(x_132); +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 +{ +uint8_t x_224; lean_dec(x_36); +lean_dec(x_35); +lean_dec(x_34); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_230 = !lean_is_exclusive(x_131); -if (x_230 == 0) +x_224 = !lean_is_exclusive(x_125); +if (x_224 == 0) { -return x_131; +return x_125; } else { -lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_131, 0); -x_232 = lean_ctor_get(x_131, 1); -lean_inc(x_232); -lean_inc(x_231); -lean_dec(x_131); -x_233 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_233, 0, x_231); -lean_ctor_set(x_233, 1, x_232); -return x_233; +lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_225 = lean_ctor_get(x_125, 0); +x_226 = lean_ctor_get(x_125, 1); +lean_inc(x_226); +lean_inc(x_225); +lean_dec(x_125); +x_227 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_227, 0, x_225); +lean_ctor_set(x_227, 1, x_226); +return x_227; } } } @@ -1246,359 +1236,379 @@ 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; lean_object* x_240; lean_object* x_241; lean_object* x_242; -x_234 = l_Lean_Expr_getAppNumArgsAux___main(x_21, x_22); -x_235 = lean_nat_sub(x_234, x_22); -x_236 = lean_unsigned_to_nat(1u); -x_237 = lean_nat_sub(x_235, x_236); -lean_dec(x_235); -x_238 = l_Lean_Expr_getRevArg_x21___main(x_21, x_237); -x_239 = lean_nat_sub(x_234, x_236); -lean_dec(x_234); -x_240 = lean_nat_sub(x_239, x_236); -lean_dec(x_239); -x_241 = l_Lean_Expr_getRevArg_x21___main(x_21, x_240); +lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; +x_228 = l_Lean_Expr_appFn_x21(x_21); +x_229 = l_Lean_Expr_appArg_x21(x_228); +lean_dec(x_228); +x_230 = l_Lean_Expr_appArg_x21(x_21); lean_dec(x_21); lean_inc(x_8); -lean_inc(x_241); -lean_inc(x_238); -x_242 = l_Lean_Meta_mkEq(x_238, x_241, x_8, x_18); -if (lean_obj_tag(x_242) == 0) +lean_inc(x_230); +lean_inc(x_229); +x_231 = l_Lean_Meta_mkEq(x_229, x_230, x_8, x_18); +if (lean_obj_tag(x_231) == 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; uint8_t x_249; -x_243 = lean_ctor_get(x_242, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_242, 1); -lean_inc(x_244); -lean_dec(x_242); -x_245 = l_Lean_Meta_rewriteCore___lambda__1___closed__17; -x_246 = l_Lean_mkApp3(x_245, x_238, x_241, x_23); -x_247 = l_Lean_Expr_eq_x3f___closed__2; -x_248 = lean_unsigned_to_nat(3u); -x_249 = l_Lean_Expr_isAppOfArity___main(x_243, x_247, x_248); -if (x_249 == 0) +lean_object* x_232; 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_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 = l_Lean_Meta_rewriteCore___lambda__1___closed__17; +x_235 = l_Lean_mkApp3(x_234, x_229, x_230, x_23); +x_236 = l_Lean_Expr_eq_x3f___closed__2; +x_237 = lean_unsigned_to_nat(3u); +x_238 = l_Lean_Expr_isAppOfArity___main(x_232, x_236, x_237); +if (x_238 == 0) { -lean_object* x_250; lean_object* x_251; -lean_dec(x_246); -lean_dec(x_243); +lean_object* x_239; lean_object* x_240; +lean_dec(x_235); +lean_dec(x_232); lean_dec(x_20); lean_dec(x_19); lean_dec(x_5); -x_250 = l_Lean_Meta_rewriteCore___lambda__1___closed__3; -x_251 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_250, x_8, x_244); +x_239 = l_Lean_Meta_rewriteCore___lambda__1___closed__3; +x_240 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_239, x_8, x_233); lean_dec(x_8); -return x_251; +return x_240; } 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; -x_252 = l_Lean_Expr_getAppNumArgsAux___main(x_243, x_22); -x_253 = lean_nat_sub(x_252, x_22); -x_254 = lean_nat_sub(x_253, x_236); -lean_dec(x_253); -x_255 = l_Lean_Expr_getRevArg_x21___main(x_243, x_254); -x_256 = lean_nat_sub(x_252, x_236); -x_257 = lean_nat_sub(x_256, x_236); -lean_dec(x_256); -x_258 = l_Lean_Expr_getRevArg_x21___main(x_243, x_257); -x_259 = lean_nat_sub(x_252, x_25); -lean_dec(x_252); -x_260 = lean_nat_sub(x_259, x_236); -lean_dec(x_259); -x_261 = l_Lean_Expr_getRevArg_x21___main(x_243, x_260); -lean_dec(x_243); +lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_241 = l_Lean_Expr_appFn_x21(x_232); +x_242 = l_Lean_Expr_appFn_x21(x_241); +x_243 = l_Lean_Expr_appArg_x21(x_242); +lean_dec(x_242); +x_244 = l_Lean_Expr_appArg_x21(x_241); +lean_dec(x_241); +x_245 = l_Lean_Expr_appArg_x21(x_232); +lean_dec(x_232); if (x_4 == 0) { -lean_object* x_262; uint8_t x_263; -x_262 = l_Lean_Expr_getAppFn___main(x_258); -x_263 = l_Lean_Expr_isMVar(x_262); -lean_dec(x_262); -if (x_263 == 0) -{ -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; -x_264 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_244); -x_265 = lean_ctor_get(x_264, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_264, 1); -lean_inc(x_266); -lean_dec(x_264); -lean_inc(x_8); -lean_inc(x_265); -x_267 = l_Lean_Meta_kabstract(x_265, x_258, x_6, x_8, x_266); -if (lean_obj_tag(x_267) == 0) -{ -lean_object* x_268; lean_object* x_269; lean_object* x_270; uint8_t x_333; -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_333 = l_Lean_Expr_hasLooseBVars(x_268); -if (x_333 == 0) -{ -lean_object* x_334; lean_object* x_335; uint8_t x_336; -lean_dec(x_268); -lean_dec(x_265); -lean_dec(x_261); -lean_dec(x_255); +lean_object* x_246; uint8_t x_247; +x_246 = l_Lean_Expr_getAppFn___main(x_244); +x_247 = l_Lean_Expr_isMVar(x_246); lean_dec(x_246); +if (x_247 == 0) +{ +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; +x_248 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_233); +x_249 = lean_ctor_get(x_248, 0); +lean_inc(x_249); +x_250 = lean_ctor_get(x_248, 1); +lean_inc(x_250); +lean_dec(x_248); +lean_inc(x_8); +lean_inc(x_249); +x_251 = l_Lean_Meta_kabstract(x_249, x_244, x_6, x_8, x_250); +if (lean_obj_tag(x_251) == 0) +{ +lean_object* x_252; lean_object* x_253; lean_object* x_254; uint8_t x_317; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +x_253 = lean_ctor_get(x_251, 1); +lean_inc(x_253); +lean_dec(x_251); +x_317 = l_Lean_Expr_hasLooseBVars(x_252); +if (x_317 == 0) +{ +lean_object* x_318; lean_object* x_319; uint8_t x_320; +lean_dec(x_252); +lean_dec(x_249); +lean_dec(x_245); +lean_dec(x_243); +lean_dec(x_235); lean_dec(x_20); lean_dec(x_19); -x_334 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; -x_335 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_334, x_8, x_269); +x_318 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; +x_319 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_318, x_8, x_253); lean_dec(x_8); -x_336 = !lean_is_exclusive(x_335); -if (x_336 == 0) +x_320 = !lean_is_exclusive(x_319); +if (x_320 == 0) { -return x_335; +return x_319; } else { -lean_object* x_337; lean_object* x_338; lean_object* x_339; -x_337 = lean_ctor_get(x_335, 0); -x_338 = lean_ctor_get(x_335, 1); -lean_inc(x_338); -lean_inc(x_337); -lean_dec(x_335); -x_339 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_339, 0, x_337); -lean_ctor_set(x_339, 1, x_338); -return x_339; +lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_321 = lean_ctor_get(x_319, 0); +x_322 = lean_ctor_get(x_319, 1); +lean_inc(x_322); +lean_inc(x_321); +lean_dec(x_319); +x_323 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_323, 0, x_321); +lean_ctor_set(x_323, 1, x_322); +return x_323; } } else { -x_270 = x_269; -goto block_332; -} -block_332: -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_271 = lean_expr_instantiate1(x_268, x_261); -lean_dec(x_261); -x_272 = l_Lean_Meta_instantiateMVars(x_271, x_8, x_270); -x_273 = lean_ctor_get(x_272, 0); -lean_inc(x_273); -x_274 = lean_ctor_get(x_272, 1); -lean_inc(x_274); -lean_dec(x_272); -lean_inc(x_8); -lean_inc_n(x_265, 2); -x_275 = l_Lean_Meta_mkEq(x_265, x_265, x_8, x_274); -if (lean_obj_tag(x_275) == 0) -{ -lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; uint8_t x_281; lean_object* x_282; lean_object* x_283; lean_object* x_317; lean_object* x_318; uint8_t x_319; -x_276 = lean_ctor_get(x_275, 0); -lean_inc(x_276); -x_277 = lean_ctor_get(x_275, 1); -lean_inc(x_277); -lean_dec(x_275); -x_278 = l_Lean_Expr_appFn_x21(x_276); -lean_dec(x_276); -x_279 = l_Lean_mkApp(x_278, x_268); -x_280 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; -x_281 = 0; -x_282 = l_Lean_mkLambda(x_280, x_281, x_255, x_279); -lean_inc(x_8); -lean_inc(x_282); -x_317 = l_Lean_Meta_isTypeCorrect(x_282, x_8, x_277); -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_unbox(x_318); -lean_dec(x_318); -if (x_319 == 0) -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; uint8_t x_323; -lean_dec(x_282); -lean_dec(x_273); -lean_dec(x_265); -lean_dec(x_246); -lean_dec(x_20); -lean_dec(x_19); -x_320 = lean_ctor_get(x_317, 1); -lean_inc(x_320); -lean_dec(x_317); -x_321 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; -x_322 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_321, x_8, x_320); -lean_dec(x_8); -x_323 = !lean_is_exclusive(x_322); -if (x_323 == 0) -{ -return x_322; -} -else -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_322, 0); -x_325 = lean_ctor_get(x_322, 1); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_322); -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; -} -} -else -{ -lean_object* x_327; -x_327 = lean_ctor_get(x_317, 1); -lean_inc(x_327); -lean_dec(x_317); -x_283 = x_327; +x_254 = x_253; goto block_316; } block_316: { -lean_object* x_284; +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; +x_255 = lean_expr_instantiate1(x_252, x_245); +lean_dec(x_245); +x_256 = l_Lean_Meta_instantiateMVars(x_255, x_8, x_254); +x_257 = lean_ctor_get(x_256, 0); +lean_inc(x_257); +x_258 = lean_ctor_get(x_256, 1); +lean_inc(x_258); +lean_dec(x_256); lean_inc(x_8); -x_284 = l_Lean_Meta_mkEqRefl(x_265, x_8, x_283); -if (lean_obj_tag(x_284) == 0) +lean_inc_n(x_249, 2); +x_259 = l_Lean_Meta_mkEq(x_249, x_249, x_8, x_258); +if (lean_obj_tag(x_259) == 0) { -lean_object* x_285; lean_object* x_286; lean_object* x_287; -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); +lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; uint8_t x_265; lean_object* x_266; lean_object* x_267; lean_object* x_301; lean_object* x_302; uint8_t x_303; +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 = l_Lean_Expr_appFn_x21(x_260); +lean_dec(x_260); +x_263 = l_Lean_mkApp(x_262, x_252); +x_264 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; +x_265 = 0; +x_266 = l_Lean_mkLambda(x_264, x_265, x_243, x_263); lean_inc(x_8); -x_287 = l_Lean_Meta_mkEqNDRec(x_282, x_285, x_246, x_8, x_286); -if (lean_obj_tag(x_287) == 0) +lean_inc(x_266); +x_301 = l_Lean_Meta_isTypeCorrect(x_266, x_8, x_261); +x_302 = lean_ctor_get(x_301, 0); +lean_inc(x_302); +x_303 = lean_unbox(x_302); +lean_dec(x_302); +if (x_303 == 0) { -lean_object* x_288; lean_object* x_289; lean_object* x_290; -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); -lean_inc(x_8); -x_290 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_289); +lean_object* x_304; lean_object* x_305; lean_object* x_306; uint8_t x_307; +lean_dec(x_266); +lean_dec(x_257); +lean_dec(x_249); +lean_dec(x_235); lean_dec(x_20); -if (lean_obj_tag(x_290) == 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); -lean_dec(x_290); -x_292 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_291); +lean_dec(x_19); +x_304 = lean_ctor_get(x_301, 1); +lean_inc(x_304); +lean_dec(x_301); +x_305 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; +x_306 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_305, x_8, x_304); lean_dec(x_8); -x_293 = !lean_is_exclusive(x_292); -if (x_293 == 0) +x_307 = !lean_is_exclusive(x_306); +if (x_307 == 0) { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; -x_294 = lean_ctor_get(x_292, 0); -x_295 = l_Array_toList___rarg(x_294); -lean_dec(x_294); -x_296 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_295); -x_297 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_297, 0, x_273); -lean_ctor_set(x_297, 1, x_288); -lean_ctor_set(x_297, 2, x_296); -lean_ctor_set(x_292, 0, x_297); -return x_292; +return x_306; } else { -lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_298 = lean_ctor_get(x_292, 0); -x_299 = lean_ctor_get(x_292, 1); -lean_inc(x_299); -lean_inc(x_298); -lean_dec(x_292); -x_300 = l_Array_toList___rarg(x_298); -lean_dec(x_298); -x_301 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_300); -x_302 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_302, 0, x_273); -lean_ctor_set(x_302, 1, x_288); -lean_ctor_set(x_302, 2, x_301); -x_303 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_303, 0, x_302); -lean_ctor_set(x_303, 1, x_299); -return x_303; +lean_object* x_308; lean_object* x_309; lean_object* x_310; +x_308 = lean_ctor_get(x_306, 0); +x_309 = lean_ctor_get(x_306, 1); +lean_inc(x_309); +lean_inc(x_308); +lean_dec(x_306); +x_310 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_310, 0, x_308); +lean_ctor_set(x_310, 1, x_309); +return x_310; } } else { -uint8_t x_304; -lean_dec(x_288); -lean_dec(x_273); +lean_object* x_311; +x_311 = lean_ctor_get(x_301, 1); +lean_inc(x_311); +lean_dec(x_301); +x_267 = x_311; +goto block_300; +} +block_300: +{ +lean_object* x_268; +lean_inc(x_8); +x_268 = l_Lean_Meta_mkEqRefl(x_249, x_8, x_267); +if (lean_obj_tag(x_268) == 0) +{ +lean_object* x_269; lean_object* x_270; lean_object* x_271; +x_269 = lean_ctor_get(x_268, 0); +lean_inc(x_269); +x_270 = lean_ctor_get(x_268, 1); +lean_inc(x_270); +lean_dec(x_268); +lean_inc(x_8); +x_271 = l_Lean_Meta_mkEqNDRec(x_266, x_269, x_235, x_8, x_270); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; lean_object* x_273; lean_object* x_274; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +x_273 = lean_ctor_get(x_271, 1); +lean_inc(x_273); +lean_dec(x_271); +lean_inc(x_8); +x_274 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_273); +lean_dec(x_20); +if (lean_obj_tag(x_274) == 0) +{ +lean_object* x_275; lean_object* x_276; uint8_t x_277; +x_275 = lean_ctor_get(x_274, 1); +lean_inc(x_275); +lean_dec(x_274); +x_276 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_275); +lean_dec(x_8); +x_277 = !lean_is_exclusive(x_276); +if (x_277 == 0) +{ +lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; +x_278 = lean_ctor_get(x_276, 0); +x_279 = l_Array_toList___rarg(x_278); +lean_dec(x_278); +x_280 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_279); +x_281 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_281, 0, x_257); +lean_ctor_set(x_281, 1, x_272); +lean_ctor_set(x_281, 2, x_280); +lean_ctor_set(x_276, 0, x_281); +return x_276; +} +else +{ +lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; +x_282 = lean_ctor_get(x_276, 0); +x_283 = lean_ctor_get(x_276, 1); +lean_inc(x_283); +lean_inc(x_282); +lean_dec(x_276); +x_284 = l_Array_toList___rarg(x_282); +lean_dec(x_282); +x_285 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_284); +x_286 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_286, 0, x_257); +lean_ctor_set(x_286, 1, x_272); +lean_ctor_set(x_286, 2, x_285); +x_287 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_287, 0, x_286); +lean_ctor_set(x_287, 1, x_283); +return x_287; +} +} +else +{ +uint8_t x_288; +lean_dec(x_272); +lean_dec(x_257); lean_dec(x_19); lean_dec(x_8); -x_304 = !lean_is_exclusive(x_290); -if (x_304 == 0) +x_288 = !lean_is_exclusive(x_274); +if (x_288 == 0) { -return x_290; +return x_274; } else { -lean_object* x_305; lean_object* x_306; lean_object* x_307; -x_305 = lean_ctor_get(x_290, 0); -x_306 = lean_ctor_get(x_290, 1); -lean_inc(x_306); -lean_inc(x_305); -lean_dec(x_290); -x_307 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_307, 0, x_305); -lean_ctor_set(x_307, 1, x_306); -return x_307; +lean_object* x_289; lean_object* x_290; lean_object* x_291; +x_289 = lean_ctor_get(x_274, 0); +x_290 = lean_ctor_get(x_274, 1); +lean_inc(x_290); +lean_inc(x_289); +lean_dec(x_274); +x_291 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_291, 0, x_289); +lean_ctor_set(x_291, 1, x_290); +return x_291; } } } else { -uint8_t x_308; -lean_dec(x_273); +uint8_t x_292; +lean_dec(x_257); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_308 = !lean_is_exclusive(x_287); -if (x_308 == 0) +x_292 = !lean_is_exclusive(x_271); +if (x_292 == 0) { -return x_287; +return x_271; } else { -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_287, 0); -x_310 = lean_ctor_get(x_287, 1); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_287); -x_311 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_311, 0, x_309); -lean_ctor_set(x_311, 1, x_310); -return x_311; +lean_object* x_293; lean_object* x_294; lean_object* x_295; +x_293 = lean_ctor_get(x_271, 0); +x_294 = lean_ctor_get(x_271, 1); +lean_inc(x_294); +lean_inc(x_293); +lean_dec(x_271); +x_295 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_295, 0, x_293); +lean_ctor_set(x_295, 1, x_294); +return x_295; +} +} +} +else +{ +uint8_t x_296; +lean_dec(x_266); +lean_dec(x_257); +lean_dec(x_235); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_296 = !lean_is_exclusive(x_268); +if (x_296 == 0) +{ +return x_268; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; +x_297 = lean_ctor_get(x_268, 0); +x_298 = lean_ctor_get(x_268, 1); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_268); +x_299 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_299, 0, x_297); +lean_ctor_set(x_299, 1, x_298); +return x_299; +} } } } else { uint8_t x_312; -lean_dec(x_282); -lean_dec(x_273); -lean_dec(x_246); +lean_dec(x_257); +lean_dec(x_252); +lean_dec(x_249); +lean_dec(x_243); +lean_dec(x_235); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_312 = !lean_is_exclusive(x_284); +x_312 = !lean_is_exclusive(x_259); if (x_312 == 0) { -return x_284; +return x_259; } else { lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_284, 0); -x_314 = lean_ctor_get(x_284, 1); +x_313 = lean_ctor_get(x_259, 0); +x_314 = lean_ctor_get(x_259, 1); lean_inc(x_314); lean_inc(x_313); -lean_dec(x_284); +lean_dec(x_259); x_315 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_315, 0, x_313); lean_ctor_set(x_315, 1, x_314); @@ -1609,485 +1619,485 @@ return x_315; } else { -uint8_t x_328; -lean_dec(x_273); -lean_dec(x_268); -lean_dec(x_265); -lean_dec(x_255); -lean_dec(x_246); +uint8_t x_324; +lean_dec(x_249); +lean_dec(x_245); +lean_dec(x_243); +lean_dec(x_235); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_328 = !lean_is_exclusive(x_275); -if (x_328 == 0) +x_324 = !lean_is_exclusive(x_251); +if (x_324 == 0) { -return x_275; +return x_251; } else { -lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_329 = lean_ctor_get(x_275, 0); -x_330 = lean_ctor_get(x_275, 1); -lean_inc(x_330); -lean_inc(x_329); -lean_dec(x_275); -x_331 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_331, 0, x_329); -lean_ctor_set(x_331, 1, x_330); -return x_331; -} +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_251, 0); +x_326 = lean_ctor_get(x_251, 1); +lean_inc(x_326); +lean_inc(x_325); +lean_dec(x_251); +x_327 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_327, 0, x_325); +lean_ctor_set(x_327, 1, x_326); +return x_327; } } } else { -uint8_t x_340; -lean_dec(x_265); -lean_dec(x_261); -lean_dec(x_255); -lean_dec(x_246); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_340 = !lean_is_exclusive(x_267); -if (x_340 == 0) -{ -return x_267; -} -else -{ -lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_341 = lean_ctor_get(x_267, 0); -x_342 = lean_ctor_get(x_267, 1); -lean_inc(x_342); -lean_inc(x_341); -lean_dec(x_267); -x_343 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_343, 0, x_341); -lean_ctor_set(x_343, 1, x_342); -return x_343; -} -} -} -else -{ -lean_object* x_344; lean_object* x_345; uint8_t x_346; -lean_dec(x_261); -lean_dec(x_258); -lean_dec(x_255); -lean_dec(x_246); +lean_object* x_328; lean_object* x_329; uint8_t x_330; +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_243); +lean_dec(x_235); lean_dec(x_20); lean_dec(x_19); lean_dec(x_5); -x_344 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; -x_345 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_344, x_8, x_244); +x_328 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; +x_329 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_328, x_8, x_233); lean_dec(x_8); -x_346 = !lean_is_exclusive(x_345); -if (x_346 == 0) +x_330 = !lean_is_exclusive(x_329); +if (x_330 == 0) { -return x_345; +return x_329; } else { -lean_object* x_347; lean_object* x_348; lean_object* x_349; -x_347 = lean_ctor_get(x_345, 0); -x_348 = lean_ctor_get(x_345, 1); -lean_inc(x_348); -lean_inc(x_347); -lean_dec(x_345); -x_349 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_349, 0, x_347); -lean_ctor_set(x_349, 1, x_348); -return x_349; +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_329, 0); +x_332 = lean_ctor_get(x_329, 1); +lean_inc(x_332); +lean_inc(x_331); +lean_dec(x_329); +x_333 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_333, 0, x_331); +lean_ctor_set(x_333, 1, x_332); +return x_333; } } } else { -lean_object* x_350; +lean_object* x_334; lean_inc(x_8); -x_350 = l_Lean_Meta_mkEqSymm(x_246, x_8, x_244); -if (lean_obj_tag(x_350) == 0) +x_334 = l_Lean_Meta_mkEqSymm(x_235, x_8, x_233); +if (lean_obj_tag(x_334) == 0) { -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_435; -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); +lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_419; +x_335 = lean_ctor_get(x_334, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_334, 1); +lean_inc(x_336); +lean_dec(x_334); lean_inc(x_8); -lean_inc(x_258); -lean_inc(x_261); -x_435 = l_Lean_Meta_mkEq(x_261, x_258, x_8, x_352); -if (lean_obj_tag(x_435) == 0) +lean_inc(x_244); +lean_inc(x_245); +x_419 = l_Lean_Meta_mkEq(x_245, x_244, x_8, x_336); +if (lean_obj_tag(x_419) == 0) { -lean_object* x_436; lean_object* x_437; uint8_t x_438; -x_436 = lean_ctor_get(x_435, 1); -lean_inc(x_436); -lean_dec(x_435); -x_437 = l_Lean_Expr_getAppFn___main(x_261); -x_438 = l_Lean_Expr_isMVar(x_437); -lean_dec(x_437); -if (x_438 == 0) +lean_object* x_420; lean_object* x_421; uint8_t x_422; +x_420 = lean_ctor_get(x_419, 1); +lean_inc(x_420); +lean_dec(x_419); +x_421 = l_Lean_Expr_getAppFn___main(x_245); +x_422 = l_Lean_Expr_isMVar(x_421); +lean_dec(x_421); +if (x_422 == 0) { -x_353 = x_436; -goto block_434; +x_337 = x_420; +goto block_418; } else { -lean_object* x_439; lean_object* x_440; uint8_t x_441; -lean_dec(x_351); -lean_dec(x_261); -lean_dec(x_258); -lean_dec(x_255); +lean_object* x_423; lean_object* x_424; uint8_t x_425; +lean_dec(x_335); +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_243); lean_dec(x_20); lean_dec(x_19); lean_dec(x_5); -x_439 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; -x_440 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_439, x_8, x_436); +x_423 = l_Lean_Meta_rewriteCore___lambda__1___closed__14; +x_424 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_423, x_8, x_420); lean_dec(x_8); -x_441 = !lean_is_exclusive(x_440); -if (x_441 == 0) +x_425 = !lean_is_exclusive(x_424); +if (x_425 == 0) { -return x_440; +return x_424; } else { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_440, 0); -x_443 = lean_ctor_get(x_440, 1); -lean_inc(x_443); -lean_inc(x_442); -lean_dec(x_440); -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; -} -} -} -else -{ -uint8_t x_445; -lean_dec(x_351); -lean_dec(x_261); -lean_dec(x_258); -lean_dec(x_255); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_445 = !lean_is_exclusive(x_435); -if (x_445 == 0) -{ -return x_435; -} -else -{ -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_435, 0); -x_447 = lean_ctor_get(x_435, 1); -lean_inc(x_447); -lean_inc(x_446); -lean_dec(x_435); -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; -} -} -block_434: -{ -lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; -x_354 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_353); -x_355 = lean_ctor_get(x_354, 0); -lean_inc(x_355); -x_356 = lean_ctor_get(x_354, 1); -lean_inc(x_356); -lean_dec(x_354); -lean_inc(x_8); -lean_inc(x_355); -x_357 = l_Lean_Meta_kabstract(x_355, x_261, x_6, x_8, x_356); -if (lean_obj_tag(x_357) == 0) -{ -lean_object* x_358; lean_object* x_359; lean_object* x_360; uint8_t x_423; -x_358 = lean_ctor_get(x_357, 0); -lean_inc(x_358); -x_359 = lean_ctor_get(x_357, 1); -lean_inc(x_359); -lean_dec(x_357); -x_423 = l_Lean_Expr_hasLooseBVars(x_358); -if (x_423 == 0) -{ -lean_object* x_424; lean_object* x_425; uint8_t x_426; -lean_dec(x_358); -lean_dec(x_355); -lean_dec(x_351); -lean_dec(x_258); -lean_dec(x_255); -lean_dec(x_20); -lean_dec(x_19); -x_424 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; -x_425 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_424, x_8, x_359); -lean_dec(x_8); -x_426 = !lean_is_exclusive(x_425); -if (x_426 == 0) -{ -return x_425; -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; -x_427 = lean_ctor_get(x_425, 0); -x_428 = lean_ctor_get(x_425, 1); -lean_inc(x_428); +lean_object* x_426; lean_object* x_427; lean_object* x_428; +x_426 = lean_ctor_get(x_424, 0); +x_427 = lean_ctor_get(x_424, 1); lean_inc(x_427); -lean_dec(x_425); -x_429 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_429, 0, x_427); -lean_ctor_set(x_429, 1, x_428); -return x_429; +lean_inc(x_426); +lean_dec(x_424); +x_428 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_428, 0, x_426); +lean_ctor_set(x_428, 1, x_427); +return x_428; +} } } else { -x_360 = x_359; -goto block_422; -} -block_422: -{ -lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; -x_361 = lean_expr_instantiate1(x_358, x_258); -lean_dec(x_258); -x_362 = l_Lean_Meta_instantiateMVars(x_361, x_8, 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); -lean_inc(x_8); -lean_inc_n(x_355, 2); -x_365 = l_Lean_Meta_mkEq(x_355, x_355, x_8, x_364); -if (lean_obj_tag(x_365) == 0) -{ -lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; uint8_t x_371; lean_object* x_372; lean_object* x_373; lean_object* x_407; lean_object* x_408; uint8_t x_409; -x_366 = lean_ctor_get(x_365, 0); -lean_inc(x_366); -x_367 = lean_ctor_get(x_365, 1); -lean_inc(x_367); -lean_dec(x_365); -x_368 = l_Lean_Expr_appFn_x21(x_366); -lean_dec(x_366); -x_369 = l_Lean_mkApp(x_368, x_358); -x_370 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; -x_371 = 0; -x_372 = l_Lean_mkLambda(x_370, x_371, x_255, x_369); -lean_inc(x_8); -lean_inc(x_372); -x_407 = l_Lean_Meta_isTypeCorrect(x_372, x_8, x_367); -x_408 = lean_ctor_get(x_407, 0); -lean_inc(x_408); -x_409 = lean_unbox(x_408); -lean_dec(x_408); -if (x_409 == 0) -{ -lean_object* x_410; lean_object* x_411; lean_object* x_412; uint8_t x_413; -lean_dec(x_372); -lean_dec(x_363); -lean_dec(x_355); -lean_dec(x_351); +uint8_t x_429; +lean_dec(x_335); +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_243); lean_dec(x_20); lean_dec(x_19); -x_410 = lean_ctor_get(x_407, 1); -lean_inc(x_410); -lean_dec(x_407); -x_411 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; -x_412 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_411, x_8, x_410); lean_dec(x_8); -x_413 = !lean_is_exclusive(x_412); -if (x_413 == 0) +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_429 = !lean_is_exclusive(x_419); +if (x_429 == 0) { -return x_412; +return x_419; } else { -lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_414 = lean_ctor_get(x_412, 0); -x_415 = lean_ctor_get(x_412, 1); -lean_inc(x_415); -lean_inc(x_414); -lean_dec(x_412); -x_416 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_416, 0, x_414); -lean_ctor_set(x_416, 1, x_415); -return x_416; +lean_object* x_430; lean_object* x_431; lean_object* x_432; +x_430 = lean_ctor_get(x_419, 0); +x_431 = lean_ctor_get(x_419, 1); +lean_inc(x_431); +lean_inc(x_430); +lean_dec(x_419); +x_432 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_432, 0, x_430); +lean_ctor_set(x_432, 1, x_431); +return x_432; +} +} +block_418: +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_338 = l_Lean_Meta_instantiateMVars(x_5, x_8, x_337); +x_339 = lean_ctor_get(x_338, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_338, 1); +lean_inc(x_340); +lean_dec(x_338); +lean_inc(x_8); +lean_inc(x_339); +x_341 = l_Lean_Meta_kabstract(x_339, x_245, x_6, x_8, x_340); +if (lean_obj_tag(x_341) == 0) +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; uint8_t x_407; +x_342 = lean_ctor_get(x_341, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_341, 1); +lean_inc(x_343); +lean_dec(x_341); +x_407 = l_Lean_Expr_hasLooseBVars(x_342); +if (x_407 == 0) +{ +lean_object* x_408; lean_object* x_409; uint8_t x_410; +lean_dec(x_342); +lean_dec(x_339); +lean_dec(x_335); +lean_dec(x_244); +lean_dec(x_243); +lean_dec(x_20); +lean_dec(x_19); +x_408 = l_Lean_Meta_rewriteCore___lambda__1___closed__11; +x_409 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_408, x_8, x_343); +lean_dec(x_8); +x_410 = !lean_is_exclusive(x_409); +if (x_410 == 0) +{ +return x_409; +} +else +{ +lean_object* x_411; lean_object* x_412; lean_object* x_413; +x_411 = lean_ctor_get(x_409, 0); +x_412 = lean_ctor_get(x_409, 1); +lean_inc(x_412); +lean_inc(x_411); +lean_dec(x_409); +x_413 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_413, 0, x_411); +lean_ctor_set(x_413, 1, x_412); +return x_413; } } else { -lean_object* x_417; -x_417 = lean_ctor_get(x_407, 1); -lean_inc(x_417); -lean_dec(x_407); -x_373 = x_417; +x_344 = x_343; goto block_406; } block_406: { -lean_object* x_374; +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; +x_345 = lean_expr_instantiate1(x_342, x_244); +lean_dec(x_244); +x_346 = l_Lean_Meta_instantiateMVars(x_345, x_8, x_344); +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); lean_inc(x_8); -x_374 = l_Lean_Meta_mkEqRefl(x_355, x_8, x_373); -if (lean_obj_tag(x_374) == 0) +lean_inc_n(x_339, 2); +x_349 = l_Lean_Meta_mkEq(x_339, x_339, x_8, x_348); +if (lean_obj_tag(x_349) == 0) { -lean_object* x_375; lean_object* x_376; lean_object* x_377; -x_375 = lean_ctor_get(x_374, 0); -lean_inc(x_375); -x_376 = lean_ctor_get(x_374, 1); -lean_inc(x_376); -lean_dec(x_374); +lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; uint8_t x_355; lean_object* x_356; lean_object* x_357; lean_object* x_391; lean_object* x_392; uint8_t x_393; +x_350 = lean_ctor_get(x_349, 0); +lean_inc(x_350); +x_351 = lean_ctor_get(x_349, 1); +lean_inc(x_351); +lean_dec(x_349); +x_352 = l_Lean_Expr_appFn_x21(x_350); +lean_dec(x_350); +x_353 = l_Lean_mkApp(x_352, x_342); +x_354 = l_Lean_Meta_rewriteCore___lambda__1___closed__5; +x_355 = 0; +x_356 = l_Lean_mkLambda(x_354, x_355, x_243, x_353); lean_inc(x_8); -x_377 = l_Lean_Meta_mkEqNDRec(x_372, x_375, x_351, x_8, x_376); -if (lean_obj_tag(x_377) == 0) +lean_inc(x_356); +x_391 = l_Lean_Meta_isTypeCorrect(x_356, x_8, x_351); +x_392 = lean_ctor_get(x_391, 0); +lean_inc(x_392); +x_393 = lean_unbox(x_392); +lean_dec(x_392); +if (x_393 == 0) { -lean_object* x_378; lean_object* x_379; lean_object* x_380; -x_378 = lean_ctor_get(x_377, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_377, 1); -lean_inc(x_379); -lean_dec(x_377); -lean_inc(x_8); -x_380 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_379); +lean_object* x_394; lean_object* x_395; lean_object* x_396; uint8_t x_397; +lean_dec(x_356); +lean_dec(x_347); +lean_dec(x_339); +lean_dec(x_335); lean_dec(x_20); -if (lean_obj_tag(x_380) == 0) -{ -lean_object* x_381; lean_object* x_382; uint8_t x_383; -x_381 = lean_ctor_get(x_380, 1); -lean_inc(x_381); -lean_dec(x_380); -x_382 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_381); +lean_dec(x_19); +x_394 = lean_ctor_get(x_391, 1); +lean_inc(x_394); +lean_dec(x_391); +x_395 = l_Lean_Meta_rewriteCore___lambda__1___closed__8; +x_396 = l_Lean_Meta_throwTacticEx___rarg(x_2, x_3, x_395, x_8, x_394); lean_dec(x_8); -x_383 = !lean_is_exclusive(x_382); -if (x_383 == 0) +x_397 = !lean_is_exclusive(x_396); +if (x_397 == 0) { -lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; -x_384 = lean_ctor_get(x_382, 0); -x_385 = l_Array_toList___rarg(x_384); -lean_dec(x_384); -x_386 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_385); -x_387 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_387, 0, x_363); -lean_ctor_set(x_387, 1, x_378); -lean_ctor_set(x_387, 2, x_386); -lean_ctor_set(x_382, 0, x_387); -return x_382; +return x_396; } else { -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_388 = lean_ctor_get(x_382, 0); -x_389 = lean_ctor_get(x_382, 1); -lean_inc(x_389); -lean_inc(x_388); -lean_dec(x_382); -x_390 = l_Array_toList___rarg(x_388); -lean_dec(x_388); -x_391 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_390); -x_392 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_392, 0, x_363); -lean_ctor_set(x_392, 1, x_378); -lean_ctor_set(x_392, 2, x_391); -x_393 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_393, 0, x_392); -lean_ctor_set(x_393, 1, x_389); -return x_393; +lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_398 = lean_ctor_get(x_396, 0); +x_399 = lean_ctor_get(x_396, 1); +lean_inc(x_399); +lean_inc(x_398); +lean_dec(x_396); +x_400 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_400, 0, x_398); +lean_ctor_set(x_400, 1, x_399); +return x_400; } } else { -uint8_t x_394; -lean_dec(x_378); -lean_dec(x_363); +lean_object* x_401; +x_401 = lean_ctor_get(x_391, 1); +lean_inc(x_401); +lean_dec(x_391); +x_357 = x_401; +goto block_390; +} +block_390: +{ +lean_object* x_358; +lean_inc(x_8); +x_358 = l_Lean_Meta_mkEqRefl(x_339, x_8, x_357); +if (lean_obj_tag(x_358) == 0) +{ +lean_object* x_359; lean_object* x_360; lean_object* x_361; +x_359 = lean_ctor_get(x_358, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_358, 1); +lean_inc(x_360); +lean_dec(x_358); +lean_inc(x_8); +x_361 = l_Lean_Meta_mkEqNDRec(x_356, x_359, x_335, x_8, x_360); +if (lean_obj_tag(x_361) == 0) +{ +lean_object* x_362; lean_object* x_363; lean_object* x_364; +x_362 = lean_ctor_get(x_361, 0); +lean_inc(x_362); +x_363 = lean_ctor_get(x_361, 1); +lean_inc(x_363); +lean_dec(x_361); +lean_inc(x_8); +x_364 = l_Lean_Meta_postprocessAppMVars(x_2, x_3, x_19, x_20, x_8, x_363); +lean_dec(x_20); +if (lean_obj_tag(x_364) == 0) +{ +lean_object* x_365; lean_object* x_366; uint8_t x_367; +x_365 = lean_ctor_get(x_364, 1); +lean_inc(x_365); +lean_dec(x_364); +x_366 = l_Array_filterMAux___main___at_Lean_Meta_apply___spec__1(x_19, x_22, x_22, x_8, x_365); +lean_dec(x_8); +x_367 = !lean_is_exclusive(x_366); +if (x_367 == 0) +{ +lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; +x_368 = lean_ctor_get(x_366, 0); +x_369 = l_Array_toList___rarg(x_368); +lean_dec(x_368); +x_370 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_369); +x_371 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_371, 0, x_347); +lean_ctor_set(x_371, 1, x_362); +lean_ctor_set(x_371, 2, x_370); +lean_ctor_set(x_366, 0, x_371); +return x_366; +} +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; +x_372 = lean_ctor_get(x_366, 0); +x_373 = lean_ctor_get(x_366, 1); +lean_inc(x_373); +lean_inc(x_372); +lean_dec(x_366); +x_374 = l_Array_toList___rarg(x_372); +lean_dec(x_372); +x_375 = l_List_map___main___at_Lean_Meta_rewriteCore___spec__1(x_374); +x_376 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_376, 0, x_347); +lean_ctor_set(x_376, 1, x_362); +lean_ctor_set(x_376, 2, x_375); +x_377 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_377, 0, x_376); +lean_ctor_set(x_377, 1, x_373); +return x_377; +} +} +else +{ +uint8_t x_378; +lean_dec(x_362); +lean_dec(x_347); lean_dec(x_19); lean_dec(x_8); -x_394 = !lean_is_exclusive(x_380); -if (x_394 == 0) +x_378 = !lean_is_exclusive(x_364); +if (x_378 == 0) { -return x_380; +return x_364; } else { -lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_395 = lean_ctor_get(x_380, 0); -x_396 = lean_ctor_get(x_380, 1); -lean_inc(x_396); -lean_inc(x_395); -lean_dec(x_380); -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; +lean_object* x_379; lean_object* x_380; lean_object* x_381; +x_379 = lean_ctor_get(x_364, 0); +x_380 = lean_ctor_get(x_364, 1); +lean_inc(x_380); +lean_inc(x_379); +lean_dec(x_364); +x_381 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_381, 0, x_379); +lean_ctor_set(x_381, 1, x_380); +return x_381; } } } else { -uint8_t x_398; -lean_dec(x_363); +uint8_t x_382; +lean_dec(x_347); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_398 = !lean_is_exclusive(x_377); -if (x_398 == 0) +x_382 = !lean_is_exclusive(x_361); +if (x_382 == 0) { -return x_377; +return x_361; } else { -lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_399 = lean_ctor_get(x_377, 0); -x_400 = lean_ctor_get(x_377, 1); -lean_inc(x_400); -lean_inc(x_399); -lean_dec(x_377); -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; +lean_object* x_383; lean_object* x_384; lean_object* x_385; +x_383 = lean_ctor_get(x_361, 0); +x_384 = lean_ctor_get(x_361, 1); +lean_inc(x_384); +lean_inc(x_383); +lean_dec(x_361); +x_385 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_385, 0, x_383); +lean_ctor_set(x_385, 1, x_384); +return x_385; +} +} +} +else +{ +uint8_t x_386; +lean_dec(x_356); +lean_dec(x_347); +lean_dec(x_335); +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_2); +x_386 = !lean_is_exclusive(x_358); +if (x_386 == 0) +{ +return x_358; +} +else +{ +lean_object* x_387; lean_object* x_388; lean_object* x_389; +x_387 = lean_ctor_get(x_358, 0); +x_388 = lean_ctor_get(x_358, 1); +lean_inc(x_388); +lean_inc(x_387); +lean_dec(x_358); +x_389 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_389, 0, x_387); +lean_ctor_set(x_389, 1, x_388); +return x_389; +} } } } else { uint8_t x_402; -lean_dec(x_372); -lean_dec(x_363); -lean_dec(x_351); +lean_dec(x_347); +lean_dec(x_342); +lean_dec(x_339); +lean_dec(x_335); +lean_dec(x_243); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_402 = !lean_is_exclusive(x_374); +x_402 = !lean_is_exclusive(x_349); if (x_402 == 0) { -return x_374; +return x_349; } else { lean_object* x_403; lean_object* x_404; lean_object* x_405; -x_403 = lean_ctor_get(x_374, 0); -x_404 = lean_ctor_get(x_374, 1); +x_403 = lean_ctor_get(x_349, 0); +x_404 = lean_ctor_get(x_349, 1); lean_inc(x_404); lean_inc(x_403); -lean_dec(x_374); +lean_dec(x_349); x_405 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_405, 0, x_403); lean_ctor_set(x_405, 1, x_404); @@ -2098,100 +2108,66 @@ return x_405; } else { -uint8_t x_418; -lean_dec(x_363); -lean_dec(x_358); -lean_dec(x_355); -lean_dec(x_351); -lean_dec(x_255); +uint8_t x_414; +lean_dec(x_339); +lean_dec(x_335); +lean_dec(x_244); +lean_dec(x_243); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -x_418 = !lean_is_exclusive(x_365); -if (x_418 == 0) +x_414 = !lean_is_exclusive(x_341); +if (x_414 == 0) { -return x_365; +return x_341; } else { -lean_object* x_419; lean_object* x_420; lean_object* x_421; -x_419 = lean_ctor_get(x_365, 0); -x_420 = lean_ctor_get(x_365, 1); -lean_inc(x_420); -lean_inc(x_419); -lean_dec(x_365); -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; +lean_object* x_415; lean_object* x_416; lean_object* x_417; +x_415 = lean_ctor_get(x_341, 0); +x_416 = lean_ctor_get(x_341, 1); +lean_inc(x_416); +lean_inc(x_415); +lean_dec(x_341); +x_417 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_417, 0, x_415); +lean_ctor_set(x_417, 1, x_416); +return x_417; } } } } else { -uint8_t x_430; -lean_dec(x_355); -lean_dec(x_351); -lean_dec(x_258); -lean_dec(x_255); -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_430 = !lean_is_exclusive(x_357); -if (x_430 == 0) -{ -return x_357; -} -else -{ -lean_object* x_431; lean_object* x_432; lean_object* x_433; -x_431 = lean_ctor_get(x_357, 0); -x_432 = lean_ctor_get(x_357, 1); -lean_inc(x_432); -lean_inc(x_431); -lean_dec(x_357); -x_433 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_433, 0, x_431); -lean_ctor_set(x_433, 1, x_432); -return x_433; -} -} -} -} -else -{ -uint8_t x_449; -lean_dec(x_261); -lean_dec(x_258); -lean_dec(x_255); +uint8_t x_433; +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_243); lean_dec(x_20); lean_dec(x_19); lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_449 = !lean_is_exclusive(x_350); -if (x_449 == 0) +x_433 = !lean_is_exclusive(x_334); +if (x_433 == 0) { -return x_350; +return x_334; } else { -lean_object* x_450; lean_object* x_451; lean_object* x_452; -x_450 = lean_ctor_get(x_350, 0); -x_451 = lean_ctor_get(x_350, 1); -lean_inc(x_451); -lean_inc(x_450); -lean_dec(x_350); -x_452 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_452, 0, x_450); -lean_ctor_set(x_452, 1, x_451); -return x_452; +lean_object* x_434; lean_object* x_435; lean_object* x_436; +x_434 = lean_ctor_get(x_334, 0); +x_435 = lean_ctor_get(x_334, 1); +lean_inc(x_435); +lean_inc(x_434); +lean_dec(x_334); +x_436 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_436, 0, x_434); +lean_ctor_set(x_436, 1, x_435); +return x_436; } } } @@ -2199,9 +2175,9 @@ return x_452; } else { -uint8_t x_453; -lean_dec(x_241); -lean_dec(x_238); +uint8_t x_437; +lean_dec(x_230); +lean_dec(x_229); lean_dec(x_23); lean_dec(x_20); lean_dec(x_19); @@ -2209,80 +2185,80 @@ lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_453 = !lean_is_exclusive(x_242); -if (x_453 == 0) +x_437 = !lean_is_exclusive(x_231); +if (x_437 == 0) { -return x_242; +return x_231; } else { -lean_object* x_454; lean_object* x_455; lean_object* x_456; -x_454 = lean_ctor_get(x_242, 0); -x_455 = lean_ctor_get(x_242, 1); -lean_inc(x_455); -lean_inc(x_454); -lean_dec(x_242); -x_456 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_456, 0, x_454); -lean_ctor_set(x_456, 1, x_455); -return x_456; +lean_object* x_438; lean_object* x_439; lean_object* x_440; +x_438 = lean_ctor_get(x_231, 0); +x_439 = lean_ctor_get(x_231, 1); +lean_inc(x_439); +lean_inc(x_438); +lean_dec(x_231); +x_440 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_440, 0, x_438); +lean_ctor_set(x_440, 1, x_439); +return x_440; } } } } else { -uint8_t x_457; +uint8_t x_441; lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_457 = !lean_is_exclusive(x_15); -if (x_457 == 0) +x_441 = !lean_is_exclusive(x_15); +if (x_441 == 0) { return x_15; } else { -lean_object* x_458; lean_object* x_459; lean_object* x_460; -x_458 = lean_ctor_get(x_15, 0); -x_459 = lean_ctor_get(x_15, 1); -lean_inc(x_459); -lean_inc(x_458); +lean_object* x_442; lean_object* x_443; lean_object* x_444; +x_442 = lean_ctor_get(x_15, 0); +x_443 = lean_ctor_get(x_15, 1); +lean_inc(x_443); +lean_inc(x_442); lean_dec(x_15); -x_460 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_460, 0, x_458); -lean_ctor_set(x_460, 1, x_459); -return x_460; +x_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; } } } else { -uint8_t x_461; +uint8_t x_445; lean_dec(x_8); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_461 = !lean_is_exclusive(x_10); -if (x_461 == 0) +x_445 = !lean_is_exclusive(x_10); +if (x_445 == 0) { return x_10; } else { -lean_object* x_462; lean_object* x_463; lean_object* x_464; -x_462 = lean_ctor_get(x_10, 0); -x_463 = lean_ctor_get(x_10, 1); -lean_inc(x_463); -lean_inc(x_462); +lean_object* x_446; lean_object* x_447; lean_object* x_448; +x_446 = lean_ctor_get(x_10, 0); +x_447 = lean_ctor_get(x_10, 1); +lean_inc(x_447); +lean_inc(x_446); lean_dec(x_10); -x_464 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_464, 0, x_462); -lean_ctor_set(x_464, 1, x_463); -return x_464; +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; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Subst.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Subst.c index e0d4da8a10..3b58929395 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Subst.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Subst.c @@ -35,6 +35,7 @@ lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___r lean_object* l_Lean_Meta_substCore___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkEqRec(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_subst(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_appFn_x21(lean_object*); lean_object* lean_expr_instantiate1(lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__6; @@ -42,13 +43,13 @@ lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__13; extern lean_object* l_Lean_Name_inhabited; lean_object* l_Lean_Meta_substCore___lambda__2___closed__1; +lean_object* l_Lean_Expr_appArg_x21(lean_object*); lean_object* l_Lean_LocalContext_findDeclM_x3f___at_Lean_Meta_subst___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkEqRefl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_LocalContext_findDeclM_x3f___at_Lean_Meta_subst___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentArray_findSomeMAux___main___at_Lean_Meta_subst___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; -lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); lean_object* l_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__11; lean_object* lean_array_fget(lean_object*, lean_object*); @@ -98,7 +99,6 @@ lean_object* l_Lean_Meta_checkNotAssigned(lean_object*, lean_object*, lean_objec lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_FVarSubst_empty; lean_object* l_Lean_Meta_substCore___lambda__3(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Nat_foldMAux___main___at_Lean_Meta_substCore___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -344,34 +344,22 @@ return x_286; } else { -lean_object* x_287; lean_object* x_288; -x_287 = lean_unsigned_to_nat(0u); -x_288 = l_Lean_Expr_getAppNumArgsAux___main(x_281, x_287); if (x_8 == 0) { -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -x_289 = lean_unsigned_to_nat(2u); -x_290 = lean_nat_sub(x_288, x_289); -lean_dec(x_288); -x_291 = lean_unsigned_to_nat(1u); -x_292 = lean_nat_sub(x_290, x_291); -lean_dec(x_290); -x_293 = l_Lean_Expr_getRevArg_x21___main(x_281, x_292); +lean_object* x_287; +x_287 = l_Lean_Expr_appArg_x21(x_281); lean_dec(x_281); -x_19 = x_293; +x_19 = x_287; goto block_280; } else { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; -x_294 = lean_unsigned_to_nat(1u); -x_295 = lean_nat_sub(x_288, x_294); -lean_dec(x_288); -x_296 = lean_nat_sub(x_295, x_294); -lean_dec(x_295); -x_297 = l_Lean_Expr_getRevArg_x21___main(x_281, x_296); +lean_object* x_288; lean_object* x_289; +x_288 = l_Lean_Expr_appFn_x21(x_281); lean_dec(x_281); -x_19 = x_297; +x_289 = l_Lean_Expr_appArg_x21(x_288); +lean_dec(x_288); +x_19 = x_289; goto block_280; } } @@ -1558,7 +1546,7 @@ return x_279; } else { -uint8_t x_298; +uint8_t x_290; lean_dec(x_15); lean_dec(x_13); lean_dec(x_10); @@ -1569,23 +1557,23 @@ lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_298 = !lean_is_exclusive(x_16); -if (x_298 == 0) +x_290 = !lean_is_exclusive(x_16); +if (x_290 == 0) { return x_16; } else { -lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_299 = lean_ctor_get(x_16, 0); -x_300 = lean_ctor_get(x_16, 1); -lean_inc(x_300); -lean_inc(x_299); +lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_291 = lean_ctor_get(x_16, 0); +x_292 = lean_ctor_get(x_16, 1); +lean_inc(x_292); +lean_inc(x_291); lean_dec(x_16); -x_301 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_301, 0, x_299); -lean_ctor_set(x_301, 1, x_300); -return x_301; +x_293 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_293, 0, x_291); +lean_ctor_set(x_293, 1, x_292); +return x_293; } } } @@ -1814,249 +1802,269 @@ return x_18; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; -x_19 = lean_unsigned_to_nat(0u); -x_20 = l_Lean_Expr_getAppNumArgsAux___main(x_13, x_19); -x_21 = lean_unsigned_to_nat(1u); -x_22 = lean_nat_sub(x_20, x_21); -x_23 = lean_nat_sub(x_22, x_21); -lean_dec(x_22); -x_24 = l_Lean_Expr_getRevArg_x21___main(x_13, x_23); -x_25 = lean_unsigned_to_nat(2u); -x_26 = lean_nat_sub(x_20, x_25); -lean_dec(x_20); -x_27 = lean_nat_sub(x_26, x_21); -lean_dec(x_26); -x_28 = l_Lean_Expr_getRevArg_x21___main(x_13, x_27); +lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_19 = l_Lean_Expr_appFn_x21(x_13); +x_20 = l_Lean_Expr_appArg_x21(x_19); +lean_dec(x_19); +x_21 = l_Lean_Expr_appArg_x21(x_13); if (x_3 == 0) { -uint8_t x_121; -x_121 = 0; -x_29 = x_121; -goto block_120; +uint8_t x_117; +x_117 = 0; +x_22 = x_117; +goto block_116; } else { -uint8_t x_122; -x_122 = 1; -x_29 = x_122; -goto block_120; +uint8_t x_118; +x_118 = 1; +x_22 = x_118; +goto block_116; } -block_120: +block_116: { -lean_object* x_30; -if (x_29 == 0) +lean_object* x_23; +if (x_22 == 0) { -lean_inc(x_24); -x_30 = x_24; -goto block_119; +lean_inc(x_20); +x_23 = x_20; +goto block_115; } else { -lean_inc(x_28); -x_30 = x_28; -goto block_119; +lean_inc(x_21); +x_23 = x_21; +goto block_115; } -block_119: +block_115: { -lean_object* x_31; -if (x_29 == 0) +lean_object* x_24; +if (x_22 == 0) { -lean_dec(x_24); -x_31 = x_28; -goto block_118; +lean_dec(x_20); +x_24 = x_21; +goto block_114; } else { -lean_dec(x_28); -x_31 = x_24; -goto block_118; +lean_dec(x_21); +x_24 = x_20; +goto block_114; } -block_118: +block_114: { -lean_object* x_32; +lean_object* x_25; lean_inc(x_5); -x_32 = l_Lean_Meta_whnf(x_30, x_5, x_12); -if (lean_obj_tag(x_32) == 0) +x_25 = l_Lean_Meta_whnf(x_23, x_5, x_12); +if (lean_obj_tag(x_25) == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -if (lean_obj_tag(x_33) == 1) +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +if (lean_obj_tag(x_26) == 1) { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_98; uint8_t x_99; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_94; uint8_t x_95; lean_dec(x_13); -x_45 = lean_ctor_get(x_33, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_34, 1); -lean_inc(x_46); -lean_inc(x_31); -x_98 = l_Lean_MetavarContext_exprDependsOn(x_46, x_31, x_45); -x_99 = lean_unbox(x_98); -lean_dec(x_98); -if (x_99 == 0) +x_38 = lean_ctor_get(x_26, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_27, 1); +lean_inc(x_39); +lean_inc(x_24); +x_94 = l_Lean_MetavarContext_exprDependsOn(x_39, x_24, x_38); +x_95 = lean_unbox(x_94); +lean_dec(x_94); +if (x_95 == 0) { -lean_dec(x_33); -lean_dec(x_31); -x_47 = x_34; -goto block_97; +lean_dec(x_26); +lean_dec(x_24); +x_40 = x_27; +goto block_93; } else { -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_dec(x_45); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; uint8_t x_105; +lean_dec(x_38); lean_dec(x_4); lean_dec(x_2); -x_100 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_100, 0, x_33); -x_101 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; -x_102 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_100); -x_103 = l_Lean_Meta_substCore___lambda__3___closed__19; -x_104 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_104, 0, x_102); -lean_ctor_set(x_104, 1, x_103); -x_105 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_105, 0, x_31); -x_106 = l_Lean_indentExpr(x_105); -x_107 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_107, 0, x_104); -lean_ctor_set(x_107, 1, x_106); -x_108 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_107, x_5, x_34); +x_96 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_96, 0, x_26); +x_97 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; +x_98 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_98, 0, x_97); +lean_ctor_set(x_98, 1, x_96); +x_99 = l_Lean_Meta_substCore___lambda__3___closed__19; +x_100 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_100, 0, x_98); +lean_ctor_set(x_100, 1, x_99); +x_101 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_101, 0, x_24); +x_102 = l_Lean_indentExpr(x_101); +x_103 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_103, 0, x_100); +lean_ctor_set(x_103, 1, x_102); +x_104 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_103, x_5, x_27); lean_dec(x_5); -x_109 = !lean_is_exclusive(x_108); -if (x_109 == 0) +x_105 = !lean_is_exclusive(x_104); +if (x_105 == 0) { -return x_108; +return x_104; } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_108, 0); -x_111 = lean_ctor_get(x_108, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_108); -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; +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_104, 0); +x_107 = lean_ctor_get(x_104, 1); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_104); +x_108 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_108, 0, x_106); +lean_ctor_set(x_108, 1, x_107); +return x_108; } } -block_97: +block_93: { -lean_object* x_48; +lean_object* x_41; lean_inc(x_5); -lean_inc(x_45); -x_48 = l_Lean_Meta_getLocalDecl(x_45, x_5, x_47); -if (lean_obj_tag(x_48) == 0) +lean_inc(x_38); +x_41 = l_Lean_Meta_getLocalDecl(x_38, x_5, x_40); +if (lean_obj_tag(x_41) == 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, 1); +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; +x_42 = lean_ctor_get(x_41, 1); +lean_inc(x_42); +lean_dec(x_41); +x_43 = l_Lean_mkAppStx___closed__9; +x_44 = lean_array_push(x_43, x_38); +x_45 = lean_array_push(x_44, x_2); +x_46 = 1; +x_47 = l_Lean_Meta_revert(x_1, x_45, x_46, x_5, x_42); +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_53; lean_object* x_54; lean_object* x_55; +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_48, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_48, 1); +lean_inc(x_51); lean_dec(x_48); -x_50 = l_Lean_mkAppStx___closed__9; -x_51 = lean_array_push(x_50, x_45); -x_52 = lean_array_push(x_51, x_2); -x_53 = 1; -x_54 = l_Lean_Meta_revert(x_1, x_52, x_53, x_5, x_49); -if (lean_obj_tag(x_54) == 0) +x_52 = lean_box(0); +x_53 = 0; +x_54 = lean_unsigned_to_nat(2u); +x_55 = l_Lean_Meta_introNCore___at_Lean_Meta_introN___spec__1(x_53, x_51, x_54, x_52, x_5, x_49); +if (lean_obj_tag(x_55) == 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; lean_object* x_61; -x_55 = lean_ctor_get(x_54, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 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; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_56 = lean_ctor_get(x_55, 0); lean_inc(x_56); -lean_dec(x_54); -x_57 = lean_ctor_get(x_55, 0); +x_57 = lean_ctor_get(x_55, 1); lean_inc(x_57); -x_58 = lean_ctor_get(x_55, 1); -lean_inc(x_58); lean_dec(x_55); -x_59 = lean_box(0); -x_60 = 0; -x_61 = l_Lean_Meta_introNCore___at_Lean_Meta_introN___spec__1(x_60, x_58, x_25, x_59, x_5, x_56); -if (lean_obj_tag(x_61) == 0) -{ -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_61, 0); +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 = l_Lean_Name_inhabited; +x_61 = lean_unsigned_to_nat(0u); +x_62 = lean_array_get(x_60, x_58, x_61); lean_inc(x_62); -x_63 = lean_ctor_get(x_61, 1); -lean_inc(x_63); -lean_dec(x_61); -x_64 = lean_ctor_get(x_62, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_62, 1); +x_63 = l_Lean_mkFVar(x_62); +x_64 = lean_unsigned_to_nat(1u); +x_65 = lean_array_get(x_60, x_58, x_64); +lean_dec(x_58); lean_inc(x_65); -lean_dec(x_62); -x_66 = l_Lean_Name_inhabited; -x_67 = lean_array_get(x_66, x_64, x_19); -lean_inc(x_67); -x_68 = l_Lean_mkFVar(x_67); -x_69 = lean_array_get(x_66, x_64, x_21); -lean_dec(x_64); -lean_inc(x_69); -x_70 = l_Lean_mkFVar(x_69); -lean_inc(x_65); -x_71 = lean_alloc_closure((void*)(l_Lean_Meta_getMVarDecl___boxed), 3, 1); -lean_closure_set(x_71, 0, x_65); -x_72 = lean_box(x_29); -lean_inc(x_65); -x_73 = lean_alloc_closure((void*)(l_Lean_Meta_substCore___lambda__2___boxed), 14, 11); -lean_closure_set(x_73, 0, x_69); -lean_closure_set(x_73, 1, x_68); -lean_closure_set(x_73, 2, x_4); -lean_closure_set(x_73, 3, x_65); -lean_closure_set(x_73, 4, x_67); -lean_closure_set(x_73, 5, x_57); -lean_closure_set(x_73, 6, x_59); -lean_closure_set(x_73, 7, x_72); -lean_closure_set(x_73, 8, x_70); -lean_closure_set(x_73, 9, x_50); -lean_closure_set(x_73, 10, x_14); -x_74 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 2); -lean_closure_set(x_74, 0, x_71); -lean_closure_set(x_74, 1, x_73); -x_75 = l_Lean_Meta_getMVarDecl(x_65, x_5, x_63); -if (lean_obj_tag(x_75) == 0) +x_66 = l_Lean_mkFVar(x_65); +lean_inc(x_59); +x_67 = lean_alloc_closure((void*)(l_Lean_Meta_getMVarDecl___boxed), 3, 1); +lean_closure_set(x_67, 0, x_59); +x_68 = lean_box(x_22); +lean_inc(x_59); +x_69 = lean_alloc_closure((void*)(l_Lean_Meta_substCore___lambda__2___boxed), 14, 11); +lean_closure_set(x_69, 0, x_65); +lean_closure_set(x_69, 1, x_63); +lean_closure_set(x_69, 2, x_4); +lean_closure_set(x_69, 3, x_59); +lean_closure_set(x_69, 4, x_62); +lean_closure_set(x_69, 5, x_50); +lean_closure_set(x_69, 6, x_52); +lean_closure_set(x_69, 7, x_68); +lean_closure_set(x_69, 8, x_66); +lean_closure_set(x_69, 9, x_43); +lean_closure_set(x_69, 10, x_14); +x_70 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 2); +lean_closure_set(x_70, 0, x_67); +lean_closure_set(x_70, 1, x_69); +x_71 = l_Lean_Meta_getMVarDecl(x_59, x_5, x_57); +if (lean_obj_tag(x_71) == 0) { -lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_76 = lean_ctor_get(x_75, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_75, 1); -lean_inc(x_77); -lean_dec(x_75); -x_78 = lean_ctor_get(x_76, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_76, 4); -lean_inc(x_79); -lean_dec(x_76); -x_80 = l_Lean_Meta_withLocalContext___rarg(x_78, x_79, x_74, x_5, x_77); +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_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_ctor_get(x_72, 1); +lean_inc(x_74); +x_75 = lean_ctor_get(x_72, 4); +lean_inc(x_75); +lean_dec(x_72); +x_76 = l_Lean_Meta_withLocalContext___rarg(x_74, x_75, x_70, x_5, x_73); lean_dec(x_5); +return x_76; +} +else +{ +uint8_t x_77; +lean_dec(x_70); +lean_dec(x_5); +x_77 = !lean_is_exclusive(x_71); +if (x_77 == 0) +{ +return x_71; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_71, 0); +x_79 = lean_ctor_get(x_71, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_71); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); return x_80; } +} +} else { uint8_t x_81; -lean_dec(x_74); +lean_dec(x_50); lean_dec(x_5); -x_81 = !lean_is_exclusive(x_75); +lean_dec(x_4); +x_81 = !lean_is_exclusive(x_55); if (x_81 == 0) { -return x_75; +return x_55; } else { lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_75, 0); -x_83 = lean_ctor_get(x_75, 1); +x_82 = lean_ctor_get(x_55, 0); +x_83 = lean_ctor_get(x_55, 1); lean_inc(x_83); lean_inc(x_82); -lean_dec(x_75); +lean_dec(x_55); x_84 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_84, 0, x_82); lean_ctor_set(x_84, 1, x_83); @@ -2067,22 +2075,21 @@ return x_84; else { uint8_t x_85; -lean_dec(x_57); lean_dec(x_5); lean_dec(x_4); -x_85 = !lean_is_exclusive(x_61); +x_85 = !lean_is_exclusive(x_47); if (x_85 == 0) { -return x_61; +return x_47; } else { lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_61, 0); -x_87 = lean_ctor_get(x_61, 1); +x_86 = lean_ctor_get(x_47, 0); +x_87 = lean_ctor_get(x_47, 1); lean_inc(x_87); lean_inc(x_86); -lean_dec(x_61); +lean_dec(x_47); x_88 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_88, 0, x_86); lean_ctor_set(x_88, 1, x_87); @@ -2093,21 +2100,24 @@ return x_88; else { uint8_t x_89; +lean_dec(x_38); lean_dec(x_5); lean_dec(x_4); -x_89 = !lean_is_exclusive(x_54); +lean_dec(x_2); +lean_dec(x_1); +x_89 = !lean_is_exclusive(x_41); if (x_89 == 0) { -return x_54; +return x_41; } else { lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_54, 0); -x_91 = lean_ctor_get(x_54, 1); +x_90 = lean_ctor_get(x_41, 0); +x_91 = lean_ctor_get(x_41, 1); lean_inc(x_91); lean_inc(x_90); -lean_dec(x_54); +lean_dec(x_41); x_92 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_92, 0, x_90); lean_ctor_set(x_92, 1, x_91); @@ -2115,103 +2125,75 @@ return x_92; } } } +} else { -uint8_t x_93; -lean_dec(x_45); -lean_dec(x_5); +lean_object* x_109; +lean_dec(x_26); +lean_dec(x_24); lean_dec(x_4); lean_dec(x_2); -lean_dec(x_1); -x_93 = !lean_is_exclusive(x_48); -if (x_93 == 0) +x_109 = lean_box(0); +x_28 = x_109; +goto block_37; +} +block_37: { -return x_48; -} -else +lean_object* x_29; lean_object* x_30; +lean_dec(x_28); +x_29 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_29, 0, x_13); +x_30 = l_Lean_indentExpr(x_29); +if (x_22 == 0) { -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_48, 0); -x_95 = lean_ctor_get(x_48, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_48); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -return x_96; -} -} -} -} -else -{ -lean_object* x_113; -lean_dec(x_33); -lean_dec(x_31); -lean_dec(x_4); -lean_dec(x_2); -x_113 = lean_box(0); -x_35 = x_113; -goto block_44; -} -block_44: -{ -lean_object* x_36; lean_object* x_37; -lean_dec(x_35); -x_36 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_36, 0, x_13); -x_37 = l_Lean_indentExpr(x_36); -if (x_29 == 0) -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = l_Lean_Meta_substCore___lambda__3___closed__12; -x_39 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_39, 0, x_38); -lean_ctor_set(x_39, 1, x_37); -x_40 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_39, x_5, x_34); +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = l_Lean_Meta_substCore___lambda__3___closed__12; +x_32 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_32, 0, x_31); +lean_ctor_set(x_32, 1, x_30); +x_33 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_32, x_5, x_27); lean_dec(x_5); -return x_40; +return x_33; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_41 = l_Lean_Meta_substCore___lambda__3___closed__16; -x_42 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_42, 0, x_41); -lean_ctor_set(x_42, 1, x_37); -x_43 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_42, x_5, x_34); +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = l_Lean_Meta_substCore___lambda__3___closed__16; +x_35 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_35, 0, x_34); +lean_ctor_set(x_35, 1, x_30); +x_36 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_35, x_5, x_27); lean_dec(x_5); -return x_43; +return x_36; } } } else { -uint8_t x_114; -lean_dec(x_31); +uint8_t x_110; +lean_dec(x_24); lean_dec(x_13); lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_114 = !lean_is_exclusive(x_32); -if (x_114 == 0) +x_110 = !lean_is_exclusive(x_25); +if (x_110 == 0) { -return x_32; +return x_25; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_32, 0); -x_116 = lean_ctor_get(x_32, 1); -lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_32); -x_117 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_117, 0, x_115); -lean_ctor_set(x_117, 1, x_116); -return x_117; +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_25, 0); +x_112 = lean_ctor_get(x_25, 1); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_25); +x_113 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_113, 0, x_111); +lean_ctor_set(x_113, 1, x_112); +return x_113; } } } @@ -2221,55 +2203,55 @@ return x_117; } else { +uint8_t x_119; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_119 = !lean_is_exclusive(x_10); +if (x_119 == 0) +{ +return x_10; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_10, 0); +x_121 = lean_ctor_get(x_10, 1); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_10); +x_122 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_122, 0, x_120); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} +} +} +else +{ uint8_t x_123; lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_123 = !lean_is_exclusive(x_10); +x_123 = !lean_is_exclusive(x_8); if (x_123 == 0) { -return x_10; -} -else -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_124 = lean_ctor_get(x_10, 0); -x_125 = lean_ctor_get(x_10, 1); -lean_inc(x_125); -lean_inc(x_124); -lean_dec(x_10); -x_126 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_126, 0, x_124); -lean_ctor_set(x_126, 1, x_125); -return x_126; -} -} -} -else -{ -uint8_t x_127; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_127 = !lean_is_exclusive(x_8); -if (x_127 == 0) -{ return x_8; } else { -lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_128 = lean_ctor_get(x_8, 0); -x_129 = lean_ctor_get(x_8, 1); -lean_inc(x_129); -lean_inc(x_128); +lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_124 = lean_ctor_get(x_8, 0); +x_125 = lean_ctor_get(x_8, 1); +lean_inc(x_125); +lean_inc(x_124); lean_dec(x_8); -x_130 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_130, 0, x_128); -lean_ctor_set(x_130, 1, x_129); -return x_130; +x_126 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_126, 0, x_124); +lean_ctor_set(x_126, 1, x_125); +return x_126; } } } @@ -2541,154 +2523,148 @@ goto _start; } 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; uint8_t x_53; -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_18, x_24); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_sub(x_25, x_26); -x_28 = lean_nat_sub(x_27, x_26); -lean_dec(x_27); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_18, x_28); -x_30 = lean_unsigned_to_nat(2u); -x_31 = lean_nat_sub(x_25, x_30); -lean_dec(x_25); -x_32 = lean_nat_sub(x_31, x_26); -lean_dec(x_31); -x_33 = l_Lean_Expr_getRevArg_x21___main(x_18, x_32); +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_49; +x_24 = l_Lean_Expr_appFn_x21(x_18); +x_25 = l_Lean_Expr_appArg_x21(x_24); +lean_dec(x_24); +x_26 = l_Lean_Expr_appArg_x21(x_18); lean_dec(x_18); -x_53 = l_Lean_Expr_isFVar(x_33); -if (x_53 == 0) -{ -lean_object* x_54; -x_54 = lean_box(0); -x_34 = x_54; -goto block_52; -} -else -{ -lean_object* x_55; uint8_t x_56; -x_55 = l_Lean_Expr_fvarId_x21(x_33); -x_56 = lean_name_eq(x_55, x_1); -lean_dec(x_55); -if (x_56 == 0) -{ -lean_object* x_57; -x_57 = lean_box(0); -x_34 = x_57; -goto block_52; -} -else -{ -lean_object* x_58; uint8_t x_59; -lean_inc(x_29); -lean_inc(x_3); -x_58 = l_Lean_MetavarContext_exprDependsOn(x_3, x_29, x_1); -x_59 = lean_unbox(x_58); -lean_dec(x_58); -if (x_59 == 0) -{ -lean_object* x_60; uint8_t x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_3); -x_60 = l_Lean_LocalDecl_fvarId(x_16); -lean_dec(x_16); -x_61 = 1; -x_62 = lean_box(x_61); -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_64 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_64, 0, x_63); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_64); -lean_ctor_set(x_65, 1, x_7); -return x_65; -} -else -{ -lean_object* x_66; -x_66 = lean_box(0); -x_34 = x_66; -goto block_52; -} -} -} -block_52: -{ -uint8_t x_35; -lean_dec(x_34); -x_35 = l_Lean_Expr_isFVar(x_29); -if (x_35 == 0) -{ -lean_object* x_36; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_17); -lean_dec(x_16); -x_36 = lean_nat_add(x_5, x_26); -lean_dec(x_5); -x_5 = x_36; -goto _start; -} -else -{ -lean_object* x_38; uint8_t x_39; -x_38 = l_Lean_Expr_fvarId_x21(x_29); -lean_dec(x_29); -x_39 = lean_name_eq(x_38, x_1); -lean_dec(x_38); -if (x_39 == 0) -{ -lean_object* x_40; -lean_dec(x_33); -lean_dec(x_17); -lean_dec(x_16); -x_40 = lean_nat_add(x_5, x_26); -lean_dec(x_5); -x_5 = x_40; -goto _start; -} -else -{ -lean_object* x_42; uint8_t x_43; -lean_inc(x_3); -x_42 = l_Lean_MetavarContext_exprDependsOn(x_3, x_33, x_1); -x_43 = lean_unbox(x_42); -lean_dec(x_42); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_5); -lean_dec(x_3); -x_44 = l_Lean_LocalDecl_fvarId(x_16); -lean_dec(x_16); -x_45 = 0; -x_46 = lean_box(x_45); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_46); -if (lean_is_scalar(x_17)) { - x_48 = lean_alloc_ctor(1, 1, 0); -} else { - x_48 = x_17; -} -lean_ctor_set(x_48, 0, x_47); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_7); -return x_49; -} -else +x_49 = l_Lean_Expr_isFVar(x_26); +if (x_49 == 0) { lean_object* x_50; +x_50 = lean_box(0); +x_27 = x_50; +goto block_48; +} +else +{ +lean_object* x_51; uint8_t x_52; +x_51 = l_Lean_Expr_fvarId_x21(x_26); +x_52 = lean_name_eq(x_51, x_1); +lean_dec(x_51); +if (x_52 == 0) +{ +lean_object* x_53; +x_53 = lean_box(0); +x_27 = x_53; +goto block_48; +} +else +{ +lean_object* x_54; uint8_t x_55; +lean_inc(x_25); +lean_inc(x_3); +x_54 = l_Lean_MetavarContext_exprDependsOn(x_3, x_25, x_1); +x_55 = lean_unbox(x_54); +lean_dec(x_54); +if (x_55 == 0) +{ +lean_object* x_56; uint8_t x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_3); +x_56 = l_Lean_LocalDecl_fvarId(x_16); +lean_dec(x_16); +x_57 = 1; +x_58 = lean_box(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); +x_60 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_60, 0, x_59); +x_61 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_61, 0, x_60); +lean_ctor_set(x_61, 1, x_7); +return x_61; +} +else +{ +lean_object* x_62; +x_62 = lean_box(0); +x_27 = x_62; +goto block_48; +} +} +} +block_48: +{ +uint8_t x_28; +lean_dec(x_27); +x_28 = l_Lean_Expr_isFVar(x_25); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; +lean_dec(x_26); +lean_dec(x_25); lean_dec(x_17); lean_dec(x_16); -x_50 = lean_nat_add(x_5, x_26); +x_29 = lean_unsigned_to_nat(1u); +x_30 = lean_nat_add(x_5, x_29); lean_dec(x_5); -x_5 = x_50; +x_5 = x_30; +goto _start; +} +else +{ +lean_object* x_32; uint8_t x_33; +x_32 = l_Lean_Expr_fvarId_x21(x_25); +lean_dec(x_25); +x_33 = lean_name_eq(x_32, x_1); +lean_dec(x_32); +if (x_33 == 0) +{ +lean_object* x_34; lean_object* x_35; +lean_dec(x_26); +lean_dec(x_17); +lean_dec(x_16); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_5, x_34); +lean_dec(x_5); +x_5 = x_35; +goto _start; +} +else +{ +lean_object* x_37; uint8_t x_38; +lean_inc(x_3); +x_37 = l_Lean_MetavarContext_exprDependsOn(x_3, x_26, x_1); +x_38 = lean_unbox(x_37); +lean_dec(x_37); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +lean_dec(x_5); +lean_dec(x_3); +x_39 = l_Lean_LocalDecl_fvarId(x_16); +lean_dec(x_16); +x_40 = 0; +x_41 = lean_box(x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_39); +lean_ctor_set(x_42, 1, x_41); +if (lean_is_scalar(x_17)) { + x_43 = lean_alloc_ctor(1, 1, 0); +} else { + x_43 = x_17; +} +lean_ctor_set(x_43, 0, x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_7); +return x_44; +} +else +{ +lean_object* x_45; lean_object* x_46; +lean_dec(x_17); +lean_dec(x_16); +x_45 = lean_unsigned_to_nat(1u); +x_46 = lean_nat_add(x_5, x_45); +lean_dec(x_5); +x_5 = x_46; goto _start; } } @@ -2780,154 +2756,148 @@ goto _start; } 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; uint8_t x_53; -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_18, x_24); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_sub(x_25, x_26); -x_28 = lean_nat_sub(x_27, x_26); -lean_dec(x_27); -x_29 = l_Lean_Expr_getRevArg_x21___main(x_18, x_28); -x_30 = lean_unsigned_to_nat(2u); -x_31 = lean_nat_sub(x_25, x_30); -lean_dec(x_25); -x_32 = lean_nat_sub(x_31, x_26); -lean_dec(x_31); -x_33 = l_Lean_Expr_getRevArg_x21___main(x_18, x_32); +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_49; +x_24 = l_Lean_Expr_appFn_x21(x_18); +x_25 = l_Lean_Expr_appArg_x21(x_24); +lean_dec(x_24); +x_26 = l_Lean_Expr_appArg_x21(x_18); lean_dec(x_18); -x_53 = l_Lean_Expr_isFVar(x_33); -if (x_53 == 0) -{ -lean_object* x_54; -x_54 = lean_box(0); -x_34 = x_54; -goto block_52; -} -else -{ -lean_object* x_55; uint8_t x_56; -x_55 = l_Lean_Expr_fvarId_x21(x_33); -x_56 = lean_name_eq(x_55, x_1); -lean_dec(x_55); -if (x_56 == 0) -{ -lean_object* x_57; -x_57 = lean_box(0); -x_34 = x_57; -goto block_52; -} -else -{ -lean_object* x_58; uint8_t x_59; -lean_inc(x_29); -lean_inc(x_3); -x_58 = l_Lean_MetavarContext_exprDependsOn(x_3, x_29, x_1); -x_59 = lean_unbox(x_58); -lean_dec(x_58); -if (x_59 == 0) -{ -lean_object* x_60; uint8_t x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_3); -x_60 = l_Lean_LocalDecl_fvarId(x_16); -lean_dec(x_16); -x_61 = 1; -x_62 = lean_box(x_61); -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_64 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_64, 0, x_63); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_64); -lean_ctor_set(x_65, 1, x_7); -return x_65; -} -else -{ -lean_object* x_66; -x_66 = lean_box(0); -x_34 = x_66; -goto block_52; -} -} -} -block_52: -{ -uint8_t x_35; -lean_dec(x_34); -x_35 = l_Lean_Expr_isFVar(x_29); -if (x_35 == 0) -{ -lean_object* x_36; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_17); -lean_dec(x_16); -x_36 = lean_nat_add(x_5, x_26); -lean_dec(x_5); -x_5 = x_36; -goto _start; -} -else -{ -lean_object* x_38; uint8_t x_39; -x_38 = l_Lean_Expr_fvarId_x21(x_29); -lean_dec(x_29); -x_39 = lean_name_eq(x_38, x_1); -lean_dec(x_38); -if (x_39 == 0) -{ -lean_object* x_40; -lean_dec(x_33); -lean_dec(x_17); -lean_dec(x_16); -x_40 = lean_nat_add(x_5, x_26); -lean_dec(x_5); -x_5 = x_40; -goto _start; -} -else -{ -lean_object* x_42; uint8_t x_43; -lean_inc(x_3); -x_42 = l_Lean_MetavarContext_exprDependsOn(x_3, x_33, x_1); -x_43 = lean_unbox(x_42); -lean_dec(x_42); -if (x_43 == 0) -{ -lean_object* x_44; uint8_t x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_5); -lean_dec(x_3); -x_44 = l_Lean_LocalDecl_fvarId(x_16); -lean_dec(x_16); -x_45 = 0; -x_46 = lean_box(x_45); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_46); -if (lean_is_scalar(x_17)) { - x_48 = lean_alloc_ctor(1, 1, 0); -} else { - x_48 = x_17; -} -lean_ctor_set(x_48, 0, x_47); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_7); -return x_49; -} -else +x_49 = l_Lean_Expr_isFVar(x_26); +if (x_49 == 0) { lean_object* x_50; +x_50 = lean_box(0); +x_27 = x_50; +goto block_48; +} +else +{ +lean_object* x_51; uint8_t x_52; +x_51 = l_Lean_Expr_fvarId_x21(x_26); +x_52 = lean_name_eq(x_51, x_1); +lean_dec(x_51); +if (x_52 == 0) +{ +lean_object* x_53; +x_53 = lean_box(0); +x_27 = x_53; +goto block_48; +} +else +{ +lean_object* x_54; uint8_t x_55; +lean_inc(x_25); +lean_inc(x_3); +x_54 = l_Lean_MetavarContext_exprDependsOn(x_3, x_25, x_1); +x_55 = lean_unbox(x_54); +lean_dec(x_54); +if (x_55 == 0) +{ +lean_object* x_56; uint8_t x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_3); +x_56 = l_Lean_LocalDecl_fvarId(x_16); +lean_dec(x_16); +x_57 = 1; +x_58 = lean_box(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); +x_60 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_60, 0, x_59); +x_61 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_61, 0, x_60); +lean_ctor_set(x_61, 1, x_7); +return x_61; +} +else +{ +lean_object* x_62; +x_62 = lean_box(0); +x_27 = x_62; +goto block_48; +} +} +} +block_48: +{ +uint8_t x_28; +lean_dec(x_27); +x_28 = l_Lean_Expr_isFVar(x_25); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; +lean_dec(x_26); +lean_dec(x_25); lean_dec(x_17); lean_dec(x_16); -x_50 = lean_nat_add(x_5, x_26); +x_29 = lean_unsigned_to_nat(1u); +x_30 = lean_nat_add(x_5, x_29); lean_dec(x_5); -x_5 = x_50; +x_5 = x_30; +goto _start; +} +else +{ +lean_object* x_32; uint8_t x_33; +x_32 = l_Lean_Expr_fvarId_x21(x_25); +lean_dec(x_25); +x_33 = lean_name_eq(x_32, x_1); +lean_dec(x_32); +if (x_33 == 0) +{ +lean_object* x_34; lean_object* x_35; +lean_dec(x_26); +lean_dec(x_17); +lean_dec(x_16); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_add(x_5, x_34); +lean_dec(x_5); +x_5 = x_35; +goto _start; +} +else +{ +lean_object* x_37; uint8_t x_38; +lean_inc(x_3); +x_37 = l_Lean_MetavarContext_exprDependsOn(x_3, x_26, x_1); +x_38 = lean_unbox(x_37); +lean_dec(x_37); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +lean_dec(x_5); +lean_dec(x_3); +x_39 = l_Lean_LocalDecl_fvarId(x_16); +lean_dec(x_16); +x_40 = 0; +x_41 = lean_box(x_40); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_39); +lean_ctor_set(x_42, 1, x_41); +if (lean_is_scalar(x_17)) { + x_43 = lean_alloc_ctor(1, 1, 0); +} else { + x_43 = x_17; +} +lean_ctor_set(x_43, 0, x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_7); +return x_44; +} +else +{ +lean_object* x_45; lean_object* x_46; +lean_dec(x_17); +lean_dec(x_16); +x_45 = lean_unsigned_to_nat(1u); +x_46 = lean_nat_add(x_5, x_45); +lean_dec(x_5); +x_5 = x_46; goto _start; } } @@ -3164,162 +3134,153 @@ return x_40; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; -x_41 = lean_unsigned_to_nat(0u); -x_42 = l_Lean_Expr_getAppNumArgsAux___main(x_6, x_41); -x_43 = lean_unsigned_to_nat(1u); -x_44 = lean_nat_sub(x_42, x_43); -x_45 = lean_nat_sub(x_44, x_43); -lean_dec(x_44); -x_46 = l_Lean_Expr_getRevArg_x21___main(x_6, x_45); -x_47 = lean_unsigned_to_nat(2u); -x_48 = lean_nat_sub(x_42, x_47); +lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_41 = l_Lean_Expr_appFn_x21(x_6); +x_42 = l_Lean_Expr_appArg_x21(x_41); +lean_dec(x_41); +x_43 = l_Lean_Expr_appArg_x21(x_6); +x_44 = l_Lean_Expr_isFVar(x_43); +lean_dec(x_43); +if (x_44 == 0) +{ +uint8_t x_45; +x_45 = l_Lean_Expr_isFVar(x_42); lean_dec(x_42); -x_49 = lean_nat_sub(x_48, x_43); -lean_dec(x_48); -x_50 = l_Lean_Expr_getRevArg_x21___main(x_6, x_49); -x_51 = l_Lean_Expr_isFVar(x_50); -lean_dec(x_50); -if (x_51 == 0) +if (x_45 == 0) { -uint8_t x_52; -x_52 = l_Lean_Expr_isFVar(x_46); -lean_dec(x_46); -if (x_52 == 0) -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_dec(x_1); -x_53 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_53, 0, x_6); -x_54 = l_Lean_indentExpr(x_53); -x_55 = l_Lean_Meta_subst___lambda__1___closed__6; -x_56 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_56, 0, x_55); -lean_ctor_set(x_56, 1, x_54); -x_57 = l_Lean_Meta_substCore___lambda__3___closed__2; -x_58 = l_Lean_Meta_throwTacticEx___rarg(x_57, x_2, x_56, x_4, x_5); -return x_58; +x_46 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_46, 0, x_6); +x_47 = l_Lean_indentExpr(x_46); +x_48 = l_Lean_Meta_subst___lambda__1___closed__6; +x_49 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_47); +x_50 = l_Lean_Meta_substCore___lambda__3___closed__2; +x_51 = l_Lean_Meta_throwTacticEx___rarg(x_50, x_2, x_49, x_4, x_5); +return x_51; } else { -uint8_t x_59; lean_object* x_60; +uint8_t x_52; lean_object* x_53; lean_dec(x_6); -x_59 = 0; -x_60 = l_Lean_Meta_substCore(x_2, x_1, x_59, x_59, x_4, x_5); -if (lean_obj_tag(x_60) == 0) +x_52 = 0; +x_53 = l_Lean_Meta_substCore(x_2, x_1, x_52, x_52, x_4, x_5); +if (lean_obj_tag(x_53) == 0) +{ +uint8_t x_54; +x_54 = !lean_is_exclusive(x_53); +if (x_54 == 0) +{ +lean_object* x_55; lean_object* x_56; +x_55 = lean_ctor_get(x_53, 0); +x_56 = lean_ctor_get(x_55, 1); +lean_inc(x_56); +lean_dec(x_55); +lean_ctor_set(x_53, 0, x_56); +return x_53; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_57 = lean_ctor_get(x_53, 0); +x_58 = lean_ctor_get(x_53, 1); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_53); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_58); +return x_60; +} +} +else { uint8_t x_61; -x_61 = !lean_is_exclusive(x_60); +x_61 = !lean_is_exclusive(x_53); if (x_61 == 0) { -lean_object* x_62; lean_object* x_63; -x_62 = lean_ctor_get(x_60, 0); -x_63 = lean_ctor_get(x_62, 1); -lean_inc(x_63); -lean_dec(x_62); -lean_ctor_set(x_60, 0, x_63); -return x_60; +return x_53; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_64 = lean_ctor_get(x_60, 0); -x_65 = lean_ctor_get(x_60, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_60); -x_66 = lean_ctor_get(x_64, 1); -lean_inc(x_66); -lean_dec(x_64); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_66); -lean_ctor_set(x_67, 1, x_65); -return x_67; +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_53, 0); +x_63 = lean_ctor_get(x_53, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_53); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} } } else { +uint8_t x_65; uint8_t x_66; lean_object* x_67; +lean_dec(x_42); +lean_dec(x_6); +x_65 = 1; +x_66 = 0; +x_67 = l_Lean_Meta_substCore(x_2, x_1, x_65, x_66, x_4, x_5); +if (lean_obj_tag(x_67) == 0) +{ uint8_t x_68; -x_68 = !lean_is_exclusive(x_60); +x_68 = !lean_is_exclusive(x_67); if (x_68 == 0) { -return x_60; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_60, 0); -x_70 = lean_ctor_get(x_60, 1); +lean_object* x_69; lean_object* x_70; +x_69 = lean_ctor_get(x_67, 0); +x_70 = lean_ctor_get(x_69, 1); lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_60); -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; -} -} -} +lean_dec(x_69); +lean_ctor_set(x_67, 0, x_70); +return x_67; } else { -uint8_t x_72; uint8_t x_73; lean_object* x_74; -lean_dec(x_46); -lean_dec(x_6); -x_72 = 1; -x_73 = 0; -x_74 = l_Lean_Meta_substCore(x_2, x_1, x_72, x_73, x_4, x_5); -if (lean_obj_tag(x_74) == 0) +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_71 = lean_ctor_get(x_67, 0); +x_72 = lean_ctor_get(x_67, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_67); +x_73 = lean_ctor_get(x_71, 1); +lean_inc(x_73); +lean_dec(x_71); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_73); +lean_ctor_set(x_74, 1, x_72); +return x_74; +} +} +else { uint8_t x_75; -x_75 = !lean_is_exclusive(x_74); +x_75 = !lean_is_exclusive(x_67); if (x_75 == 0) { -lean_object* x_76; lean_object* x_77; -x_76 = lean_ctor_get(x_74, 0); -x_77 = lean_ctor_get(x_76, 1); +return x_67; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_67, 0); +x_77 = lean_ctor_get(x_67, 1); lean_inc(x_77); -lean_dec(x_76); -lean_ctor_set(x_74, 0, x_77); -return x_74; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_78 = lean_ctor_get(x_74, 0); -x_79 = lean_ctor_get(x_74, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_74); -x_80 = lean_ctor_get(x_78, 1); -lean_inc(x_80); -lean_dec(x_78); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_79); -return x_81; -} -} -else -{ -uint8_t x_82; -x_82 = !lean_is_exclusive(x_74); -if (x_82 == 0) -{ -return x_74; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_74, 0); -x_84 = lean_ctor_get(x_74, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_74); -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; +lean_inc(x_76); +lean_dec(x_67); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; } } } diff --git a/stage0/stdlib/Init/Lean/Meta/Tactic/Target.c b/stage0/stdlib/Init/Lean/Meta/Tactic/Target.c index e91eb8b303..18a1c5989e 100644 --- a/stage0/stdlib/Init/Lean/Meta/Tactic/Target.c +++ b/stage0/stdlib/Init/Lean/Meta/Tactic/Target.c @@ -26,7 +26,7 @@ lean_object* l_Lean_Meta_getMVarType(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_replaceTargetDefEq___closed__1; lean_object* l_Lean_Meta_replaceTargetDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); -lean_object* l_Lean_Meta_replaceTargetEq___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_replaceTargetEq___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_replaceTargetEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_expr_eqv(lean_object*, lean_object*); @@ -34,134 +34,119 @@ lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, le lean_object* l_Lean_Meta_replaceTargetDefEq___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getLevel(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_replaceTargetEq___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_replaceTargetEq___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_replaceTargetEq___closed__1; +lean_object* l_Lean_Meta_mkExpectedTypeHint(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_replaceTargetEq___closed__2; lean_object* l_Lean_Meta_mkEq(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_replaceTargetEq___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_replaceTargetEq___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_6; +lean_object* x_7; lean_inc(x_1); -x_6 = l_Lean_Meta_getMVarTag(x_1, x_4, x_5); -if (lean_obj_tag(x_6) == 0) +x_7 = l_Lean_Meta_getMVarTag(x_1, x_5, x_6); +if (lean_obj_tag(x_7) == 0) { -lean_object* x_7; lean_object* x_8; uint8_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); +lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_8 = lean_ctor_get(x_7, 0); lean_inc(x_8); -lean_dec(x_6); -x_9 = 2; -lean_inc(x_4); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +x_10 = 2; +lean_inc(x_5); lean_inc(x_2); -x_10 = l_Lean_Meta_mkFreshExprMVar(x_2, x_7, x_9, x_4, x_8); -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); +x_11 = l_Lean_Meta_mkFreshExprMVar(x_2, x_8, x_10, x_5, x_9); +x_12 = lean_ctor_get(x_11, 0); lean_inc(x_12); -lean_dec(x_10); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); lean_inc(x_1); -x_13 = l_Lean_Meta_getMVarType(x_1, x_4, x_12); -if (lean_obj_tag(x_13) == 0) +x_14 = l_Lean_Meta_getMVarType(x_1, x_5, 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_4); -lean_inc(x_14); -x_16 = l_Lean_Meta_getLevel(x_14, x_4, x_15); -if (lean_obj_tag(x_16) == 0) +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +lean_inc(x_5); +lean_inc(x_15); +x_17 = l_Lean_Meta_getLevel(x_15, x_5, x_16); +if (lean_obj_tag(x_17) == 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_4); -x_18 = l_Lean_Meta_mkEq(x_14, x_2, x_4, x_17); -if (lean_obj_tag(x_18) == 0) +lean_object* x_18; lean_object* x_19; +x_18 = lean_ctor_get(x_17, 1); +lean_inc(x_18); +lean_dec(x_17); +lean_inc(x_5); +x_19 = l_Lean_Meta_mkEq(x_15, x_2, x_5, x_18); +if (lean_obj_tag(x_19) == 0) { -lean_object* x_19; lean_object* x_20; -x_19 = lean_ctor_get(x_18, 1); -lean_inc(x_19); -lean_dec(x_18); -lean_inc(x_11); -x_20 = l_Lean_Meta_assignExprMVar(x_1, x_11, x_4, x_19); -lean_dec(x_4); -if (lean_obj_tag(x_20) == 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_5); +x_22 = l_Lean_Meta_mkExpectedTypeHint(x_3, x_20, x_5, x_21); +if (lean_obj_tag(x_22) == 0) { -uint8_t x_21; -x_21 = !lean_is_exclusive(x_20); -if (x_21 == 0) -{ -lean_object* x_22; lean_object* x_23; -x_22 = lean_ctor_get(x_20, 0); +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_22, 1); +lean_inc(x_23); lean_dec(x_22); -x_23 = l_Lean_Expr_mvarId_x21(x_11); -lean_dec(x_11); -lean_ctor_set(x_20, 0, x_23); -return x_20; -} -else +lean_inc(x_12); +x_24 = l_Lean_Meta_assignExprMVar(x_1, x_12, x_5, x_23); +lean_dec(x_5); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_20, 1); -lean_inc(x_24); -lean_dec(x_20); -x_25 = l_Lean_Expr_mvarId_x21(x_11); -lean_dec(x_11); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_24); -return x_26; -} -} -else +uint8_t x_25; +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) { -uint8_t x_27; -lean_dec(x_11); -x_27 = !lean_is_exclusive(x_20); -if (x_27 == 0) -{ -return x_20; +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_24, 0); +lean_dec(x_26); +x_27 = l_Lean_Expr_mvarId_x21(x_12); +lean_dec(x_12); +lean_ctor_set(x_24, 0, x_27); +return x_24; } else { lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_20, 0); -x_29 = lean_ctor_get(x_20, 1); -lean_inc(x_29); +x_28 = lean_ctor_get(x_24, 1); lean_inc(x_28); -lean_dec(x_20); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); +lean_dec(x_24); +x_29 = l_Lean_Expr_mvarId_x21(x_12); +lean_dec(x_12); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_28); return x_30; } } -} else { uint8_t x_31; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_1); -x_31 = !lean_is_exclusive(x_18); +lean_dec(x_12); +x_31 = !lean_is_exclusive(x_24); if (x_31 == 0) { -return x_18; +return x_24; } 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); +x_32 = lean_ctor_get(x_24, 0); +x_33 = lean_ctor_get(x_24, 1); lean_inc(x_33); lean_inc(x_32); -lean_dec(x_18); +lean_dec(x_24); x_34 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_34, 0, x_32); lean_ctor_set(x_34, 1, x_33); @@ -172,24 +157,22 @@ return x_34; else { uint8_t x_35; -lean_dec(x_14); -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_12); +lean_dec(x_5); lean_dec(x_1); -x_35 = !lean_is_exclusive(x_16); +x_35 = !lean_is_exclusive(x_22); if (x_35 == 0) { -return x_16; +return x_22; } else { lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_16, 0); -x_37 = lean_ctor_get(x_16, 1); +x_36 = lean_ctor_get(x_22, 0); +x_37 = lean_ctor_get(x_22, 1); lean_inc(x_37); lean_inc(x_36); -lean_dec(x_16); +lean_dec(x_22); x_38 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_38, 0, x_36); lean_ctor_set(x_38, 1, x_37); @@ -200,23 +183,23 @@ return x_38; else { uint8_t x_39; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_3); lean_dec(x_1); -x_39 = !lean_is_exclusive(x_13); +x_39 = !lean_is_exclusive(x_19); if (x_39 == 0) { -return x_13; +return x_19; } else { lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_13, 0); -x_41 = lean_ctor_get(x_13, 1); +x_40 = lean_ctor_get(x_19, 0); +x_41 = lean_ctor_get(x_19, 1); lean_inc(x_41); lean_inc(x_40); -lean_dec(x_13); +lean_dec(x_19); x_42 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_42, 0, x_40); lean_ctor_set(x_42, 1, x_41); @@ -227,22 +210,25 @@ return x_42; else { uint8_t x_43; -lean_dec(x_4); +lean_dec(x_15); +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_43 = !lean_is_exclusive(x_6); +x_43 = !lean_is_exclusive(x_17); if (x_43 == 0) { -return x_6; +return x_17; } else { lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_6, 0); -x_45 = lean_ctor_get(x_6, 1); +x_44 = lean_ctor_get(x_17, 0); +x_45 = lean_ctor_get(x_17, 1); lean_inc(x_45); lean_inc(x_44); -lean_dec(x_6); +lean_dec(x_17); x_46 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_46, 0, x_44); lean_ctor_set(x_46, 1, x_45); @@ -250,6 +236,61 @@ return x_46; } } } +else +{ +uint8_t x_47; +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_47 = !lean_is_exclusive(x_14); +if (x_47 == 0) +{ +return x_14; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_14, 0); +x_49 = lean_ctor_get(x_14, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_14); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +else +{ +uint8_t x_51; +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_51 = !lean_is_exclusive(x_7); +if (x_51 == 0) +{ +return x_7; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_7, 0); +x_53 = lean_ctor_get(x_7, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_7); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} } lean_object* _init_l_Lean_Meta_replaceTargetEq___closed__1() { _start: @@ -279,9 +320,10 @@ x_7 = lean_alloc_closure((void*)(l_Lean_Meta_checkNotAssigned___boxed), 4, 2); lean_closure_set(x_7, 0, x_1); lean_closure_set(x_7, 1, x_6); lean_inc(x_1); -x_8 = lean_alloc_closure((void*)(l_Lean_Meta_replaceTargetEq___lambda__1___boxed), 5, 2); +x_8 = lean_alloc_closure((void*)(l_Lean_Meta_replaceTargetEq___lambda__1___boxed), 6, 3); lean_closure_set(x_8, 0, x_1); lean_closure_set(x_8, 1, x_2); +lean_closure_set(x_8, 2, x_3); x_9 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 2); lean_closure_set(x_9, 0, x_7); lean_closure_set(x_9, 1, x_8); @@ -327,13 +369,13 @@ return x_19; } } } -lean_object* l_Lean_Meta_replaceTargetEq___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_replaceTargetEq___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_6; -x_6 = l_Lean_Meta_replaceTargetEq___lambda__1(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -return x_6; +lean_object* x_7; +x_7 = l_Lean_Meta_replaceTargetEq___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_4); +return x_7; } } lean_object* l_Lean_Meta_replaceTargetEq___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { @@ -342,7 +384,6 @@ _start: lean_object* x_6; x_6 = l_Lean_Meta_replaceTargetEq(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); -lean_dec(x_3); return x_6; } } @@ -385,7 +426,8 @@ x_17 = lean_ctor_get(x_15, 1); lean_inc(x_17); lean_dec(x_15); lean_inc(x_4); -x_18 = l_Lean_Meta_getLevel(x_8, x_4, x_17); +lean_inc(x_16); +x_18 = l_Lean_Meta_mkExpectedTypeHint(x_16, x_8, x_4, x_17); if (lean_obj_tag(x_18) == 0) { lean_object* x_19; lean_object* x_20; @@ -540,7 +582,8 @@ x_48 = lean_ctor_get(x_46, 1); lean_inc(x_48); lean_dec(x_46); lean_inc(x_4); -x_49 = l_Lean_Meta_getLevel(x_39, x_4, x_48); +lean_inc(x_47); +x_49 = l_Lean_Meta_mkExpectedTypeHint(x_47, x_39, x_4, x_48); if (lean_obj_tag(x_49) == 0) { lean_object* x_50; lean_object* x_51; diff --git a/stage0/stdlib/Init/Lean/Meta/WHNF.c b/stage0/stdlib/Init/Lean/Meta/WHNF.c index ef159491de..ad75eb6b92 100644 --- a/stage0/stdlib/Init/Lean/Meta/WHNF.c +++ b/stage0/stdlib/Init/Lean/Meta/WHNF.c @@ -15,13 +15,16 @@ extern "C" { #endif lean_object* l___private_Init_Lean_Util_WHNF_4__toCtorWhenK___at_Lean_Meta_unfoldDefinition_x3f___spec__9(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___closed__1; +size_t l_USize_add(size_t, size_t); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_unfoldDefinition_x3f___spec__14___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_4__toCtorWhenK___at_Lean_Meta_whnfCore___spec__5(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___closed__2; lean_object* l___private_Init_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_unfoldDefinition_x3f___spec__14(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__7; +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__4(size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_6__extractIdRhs(lean_object*); lean_object* lean_mk_empty_array_with_capacity(lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -38,28 +41,33 @@ lean_object* l_Nat_beq___boxed(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_9__whnfCoreUnstuck___main___at_Lean_Meta_unfoldDefinition_x3f___spec__4(lean_object*, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceProj_x3f___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +extern size_t l_PersistentHashMap_insertAux___main___rarg___closed__2; lean_object* l_Lean_WHNF_reduceRec___at_Lean_Meta_unfoldDefinition_x3f___spec__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__5; extern lean_object* l_Nat_HasMod___closed__1; lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfUntil___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); lean_object* l_Lean_WHNF_isQuotRecStuck_x3f___at_Lean_Meta_getStuckMVar_x3f___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +size_t l_USize_sub(size_t, size_t); 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_getStuckMVar_x3f(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNatValue___rarg(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Nat_HasMul___closed__1; lean_object* l_Lean_Meta_reduceBinNatPred(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_reduceRec___at_Lean_Meta_whnfCore___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2(lean_object*, size_t, lean_object*); uint8_t l_Lean_Expr_isAppOf(lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___closed__5; lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfCore___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_setWHNFRef___closed__1; lean_object* l_Lean_Meta_isAuxDef_x3f___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate1(lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f(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* l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); extern lean_object* l_Lean_Expr_getAppArgs___closed__1; lean_object* l_Lean_Meta_unfoldDefinition_x3f(lean_object*, lean_object*, lean_object*); @@ -67,25 +75,27 @@ lean_object* l_Lean_WHNF_reduceQuotRec___at_Lean_Meta_unfoldDefinition_x3f___spe lean_object* l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_Exception_Inhabited___closed__1; lean_object* l_Lean_Meta_whnfUntil___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +size_t l_USize_shiftRight(size_t, size_t); lean_object* l_Lean_Meta_reduceNatNative___rarg(lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_3__getRecRuleFor(lean_object*, lean_object*); +lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(lean_object*, size_t, size_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__6; extern lean_object* l_Lean_auxRecExt; -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfCore___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_isRecStuck_x3f___at_Lean_Meta_getStuckMVar_x3f___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_getStuckMVar_x3f___main___at_Lean_Meta_unfoldDefinition_x3f___spec__15(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_2__mkNullaryCtor___at_Lean_Meta_unfoldDefinition_x3f___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_isRecStuck_x3f___at_Lean_Meta_getStuckMVar_x3f___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNatNative___boxed(lean_object*, lean_object*); lean_object* l_Lean_WHNF_toCtorIfLit(lean_object*); lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__12; -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBoolNative___rarg(lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_3__cache___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfCore___spec__8___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfCore___main___at_Lean_Meta_unfoldDefinition_x3f___spec__5(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_isQuotRecStuck_x3f___at_Lean_Meta_unfoldDefinition_x3f___spec__16___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -94,6 +104,8 @@ lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_WHNF_isRecStuck_x3f___at_Lean_Meta_unfoldDefinition_x3f___spec__17(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); lean_object* l_Lean_Meta_setWHNFRef(lean_object*); +lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_2__cached_x3f___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Array_shrink___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstNoEx___boxed(lean_object*, lean_object*, lean_object*); @@ -103,30 +115,38 @@ lean_object* l___private_Init_Lean_Expr_2__mkAppRangeAux___main(lean_object*, le lean_object* l_Lean_Meta_reduceBinNatOp___closed__10; lean_object* l_Lean_Meta_reduceNat_x3f___closed__10; extern lean_object* l_Nat_HasAdd___closed__1; +lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__11; lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_7__deltaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_WHNF_toCtorIfLit___closed__2; lean_object* l_Lean_Expr_instantiateLevelParams(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_ConstantInfo_name(lean_object*); +lean_object* l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1___boxed(lean_object*, lean_object*); lean_object* l_Nat_repr(lean_object*); lean_object* l_Lean_Meta_reduceUnaryNatOp(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_PersistentHashMap_insertAux___main___rarg___closed__3; lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfCore___spec__8___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +size_t l_Lean_Expr_hash(lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); extern lean_object* l_Lean_Literal_type___closed__1; +lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_ConstantInfo_hasValue(lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___closed__3; lean_object* l_Lean_Meta_reduceBinNatOp___closed__7; -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2; extern lean_object* l_Lean_WHNF_toCtorIfLit___closed__4; lean_object* l_Lean_Meta_reduceBoolNativeUnsafe(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1(lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Meta_TransparencyMode_beq(uint8_t, uint8_t); uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_unfoldDefinition_x3f___spec__12(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Literal_type___closed__2; lean_object* l_Lean_Meta_reduceNativeConst(lean_object*); uint8_t l_Lean_Expr_isConstOf(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_1__useWHNFCache___boxed(lean_object*, lean_object*, lean_object*); +size_t l_USize_mul(size_t, size_t); lean_object* l_Lean_WHNF_reduceQuotRec___at_Lean_Meta_whnfCore___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__9; @@ -137,8 +157,8 @@ uint8_t l_Lean_Expr_isLambda(lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__8; lean_object* l_Lean_Meta_reduceNativeConst___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_isQuotRecStuck_x3f___at_Lean_Meta_getStuckMVar_x3f___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1; lean_object* l_Lean_Meta_reduceNat_x3f___closed__17; +size_t l_USize_land(size_t, size_t); lean_object* l_Lean_Environment_evalConstCheck___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_unfoldDefinition_x3f___spec__12___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isAuxDef_x3f(lean_object*, lean_object*, lean_object*); @@ -153,21 +173,27 @@ lean_object* l_Lean_LocalDecl_value_x3f(lean_object*); lean_object* l_Lean_ConstantInfo_lparams(lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__11; lean_object* l_Lean_Meta_whnfHeadPred(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_1__useWHNFCache(lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_unfoldDefinition_x3f___spec__13(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_unfoldDefinition_x3f___spec__14___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2; lean_object* l_Lean_Meta_reduceNat_x3f___lambda__1(lean_object*); lean_object* lean_instantiate_value_lparams(lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfCore___spec__6(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_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); uint8_t lean_expr_eqv(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1; lean_object* l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(lean_object*, lean_object*); +uint8_t lean_expr_equal(lean_object*, lean_object*); lean_object* l_Lean_Expr_getRevArg_x21___main(lean_object*, lean_object*); lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_unfoldDefinition_x3f___spec__13___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceProj_x3f(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_reduceRec___at_Lean_Meta_unfoldDefinition_x3f___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_getStuckMVar_x3f___main___at_Lean_Meta_getStuckMVar_x3f___spec__1(lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_le(lean_object*, lean_object*); +uint8_t l_USize_decLe(size_t, size_t); +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); uint8_t l_Lean_Expr_hasMVar(lean_object*); lean_object* l_Lean_Expr_betaRev(lean_object*, lean_object*); @@ -176,7 +202,6 @@ lean_object* l_Lean_Meta_reduceNatNative(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_1__getFirstCtor___at_Lean_Meta_unfoldDefinition_x3f___spec__11(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstAux(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__13; -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNatNativeUnsafe___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_updateFn___main(lean_object*, lean_object*); extern lean_object* l_Lean_Meta_whnfRef; @@ -186,13 +211,18 @@ lean_object* l_Lean_Meta_reduceBinNatOp___closed__12; lean_object* l_Lean_Meta_getExprMVarAssignment_x3f___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_reduceQuotRec___at_Lean_Meta_whnfCore___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_whnfImpl___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_2__cached_x3f(uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1; +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isExprDefEq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentHashMap_getCollisionNodeSize___rarg(lean_object*); +lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_isQuotRecStuck_x3f___at_Lean_Meta_unfoldDefinition_x3f___spec__16(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__3(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_Inhabited; uint8_t l_Lean_TagDeclarationExtension_isTagged(lean_object*, lean_object*, lean_object*); lean_object* lean_mk_array(lean_object*, lean_object*); @@ -202,6 +232,7 @@ lean_object* l_Lean_Meta_reduceNat_x3f___lambda__1___boxed(lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__8; lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_whnfCore___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__18(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_WHNF_3__cache___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNative_x3f___closed__4; lean_object* l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); @@ -214,12 +245,14 @@ lean_object* l_Lean_Meta_reduceNativeConst___rarg(lean_object*, lean_object*, le lean_object* l_Lean_Meta_reduceNat_x3f___closed__15; lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__2; +lean_object* lean_usize_to_nat(size_t); lean_object* l_Lean_Meta_reduceNat_x3f___closed__14; lean_object* l_Lean_Meta_reduceBoolNativeUnsafe___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfCore___spec__8___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getRevArgD___main(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__1; lean_object* l_Lean_Meta_whnfImpl(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_WHNF_3__cache(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBoolNative(lean_object*, lean_object*); uint8_t l_Lean_Expr_hasFVar(lean_object*); extern lean_object* l_Lean_mkAppStx___closed__2; @@ -230,6 +263,7 @@ lean_object* l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_unfoldDefinition_x3 lean_object* l_Lean_Meta_reduceNatNativeUnsafe(lean_object*, lean_object*, lean_object*); lean_object* l_Nat_ble___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceBinNatOp___closed__4; +lean_object* l_PersistentHashMap_mkCollisionNode___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__3; lean_object* l___private_Init_Lean_Util_WHNF_4__toCtorWhenK___at_Lean_Meta_unfoldDefinition_x3f___spec__9___closed__1; lean_object* l___private_Init_Lean_Util_WHNF_8__deltaBetaDefinition___at_Lean_Meta_whnfCore___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -15909,6 +15943,883 @@ lean_dec(x_1); return x_2; } } +lean_object* l___private_Init_Lean_Meta_WHNF_1__useWHNFCache(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; +x_4 = l_Lean_Expr_hasFVar(x_1); +if (x_4 == 0) +{ +lean_object* x_5; uint8_t x_6; uint8_t x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; +x_5 = lean_ctor_get(x_2, 0); +x_6 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); +x_7 = 1; +x_8 = l_Lean_Meta_TransparencyMode_beq(x_6, x_7); +x_9 = lean_box(x_8); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_3); +return x_10; +} +else +{ +uint8_t x_11; lean_object* x_12; lean_object* x_13; +x_11 = 0; +x_12 = lean_box(x_11); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_3); +return x_13; +} +} +} +lean_object* l___private_Init_Lean_Meta_WHNF_1__useWHNFCache___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_WHNF_1__useWHNFCache(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_1); +x_7 = lean_nat_dec_lt(x_4, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; +lean_dec(x_4); +x_8 = lean_box(0); +return x_8; +} +else +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_array_fget(x_1, x_4); +x_10 = lean_expr_equal(x_5, x_9); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_4, x_11); +lean_dec(x_4); +x_3 = lean_box(0); +x_4 = x_12; +goto _start; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_array_fget(x_2, x_4); +lean_dec(x_4); +x_15 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_15, 0, x_14); +return x_15; +} +} +} +} +lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2(lean_object* x_1, size_t x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +lean_object* x_4; size_t x_5; size_t x_6; size_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +x_5 = 5; +x_6 = l_PersistentHashMap_insertAux___main___rarg___closed__2; +x_7 = x_2 & x_6; +x_8 = lean_usize_to_nat(x_7); +x_9 = lean_box(2); +x_10 = lean_array_get(x_9, x_4, x_8); +lean_dec(x_8); +lean_dec(x_4); +switch (lean_obj_tag(x_10)) { +case 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_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_expr_equal(x_3, x_11); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; +lean_dec(x_12); +x_14 = lean_box(0); +return x_14; +} +else +{ +lean_object* x_15; +x_15 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_15, 0, x_12); +return x_15; +} +} +case 1: +{ +lean_object* x_16; size_t x_17; +x_16 = lean_ctor_get(x_10, 0); +lean_inc(x_16); +lean_dec(x_10); +x_17 = x_2 >> x_5; +x_1 = x_16; +x_2 = x_17; +goto _start; +} +default: +{ +lean_object* x_19; +x_19 = lean_box(0); +return x_19; +} +} +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +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); +x_22 = lean_unsigned_to_nat(0u); +x_23 = l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3(x_20, x_21, lean_box(0), x_22, x_3); +lean_dec(x_21); +lean_dec(x_20); +return x_23; +} +} +} +lean_object* l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; size_t x_4; lean_object* x_5; +x_3 = lean_ctor_get(x_1, 0); +lean_inc(x_3); +lean_dec(x_1); +x_4 = l_Lean_Expr_hash(x_2); +x_5 = l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2(x_3, x_4, x_2); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_WHNF_2__cached_x3f(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +if (x_1 == 0) +{ +lean_object* x_5; lean_object* x_6; +x_5 = lean_box(0); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_4); +return x_6; +} +else +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_7 = lean_ctor_get(x_4, 2); +lean_inc(x_7); +x_8 = lean_ctor_get(x_7, 3); +lean_inc(x_8); +lean_dec(x_7); +x_9 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_8, x_2); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_4); +return x_10; +} +} +} +lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__3(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +size_t x_4; lean_object* x_5; +x_4 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_5 = l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__2(x_1, x_4, x_3); +lean_dec(x_3); +return x_5; +} +} +lean_object* l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l___private_Init_Lean_Meta_WHNF_2__cached_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; lean_object* x_6; +x_5 = lean_unbox(x_1); +lean_dec(x_1); +x_6 = l___private_Init_Lean_Meta_WHNF_2__cached_x3f(x_5, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +return x_6; +} +} +lean_object* l_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_5 = lean_ctor_get(x_1, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_1, 1); +lean_inc(x_6); +x_7 = lean_array_get_size(x_5); +x_8 = lean_nat_dec_lt(x_2, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +uint8_t x_9; +lean_dec(x_2); +x_9 = !lean_is_exclusive(x_1); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_1, 1); +lean_dec(x_10); +x_11 = lean_ctor_get(x_1, 0); +lean_dec(x_11); +x_12 = lean_array_push(x_5, x_3); +x_13 = lean_array_push(x_6, x_4); +lean_ctor_set(x_1, 1, x_13); +lean_ctor_set(x_1, 0, x_12); +return x_1; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_14 = lean_array_push(x_5, x_3); +x_15 = lean_array_push(x_6, x_4); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_14); +lean_ctor_set(x_16, 1, x_15); +return x_16; +} +} +else +{ +lean_object* x_17; uint8_t x_18; +x_17 = lean_array_fget(x_5, x_2); +x_18 = lean_expr_equal(x_3, x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; +lean_dec(x_6); +lean_dec(x_5); +x_19 = lean_unsigned_to_nat(1u); +x_20 = lean_nat_add(x_2, x_19); +lean_dec(x_2); +x_2 = x_20; +goto _start; +} +else +{ +uint8_t x_22; +x_22 = !lean_is_exclusive(x_1); +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_1, 1); +lean_dec(x_23); +x_24 = lean_ctor_get(x_1, 0); +lean_dec(x_24); +x_25 = lean_array_fset(x_5, x_2, x_3); +x_26 = lean_array_fset(x_6, x_2, x_4); +lean_dec(x_2); +lean_ctor_set(x_1, 1, x_26); +lean_ctor_set(x_1, 0, x_25); +return x_1; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_1); +x_27 = lean_array_fset(x_5, x_2, x_3); +x_28 = lean_array_fset(x_6, x_2, x_4); +lean_dec(x_2); +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_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__4(size_t 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_5, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_dec(x_5); +return x_6; +} +else +{ +lean_object* x_9; lean_object* x_10; size_t x_11; size_t x_12; size_t x_13; size_t x_14; size_t x_15; size_t x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_9 = lean_array_fget(x_4, x_5); +x_10 = lean_array_fget(x_3, x_5); +x_11 = l_Lean_Expr_hash(x_9); +x_12 = 1; +x_13 = x_1 - x_12; +x_14 = 5; +x_15 = x_14 * x_13; +x_16 = x_11 >> x_15; +x_17 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_6, x_16, x_1, x_9, x_10); +x_18 = lean_unsigned_to_nat(1u); +x_19 = lean_nat_add(x_5, x_18); +lean_dec(x_5); +x_5 = x_19; +x_6 = x_17; +goto _start; +} +} +} +lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(lean_object* x_1, size_t x_2, size_t x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +uint8_t x_6; +x_6 = !lean_is_exclusive(x_1); +if (x_6 == 0) +{ +lean_object* x_7; size_t x_8; size_t x_9; size_t x_10; size_t x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_7 = lean_ctor_get(x_1, 0); +x_8 = 1; +x_9 = 5; +x_10 = l_PersistentHashMap_insertAux___main___rarg___closed__2; +x_11 = x_2 & x_10; +x_12 = lean_usize_to_nat(x_11); +x_13 = lean_array_get_size(x_7); +x_14 = lean_nat_dec_lt(x_12, x_13); +lean_dec(x_13); +if (x_14 == 0) +{ +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_4); +return x_1; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_array_fget(x_7, x_12); +x_16 = lean_box(2); +x_17 = lean_array_fset(x_7, x_12, x_16); +switch (lean_obj_tag(x_15)) { +case 0: +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_15); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; uint8_t x_21; +x_19 = lean_ctor_get(x_15, 0); +x_20 = lean_ctor_get(x_15, 1); +x_21 = lean_expr_equal(x_4, x_19); +if (x_21 == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_free_object(x_15); +x_22 = l_PersistentHashMap_mkCollisionNode___rarg(x_19, x_20, x_4, x_5); +x_23 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_23, 0, x_22); +x_24 = lean_array_fset(x_17, x_12, x_23); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_24); +return x_1; +} +else +{ +lean_object* x_25; +lean_dec(x_20); +lean_dec(x_19); +lean_ctor_set(x_15, 1, x_5); +lean_ctor_set(x_15, 0, x_4); +x_25 = lean_array_fset(x_17, x_12, x_15); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_25); +return x_1; +} +} +else +{ +lean_object* x_26; lean_object* x_27; uint8_t x_28; +x_26 = lean_ctor_get(x_15, 0); +x_27 = lean_ctor_get(x_15, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_15); +x_28 = lean_expr_equal(x_4, x_26); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = l_PersistentHashMap_mkCollisionNode___rarg(x_26, x_27, x_4, x_5); +x_30 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_30, 0, x_29); +x_31 = lean_array_fset(x_17, x_12, x_30); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_31); +return x_1; +} +else +{ +lean_object* x_32; lean_object* x_33; +lean_dec(x_27); +lean_dec(x_26); +x_32 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_32, 0, x_4); +lean_ctor_set(x_32, 1, x_5); +x_33 = lean_array_fset(x_17, x_12, x_32); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_33); +return x_1; +} +} +} +case 1: +{ +uint8_t x_34; +x_34 = !lean_is_exclusive(x_15); +if (x_34 == 0) +{ +lean_object* x_35; size_t x_36; size_t x_37; lean_object* x_38; lean_object* x_39; +x_35 = lean_ctor_get(x_15, 0); +x_36 = x_2 >> x_9; +x_37 = x_3 + x_8; +x_38 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_35, x_36, x_37, x_4, x_5); +lean_ctor_set(x_15, 0, x_38); +x_39 = lean_array_fset(x_17, x_12, x_15); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_39); +return x_1; +} +else +{ +lean_object* x_40; size_t x_41; size_t x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_15, 0); +lean_inc(x_40); +lean_dec(x_15); +x_41 = x_2 >> x_9; +x_42 = x_3 + x_8; +x_43 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_40, x_41, x_42, x_4, x_5); +x_44 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_44, 0, x_43); +x_45 = lean_array_fset(x_17, x_12, x_44); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_45); +return x_1; +} +} +default: +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_46, 0, x_4); +lean_ctor_set(x_46, 1, x_5); +x_47 = lean_array_fset(x_17, x_12, x_46); +lean_dec(x_12); +lean_ctor_set(x_1, 0, x_47); +return x_1; +} +} +} +} +else +{ +lean_object* x_48; size_t x_49; size_t x_50; size_t x_51; size_t x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_48 = lean_ctor_get(x_1, 0); +lean_inc(x_48); +lean_dec(x_1); +x_49 = 1; +x_50 = 5; +x_51 = l_PersistentHashMap_insertAux___main___rarg___closed__2; +x_52 = x_2 & x_51; +x_53 = lean_usize_to_nat(x_52); +x_54 = lean_array_get_size(x_48); +x_55 = lean_nat_dec_lt(x_53, x_54); +lean_dec(x_54); +if (x_55 == 0) +{ +lean_object* x_56; +lean_dec(x_53); +lean_dec(x_5); +lean_dec(x_4); +x_56 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_56, 0, x_48); +return x_56; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_array_fget(x_48, x_53); +x_58 = lean_box(2); +x_59 = lean_array_fset(x_48, x_53, x_58); +switch (lean_obj_tag(x_57)) { +case 0: +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_60 = lean_ctor_get(x_57, 0); +lean_inc(x_60); +x_61 = lean_ctor_get(x_57, 1); +lean_inc(x_61); +if (lean_is_exclusive(x_57)) { + lean_ctor_release(x_57, 0); + lean_ctor_release(x_57, 1); + x_62 = x_57; +} else { + lean_dec_ref(x_57); + x_62 = lean_box(0); +} +x_63 = lean_expr_equal(x_4, x_60); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +lean_dec(x_62); +x_64 = l_PersistentHashMap_mkCollisionNode___rarg(x_60, x_61, x_4, x_5); +x_65 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_65, 0, x_64); +x_66 = lean_array_fset(x_59, x_53, x_65); +lean_dec(x_53); +x_67 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_67, 0, x_66); +return x_67; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +lean_dec(x_61); +lean_dec(x_60); +if (lean_is_scalar(x_62)) { + x_68 = lean_alloc_ctor(0, 2, 0); +} else { + x_68 = x_62; +} +lean_ctor_set(x_68, 0, x_4); +lean_ctor_set(x_68, 1, x_5); +x_69 = lean_array_fset(x_59, x_53, x_68); +lean_dec(x_53); +x_70 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_70, 0, x_69); +return x_70; +} +} +case 1: +{ +lean_object* x_71; lean_object* x_72; size_t x_73; size_t x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_71 = lean_ctor_get(x_57, 0); +lean_inc(x_71); +if (lean_is_exclusive(x_57)) { + lean_ctor_release(x_57, 0); + x_72 = x_57; +} else { + lean_dec_ref(x_57); + x_72 = lean_box(0); +} +x_73 = x_2 >> x_50; +x_74 = x_3 + x_49; +x_75 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_71, x_73, x_74, x_4, x_5); +if (lean_is_scalar(x_72)) { + x_76 = lean_alloc_ctor(1, 1, 0); +} else { + x_76 = x_72; +} +lean_ctor_set(x_76, 0, x_75); +x_77 = lean_array_fset(x_59, x_53, x_76); +lean_dec(x_53); +x_78 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_78, 0, x_77); +return x_78; +} +default: +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_79, 0, x_4); +lean_ctor_set(x_79, 1, x_5); +x_80 = lean_array_fset(x_59, x_53, x_79); +lean_dec(x_53); +x_81 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_81, 0, x_80); +return x_81; +} +} +} +} +} +else +{ +lean_object* x_82; lean_object* x_83; size_t x_84; uint8_t x_85; +x_82 = lean_unsigned_to_nat(0u); +x_83 = l_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__3(x_1, x_82, x_4, x_5); +x_84 = 7; +x_85 = x_84 <= x_3; +if (x_85 == 0) +{ +lean_object* x_86; lean_object* x_87; uint8_t x_88; +x_86 = l_PersistentHashMap_getCollisionNodeSize___rarg(x_83); +x_87 = lean_unsigned_to_nat(4u); +x_88 = lean_nat_dec_lt(x_86, x_87); +lean_dec(x_86); +if (x_88 == 0) +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_89 = lean_ctor_get(x_83, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_83, 1); +lean_inc(x_90); +lean_dec(x_83); +x_91 = l_PersistentHashMap_insertAux___main___rarg___closed__3; +x_92 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__4(x_3, x_89, x_90, x_89, x_82, x_91); +lean_dec(x_90); +lean_dec(x_89); +return x_92; +} +else +{ +return x_83; +} +} +else +{ +return x_83; +} +} +} +} +lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_WHNF_3__cache___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_1); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; size_t x_7; size_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_5 = lean_ctor_get(x_1, 0); +x_6 = lean_ctor_get(x_1, 1); +x_7 = l_Lean_Expr_hash(x_2); +x_8 = 1; +x_9 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_5, x_7, x_8, x_2, x_3); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_6, x_10); +lean_dec(x_6); +lean_ctor_set(x_1, 1, x_11); +lean_ctor_set(x_1, 0, x_9); +return x_1; +} +else +{ +lean_object* x_12; lean_object* x_13; size_t x_14; size_t x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_12 = lean_ctor_get(x_1, 0); +x_13 = lean_ctor_get(x_1, 1); +lean_inc(x_13); +lean_inc(x_12); +lean_dec(x_1); +x_14 = l_Lean_Expr_hash(x_2); +x_15 = 1; +x_16 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_12, x_14, x_15, x_2, x_3); +x_17 = lean_unsigned_to_nat(1u); +x_18 = lean_nat_add(x_13, x_17); +lean_dec(x_13); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_16); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_Meta_WHNF_3__cache(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (x_1 == 0) +{ +lean_object* x_6; +lean_dec(x_2); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_3); +lean_ctor_set(x_6, 1, x_5); +return x_6; +} +else +{ +uint8_t x_7; +x_7 = !lean_is_exclusive(x_5); +if (x_7 == 0) +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_ctor_get(x_5, 2); +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_8, 3); +lean_inc(x_3); +x_11 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_WHNF_3__cache___spec__1(x_10, x_2, x_3); +lean_ctor_set(x_8, 3, x_11); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_3); +lean_ctor_set(x_12, 1, x_5); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_13 = lean_ctor_get(x_8, 0); +x_14 = lean_ctor_get(x_8, 1); +x_15 = lean_ctor_get(x_8, 2); +x_16 = lean_ctor_get(x_8, 3); +lean_inc(x_16); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_8); +lean_inc(x_3); +x_17 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_WHNF_3__cache___spec__1(x_16, x_2, x_3); +x_18 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_14); +lean_ctor_set(x_18, 2, x_15); +lean_ctor_set(x_18, 3, x_17); +lean_ctor_set(x_5, 2, x_18); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_3); +lean_ctor_set(x_19, 1, x_5); +return x_19; +} +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_20 = lean_ctor_get(x_5, 2); +x_21 = lean_ctor_get(x_5, 0); +x_22 = lean_ctor_get(x_5, 1); +x_23 = lean_ctor_get(x_5, 3); +x_24 = lean_ctor_get(x_5, 4); +x_25 = lean_ctor_get(x_5, 5); +lean_inc(x_25); +lean_inc(x_24); +lean_inc(x_23); +lean_inc(x_20); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_5); +x_26 = lean_ctor_get(x_20, 0); +lean_inc(x_26); +x_27 = lean_ctor_get(x_20, 1); +lean_inc(x_27); +x_28 = lean_ctor_get(x_20, 2); +lean_inc(x_28); +x_29 = lean_ctor_get(x_20, 3); +lean_inc(x_29); +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + lean_ctor_release(x_20, 2); + lean_ctor_release(x_20, 3); + x_30 = x_20; +} else { + lean_dec_ref(x_20); + x_30 = lean_box(0); +} +lean_inc(x_3); +x_31 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_WHNF_3__cache___spec__1(x_29, x_2, x_3); +if (lean_is_scalar(x_30)) { + x_32 = lean_alloc_ctor(0, 4, 0); +} else { + x_32 = x_30; +} +lean_ctor_set(x_32, 0, x_26); +lean_ctor_set(x_32, 1, x_27); +lean_ctor_set(x_32, 2, x_28); +lean_ctor_set(x_32, 3, x_31); +x_33 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_33, 0, x_21); +lean_ctor_set(x_33, 1, x_22); +lean_ctor_set(x_33, 2, x_32); +lean_ctor_set(x_33, 3, x_23); +lean_ctor_set(x_33, 4, x_24); +lean_ctor_set(x_33, 5, x_25); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_3); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +} +} +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___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: +{ +size_t x_7; lean_object* x_8; +x_7 = lean_unbox_usize(x_1); +lean_dec(x_1); +x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__4(x_7, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +return x_8; +} +} +lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2___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; size_t x_7; lean_object* x_8; +x_6 = lean_unbox_usize(x_2); +lean_dec(x_2); +x_7 = lean_unbox_usize(x_3); +lean_dec(x_3); +x_8 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_WHNF_3__cache___spec__2(x_1, x_6, x_7, x_4, x_5); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_WHNF_3__cache___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = lean_unbox(x_1); +lean_dec(x_1); +x_7 = l___private_Init_Lean_Meta_WHNF_3__cache(x_6, x_2, x_3, x_4, x_5); +lean_dec(x_4); +return x_7; +} +} lean_object* _init_l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1() { _start: { @@ -16056,204 +16967,234 @@ goto _start; } case 4: { -lean_object* x_31; -lean_inc(x_2); -x_31 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_3); -if (lean_obj_tag(x_31) == 0) +uint8_t x_31; lean_object* x_32; uint8_t x_81; +x_81 = l_Lean_Expr_hasFVar(x_1); +if (x_81 == 0) { -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_31, 1); -lean_inc(x_33); -lean_dec(x_31); -lean_inc(x_2); -lean_inc(x_32); -x_34 = l_Lean_Meta_reduceNat_x3f(x_32, x_2, x_33); -if (lean_obj_tag(x_34) == 0) +lean_object* x_82; uint8_t x_83; uint8_t x_84; uint8_t x_85; +x_82 = lean_ctor_get(x_2, 0); +lean_inc(x_82); +x_83 = lean_ctor_get_uint8(x_82, sizeof(void*)*1 + 6); +lean_dec(x_82); +x_84 = 1; +x_85 = l_Lean_Meta_TransparencyMode_beq(x_83, x_84); +x_31 = x_85; +x_32 = x_3; +goto block_80; +} +else +{ +uint8_t x_86; +x_86 = 0; +x_31 = x_86; +x_32 = x_3; +goto block_80; +} +block_80: +{ +lean_object* x_33; lean_object* x_34; +if (x_31 == 0) +{ +lean_object* x_76; +x_76 = lean_box(0); +x_33 = x_76; +x_34 = x_32; +goto block_75; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_32, 2); +lean_inc(x_77); +x_78 = lean_ctor_get(x_77, 3); +lean_inc(x_78); +lean_dec(x_77); +x_79 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_78, x_1); +x_33 = x_79; +x_34 = x_32; +goto block_75; +} +block_75: +{ +if (lean_obj_tag(x_33) == 0) { lean_object* x_35; -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); +lean_inc(x_2); +lean_inc(x_1); +x_35 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_34); if (lean_obj_tag(x_35) == 0) { -lean_object* x_36; lean_object* x_37; -x_36 = lean_ctor_get(x_34, 1); +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_35, 0); lean_inc(x_36); -lean_dec(x_34); -lean_inc(x_32); -x_37 = l_Lean_Meta_reduceNative_x3f(x_32, x_2, x_36); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); +x_37 = lean_ctor_get(x_35, 1); +lean_inc(x_37); +lean_dec(x_35); +lean_inc(x_2); +lean_inc(x_36); +x_38 = l_Lean_Meta_reduceNat_x3f(x_36, x_2, x_37); if (lean_obj_tag(x_38) == 0) { -lean_object* x_39; lean_object* x_40; -x_39 = lean_ctor_get(x_37, 1); +lean_object* x_39; +x_39 = lean_ctor_get(x_38, 0); lean_inc(x_39); -lean_dec(x_37); -lean_inc(x_2); -lean_inc(x_32); -x_40 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_32, x_2, x_39); -if (lean_obj_tag(x_40) == 0) +if (lean_obj_tag(x_39) == 0) { -lean_object* x_41; -x_41 = lean_ctor_get(x_40, 0); -lean_inc(x_41); +lean_object* x_40; lean_object* x_41; +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +lean_dec(x_38); +lean_inc(x_36); +x_41 = l_Lean_Meta_reduceNative_x3f(x_36, x_2, x_40); if (lean_obj_tag(x_41) == 0) { -uint8_t x_42; -lean_dec(x_2); -x_42 = !lean_is_exclusive(x_40); -if (x_42 == 0) +lean_object* x_42; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +if (lean_obj_tag(x_42) == 0) { -lean_object* x_43; -x_43 = lean_ctor_get(x_40, 0); -lean_dec(x_43); -lean_ctor_set(x_40, 0, x_32); -return x_40; -} -else +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_41, 1); +lean_inc(x_43); +lean_dec(x_41); +lean_inc(x_2); +lean_inc(x_36); +x_44 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_36, x_2, x_43); +if (lean_obj_tag(x_44) == 0) { -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_40, 1); -lean_inc(x_44); -lean_dec(x_40); -x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_32); -lean_ctor_set(x_45, 1, x_44); -return x_45; -} -} -else +lean_object* x_45; +x_45 = lean_ctor_get(x_44, 0); +lean_inc(x_45); +if (lean_obj_tag(x_45) == 0) { lean_object* x_46; lean_object* x_47; -lean_dec(x_32); -x_46 = lean_ctor_get(x_40, 1); +x_46 = lean_ctor_get(x_44, 1); lean_inc(x_46); -lean_dec(x_40); -x_47 = lean_ctor_get(x_41, 0); -lean_inc(x_47); -lean_dec(x_41); -x_1 = x_47; -x_3 = x_46; +lean_dec(x_44); +x_47 = l___private_Init_Lean_Meta_WHNF_3__cache(x_31, x_1, x_36, x_2, x_46); +lean_dec(x_2); +return x_47; +} +else +{ +lean_object* x_48; lean_object* x_49; +lean_dec(x_36); +lean_dec(x_1); +x_48 = lean_ctor_get(x_44, 1); +lean_inc(x_48); +lean_dec(x_44); +x_49 = lean_ctor_get(x_45, 0); +lean_inc(x_49); +lean_dec(x_45); +x_1 = x_49; +x_3 = x_48; goto _start; } } else { -uint8_t x_49; -lean_dec(x_32); +uint8_t x_51; +lean_dec(x_36); lean_dec(x_2); -x_49 = !lean_is_exclusive(x_40); -if (x_49 == 0) +lean_dec(x_1); +x_51 = !lean_is_exclusive(x_44); +if (x_51 == 0) { -return x_40; +return x_44; } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_40, 0); -x_51 = lean_ctor_get(x_40, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_40); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_44, 0); +x_53 = lean_ctor_get(x_44, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_44); +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_53; -lean_dec(x_32); -lean_dec(x_2); -x_53 = !lean_is_exclusive(x_37); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_37, 0); -lean_dec(x_54); -x_55 = lean_ctor_get(x_38, 0); +lean_object* x_55; lean_object* x_56; lean_object* x_57; +lean_dec(x_36); +x_55 = lean_ctor_get(x_41, 1); lean_inc(x_55); -lean_dec(x_38); -lean_ctor_set(x_37, 0, x_55); -return x_37; -} -else -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_37, 1); +lean_dec(x_41); +x_56 = lean_ctor_get(x_42, 0); lean_inc(x_56); -lean_dec(x_37); -x_57 = lean_ctor_get(x_38, 0); -lean_inc(x_57); -lean_dec(x_38); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); -return x_58; -} -} -} -else -{ -uint8_t x_59; -lean_dec(x_32); +lean_dec(x_42); +x_57 = l___private_Init_Lean_Meta_WHNF_3__cache(x_31, x_1, x_56, x_2, x_55); lean_dec(x_2); -x_59 = !lean_is_exclusive(x_37); -if (x_59 == 0) -{ -return x_37; +return x_57; +} } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_37, 0); -x_61 = lean_ctor_get(x_37, 1); -lean_inc(x_61); +uint8_t x_58; +lean_dec(x_36); +lean_dec(x_2); +lean_dec(x_1); +x_58 = !lean_is_exclusive(x_41); +if (x_58 == 0) +{ +return x_41; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_41, 0); +x_60 = lean_ctor_get(x_41, 1); lean_inc(x_60); -lean_dec(x_37); -x_62 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_62, 0, x_60); -lean_ctor_set(x_62, 1, x_61); -return x_62; +lean_inc(x_59); +lean_dec(x_41); +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_63; -lean_dec(x_32); +lean_object* x_62; lean_object* x_63; lean_object* x_64; +lean_dec(x_36); +x_62 = lean_ctor_get(x_38, 1); +lean_inc(x_62); +lean_dec(x_38); +x_63 = lean_ctor_get(x_39, 0); +lean_inc(x_63); +lean_dec(x_39); +x_64 = l___private_Init_Lean_Meta_WHNF_3__cache(x_31, x_1, x_63, x_2, x_62); lean_dec(x_2); -x_63 = !lean_is_exclusive(x_34); -if (x_63 == 0) +return x_64; +} +} +else { -lean_object* x_64; lean_object* x_65; -x_64 = lean_ctor_get(x_34, 0); -lean_dec(x_64); -x_65 = lean_ctor_get(x_35, 0); -lean_inc(x_65); -lean_dec(x_35); -lean_ctor_set(x_34, 0, x_65); -return x_34; +uint8_t x_65; +lean_dec(x_36); +lean_dec(x_2); +lean_dec(x_1); +x_65 = !lean_is_exclusive(x_38); +if (x_65 == 0) +{ +return x_38; } else { lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_34, 1); -lean_inc(x_66); -lean_dec(x_34); -x_67 = lean_ctor_get(x_35, 0); +x_66 = lean_ctor_get(x_38, 0); +x_67 = lean_ctor_get(x_38, 1); lean_inc(x_67); -lean_dec(x_35); -x_68 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_68, 0, x_67); -lean_ctor_set(x_68, 1, x_66); +lean_inc(x_66); +lean_dec(x_38); +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; } } @@ -16261,21 +17202,21 @@ return x_68; else { uint8_t x_69; -lean_dec(x_32); lean_dec(x_2); -x_69 = !lean_is_exclusive(x_34); +lean_dec(x_1); +x_69 = !lean_is_exclusive(x_35); if (x_69 == 0) { -return x_34; +return x_35; } else { lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_34, 0); -x_71 = lean_ctor_get(x_34, 1); +x_70 = lean_ctor_get(x_35, 0); +x_71 = lean_ctor_get(x_35, 1); lean_inc(x_71); lean_inc(x_70); -lean_dec(x_34); +lean_dec(x_35); x_72 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_72, 0, x_70); lean_ctor_set(x_72, 1, x_71); @@ -16285,813 +17226,871 @@ return x_72; } else { -uint8_t x_73; +lean_object* x_73; lean_object* x_74; lean_dec(x_2); -x_73 = !lean_is_exclusive(x_31); -if (x_73 == 0) -{ -return x_31; +lean_dec(x_1); +x_73 = lean_ctor_get(x_33, 0); +lean_inc(x_73); +lean_dec(x_33); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_73); +lean_ctor_set(x_74, 1, x_34); +return x_74; } -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_31, 0); -x_75 = lean_ctor_get(x_31, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_31); -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; } } } case 5: { -lean_object* x_77; -lean_inc(x_2); -x_77 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_3); -if (lean_obj_tag(x_77) == 0) +uint8_t x_87; lean_object* x_88; uint8_t x_137; +x_137 = l_Lean_Expr_hasFVar(x_1); +if (x_137 == 0) { -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_77, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_77, 1); -lean_inc(x_79); -lean_dec(x_77); -lean_inc(x_2); -lean_inc(x_78); -x_80 = l_Lean_Meta_reduceNat_x3f(x_78, x_2, x_79); -if (lean_obj_tag(x_80) == 0) -{ -lean_object* x_81; -x_81 = lean_ctor_get(x_80, 0); -lean_inc(x_81); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; lean_object* x_83; -x_82 = lean_ctor_get(x_80, 1); -lean_inc(x_82); -lean_dec(x_80); -lean_inc(x_78); -x_83 = l_Lean_Meta_reduceNative_x3f(x_78, x_2, x_82); -if (lean_obj_tag(x_83) == 0) -{ -lean_object* x_84; -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; lean_object* x_86; -x_85 = lean_ctor_get(x_83, 1); -lean_inc(x_85); -lean_dec(x_83); -lean_inc(x_2); -lean_inc(x_78); -x_86 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_78, x_2, x_85); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; -x_87 = lean_ctor_get(x_86, 0); -lean_inc(x_87); -if (lean_obj_tag(x_87) == 0) -{ -uint8_t x_88; -lean_dec(x_2); -x_88 = !lean_is_exclusive(x_86); -if (x_88 == 0) -{ -lean_object* x_89; -x_89 = lean_ctor_get(x_86, 0); -lean_dec(x_89); -lean_ctor_set(x_86, 0, x_78); -return x_86; +lean_object* x_138; uint8_t x_139; uint8_t x_140; uint8_t x_141; +x_138 = lean_ctor_get(x_2, 0); +lean_inc(x_138); +x_139 = lean_ctor_get_uint8(x_138, sizeof(void*)*1 + 6); +lean_dec(x_138); +x_140 = 1; +x_141 = l_Lean_Meta_TransparencyMode_beq(x_139, x_140); +x_87 = x_141; +x_88 = x_3; +goto block_136; } else { -lean_object* x_90; lean_object* x_91; -x_90 = lean_ctor_get(x_86, 1); -lean_inc(x_90); -lean_dec(x_86); -x_91 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_91, 0, x_78); -lean_ctor_set(x_91, 1, x_90); -return x_91; +uint8_t x_142; +x_142 = 0; +x_87 = x_142; +x_88 = x_3; +goto block_136; } +block_136: +{ +lean_object* x_89; lean_object* x_90; +if (x_87 == 0) +{ +lean_object* x_132; +x_132 = lean_box(0); +x_89 = x_132; +x_90 = x_88; +goto block_131; } else { -lean_object* x_92; lean_object* x_93; -lean_dec(x_78); -x_92 = lean_ctor_get(x_86, 1); +lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_133 = lean_ctor_get(x_88, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_133, 3); +lean_inc(x_134); +lean_dec(x_133); +x_135 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_134, x_1); +x_89 = x_135; +x_90 = x_88; +goto block_131; +} +block_131: +{ +if (lean_obj_tag(x_89) == 0) +{ +lean_object* x_91; +lean_inc(x_2); +lean_inc(x_1); +x_91 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_90); +if (lean_obj_tag(x_91) == 0) +{ +lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_92 = lean_ctor_get(x_91, 0); lean_inc(x_92); -lean_dec(x_86); -x_93 = lean_ctor_get(x_87, 0); +x_93 = lean_ctor_get(x_91, 1); lean_inc(x_93); -lean_dec(x_87); -x_1 = x_93; -x_3 = x_92; +lean_dec(x_91); +lean_inc(x_2); +lean_inc(x_92); +x_94 = l_Lean_Meta_reduceNat_x3f(x_92, x_2, x_93); +if (lean_obj_tag(x_94) == 0) +{ +lean_object* x_95; +x_95 = lean_ctor_get(x_94, 0); +lean_inc(x_95); +if (lean_obj_tag(x_95) == 0) +{ +lean_object* x_96; lean_object* x_97; +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +lean_inc(x_92); +x_97 = l_Lean_Meta_reduceNative_x3f(x_92, x_2, x_96); +if (lean_obj_tag(x_97) == 0) +{ +lean_object* x_98; +x_98 = lean_ctor_get(x_97, 0); +lean_inc(x_98); +if (lean_obj_tag(x_98) == 0) +{ +lean_object* x_99; lean_object* x_100; +x_99 = lean_ctor_get(x_97, 1); +lean_inc(x_99); +lean_dec(x_97); +lean_inc(x_2); +lean_inc(x_92); +x_100 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_92, x_2, x_99); +if (lean_obj_tag(x_100) == 0) +{ +lean_object* x_101; +x_101 = lean_ctor_get(x_100, 0); +lean_inc(x_101); +if (lean_obj_tag(x_101) == 0) +{ +lean_object* x_102; lean_object* x_103; +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = l___private_Init_Lean_Meta_WHNF_3__cache(x_87, x_1, x_92, x_2, x_102); +lean_dec(x_2); +return x_103; +} +else +{ +lean_object* x_104; lean_object* x_105; +lean_dec(x_92); +lean_dec(x_1); +x_104 = lean_ctor_get(x_100, 1); +lean_inc(x_104); +lean_dec(x_100); +x_105 = lean_ctor_get(x_101, 0); +lean_inc(x_105); +lean_dec(x_101); +x_1 = x_105; +x_3 = x_104; goto _start; } } else { -uint8_t x_95; -lean_dec(x_78); +uint8_t x_107; +lean_dec(x_92); lean_dec(x_2); -x_95 = !lean_is_exclusive(x_86); -if (x_95 == 0) +lean_dec(x_1); +x_107 = !lean_is_exclusive(x_100); +if (x_107 == 0) { -return x_86; +return x_100; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_96 = lean_ctor_get(x_86, 0); -x_97 = lean_ctor_get(x_86, 1); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_86); -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 -{ -uint8_t x_99; -lean_dec(x_78); -lean_dec(x_2); -x_99 = !lean_is_exclusive(x_83); -if (x_99 == 0) -{ -lean_object* x_100; lean_object* x_101; -x_100 = lean_ctor_get(x_83, 0); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_100, 0); +x_109 = lean_ctor_get(x_100, 1); +lean_inc(x_109); +lean_inc(x_108); lean_dec(x_100); -x_101 = lean_ctor_get(x_84, 0); -lean_inc(x_101); -lean_dec(x_84); -lean_ctor_set(x_83, 0, x_101); -return x_83; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_83, 1); -lean_inc(x_102); -lean_dec(x_83); -x_103 = lean_ctor_get(x_84, 0); -lean_inc(x_103); -lean_dec(x_84); -x_104 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_104, 0, x_103); -lean_ctor_set(x_104, 1, x_102); -return x_104; +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_105; -lean_dec(x_78); -lean_dec(x_2); -x_105 = !lean_is_exclusive(x_83); -if (x_105 == 0) -{ -return x_83; -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_83, 0); -x_107 = lean_ctor_get(x_83, 1); -lean_inc(x_107); -lean_inc(x_106); -lean_dec(x_83); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_106); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_78); -lean_dec(x_2); -x_109 = !lean_is_exclusive(x_80); -if (x_109 == 0) -{ -lean_object* x_110; lean_object* x_111; -x_110 = lean_ctor_get(x_80, 0); -lean_dec(x_110); -x_111 = lean_ctor_get(x_81, 0); +lean_object* x_111; lean_object* x_112; lean_object* x_113; +lean_dec(x_92); +x_111 = lean_ctor_get(x_97, 1); lean_inc(x_111); -lean_dec(x_81); -lean_ctor_set(x_80, 0, x_111); -return x_80; -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_112 = lean_ctor_get(x_80, 1); +lean_dec(x_97); +x_112 = lean_ctor_get(x_98, 0); lean_inc(x_112); -lean_dec(x_80); -x_113 = lean_ctor_get(x_81, 0); -lean_inc(x_113); -lean_dec(x_81); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_112); -return x_114; -} -} -} -else -{ -uint8_t x_115; -lean_dec(x_78); +lean_dec(x_98); +x_113 = l___private_Init_Lean_Meta_WHNF_3__cache(x_87, x_1, x_112, x_2, x_111); lean_dec(x_2); -x_115 = !lean_is_exclusive(x_80); -if (x_115 == 0) -{ -return x_80; +return x_113; +} } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_80, 0); -x_117 = lean_ctor_get(x_80, 1); -lean_inc(x_117); +uint8_t x_114; +lean_dec(x_92); +lean_dec(x_2); +lean_dec(x_1); +x_114 = !lean_is_exclusive(x_97); +if (x_114 == 0) +{ +return x_97; +} +else +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_115 = lean_ctor_get(x_97, 0); +x_116 = lean_ctor_get(x_97, 1); lean_inc(x_116); -lean_dec(x_80); -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; +lean_inc(x_115); +lean_dec(x_97); +x_117 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_117, 0, x_115); +lean_ctor_set(x_117, 1, x_116); +return x_117; } } } else { -uint8_t x_119; +lean_object* x_118; lean_object* x_119; lean_object* x_120; +lean_dec(x_92); +x_118 = lean_ctor_get(x_94, 1); +lean_inc(x_118); +lean_dec(x_94); +x_119 = lean_ctor_get(x_95, 0); +lean_inc(x_119); +lean_dec(x_95); +x_120 = l___private_Init_Lean_Meta_WHNF_3__cache(x_87, x_1, x_119, x_2, x_118); lean_dec(x_2); -x_119 = !lean_is_exclusive(x_77); -if (x_119 == 0) -{ -return x_77; +return x_120; +} } else { -lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_120 = lean_ctor_get(x_77, 0); -x_121 = lean_ctor_get(x_77, 1); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_77); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_120); -lean_ctor_set(x_122, 1, x_121); -return x_122; +uint8_t x_121; +lean_dec(x_92); +lean_dec(x_2); +lean_dec(x_1); +x_121 = !lean_is_exclusive(x_94); +if (x_121 == 0) +{ +return x_94; +} +else +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_94, 0); +x_123 = lean_ctor_get(x_94, 1); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_94); +x_124 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_124, 0, x_122); +lean_ctor_set(x_124, 1, x_123); +return x_124; +} +} +} +else +{ +uint8_t x_125; +lean_dec(x_2); +lean_dec(x_1); +x_125 = !lean_is_exclusive(x_91); +if (x_125 == 0) +{ +return x_91; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_91, 0); +x_127 = lean_ctor_get(x_91, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_91); +x_128 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +return x_128; +} +} +} +else +{ +lean_object* x_129; lean_object* x_130; +lean_dec(x_2); +lean_dec(x_1); +x_129 = lean_ctor_get(x_89, 0); +lean_inc(x_129); +lean_dec(x_89); +x_130 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_130, 0, x_129); +lean_ctor_set(x_130, 1, x_90); +return x_130; +} } } } case 8: { -lean_object* x_123; +uint8_t x_143; lean_object* x_144; uint8_t x_193; +x_193 = l_Lean_Expr_hasFVar(x_1); +if (x_193 == 0) +{ +lean_object* x_194; uint8_t x_195; uint8_t x_196; uint8_t x_197; +x_194 = lean_ctor_get(x_2, 0); +lean_inc(x_194); +x_195 = lean_ctor_get_uint8(x_194, sizeof(void*)*1 + 6); +lean_dec(x_194); +x_196 = 1; +x_197 = l_Lean_Meta_TransparencyMode_beq(x_195, x_196); +x_143 = x_197; +x_144 = x_3; +goto block_192; +} +else +{ +uint8_t x_198; +x_198 = 0; +x_143 = x_198; +x_144 = x_3; +goto block_192; +} +block_192: +{ +lean_object* x_145; lean_object* x_146; +if (x_143 == 0) +{ +lean_object* x_188; +x_188 = lean_box(0); +x_145 = x_188; +x_146 = x_144; +goto block_187; +} +else +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_144, 2); +lean_inc(x_189); +x_190 = lean_ctor_get(x_189, 3); +lean_inc(x_190); +lean_dec(x_189); +x_191 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_190, x_1); +x_145 = x_191; +x_146 = x_144; +goto block_187; +} +block_187: +{ +if (lean_obj_tag(x_145) == 0) +{ +lean_object* x_147; lean_inc(x_2); -x_123 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_3); -if (lean_obj_tag(x_123) == 0) +lean_inc(x_1); +x_147 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_146); +if (lean_obj_tag(x_147) == 0) { -lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_124 = lean_ctor_get(x_123, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_123, 1); -lean_inc(x_125); -lean_dec(x_123); +lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_148 = lean_ctor_get(x_147, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_147, 1); +lean_inc(x_149); +lean_dec(x_147); lean_inc(x_2); -lean_inc(x_124); -x_126 = l_Lean_Meta_reduceNat_x3f(x_124, x_2, x_125); -if (lean_obj_tag(x_126) == 0) +lean_inc(x_148); +x_150 = l_Lean_Meta_reduceNat_x3f(x_148, x_2, x_149); +if (lean_obj_tag(x_150) == 0) { -lean_object* x_127; -x_127 = lean_ctor_get(x_126, 0); -lean_inc(x_127); -if (lean_obj_tag(x_127) == 0) +lean_object* x_151; +x_151 = lean_ctor_get(x_150, 0); +lean_inc(x_151); +if (lean_obj_tag(x_151) == 0) { -lean_object* x_128; lean_object* x_129; -x_128 = lean_ctor_get(x_126, 1); -lean_inc(x_128); -lean_dec(x_126); -lean_inc(x_124); -x_129 = l_Lean_Meta_reduceNative_x3f(x_124, x_2, x_128); -if (lean_obj_tag(x_129) == 0) +lean_object* x_152; lean_object* x_153; +x_152 = lean_ctor_get(x_150, 1); +lean_inc(x_152); +lean_dec(x_150); +lean_inc(x_148); +x_153 = l_Lean_Meta_reduceNative_x3f(x_148, x_2, x_152); +if (lean_obj_tag(x_153) == 0) { -lean_object* x_130; -x_130 = lean_ctor_get(x_129, 0); -lean_inc(x_130); -if (lean_obj_tag(x_130) == 0) +lean_object* x_154; +x_154 = lean_ctor_get(x_153, 0); +lean_inc(x_154); +if (lean_obj_tag(x_154) == 0) { -lean_object* x_131; lean_object* x_132; -x_131 = lean_ctor_get(x_129, 1); -lean_inc(x_131); -lean_dec(x_129); +lean_object* x_155; lean_object* x_156; +x_155 = lean_ctor_get(x_153, 1); +lean_inc(x_155); +lean_dec(x_153); lean_inc(x_2); -lean_inc(x_124); -x_132 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_124, x_2, x_131); -if (lean_obj_tag(x_132) == 0) +lean_inc(x_148); +x_156 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_148, x_2, x_155); +if (lean_obj_tag(x_156) == 0) { -lean_object* x_133; -x_133 = lean_ctor_get(x_132, 0); -lean_inc(x_133); -if (lean_obj_tag(x_133) == 0) +lean_object* x_157; +x_157 = lean_ctor_get(x_156, 0); +lean_inc(x_157); +if (lean_obj_tag(x_157) == 0) { -uint8_t x_134; +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_156, 1); +lean_inc(x_158); +lean_dec(x_156); +x_159 = l___private_Init_Lean_Meta_WHNF_3__cache(x_143, x_1, x_148, x_2, x_158); lean_dec(x_2); -x_134 = !lean_is_exclusive(x_132); -if (x_134 == 0) -{ -lean_object* x_135; -x_135 = lean_ctor_get(x_132, 0); -lean_dec(x_135); -lean_ctor_set(x_132, 0, x_124); -return x_132; +return x_159; } else { -lean_object* x_136; lean_object* x_137; -x_136 = lean_ctor_get(x_132, 1); -lean_inc(x_136); -lean_dec(x_132); -x_137 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -} -else -{ -lean_object* x_138; lean_object* x_139; -lean_dec(x_124); -x_138 = lean_ctor_get(x_132, 1); -lean_inc(x_138); -lean_dec(x_132); -x_139 = lean_ctor_get(x_133, 0); -lean_inc(x_139); -lean_dec(x_133); -x_1 = x_139; -x_3 = x_138; +lean_object* x_160; lean_object* x_161; +lean_dec(x_148); +lean_dec(x_1); +x_160 = lean_ctor_get(x_156, 1); +lean_inc(x_160); +lean_dec(x_156); +x_161 = lean_ctor_get(x_157, 0); +lean_inc(x_161); +lean_dec(x_157); +x_1 = x_161; +x_3 = x_160; goto _start; } } else { -uint8_t x_141; -lean_dec(x_124); +uint8_t x_163; +lean_dec(x_148); lean_dec(x_2); -x_141 = !lean_is_exclusive(x_132); -if (x_141 == 0) +lean_dec(x_1); +x_163 = !lean_is_exclusive(x_156); +if (x_163 == 0) { -return x_132; +return x_156; } else { -lean_object* x_142; lean_object* x_143; lean_object* x_144; -x_142 = lean_ctor_get(x_132, 0); -x_143 = lean_ctor_get(x_132, 1); -lean_inc(x_143); -lean_inc(x_142); -lean_dec(x_132); -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; +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_156, 0); +x_165 = lean_ctor_get(x_156, 1); +lean_inc(x_165); +lean_inc(x_164); +lean_dec(x_156); +x_166 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_166, 0, x_164); +lean_ctor_set(x_166, 1, x_165); +return x_166; } } } else { -uint8_t x_145; -lean_dec(x_124); +lean_object* x_167; lean_object* x_168; lean_object* x_169; +lean_dec(x_148); +x_167 = lean_ctor_get(x_153, 1); +lean_inc(x_167); +lean_dec(x_153); +x_168 = lean_ctor_get(x_154, 0); +lean_inc(x_168); +lean_dec(x_154); +x_169 = l___private_Init_Lean_Meta_WHNF_3__cache(x_143, x_1, x_168, x_2, x_167); lean_dec(x_2); -x_145 = !lean_is_exclusive(x_129); -if (x_145 == 0) -{ -lean_object* x_146; lean_object* x_147; -x_146 = lean_ctor_get(x_129, 0); -lean_dec(x_146); -x_147 = lean_ctor_get(x_130, 0); -lean_inc(x_147); -lean_dec(x_130); -lean_ctor_set(x_129, 0, x_147); -return x_129; +return x_169; +} } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; -x_148 = lean_ctor_get(x_129, 1); -lean_inc(x_148); -lean_dec(x_129); -x_149 = lean_ctor_get(x_130, 0); -lean_inc(x_149); -lean_dec(x_130); -x_150 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_150, 0, x_149); -lean_ctor_set(x_150, 1, x_148); +uint8_t x_170; +lean_dec(x_148); +lean_dec(x_2); +lean_dec(x_1); +x_170 = !lean_is_exclusive(x_153); +if (x_170 == 0) +{ +return x_153; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_153, 0); +x_172 = lean_ctor_get(x_153, 1); +lean_inc(x_172); +lean_inc(x_171); +lean_dec(x_153); +x_173 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_173, 0, x_171); +lean_ctor_set(x_173, 1, x_172); +return x_173; +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +lean_dec(x_148); +x_174 = lean_ctor_get(x_150, 1); +lean_inc(x_174); +lean_dec(x_150); +x_175 = lean_ctor_get(x_151, 0); +lean_inc(x_175); +lean_dec(x_151); +x_176 = l___private_Init_Lean_Meta_WHNF_3__cache(x_143, x_1, x_175, x_2, x_174); +lean_dec(x_2); +return x_176; +} +} +else +{ +uint8_t x_177; +lean_dec(x_148); +lean_dec(x_2); +lean_dec(x_1); +x_177 = !lean_is_exclusive(x_150); +if (x_177 == 0) +{ return x_150; } +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_150, 0); +x_179 = lean_ctor_get(x_150, 1); +lean_inc(x_179); +lean_inc(x_178); +lean_dec(x_150); +x_180 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_180, 0, x_178); +lean_ctor_set(x_180, 1, x_179); +return x_180; +} } } else { -uint8_t x_151; -lean_dec(x_124); +uint8_t x_181; lean_dec(x_2); -x_151 = !lean_is_exclusive(x_129); -if (x_151 == 0) +lean_dec(x_1); +x_181 = !lean_is_exclusive(x_147); +if (x_181 == 0) { -return x_129; +return x_147; } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; -x_152 = lean_ctor_get(x_129, 0); -x_153 = lean_ctor_get(x_129, 1); -lean_inc(x_153); -lean_inc(x_152); -lean_dec(x_129); -x_154 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_154, 0, x_152); -lean_ctor_set(x_154, 1, x_153); -return x_154; +lean_object* x_182; lean_object* x_183; lean_object* x_184; +x_182 = lean_ctor_get(x_147, 0); +x_183 = lean_ctor_get(x_147, 1); +lean_inc(x_183); +lean_inc(x_182); +lean_dec(x_147); +x_184 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_184, 0, x_182); +lean_ctor_set(x_184, 1, x_183); +return x_184; } } } else { -uint8_t x_155; -lean_dec(x_124); +lean_object* x_185; lean_object* x_186; lean_dec(x_2); -x_155 = !lean_is_exclusive(x_126); -if (x_155 == 0) -{ -lean_object* x_156; lean_object* x_157; -x_156 = lean_ctor_get(x_126, 0); -lean_dec(x_156); -x_157 = lean_ctor_get(x_127, 0); -lean_inc(x_157); -lean_dec(x_127); -lean_ctor_set(x_126, 0, x_157); -return x_126; +lean_dec(x_1); +x_185 = lean_ctor_get(x_145, 0); +lean_inc(x_185); +lean_dec(x_145); +x_186 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_186, 0, x_185); +lean_ctor_set(x_186, 1, x_146); +return x_186; } -else -{ -lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_158 = lean_ctor_get(x_126, 1); -lean_inc(x_158); -lean_dec(x_126); -x_159 = lean_ctor_get(x_127, 0); -lean_inc(x_159); -lean_dec(x_127); -x_160 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_160, 0, x_159); -lean_ctor_set(x_160, 1, x_158); -return x_160; -} -} -} -else -{ -uint8_t x_161; -lean_dec(x_124); -lean_dec(x_2); -x_161 = !lean_is_exclusive(x_126); -if (x_161 == 0) -{ -return x_126; -} -else -{ -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_126, 0); -x_163 = lean_ctor_get(x_126, 1); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_126); -x_164 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_164, 0, x_162); -lean_ctor_set(x_164, 1, x_163); -return x_164; -} -} -} -else -{ -uint8_t x_165; -lean_dec(x_2); -x_165 = !lean_is_exclusive(x_123); -if (x_165 == 0) -{ -return x_123; -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_123, 0); -x_167 = lean_ctor_get(x_123, 1); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_123); -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; } } } case 10: { -lean_object* x_169; -x_169 = lean_ctor_get(x_1, 1); -lean_inc(x_169); +lean_object* x_199; +x_199 = lean_ctor_get(x_1, 1); +lean_inc(x_199); lean_dec(x_1); -x_1 = x_169; +x_1 = x_199; goto _start; } case 11: { -lean_object* x_171; +uint8_t x_201; lean_object* x_202; uint8_t x_251; +x_251 = l_Lean_Expr_hasFVar(x_1); +if (x_251 == 0) +{ +lean_object* x_252; uint8_t x_253; uint8_t x_254; uint8_t x_255; +x_252 = lean_ctor_get(x_2, 0); +lean_inc(x_252); +x_253 = lean_ctor_get_uint8(x_252, sizeof(void*)*1 + 6); +lean_dec(x_252); +x_254 = 1; +x_255 = l_Lean_Meta_TransparencyMode_beq(x_253, x_254); +x_201 = x_255; +x_202 = x_3; +goto block_250; +} +else +{ +uint8_t x_256; +x_256 = 0; +x_201 = x_256; +x_202 = x_3; +goto block_250; +} +block_250: +{ +lean_object* x_203; lean_object* x_204; +if (x_201 == 0) +{ +lean_object* x_246; +x_246 = lean_box(0); +x_203 = x_246; +x_204 = x_202; +goto block_245; +} +else +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_202, 2); +lean_inc(x_247); +x_248 = lean_ctor_get(x_247, 3); +lean_inc(x_248); +lean_dec(x_247); +x_249 = l_PersistentHashMap_find_x3f___at___private_Init_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_248, x_1); +x_203 = x_249; +x_204 = x_202; +goto block_245; +} +block_245: +{ +if (lean_obj_tag(x_203) == 0) +{ +lean_object* x_205; lean_inc(x_2); -x_171 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_3); -if (lean_obj_tag(x_171) == 0) +lean_inc(x_1); +x_205 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_204); +if (lean_obj_tag(x_205) == 0) { -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); +lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_206 = lean_ctor_get(x_205, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_205, 1); +lean_inc(x_207); +lean_dec(x_205); lean_inc(x_2); -lean_inc(x_172); -x_174 = l_Lean_Meta_reduceNat_x3f(x_172, x_2, x_173); -if (lean_obj_tag(x_174) == 0) +lean_inc(x_206); +x_208 = l_Lean_Meta_reduceNat_x3f(x_206, x_2, x_207); +if (lean_obj_tag(x_208) == 0) { -lean_object* x_175; -x_175 = lean_ctor_get(x_174, 0); -lean_inc(x_175); -if (lean_obj_tag(x_175) == 0) +lean_object* x_209; +x_209 = lean_ctor_get(x_208, 0); +lean_inc(x_209); +if (lean_obj_tag(x_209) == 0) { -lean_object* x_176; lean_object* x_177; -x_176 = lean_ctor_get(x_174, 1); -lean_inc(x_176); -lean_dec(x_174); -lean_inc(x_172); -x_177 = l_Lean_Meta_reduceNative_x3f(x_172, x_2, x_176); -if (lean_obj_tag(x_177) == 0) +lean_object* x_210; lean_object* x_211; +x_210 = lean_ctor_get(x_208, 1); +lean_inc(x_210); +lean_dec(x_208); +lean_inc(x_206); +x_211 = l_Lean_Meta_reduceNative_x3f(x_206, x_2, x_210); +if (lean_obj_tag(x_211) == 0) { -lean_object* x_178; -x_178 = lean_ctor_get(x_177, 0); -lean_inc(x_178); -if (lean_obj_tag(x_178) == 0) +lean_object* x_212; +x_212 = lean_ctor_get(x_211, 0); +lean_inc(x_212); +if (lean_obj_tag(x_212) == 0) { -lean_object* x_179; lean_object* x_180; -x_179 = lean_ctor_get(x_177, 1); -lean_inc(x_179); -lean_dec(x_177); +lean_object* x_213; lean_object* x_214; +x_213 = lean_ctor_get(x_211, 1); +lean_inc(x_213); +lean_dec(x_211); lean_inc(x_2); -lean_inc(x_172); -x_180 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_172, x_2, x_179); -if (lean_obj_tag(x_180) == 0) +lean_inc(x_206); +x_214 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_206, x_2, x_213); +if (lean_obj_tag(x_214) == 0) { -lean_object* x_181; -x_181 = lean_ctor_get(x_180, 0); -lean_inc(x_181); -if (lean_obj_tag(x_181) == 0) +lean_object* x_215; +x_215 = lean_ctor_get(x_214, 0); +lean_inc(x_215); +if (lean_obj_tag(x_215) == 0) { -uint8_t x_182; +lean_object* x_216; lean_object* x_217; +x_216 = lean_ctor_get(x_214, 1); +lean_inc(x_216); +lean_dec(x_214); +x_217 = l___private_Init_Lean_Meta_WHNF_3__cache(x_201, x_1, x_206, x_2, x_216); lean_dec(x_2); -x_182 = !lean_is_exclusive(x_180); -if (x_182 == 0) -{ -lean_object* x_183; -x_183 = lean_ctor_get(x_180, 0); -lean_dec(x_183); -lean_ctor_set(x_180, 0, x_172); -return x_180; +return x_217; } else { -lean_object* x_184; lean_object* x_185; -x_184 = lean_ctor_get(x_180, 1); -lean_inc(x_184); -lean_dec(x_180); -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; -} -} -else -{ -lean_object* x_186; lean_object* x_187; -lean_dec(x_172); -x_186 = lean_ctor_get(x_180, 1); -lean_inc(x_186); -lean_dec(x_180); -x_187 = lean_ctor_get(x_181, 0); -lean_inc(x_187); -lean_dec(x_181); -x_1 = x_187; -x_3 = x_186; +lean_object* x_218; lean_object* x_219; +lean_dec(x_206); +lean_dec(x_1); +x_218 = lean_ctor_get(x_214, 1); +lean_inc(x_218); +lean_dec(x_214); +x_219 = lean_ctor_get(x_215, 0); +lean_inc(x_219); +lean_dec(x_215); +x_1 = x_219; +x_3 = x_218; goto _start; } } else { -uint8_t x_189; -lean_dec(x_172); +uint8_t x_221; +lean_dec(x_206); lean_dec(x_2); -x_189 = !lean_is_exclusive(x_180); -if (x_189 == 0) +lean_dec(x_1); +x_221 = !lean_is_exclusive(x_214); +if (x_221 == 0) { -return x_180; +return x_214; } else { -lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_190 = lean_ctor_get(x_180, 0); -x_191 = lean_ctor_get(x_180, 1); -lean_inc(x_191); -lean_inc(x_190); -lean_dec(x_180); -x_192 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_192, 0, x_190); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_object* x_222; lean_object* x_223; lean_object* x_224; +x_222 = lean_ctor_get(x_214, 0); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +lean_inc(x_222); +lean_dec(x_214); +x_224 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_224, 0, x_222); +lean_ctor_set(x_224, 1, x_223); +return x_224; } } } else { -uint8_t x_193; -lean_dec(x_172); +lean_object* x_225; lean_object* x_226; lean_object* x_227; +lean_dec(x_206); +x_225 = lean_ctor_get(x_211, 1); +lean_inc(x_225); +lean_dec(x_211); +x_226 = lean_ctor_get(x_212, 0); +lean_inc(x_226); +lean_dec(x_212); +x_227 = l___private_Init_Lean_Meta_WHNF_3__cache(x_201, x_1, x_226, x_2, x_225); lean_dec(x_2); -x_193 = !lean_is_exclusive(x_177); -if (x_193 == 0) -{ -lean_object* x_194; lean_object* x_195; -x_194 = lean_ctor_get(x_177, 0); -lean_dec(x_194); -x_195 = lean_ctor_get(x_178, 0); -lean_inc(x_195); -lean_dec(x_178); -lean_ctor_set(x_177, 0, x_195); -return x_177; -} -else -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_196 = lean_ctor_get(x_177, 1); -lean_inc(x_196); -lean_dec(x_177); -x_197 = lean_ctor_get(x_178, 0); -lean_inc(x_197); -lean_dec(x_178); -x_198 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_198, 0, x_197); -lean_ctor_set(x_198, 1, x_196); -return x_198; -} +return x_227; } } else { -uint8_t x_199; -lean_dec(x_172); +uint8_t x_228; +lean_dec(x_206); lean_dec(x_2); -x_199 = !lean_is_exclusive(x_177); -if (x_199 == 0) +lean_dec(x_1); +x_228 = !lean_is_exclusive(x_211); +if (x_228 == 0) { -return x_177; +return x_211; } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_200 = lean_ctor_get(x_177, 0); -x_201 = lean_ctor_get(x_177, 1); -lean_inc(x_201); -lean_inc(x_200); -lean_dec(x_177); -x_202 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_202, 0, x_200); -lean_ctor_set(x_202, 1, x_201); -return x_202; +lean_object* x_229; lean_object* x_230; lean_object* x_231; +x_229 = lean_ctor_get(x_211, 0); +x_230 = lean_ctor_get(x_211, 1); +lean_inc(x_230); +lean_inc(x_229); +lean_dec(x_211); +x_231 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_231, 0, x_229); +lean_ctor_set(x_231, 1, x_230); +return x_231; } } } else { -uint8_t x_203; -lean_dec(x_172); +lean_object* x_232; lean_object* x_233; lean_object* x_234; +lean_dec(x_206); +x_232 = lean_ctor_get(x_208, 1); +lean_inc(x_232); +lean_dec(x_208); +x_233 = lean_ctor_get(x_209, 0); +lean_inc(x_233); +lean_dec(x_209); +x_234 = l___private_Init_Lean_Meta_WHNF_3__cache(x_201, x_1, x_233, x_2, x_232); lean_dec(x_2); -x_203 = !lean_is_exclusive(x_174); -if (x_203 == 0) -{ -lean_object* x_204; lean_object* x_205; -x_204 = lean_ctor_get(x_174, 0); -lean_dec(x_204); -x_205 = lean_ctor_get(x_175, 0); -lean_inc(x_205); -lean_dec(x_175); -lean_ctor_set(x_174, 0, x_205); -return x_174; +return x_234; +} } else { -lean_object* x_206; lean_object* x_207; lean_object* x_208; -x_206 = lean_ctor_get(x_174, 1); -lean_inc(x_206); -lean_dec(x_174); -x_207 = lean_ctor_get(x_175, 0); -lean_inc(x_207); -lean_dec(x_175); -x_208 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_208, 0, x_207); -lean_ctor_set(x_208, 1, x_206); +uint8_t x_235; +lean_dec(x_206); +lean_dec(x_2); +lean_dec(x_1); +x_235 = !lean_is_exclusive(x_208); +if (x_235 == 0) +{ return x_208; } +else +{ +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_208, 0); +x_237 = lean_ctor_get(x_208, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_208); +x_238 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_238, 0, x_236); +lean_ctor_set(x_238, 1, x_237); +return x_238; +} } } else { -uint8_t x_209; -lean_dec(x_172); +uint8_t x_239; lean_dec(x_2); -x_209 = !lean_is_exclusive(x_174); -if (x_209 == 0) +lean_dec(x_1); +x_239 = !lean_is_exclusive(x_205); +if (x_239 == 0) { -return x_174; +return x_205; } else { -lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_210 = lean_ctor_get(x_174, 0); -x_211 = lean_ctor_get(x_174, 1); -lean_inc(x_211); -lean_inc(x_210); -lean_dec(x_174); -x_212 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_212, 0, x_210); -lean_ctor_set(x_212, 1, x_211); -return x_212; +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_205, 0); +x_241 = lean_ctor_get(x_205, 1); +lean_inc(x_241); +lean_inc(x_240); +lean_dec(x_205); +x_242 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_242, 0, x_240); +lean_ctor_set(x_242, 1, x_241); +return x_242; } } } else { -uint8_t x_213; +lean_object* x_243; lean_object* x_244; lean_dec(x_2); -x_213 = !lean_is_exclusive(x_171); -if (x_213 == 0) -{ -return x_171; +lean_dec(x_1); +x_243 = lean_ctor_get(x_203, 0); +lean_inc(x_243); +lean_dec(x_203); +x_244 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_244, 0, x_243); +lean_ctor_set(x_244, 1, x_204); +return x_244; } -else -{ -lean_object* x_214; lean_object* x_215; lean_object* x_216; -x_214 = lean_ctor_get(x_171, 0); -x_215 = lean_ctor_get(x_171, 1); -lean_inc(x_215); -lean_inc(x_214); -lean_dec(x_171); -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; } } } case 12: { -lean_object* x_217; lean_object* x_218; lean_object* x_219; +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_dec(x_1); -x_217 = l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1; -x_218 = l_unreachable_x21___rarg(x_217); -x_219 = lean_apply_2(x_218, x_2, x_3); -return x_219; +x_257 = l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1; +x_258 = l_unreachable_x21___rarg(x_257); +x_259 = lean_apply_2(x_258, x_2, x_3); +return x_259; } default: { -lean_object* x_220; +lean_object* x_260; lean_dec(x_2); -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_1); -lean_ctor_set(x_220, 1, x_3); -return x_220; +x_260 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_260, 0, x_1); +lean_ctor_set(x_260, 1, x_3); +return x_260; } } } @@ -17441,7 +18440,7 @@ lean_dec(x_2); return x_5; } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; @@ -17542,7 +18541,7 @@ lean_dec(x_16); x_23 = lean_ctor_get(x_17, 0); lean_inc(x_23); lean_dec(x_17); -x_24 = l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main(x_1, x_23, x_3, x_22); +x_24 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main(x_1, x_23, x_3, x_22); return x_24; } } @@ -17625,7 +18624,7 @@ return x_36; } } } -lean_object* _init_l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1() { _start: { lean_object* x_1; @@ -17633,7 +18632,7 @@ x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 0); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2() { +lean_object* _init_l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2() { _start: { lean_object* x_1; @@ -17641,25 +18640,25 @@ x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment_x3f___boxed), return x_1; } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_5 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___lambda__1), 4, 1); +x_5 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___lambda__1), 4, 1); lean_closure_set(x_5, 0, x_1); x_6 = l_Lean_MetavarContext_MkBinding_mkBinding___closed__1; -x_7 = l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1; -x_8 = l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2; +x_7 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1; +x_8 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2; x_9 = l_Lean_WHNF_whnfEasyCases___main___rarg(x_6, x_7, x_8, x_2, x_5); x_10 = lean_apply_2(x_9, x_3, x_4); return x_10; } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main(x_1, x_2, x_3, x_4); return x_5; } } @@ -17667,7 +18666,7 @@ lean_object* l_Lean_Meta_whnfHeadPred(lean_object* x_1, lean_object* x_2, lean_o _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main(x_2, x_1, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main(x_2, x_1, x_3, x_4); return x_5; } } @@ -18708,7 +19707,7 @@ return x_189; } } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; @@ -18733,11 +19732,11 @@ lean_dec(x_1); return x_5; } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___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___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___at_Lean_Meta_whnfUntil___spec__1(x_1, x_2, x_3, x_4); lean_dec(x_1); return x_5; } @@ -19332,10 +20331,10 @@ lean_mark_persistent(l_Lean_Meta_setWHNFRef___closed__1); res = l_Lean_Meta_setWHNFRef(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1 = _init_l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__1); -l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2 = _init_l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_WHNF_1__whnfHeadPredAux___main___closed__2); +l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1 = _init_l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1); +l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2 = _init_l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__2); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/stdlib/Init/Lean/Parser/Term.c b/stage0/stdlib/Init/Lean/Parser/Term.c index 912c1f222c..ef075ce1ff 100644 --- a/stage0/stdlib/Init/Lean/Parser/Term.c +++ b/stage0/stdlib/Init/Lean/Parser/Term.c @@ -109,6 +109,7 @@ lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_ lean_object* l_Lean_Parser_Term_explicit___closed__2; lean_object* l___regBuiltinParser_Lean_Parser_Term_ge(lean_object*); lean_object* l_Lean_Parser_Term_nomatch___elambda__1___closed__3; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_doPat___closed__3; lean_object* l_Lean_Parser_Term_matchAlt___closed__3; lean_object* l_Lean_Parser_Term_inaccessible___closed__2; @@ -154,6 +155,7 @@ lean_object* l_Lean_Parser_Term_str___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_andthen___closed__3; lean_object* l_Lean_Parser_Term_not___elambda__1___closed__7; lean_object* l_Lean_Parser_Term_checkIsSort___elambda__1___boxed(lean_object*); +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__1; lean_object* l_Lean_Parser_Tactic_seq___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_structInst___closed__6; lean_object* l___regBuiltinParser_Lean_Parser_Term_explicit(lean_object*); @@ -162,6 +164,7 @@ lean_object* l_Lean_Parser_Term_type___closed__3; lean_object* l_Lean_Parser_Term_subtype___closed__6; lean_object* l___regBuiltinParser_Lean_Parser_Term_append(lean_object*); lean_object* l_Lean_Parser_Term_nomatch___elambda__1___closed__5; +lean_object* l_Lean_Parser_Term_levelStxQuot___closed__5; lean_object* l_Lean_Parser_darrow___elambda__1___closed__8; lean_object* l_Lean_Parser_Term_haveAssign___closed__2; lean_object* l_Lean_Parser_Term_nativeDecide___elambda__1___closed__1; @@ -186,6 +189,7 @@ lean_object* l_Lean_Parser_Term_instBinder___closed__5; lean_object* l_Lean_Parser_Term_inaccessible___elambda__1___closed__7; lean_object* l_Lean_Parser_Term_seqLeft___closed__2; lean_object* l_Lean_Parser_Term_namedArgument___closed__5; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_matchAlts___elambda__1___spec__18___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Tactic_seq; lean_object* l_Lean_Parser_Term_show___elambda__1___closed__8; @@ -233,6 +237,7 @@ lean_object* l_Lean_Parser_Term_div___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_if___closed__10; lean_object* l_Lean_Parser_Term_namedPattern___elambda__1___closed__6; lean_object* l_Lean_Parser_Term_subst___closed__4; +lean_object* l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1; lean_object* l_Lean_Parser_Term_prop; lean_object* l_Lean_Parser_Term_binderTactic___elambda__1___closed__5; lean_object* l_Lean_Parser_Term_structInstArrayRef___elambda__1___closed__2; @@ -256,9 +261,11 @@ lean_object* l_Lean_Parser_Term_where___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_letPatDecl; lean_object* l_Lean_Parser_Term_sortApp___closed__4; lean_object* l_Lean_Parser_Term_bnot___closed__2; +lean_object* l___regBuiltinParser_Lean_Parser_Term_levelStxQuot(lean_object*); lean_object* l_Lean_Parser_Term_typeAscription___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__4; lean_object* l_Lean_Parser_Term_band___elambda__1___closed__3; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__2; lean_object* l_Lean_Parser_Term_explicitBinder___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_and___closed__3; lean_object* l_Lean_Parser_Term_tupleTail___elambda__1___closed__1; @@ -446,6 +453,7 @@ lean_object* l_Lean_Parser_Term_instBinder___closed__3; lean_object* l_Lean_Parser_Term_nativeRefl___elambda__1___closed__6; lean_object* l_Lean_Parser_Term_and; lean_object* l_Lean_Parser_Term_gt___elambda__1(lean_object*, lean_object*); +lean_object* l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2; lean_object* l_Lean_Parser_Term_bracketedDoSeq___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_suffices___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_parenSpecial___closed__1; @@ -471,6 +479,7 @@ lean_object* l_Lean_Parser_Term_bracktedBinder___elambda__1(lean_object*, lean_o lean_object* l_Lean_Parser_Term_forall___elambda__1___closed__13; lean_object* l_Lean_Parser_Term_anonymousCtor___closed__9; lean_object* l_Lean_Parser_Term_sorry___closed__1; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1; lean_object* l_Lean_Parser_Term_structInst___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_let_x21___closed__6; lean_object* l_Lean_Parser_Term_ge___elambda__1___closed__4; @@ -525,6 +534,7 @@ lean_object* l_Lean_Parser_Term_uminus___closed__7; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_matchAlts___elambda__1___spec__2___closed__4; lean_object* l_Lean_Parser_Term_suffices___elambda__1___closed__7; lean_object* l_Lean_Parser_Term_anonymousCtor___elambda__1___closed__8; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_borrowed; lean_object* l_Lean_Parser_Term_and___closed__1; lean_object* l_Lean_Parser_Term_paren___closed__7; @@ -579,12 +589,14 @@ lean_object* l_Lean_Parser_Term_str; lean_object* l_Lean_Parser_Term_decide___closed__5; lean_object* l_Lean_Parser_Term_structInstLVal___closed__5; lean_object* l_Lean_Parser_Term_binderTactic___elambda__1___closed__2; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_depArrow___closed__8; lean_object* l_Lean_Parser_Term_dollarProj___elambda__1___closed__3; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_listLit___elambda__1___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_nativeDecide___elambda__1___closed__6; lean_object* l___regBuiltinParser_Lean_Parser_Term_sorry(lean_object*); lean_object* l_Lean_Parser_Term_nomatch___closed__4; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4; lean_object* l_Lean_Parser_Term_or___elambda__1___closed__2; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Tactic_seq___elambda__1___spec__2___closed__3; lean_object* l_Lean_Parser_Term_listLit___elambda__1(lean_object*, lean_object*); @@ -640,6 +652,7 @@ lean_object* l_Lean_Parser_Term_num___closed__2; lean_object* l_Lean_Parser_Term_typeAscription___elambda__1___closed__5; lean_object* l_Lean_Parser_Term_binderDefault; lean_object* l_Lean_Parser_Term_namedPattern___elambda__1___closed__5; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1; lean_object* l_Lean_Parser_Term_fun___elambda__1___closed__9; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_matchAlts___elambda__1___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_uminus___elambda__1___closed__1; @@ -829,6 +842,7 @@ lean_object* l___regBuiltinParser_Lean_Parser_Term_dollar(lean_object*); lean_object* l_Lean_Parser_Term_explicitUniv___closed__5; lean_object* l_Lean_Parser_Term_let___closed__6; lean_object* l_Lean_Parser_Term_byTactic___elambda__1___closed__6; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__6; lean_object* l_Lean_Parser_Term_lt___closed__2; lean_object* l_Lean_Parser_Term_sorry___closed__3; lean_object* l_Lean_Parser_Term_instBinder___elambda__1___closed__2; @@ -873,6 +887,7 @@ lean_object* l_Lean_Parser_Term_bnot___closed__5; lean_object* l_Lean_Parser_Term_structInstField___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_paren___closed__4; uint8_t l_Lean_Parser_tryAnti(lean_object*, lean_object*); +lean_object* l_Lean_Parser_Term_funBinderStxQuot; lean_object* l_Lean_Parser_Term_mul; lean_object* l_Lean_Parser_Term_ge___elambda__1___closed__1; lean_object* l_Lean_Parser_Term_quotedName; @@ -912,6 +927,7 @@ lean_object* l_Lean_Parser_Term_explicitUniv___closed__3; lean_object* l___regBuiltinParser_Lean_Parser_Term_bne(lean_object*); lean_object* l___regBuiltinParser_Lean_Parser_Term_inaccessible(lean_object*); lean_object* l_Lean_Parser_Term_depArrow___closed__2; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4; lean_object* l_Lean_Parser_Term_structInst___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_explicitUniv___elambda__1___closed__13; lean_object* l_Lean_Parser_Term_andM___closed__1; @@ -1210,6 +1226,7 @@ lean_object* l_Lean_Parser_Term_sorry___elambda__1___closed__6; lean_object* l_Lean_Parser_Term_haveAssign___elambda__1___closed__8; lean_object* l_Lean_Parser_Term_num___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_and___closed__2; +lean_object* l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot(lean_object*); lean_object* l_Lean_Parser_Term_prop___closed__4; lean_object* l___regBuiltinParser_Lean_Parser_Term_mul(lean_object*); lean_object* l_Lean_Parser_Term_leftArrow___elambda__1___closed__8; @@ -1221,6 +1238,7 @@ lean_object* l_Lean_Parser_Term_binderType___elambda__2(lean_object*, lean_objec lean_object* l_Lean_Parser_Term_bracketedDoSeq___closed__2; lean_object* l_Lean_Parser_Term_andthen; lean_object* l_Lean_Parser_Term_matchAlt___closed__11; +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_or___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_mapConst___closed__3; lean_object* l_Lean_Parser_Term_doPat___closed__9; @@ -1263,6 +1281,7 @@ lean_object* l_Lean_Parser_sepBy1Fn___at_Lean_Parser_Term_matchAlts___elambda__1 lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_matchAlts___elambda__1___spec__16(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_borrowed___elambda__1___closed__9; lean_object* l_Lean_Parser_Term_typeAscription___closed__3; +extern lean_object* l_Lean_Parser_Level_paren___closed__4; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_matchAlts___elambda__1___spec__2___closed__5; lean_object* l_Lean_Parser_Term_have___closed__10; lean_object* l_Lean_Parser_Term_depArrow___elambda__1___closed__15; @@ -1474,6 +1493,7 @@ lean_object* l_Lean_Parser_Term_structInstLVal___closed__4; lean_object* l_Lean_Parser_Term_matchAlt; lean_object* l_Lean_Parser_Term_or___closed__3; lean_object* l_Lean_Parser_Term_inaccessible___elambda__1___closed__2; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__4; lean_object* l_Lean_Parser_sepBy1Fn___at_Lean_Parser_Term_subst___elambda__1___spec__1(uint8_t, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_binderDefault___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_nomatch___closed__2; @@ -1664,6 +1684,7 @@ lean_object* l_Lean_Parser_Term_subtype___closed__10; lean_object* l_Lean_Parser_Term_append___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_tupleTail___closed__2; lean_object* l_Lean_Parser_Term_structInstLVal___closed__11; +lean_object* l_Lean_Parser_Term_levelStxQuot___closed__1; lean_object* l_Lean_Parser_Term_dollar___closed__4; lean_object* l___regBuiltinParser_Lean_Parser_Term_decide(lean_object*); lean_object* l_Lean_Parser_Term_arrayRef___closed__1; @@ -1672,6 +1693,7 @@ lean_object* l_Lean_Parser_Term_nativeRefl___elambda__1___closed__1; lean_object* l_Lean_Parser_dollarSymbol___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_mapConst___elambda__1___closed__1; lean_object* l_Lean_Parser_Term_map___closed__2; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__5; lean_object* l_Lean_Parser_Term_or; lean_object* l_Lean_Parser_Term_orM___elambda__1(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_unicodeSymbolFn___closed__1; @@ -1691,12 +1713,14 @@ lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__1; lean_object* l_Lean_Parser_Term_structInstField___closed__5; lean_object* l_Lean_Parser_Term_matchAlts___closed__2; lean_object* l_Lean_Parser_Term_doPat___elambda__1___closed__6; +lean_object* l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1; lean_object* l_Lean_Parser_Term_append; lean_object* l_Lean_Parser_Term_letIdLhs___closed__6; lean_object* l_Lean_Parser_Term_borrowed___elambda__1___closed__2; lean_object* l_Lean_Parser_Tactic_seq___elambda__1___closed__4; lean_object* l_Lean_Parser_Term_not___closed__1; lean_object* l_Lean_Parser_Term_uminus___closed__1; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___closed__3; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Tactic_seq___elambda__1___spec__2(uint8_t, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_map___closed__1; lean_object* l_Lean_Parser_Term_doLet___elambda__1___closed__1; @@ -1710,6 +1734,7 @@ lean_object* l_Lean_Parser_Term_gt; lean_object* l_Lean_Parser_Term_doExpr___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_tparser_x21___closed__2; lean_object* l_Lean_Parser_Term_matchAlts___boxed(lean_object*); +lean_object* l_Lean_Parser_Term_levelStxQuot___closed__3; lean_object* l_Lean_Parser_Term_not___closed__4; lean_object* l_Lean_Parser_Term_subst___closed__1; lean_object* l_Lean_Parser_Term_beq___elambda__1___closed__3; @@ -1824,6 +1849,7 @@ lean_object* l_Lean_Parser_Term_inaccessible___elambda__1___closed__6; lean_object* l_Lean_Parser_Tactic_seq___closed__1; lean_object* l_Lean_Parser_nameLit___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_tacticBlock___closed__6; +lean_object* l_Lean_Parser_Term_levelStxQuot; lean_object* l_Lean_Parser_Term_equiv___elambda__1___closed__4; lean_object* l_Lean_Parser_Term_letPatDecl___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_letIdDecl___closed__8; @@ -1861,6 +1887,7 @@ lean_object* l_Lean_Parser_Term_match__syntax___elambda__1___closed__7; lean_object* l___regBuiltinParser_Lean_Parser_Term_arrow(lean_object*); lean_object* l_Lean_Parser_Term_modN___closed__3; lean_object* l___regBuiltinParser_Lean_Parser_Term_sortApp(lean_object*); +lean_object* l_Lean_Parser_Term_levelStxQuot___closed__4; lean_object* l_Lean_Parser_Term_typeAscription___closed__6; lean_object* l___private_Init_Lean_Parser_Parser_2__sepByFnAux___main___at_Lean_Parser_Term_explicitUniv___elambda__1___spec__2___closed__3; lean_object* l_Lean_Parser_Term_lt; @@ -1880,6 +1907,7 @@ lean_object* l_Lean_Parser_Term_depArrow___elambda__1___closed__12; lean_object* l_Lean_Parser_sepBy1Fn___at_Lean_Parser_Term_explicitUniv___elambda__1___spec__1(uint8_t, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_seqRight___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_funBinder___closed__4; +lean_object* l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2; lean_object* l___regBuiltinParser_Lean_Parser_Term_match(lean_object*); lean_object* l___regBuiltinParser_Lean_Parser_Term_depArrow(lean_object*); lean_object* l_Lean_Parser_Term_simpleBinder___elambda__1___closed__3; @@ -1938,6 +1966,7 @@ lean_object* l_Lean_Parser_regBuiltinTacticParserAttr___closed__4; lean_object* l_Lean_Parser_Term_mapConstRev___closed__2; lean_object* l_Lean_Parser_Term_structInst___elambda__1___closed__7; lean_object* l_Lean_Parser_Term_tupleTail___closed__4; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5; lean_object* l_Lean_Parser_Term_nativeRefl___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_orelse___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_gt___closed__3; @@ -1992,6 +2021,7 @@ lean_object* l_Lean_Parser_Term_binderIdent___elambda__1(lean_object*, lean_obje lean_object* l_Lean_Parser_Term_char___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_borrowed___elambda__1___closed__6; lean_object* l___regBuiltinParser_Lean_Parser_Term_borrowed(lean_object*); +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3; lean_object* l_Lean_Parser_Term_depArrow___elambda__1___closed__11; lean_object* l_Lean_Parser_Term_let_x21___elambda__1___closed__2; lean_object* l_Lean_Parser_Term_structInst___elambda__1___closed__4; @@ -2079,6 +2109,7 @@ lean_object* l_Lean_Parser_Term_unicodeInfixL___elambda__1(lean_object*, lean_ob lean_object* l_Lean_Parser_Term_nativeRefl___elambda__1___closed__9; lean_object* l_Lean_Parser_Term_subtype___closed__11; lean_object* l_Lean_Parser_unicodeSymbolFnAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Parser_Term_levelStxQuot___closed__2; lean_object* l_Lean_Parser_Term_forall___elambda__1___closed__7; lean_object* l_Lean_Parser_Term_namedArgument___closed__4; lean_object* l_Lean_Parser_Term_dollar___closed__2; @@ -2096,6 +2127,7 @@ lean_object* l_Lean_Parser_Term_bnot___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_sepBy1Fn___at_Lean_Parser_Term_matchAlts___elambda__1___spec__15___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_let; lean_object* l_Lean_Parser_Term_depArrow___closed__3; +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1(lean_object*, lean_object*); lean_object* l_Lean_Parser_Term_namedHole___closed__1; lean_object* l_Lean_Parser_Term_map; lean_object* l_Lean_Parser_Term_unicodeInfixR(lean_object*, lean_object*, lean_object*); @@ -50904,6 +50936,618 @@ x_6 = l_Lean_Parser_addBuiltinParser(x_2, x_3, x_4, x_5, x_1); return x_6; } } +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("`(level|"); +return x_1; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1; +x_2 = l_String_trim(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Char_HasRepr___closed__1; +x_2 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2; +x_3 = lean_string_append(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3; +x_2 = l_Char_HasRepr___closed__1; +x_3 = lean_string_append(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4; +x_3 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_3, 0, x_2); +lean_ctor_set(x_3, 1, x_1); +return x_3; +} +} +lean_object* l_Lean_Parser_Term_levelStxQuot___elambda__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_3 = lean_ctor_get(x_2, 0); +lean_inc(x_3); +x_4 = lean_array_get_size(x_3); +lean_dec(x_3); +x_38 = lean_ctor_get(x_2, 1); +lean_inc(x_38); +lean_inc(x_1); +x_39 = l_Lean_Parser_tokenFn(x_1, x_2); +x_40 = lean_ctor_get(x_39, 3); +lean_inc(x_40); +if (lean_obj_tag(x_40) == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_39, 0); +lean_inc(x_41); +x_42 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_41); +lean_dec(x_41); +if (lean_obj_tag(x_42) == 2) +{ +lean_object* x_43; lean_object* x_44; uint8_t x_45; +x_43 = lean_ctor_get(x_42, 1); +lean_inc(x_43); +lean_dec(x_42); +x_44 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2; +x_45 = lean_string_dec_eq(x_43, x_44); +lean_dec(x_43); +if (x_45 == 0) +{ +lean_object* x_46; lean_object* x_47; +x_46 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5; +x_47 = l_Lean_Parser_ParserState_mkErrorsAt(x_39, x_46, x_38); +x_5 = x_47; +goto block_37; +} +else +{ +lean_dec(x_38); +x_5 = x_39; +goto block_37; +} +} +else +{ +lean_object* x_48; lean_object* x_49; +lean_dec(x_42); +x_48 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5; +x_49 = l_Lean_Parser_ParserState_mkErrorsAt(x_39, x_48, x_38); +x_5 = x_49; +goto block_37; +} +} +else +{ +lean_object* x_50; lean_object* x_51; +lean_dec(x_40); +x_50 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5; +x_51 = l_Lean_Parser_ParserState_mkErrorsAt(x_39, x_50, x_38); +x_5 = x_51; +goto block_37; +} +block_37: +{ +lean_object* x_6; +x_6 = lean_ctor_get(x_5, 3); +lean_inc(x_6); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_7 = l_Lean_Parser_regBuiltinLevelParserAttr___closed__4; +x_8 = lean_unsigned_to_nat(0u); +lean_inc(x_1); +x_9 = l_Lean_Parser_categoryParser___elambda__1(x_7, x_8, x_1, x_5); +x_10 = lean_ctor_get(x_9, 3); +lean_inc(x_10); +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_9, 1); +lean_inc(x_11); +x_12 = l_Lean_Parser_tokenFn(x_1, x_9); +x_13 = lean_ctor_get(x_12, 3); +lean_inc(x_13); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_12, 0); +lean_inc(x_14); +x_15 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_14); +lean_dec(x_14); +if (lean_obj_tag(x_15) == 2) +{ +lean_object* x_16; lean_object* x_17; uint8_t x_18; +x_16 = lean_ctor_get(x_15, 1); +lean_inc(x_16); +lean_dec(x_15); +x_17 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__4; +x_18 = lean_string_dec_eq(x_16, x_17); +lean_dec(x_16); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_20 = l_Lean_Parser_ParserState_mkErrorsAt(x_12, x_19, x_11); +x_21 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_22 = l_Lean_Parser_ParserState_mkNode(x_20, x_21, x_4); +return x_22; +} +else +{ +lean_object* x_23; lean_object* x_24; +lean_dec(x_11); +x_23 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_24 = l_Lean_Parser_ParserState_mkNode(x_12, x_23, x_4); +return x_24; +} +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_dec(x_15); +x_25 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_26 = l_Lean_Parser_ParserState_mkErrorsAt(x_12, x_25, x_11); +x_27 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_28 = l_Lean_Parser_ParserState_mkNode(x_26, x_27, x_4); +return x_28; +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +lean_dec(x_13); +x_29 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_30 = l_Lean_Parser_ParserState_mkErrorsAt(x_12, x_29, x_11); +x_31 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_32 = l_Lean_Parser_ParserState_mkNode(x_30, x_31, x_4); +return x_32; +} +} +else +{ +lean_object* x_33; lean_object* x_34; +lean_dec(x_10); +lean_dec(x_1); +x_33 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_34 = l_Lean_Parser_ParserState_mkNode(x_9, x_33, x_4); +return x_34; +} +} +else +{ +lean_object* x_35; lean_object* x_36; +lean_dec(x_6); +lean_dec(x_1); +x_35 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_36 = l_Lean_Parser_ParserState_mkNode(x_5, x_35, x_4); +return x_36; +} +} +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2; +x_2 = l_Lean_Parser_Level_paren___closed__1; +x_3 = l_Lean_Parser_symbolInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_levelStxQuot___closed__1; +x_2 = l_Lean_Parser_Level_paren___closed__4; +x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_2 = l_Lean_Parser_Term_levelStxQuot___closed__2; +x_3 = l_Lean_Parser_nodeInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___closed__4() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Parser_Term_levelStxQuot___elambda__1), 2, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Parser_Term_levelStxQuot___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_levelStxQuot___closed__3; +x_2 = l_Lean_Parser_Term_levelStxQuot___closed__4; +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_Term_levelStxQuot() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Parser_Term_levelStxQuot___closed__5; +return x_1; +} +} +lean_object* _init_l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("levelStxQuot"); +return x_1; +} +} +lean_object* _init_l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_mkAppStx___closed__6; +x_2 = l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l___regBuiltinParser_Lean_Parser_Term_levelStxQuot(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; lean_object* x_5; lean_object* x_6; +x_2 = l_Lean_Parser_termParser___closed__2; +x_3 = l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2; +x_4 = 1; +x_5 = l_Lean_Parser_Term_levelStxQuot; +x_6 = l_Lean_Parser_addBuiltinParser(x_2, x_3, x_4, x_5, x_1); +return x_6; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("`(funBinder|"); +return x_1; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1; +x_2 = l_String_trim(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Char_HasRepr___closed__1; +x_2 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2; +x_3 = lean_string_append(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3; +x_2 = l_Char_HasRepr___closed__1; +x_3 = lean_string_append(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4; +x_3 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_3, 0, x_2); +lean_ctor_set(x_3, 1, x_1); +return x_3; +} +} +lean_object* l_Lean_Parser_Term_funBinderStxQuot___elambda__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_3 = lean_ctor_get(x_2, 0); +lean_inc(x_3); +x_4 = lean_array_get_size(x_3); +lean_dec(x_3); +x_36 = lean_ctor_get(x_2, 1); +lean_inc(x_36); +lean_inc(x_1); +x_37 = l_Lean_Parser_tokenFn(x_1, x_2); +x_38 = lean_ctor_get(x_37, 3); +lean_inc(x_38); +if (lean_obj_tag(x_38) == 0) +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_37, 0); +lean_inc(x_39); +x_40 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_39); +lean_dec(x_39); +if (lean_obj_tag(x_40) == 2) +{ +lean_object* x_41; lean_object* x_42; uint8_t x_43; +x_41 = lean_ctor_get(x_40, 1); +lean_inc(x_41); +lean_dec(x_40); +x_42 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2; +x_43 = lean_string_dec_eq(x_41, x_42); +lean_dec(x_41); +if (x_43 == 0) +{ +lean_object* x_44; lean_object* x_45; +x_44 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5; +x_45 = l_Lean_Parser_ParserState_mkErrorsAt(x_37, x_44, x_36); +x_5 = x_45; +goto block_35; +} +else +{ +lean_dec(x_36); +x_5 = x_37; +goto block_35; +} +} +else +{ +lean_object* x_46; lean_object* x_47; +lean_dec(x_40); +x_46 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5; +x_47 = l_Lean_Parser_ParserState_mkErrorsAt(x_37, x_46, x_36); +x_5 = x_47; +goto block_35; +} +} +else +{ +lean_object* x_48; lean_object* x_49; +lean_dec(x_38); +x_48 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5; +x_49 = l_Lean_Parser_ParserState_mkErrorsAt(x_37, x_48, x_36); +x_5 = x_49; +goto block_35; +} +block_35: +{ +lean_object* x_6; +x_6 = lean_ctor_get(x_5, 3); +lean_inc(x_6); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_inc(x_1); +x_7 = l_Lean_Parser_Term_funBinder___elambda__1(x_1, x_5); +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; +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +x_10 = l_Lean_Parser_tokenFn(x_1, x_7); +x_11 = lean_ctor_get(x_10, 3); +lean_inc(x_11); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_10, 0); +lean_inc(x_12); +x_13 = l_Array_back___at_Lean_Parser_checkStackTopFn___spec__1(x_12); +lean_dec(x_12); +if (lean_obj_tag(x_13) == 2) +{ +lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_14 = lean_ctor_get(x_13, 1); +lean_inc(x_14); +lean_dec(x_13); +x_15 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__4; +x_16 = lean_string_dec_eq(x_14, x_15); +lean_dec(x_14); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_17 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_18 = l_Lean_Parser_ParserState_mkErrorsAt(x_10, x_17, x_9); +x_19 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_20 = l_Lean_Parser_ParserState_mkNode(x_18, x_19, x_4); +return x_20; +} +else +{ +lean_object* x_21; lean_object* x_22; +lean_dec(x_9); +x_21 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_22 = l_Lean_Parser_ParserState_mkNode(x_10, x_21, x_4); +return x_22; +} +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_13); +x_23 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_24 = l_Lean_Parser_ParserState_mkErrorsAt(x_10, x_23, x_9); +x_25 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_26 = l_Lean_Parser_ParserState_mkNode(x_24, x_25, x_4); +return x_26; +} +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +lean_dec(x_11); +x_27 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___elambda__1___closed__7; +x_28 = l_Lean_Parser_ParserState_mkErrorsAt(x_10, x_27, x_9); +x_29 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_30 = l_Lean_Parser_ParserState_mkNode(x_28, x_29, x_4); +return x_30; +} +} +else +{ +lean_object* x_31; lean_object* x_32; +lean_dec(x_8); +lean_dec(x_1); +x_31 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_32 = l_Lean_Parser_ParserState_mkNode(x_7, x_31, x_4); +return x_32; +} +} +else +{ +lean_object* x_33; lean_object* x_34; +lean_dec(x_6); +lean_dec(x_1); +x_33 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_34 = l_Lean_Parser_ParserState_mkNode(x_5, x_33, x_4); +return x_34; +} +} +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2; +x_2 = l_Lean_Parser_Level_paren___closed__1; +x_3 = l_Lean_Parser_symbolInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_Lean_Parser_Term_funBinder; +x_2 = lean_ctor_get(x_1, 0); +lean_inc(x_2); +x_3 = l___private_Init_Lean_Parser_Parser_11__antiquotNestedExpr___closed__3; +x_4 = l_Lean_Parser_andthenInfo(x_2, x_3); +return x_4; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___closed__1; +x_2 = l_Lean_Parser_Term_funBinderStxQuot___closed__2; +x_3 = l_Lean_Parser_andthenInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_tacticStxQuot___elambda__1___closed__2; +x_2 = l_Lean_Parser_Term_funBinderStxQuot___closed__3; +x_3 = l_Lean_Parser_nodeInfo(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__5() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Parser_Term_funBinderStxQuot___elambda__1), 2, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Parser_Term_funBinderStxQuot___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___closed__4; +x_2 = l_Lean_Parser_Term_funBinderStxQuot___closed__5; +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_Term_funBinderStxQuot() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Parser_Term_funBinderStxQuot___closed__6; +return x_1; +} +} +lean_object* _init_l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("funBinderStxQuot"); +return x_1; +} +} +lean_object* _init_l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_mkAppStx___closed__6; +x_2 = l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; lean_object* x_5; lean_object* x_6; +x_2 = l_Lean_Parser_termParser___closed__2; +x_3 = l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2; +x_4 = 1; +x_5 = l_Lean_Parser_Term_funBinderStxQuot; +x_6 = l_Lean_Parser_addBuiltinParser(x_2, x_3, x_4, x_5, x_1); +return x_6; +} +} lean_object* initialize_Init_Lean_Parser_Parser(lean_object*); lean_object* initialize_Init_Lean_Parser_Level(lean_object*); static bool _G_initialized = false; @@ -54535,6 +55179,66 @@ lean_mark_persistent(l___regBuiltinParser_Lean_Parser_Term_tacticStxQuot___close res = l___regBuiltinParser_Lean_Parser_Term_tacticStxQuot(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1 = _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__1); +l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2 = _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__2); +l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3 = _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__3); +l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4 = _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__4); +l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5 = _init_l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___elambda__1___closed__5); +l_Lean_Parser_Term_levelStxQuot___closed__1 = _init_l_Lean_Parser_Term_levelStxQuot___closed__1(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___closed__1); +l_Lean_Parser_Term_levelStxQuot___closed__2 = _init_l_Lean_Parser_Term_levelStxQuot___closed__2(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___closed__2); +l_Lean_Parser_Term_levelStxQuot___closed__3 = _init_l_Lean_Parser_Term_levelStxQuot___closed__3(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___closed__3); +l_Lean_Parser_Term_levelStxQuot___closed__4 = _init_l_Lean_Parser_Term_levelStxQuot___closed__4(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___closed__4); +l_Lean_Parser_Term_levelStxQuot___closed__5 = _init_l_Lean_Parser_Term_levelStxQuot___closed__5(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot___closed__5); +l_Lean_Parser_Term_levelStxQuot = _init_l_Lean_Parser_Term_levelStxQuot(); +lean_mark_persistent(l_Lean_Parser_Term_levelStxQuot); +l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1 = _init_l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1(); +lean_mark_persistent(l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__1); +l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2 = _init_l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2(); +lean_mark_persistent(l___regBuiltinParser_Lean_Parser_Term_levelStxQuot___closed__2); +res = l___regBuiltinParser_Lean_Parser_Term_levelStxQuot(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1 = _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__1); +l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2 = _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__2); +l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3 = _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__3); +l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4 = _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__4); +l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5 = _init_l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___elambda__1___closed__5); +l_Lean_Parser_Term_funBinderStxQuot___closed__1 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__1(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__1); +l_Lean_Parser_Term_funBinderStxQuot___closed__2 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__2(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__2); +l_Lean_Parser_Term_funBinderStxQuot___closed__3 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__3(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__3); +l_Lean_Parser_Term_funBinderStxQuot___closed__4 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__4(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__4); +l_Lean_Parser_Term_funBinderStxQuot___closed__5 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__5(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__5); +l_Lean_Parser_Term_funBinderStxQuot___closed__6 = _init_l_Lean_Parser_Term_funBinderStxQuot___closed__6(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot___closed__6); +l_Lean_Parser_Term_funBinderStxQuot = _init_l_Lean_Parser_Term_funBinderStxQuot(); +lean_mark_persistent(l_Lean_Parser_Term_funBinderStxQuot); +l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1 = _init_l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1(); +lean_mark_persistent(l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__1); +l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2 = _init_l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2(); +lean_mark_persistent(l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot___closed__2); +res = l___regBuiltinParser_Lean_Parser_Term_funBinderStxQuot(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/Init/Lean/Util/Recognizers.c b/stage0/stdlib/Init/Lean/Util/Recognizers.c new file mode 100644 index 0000000000..b65e9b9c14 --- /dev/null +++ b/stage0/stdlib/Init/Lean/Util/Recognizers.c @@ -0,0 +1,755 @@ +// Lean compiler output +// Module: Init.Lean.Util.Recognizers +// Imports: Init.Lean.Expr +#include "runtime/lean.h" +#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_List_reverse___rarg(lean_object*); +lean_object* l_Lean_Expr_eq_x3f___closed__1; +lean_object* l_Lean_Expr_prod_x3f___closed__2; +lean_object* l_Lean_Expr_iff_x3f(lean_object*); +lean_object* l_Lean_Expr_eq_x3f___closed__2; +lean_object* l_Lean_Expr_eq_x3f___boxed(lean_object*); +lean_object* l_Lean_Expr_appFn_x21(lean_object*); +lean_object* l_Lean_Expr_listLitAux___main___closed__5; +lean_object* l_Lean_Expr_app4_x3f(lean_object*, lean_object*); +lean_object* l_Lean_Expr_appArg_x21(lean_object*); +lean_object* l_Lean_Expr_listLit_x3f(lean_object*); +lean_object* l_Lean_Expr_heq_x3f___closed__2; +lean_object* l_Lean_Expr_iff_x3f___closed__2; +lean_object* l_Lean_Expr_heq_x3f(lean_object*); +lean_object* l_Lean_Expr_app4_x3f___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Expr_eq_x3f(lean_object*); +lean_object* l_Lean_Expr_iff_x3f___boxed(lean_object*); +lean_object* lean_name_mk_string(lean_object*, lean_object*); +lean_object* l_Lean_Expr_app3_x3f___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Expr_iff_x3f___closed__1; +lean_object* l_Lean_Expr_app2_x3f(lean_object*, lean_object*); +lean_object* l_Lean_Expr_listLitAux(lean_object*, lean_object*); +lean_object* l_Lean_Expr_listLitAux___main___closed__4; +uint8_t l_Lean_Expr_isAppOfArity___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_listLitAux___main(lean_object*, lean_object*); +lean_object* l_Lean_Expr_app3_x3f(lean_object*, lean_object*); +lean_object* l_Lean_Expr_heq_x3f___closed__1; +lean_object* l_Lean_Expr_heq_x3f___boxed(lean_object*); +lean_object* l_Lean_Expr_app1_x3f___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Expr_app2_x3f___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Expr_listLitAux___main___closed__6; +lean_object* l_Lean_Expr_arrow_x3f(lean_object*); +lean_object* l_Lean_Expr_listLitAux___main___closed__2; +lean_object* l_Lean_Expr_app1_x3f(lean_object*, lean_object*); +lean_object* l_Lean_Expr_arrayLit_x3f___closed__1; +lean_object* l_Lean_Expr_arrayLit_x3f___boxed(lean_object*); +lean_object* l_Lean_Expr_arrayLit_x3f(lean_object*); +uint8_t l_Lean_Expr_hasLooseBVars(lean_object*); +lean_object* l_Lean_Expr_arrow_x3f___boxed(lean_object*); +lean_object* l_Lean_Expr_prod_x3f___closed__1; +lean_object* l_Lean_Expr_arrayLit_x3f___closed__2; +lean_object* l_Lean_Expr_prod_x3f(lean_object*); +lean_object* l_Lean_Expr_prod_x3f___boxed(lean_object*); +lean_object* l_Lean_Expr_listLitAux___main___closed__3; +lean_object* l_Lean_Expr_listLitAux___main___closed__1; +lean_object* l_Lean_Expr_app1_x3f(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = lean_unsigned_to_nat(1u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +return x_5; +} +else +{ +lean_object* x_6; lean_object* x_7; +x_6 = l_Lean_Expr_appArg_x21(x_1); +x_7 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_7, 0, x_6); +return x_7; +} +} +} +lean_object* l_Lean_Expr_app1_x3f___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_app1_x3f(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* l_Lean_Expr_app2_x3f(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = lean_unsigned_to_nat(2u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +return x_5; +} +else +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_8 = l_Lean_Expr_appArg_x21(x_1); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_7); +lean_ctor_set(x_9, 1, x_8); +x_10 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_10, 0, x_9); +return x_10; +} +} +} +lean_object* l_Lean_Expr_app2_x3f___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_app2_x3f(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* l_Lean_Expr_app3_x3f(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = lean_unsigned_to_nat(3u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +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; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appFn_x21(x_6); +x_8 = l_Lean_Expr_appArg_x21(x_7); +lean_dec(x_7); +x_9 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_10 = l_Lean_Expr_appArg_x21(x_1); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_9); +lean_ctor_set(x_11, 1, x_10); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_8); +lean_ctor_set(x_12, 1, x_11); +x_13 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_13, 0, x_12); +return x_13; +} +} +} +lean_object* l_Lean_Expr_app3_x3f___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_app3_x3f(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* l_Lean_Expr_app4_x3f(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; uint8_t x_4; +x_3 = lean_unsigned_to_nat(4u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +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; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appFn_x21(x_6); +x_8 = l_Lean_Expr_appFn_x21(x_7); +x_9 = l_Lean_Expr_appArg_x21(x_8); +lean_dec(x_8); +x_10 = l_Lean_Expr_appArg_x21(x_7); +lean_dec(x_7); +x_11 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_12 = l_Lean_Expr_appArg_x21(x_1); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_11); +lean_ctor_set(x_13, 1, x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_10); +lean_ctor_set(x_14, 1, x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_9); +lean_ctor_set(x_15, 1, x_14); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +return x_16; +} +} +} +lean_object* l_Lean_Expr_app4_x3f___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_app4_x3f(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_eq_x3f___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("Eq"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_eq_x3f___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Expr_eq_x3f___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_eq_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; +x_2 = l_Lean_Expr_eq_x3f___closed__2; +x_3 = lean_unsigned_to_nat(3u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +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; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appFn_x21(x_6); +x_8 = l_Lean_Expr_appArg_x21(x_7); +lean_dec(x_7); +x_9 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_10 = l_Lean_Expr_appArg_x21(x_1); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_9); +lean_ctor_set(x_11, 1, x_10); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_8); +lean_ctor_set(x_12, 1, x_11); +x_13 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_13, 0, x_12); +return x_13; +} +} +} +lean_object* l_Lean_Expr_eq_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_eq_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Expr_iff_x3f___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("Iff"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_iff_x3f___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Expr_iff_x3f___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_iff_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; +x_2 = l_Lean_Expr_iff_x3f___closed__2; +x_3 = lean_unsigned_to_nat(2u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +return x_5; +} +else +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_8 = l_Lean_Expr_appArg_x21(x_1); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_7); +lean_ctor_set(x_9, 1, x_8); +x_10 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_10, 0, x_9); +return x_10; +} +} +} +lean_object* l_Lean_Expr_iff_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_iff_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Expr_heq_x3f___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("HEq"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_heq_x3f___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Expr_heq_x3f___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_heq_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; +x_2 = l_Lean_Expr_heq_x3f___closed__2; +x_3 = lean_unsigned_to_nat(4u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +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; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appFn_x21(x_6); +x_8 = l_Lean_Expr_appFn_x21(x_7); +x_9 = l_Lean_Expr_appArg_x21(x_8); +lean_dec(x_8); +x_10 = l_Lean_Expr_appArg_x21(x_7); +lean_dec(x_7); +x_11 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_12 = l_Lean_Expr_appArg_x21(x_1); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_11); +lean_ctor_set(x_13, 1, x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_10); +lean_ctor_set(x_14, 1, x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_9); +lean_ctor_set(x_15, 1, x_14); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +return x_16; +} +} +} +lean_object* l_Lean_Expr_heq_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_heq_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* l_Lean_Expr_arrow_x3f(lean_object* x_1) { +_start: +{ +if (lean_obj_tag(x_1) == 7) +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; +x_2 = lean_ctor_get(x_1, 1); +x_3 = lean_ctor_get(x_1, 2); +x_4 = l_Lean_Expr_hasLooseBVars(x_3); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; +lean_inc(x_3); +lean_inc(x_2); +x_5 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_5, 0, x_2); +lean_ctor_set(x_5, 1, x_3); +x_6 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_6, 0, x_5); +return x_6; +} +else +{ +lean_object* x_7; +x_7 = lean_box(0); +return x_7; +} +} +else +{ +lean_object* x_8; +x_8 = lean_box(0); +return x_8; +} +} +} +lean_object* l_Lean_Expr_arrow_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_arrow_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("List"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Expr_listLitAux___main___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__3() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("nil"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Expr_listLitAux___main___closed__2; +x_2 = l_Lean_Expr_listLitAux___main___closed__3; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__5() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("cons"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_listLitAux___main___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Expr_listLitAux___main___closed__2; +x_2 = l_Lean_Expr_listLitAux___main___closed__5; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_listLitAux___main(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_Expr_listLitAux___main___closed__4; +x_4 = lean_unsigned_to_nat(1u); +x_5 = l_Lean_Expr_isAppOfArity___main(x_1, x_3, x_4); +if (x_5 == 0) +{ +lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_6 = l_Lean_Expr_listLitAux___main___closed__6; +x_7 = lean_unsigned_to_nat(3u); +x_8 = l_Lean_Expr_isAppOfArity___main(x_1, x_6, x_7); +if (x_8 == 0) +{ +lean_object* x_9; +lean_dec(x_2); +lean_dec(x_1); +x_9 = lean_box(0); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = l_Lean_Expr_appArg_x21(x_1); +x_11 = l_Lean_Expr_appFn_x21(x_1); +lean_dec(x_1); +x_12 = l_Lean_Expr_appArg_x21(x_11); +lean_dec(x_11); +x_13 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_2); +x_1 = x_10; +x_2 = x_13; +goto _start; +} +} +else +{ +lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_15 = l_List_reverse___rarg(x_2); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +return x_16; +} +} +} +lean_object* l_Lean_Expr_listLitAux(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_listLitAux___main(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_listLit_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = lean_box(0); +x_3 = l_Lean_Expr_listLitAux___main(x_1, x_2); +return x_3; +} +} +lean_object* _init_l_Lean_Expr_arrayLit_x3f___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("toArray"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_arrayLit_x3f___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Expr_listLitAux___main___closed__2; +x_2 = l_Lean_Expr_arrayLit_x3f___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_arrayLit_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = l_Lean_Expr_arrayLit_x3f___closed__2; +x_9 = lean_unsigned_to_nat(2u); +x_10 = l_Lean_Expr_isAppOfArity___main(x_1, x_8, x_9); +if (x_10 == 0) +{ +lean_object* x_11; +x_11 = lean_box(0); +x_2 = x_11; +goto block_7; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_12 = l_Lean_Expr_appFn_x21(x_1); +x_13 = l_Lean_Expr_appArg_x21(x_12); +lean_dec(x_12); +x_14 = l_Lean_Expr_appArg_x21(x_1); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +x_16 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_16, 0, x_15); +x_2 = x_16; +goto block_7; +} +block_7: +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +x_3 = lean_box(0); +return x_3; +} +else +{ +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 = lean_ctor_get(x_4, 1); +lean_inc(x_5); +lean_dec(x_4); +x_6 = l_Lean_Expr_listLit_x3f(x_5); +return x_6; +} +} +} +} +lean_object* l_Lean_Expr_arrayLit_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_arrayLit_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Expr_prod_x3f___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("Prod"); +return x_1; +} +} +lean_object* _init_l_Lean_Expr_prod_x3f___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Expr_prod_x3f___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_prod_x3f(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; uint8_t x_4; +x_2 = l_Lean_Expr_prod_x3f___closed__2; +x_3 = lean_unsigned_to_nat(2u); +x_4 = l_Lean_Expr_isAppOfArity___main(x_1, x_2, x_3); +if (x_4 == 0) +{ +lean_object* x_5; +x_5 = lean_box(0); +return x_5; +} +else +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = l_Lean_Expr_appFn_x21(x_1); +x_7 = l_Lean_Expr_appArg_x21(x_6); +lean_dec(x_6); +x_8 = l_Lean_Expr_appArg_x21(x_1); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_7); +lean_ctor_set(x_9, 1, x_8); +x_10 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_10, 0, x_9); +return x_10; +} +} +} +lean_object* l_Lean_Expr_prod_x3f___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Expr_prod_x3f(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* initialize_Init_Lean_Expr(lean_object*); +static bool _G_initialized = false; +lean_object* initialize_Init_Lean_Util_Recognizers(lean_object* w) { +lean_object * res; +if (_G_initialized) return lean_mk_io_result(lean_box(0)); +_G_initialized = true; +res = initialize_Init_Lean_Expr(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); +l_Lean_Expr_eq_x3f___closed__1 = _init_l_Lean_Expr_eq_x3f___closed__1(); +lean_mark_persistent(l_Lean_Expr_eq_x3f___closed__1); +l_Lean_Expr_eq_x3f___closed__2 = _init_l_Lean_Expr_eq_x3f___closed__2(); +lean_mark_persistent(l_Lean_Expr_eq_x3f___closed__2); +l_Lean_Expr_iff_x3f___closed__1 = _init_l_Lean_Expr_iff_x3f___closed__1(); +lean_mark_persistent(l_Lean_Expr_iff_x3f___closed__1); +l_Lean_Expr_iff_x3f___closed__2 = _init_l_Lean_Expr_iff_x3f___closed__2(); +lean_mark_persistent(l_Lean_Expr_iff_x3f___closed__2); +l_Lean_Expr_heq_x3f___closed__1 = _init_l_Lean_Expr_heq_x3f___closed__1(); +lean_mark_persistent(l_Lean_Expr_heq_x3f___closed__1); +l_Lean_Expr_heq_x3f___closed__2 = _init_l_Lean_Expr_heq_x3f___closed__2(); +lean_mark_persistent(l_Lean_Expr_heq_x3f___closed__2); +l_Lean_Expr_listLitAux___main___closed__1 = _init_l_Lean_Expr_listLitAux___main___closed__1(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__1); +l_Lean_Expr_listLitAux___main___closed__2 = _init_l_Lean_Expr_listLitAux___main___closed__2(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__2); +l_Lean_Expr_listLitAux___main___closed__3 = _init_l_Lean_Expr_listLitAux___main___closed__3(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__3); +l_Lean_Expr_listLitAux___main___closed__4 = _init_l_Lean_Expr_listLitAux___main___closed__4(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__4); +l_Lean_Expr_listLitAux___main___closed__5 = _init_l_Lean_Expr_listLitAux___main___closed__5(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__5); +l_Lean_Expr_listLitAux___main___closed__6 = _init_l_Lean_Expr_listLitAux___main___closed__6(); +lean_mark_persistent(l_Lean_Expr_listLitAux___main___closed__6); +l_Lean_Expr_arrayLit_x3f___closed__1 = _init_l_Lean_Expr_arrayLit_x3f___closed__1(); +lean_mark_persistent(l_Lean_Expr_arrayLit_x3f___closed__1); +l_Lean_Expr_arrayLit_x3f___closed__2 = _init_l_Lean_Expr_arrayLit_x3f___closed__2(); +lean_mark_persistent(l_Lean_Expr_arrayLit_x3f___closed__2); +l_Lean_Expr_prod_x3f___closed__1 = _init_l_Lean_Expr_prod_x3f___closed__1(); +lean_mark_persistent(l_Lean_Expr_prod_x3f___closed__1); +l_Lean_Expr_prod_x3f___closed__2 = _init_l_Lean_Expr_prod_x3f___closed__2(); +lean_mark_persistent(l_Lean_Expr_prod_x3f___closed__2); +return lean_mk_io_result(lean_box(0)); +} +#ifdef __cplusplus +} +#endif diff --git a/stage0/stdlib/Init/LeanInit.c b/stage0/stdlib/Init/LeanInit.c index 1ce6c48b0a..3fb8033c08 100644 --- a/stage0/stdlib/Init/LeanInit.c +++ b/stage0/stdlib/Init/LeanInit.c @@ -4627,7 +4627,6 @@ x_47 = lean_nat_add(x_46, x_40); lean_dec(x_40); lean_dec(x_46); x_48 = l_Char_ofNat(x_47); -lean_dec(x_47); x_49 = lean_box_uint32(x_48); lean_ctor_set(x_38, 0, x_49); return x_35; @@ -4657,7 +4656,6 @@ x_58 = lean_nat_add(x_57, x_50); lean_dec(x_50); lean_dec(x_57); x_59 = l_Char_ofNat(x_58); -lean_dec(x_58); x_60 = lean_box_uint32(x_59); x_61 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_61, 0, x_60); @@ -4701,7 +4699,6 @@ x_72 = lean_nat_add(x_71, x_63); lean_dec(x_63); lean_dec(x_71); x_73 = l_Char_ofNat(x_72); -lean_dec(x_72); x_74 = lean_box_uint32(x_73); if (lean_is_scalar(x_65)) { x_75 = lean_alloc_ctor(0, 2, 0); @@ -4771,7 +4768,6 @@ x_90 = lean_nat_add(x_89, x_87); lean_dec(x_87); lean_dec(x_89); x_91 = l_Char_ofNat(x_90); -lean_dec(x_90); x_92 = lean_box_uint32(x_91); lean_ctor_set(x_85, 0, x_92); return x_82; @@ -4791,7 +4787,6 @@ x_97 = lean_nat_add(x_96, x_93); lean_dec(x_93); lean_dec(x_96); x_98 = l_Char_ofNat(x_97); -lean_dec(x_97); x_99 = lean_box_uint32(x_98); x_100 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_100, 0, x_99); @@ -4825,7 +4820,6 @@ x_107 = lean_nat_add(x_106, x_102); lean_dec(x_102); lean_dec(x_106); x_108 = l_Char_ofNat(x_107); -lean_dec(x_107); x_109 = lean_box_uint32(x_108); if (lean_is_scalar(x_104)) { x_110 = lean_alloc_ctor(0, 2, 0);