chore: update stage0

This commit is contained in:
Lean stage0 autoupdater 2026-02-03 02:34:19 +00:00
parent c27ea08450
commit 3ad3bacd97
6 changed files with 6498 additions and 6665 deletions

View file

@ -754,14 +754,25 @@ class task_manager {
unique_lock<mutex> lock(m_mutex);
m_idle_std_workers++;
while (true) {
if (m_queues_size == 0 && m_shutting_down) {
break;
if (m_queues_size == 0) {
if (m_shutting_down) {
// We're done
break;
}
// Wait for new tasks
m_queue_cv.wait(lock);
continue;
}
if (m_queues_size == 0 ||
// If we have reached the maximum number of standard workers (because the
// maximum was decreased by `task_get`), wait for someone else to become
// idle before picking up new work.
m_std_workers.size() - m_idle_std_workers >= m_max_std_workers) {
// There's work to be done.
// If we have reached the maximum number of standard workers (because the
// maximum was decreased by `task_get`), wait for someone else to become
// idle before picking up new work.
// But during shutdown, we skip this throttling:
// because the finalizer might have called m_queue_cv.notify_all() for the last
// time, we don't want to get stuck behind the wait().
if (!m_shutting_down &&
m_std_workers.size() - m_idle_std_workers >= m_max_std_workers) {
m_queue_cv.wait(lock);
continue;
}

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -35,13 +35,6 @@ LEAN_EXPORT lean_object* l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutua
LEAN_EXPORT lean_object* l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4___redArg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_List_reverse___redArg(lean_object*);
LEAN_EXPORT lean_object* l_List_mapTR_loop___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__0(lean_object*, lean_object*);
size_t lean_usize_add(size_t, size_t);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(lean_object*, size_t, size_t, lean_object*, lean_object*);
uint8_t lean_usize_dec_eq(size_t, size_t);
lean_object* lean_array_uget(lean_object*, size_t);
uint8_t l_Lean_Elab_DefKind_isTheorem(uint8_t);
lean_object* l_Lean_Meta_markAsRecursive___redArg(lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
static const lean_string_object l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___closed__0_value = {.m_header = {.m_rc = 0, .m_cs_sz = 0, .m_other = 0, .m_tag = 249}, .m_size = 6, .m_capacity = 6, .m_length = 5, .m_data = "trace"};
static const lean_object* l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___closed__0 = (const lean_object*)&l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___closed__0_value;
static const lean_ctor_object l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___closed__1_value = {.m_header = {.m_rc = 0, .m_cs_sz = sizeof(lean_ctor_object) + sizeof(void*)*2 + 8, .m_other = 2, .m_tag = 1}, .m_objs = {((lean_object*)(((size_t)(0) << 1) | 1)),((lean_object*)&l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___closed__0_value),LEAN_SCALAR_PTR_LITERAL(212, 145, 141, 177, 67, 149, 127, 197)}};
@ -52,7 +45,10 @@ LEAN_EXPORT lean_object* l_Lean_Options_set___at___00Lean_Option_set___at___00Le
LEAN_EXPORT lean_object* l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1___boxed(lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1(lean_object*, lean_object*, uint8_t);
LEAN_EXPORT lean_object* l_Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1___boxed(lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
uint8_t lean_usize_dec_eq(size_t, size_t);
lean_object* lean_array_uget(lean_object*, size_t);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
size_t lean_usize_add(size_t, size_t);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(lean_object*, lean_object*, uint8_t, lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
static const lean_closure_object l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__0_value = {.m_header = {.m_rc = 0, .m_cs_sz = sizeof(lean_closure_object) + sizeof(void*)*0, .m_other = 0, .m_tag = 245}, .m_fun = (void*)l_Lean_Elab_Mutual_addPreDefsFromUnary___lam__0___boxed, .m_arity = 1, .m_num_fixed = 0, .m_objs = {} };
@ -62,18 +58,18 @@ static lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__1;
static lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__2;
static lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__3;
extern lean_object* l_Lean_Elab_instInhabitedPreDefinition_default;
lean_object* lean_array_get_borrowed(lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_PreDefinition_filterAttrs(lean_object*, lean_object*);
lean_object* lean_array_to_list(lean_object*);
extern lean_object* l_Lean_allowUnsafeReducibility;
extern lean_object* l_Lean_diagnostics;
extern lean_object* l_Lean_maxRecDepth;
lean_object* l_Lean_Elab_addNonRec___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec___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_array_get_size(lean_object*);
uint8_t lean_nat_dec_lt(lean_object*, lean_object*);
uint8_t lean_nat_dec_le(lean_object*, lean_object*);
size_t lean_usize_of_nat(lean_object*);
lean_object* l_Lean_Kernel_enableDiag(lean_object*, uint8_t);
lean_object* lean_array_get(lean_object*, lean_object*, lean_object*);
extern lean_object* l_Lean_allowUnsafeReducibility;
extern lean_object* l_Lean_diagnostics;
uint8_t l_Lean_Kernel_isDiagnosticsEnabled(lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary___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*);
@ -81,8 +77,6 @@ LEAN_EXPORT lean_object* l_Lean_Elab_enableInfoTree___at___00Lean_Elab_withEnabl
LEAN_EXPORT lean_object* l_Lean_Elab_enableInfoTree___at___00Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4_spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6(lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_eraseRecAppSyntax(lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_abstractNestedProofs(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Mutual_cleanPreDef(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*);
@ -502,81 +496,6 @@ goto _start;
}
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(lean_object* x_1, size_t x_2, size_t x_3, lean_object* x_4, lean_object* x_5) {
_start:
{
lean_object* x_7; lean_object* x_8; uint8_t x_13;
x_13 = lean_usize_dec_eq(x_2, x_3);
if (x_13 == 0)
{
lean_object* x_14; uint8_t x_15; lean_object* x_16; uint8_t x_17;
x_14 = lean_array_uget(x_1, x_2);
x_15 = lean_ctor_get_uint8(x_14, sizeof(void*)*9);
x_16 = lean_ctor_get(x_14, 3);
lean_inc(x_16);
lean_dec(x_14);
x_17 = l_Lean_Elab_DefKind_isTheorem(x_15);
if (x_17 == 0)
{
lean_object* x_18;
x_18 = l_Lean_Meta_markAsRecursive___redArg(x_16, x_5);
if (lean_obj_tag(x_18) == 0)
{
lean_object* x_19;
x_19 = lean_ctor_get(x_18, 0);
lean_inc(x_19);
lean_dec_ref(x_18);
x_7 = x_19;
x_8 = lean_box(0);
goto block_12;
}
else
{
return x_18;
}
}
else
{
lean_object* x_20;
lean_dec(x_16);
x_20 = lean_box(0);
x_7 = x_20;
x_8 = lean_box(0);
goto block_12;
}
}
else
{
lean_object* x_21;
x_21 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_21, 0, x_4);
return x_21;
}
block_12:
{
size_t x_9; size_t x_10;
x_9 = 1;
x_10 = lean_usize_add(x_2, x_9);
x_2 = x_10;
x_4 = x_7;
goto _start;
}
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg___boxed(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; size_t x_8; lean_object* x_9;
x_7 = lean_unbox_usize(x_2);
lean_dec(x_2);
x_8 = lean_unbox_usize(x_3);
lean_dec(x_3);
x_9 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(x_1, x_7, x_8, x_4, x_5);
lean_dec(x_5);
lean_dec_ref(x_1);
return x_9;
}
}
LEAN_EXPORT lean_object* l_Lean_Options_set___at___00Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1_spec__1(lean_object* x_1, lean_object* x_2, uint8_t x_3) {
_start:
{
@ -678,8 +597,9 @@ uint8_t x_15;
x_15 = lean_usize_dec_eq(x_5, x_6);
if (x_15 == 0)
{
lean_object* x_16; lean_object* x_17;
x_16 = lean_array_uget(x_4, x_5);
uint8_t x_16; lean_object* x_17; lean_object* x_18;
x_16 = 1;
x_17 = lean_array_uget(x_4, x_5);
lean_inc(x_13);
lean_inc_ref(x_12);
lean_inc(x_11);
@ -688,17 +608,17 @@ lean_inc(x_9);
lean_inc_ref(x_8);
lean_inc(x_2);
lean_inc_ref(x_1);
x_17 = l_Lean_Elab_addNonRec(x_1, x_16, x_15, x_2, x_3, x_15, x_8, x_9, x_10, x_11, x_12, x_13);
if (lean_obj_tag(x_17) == 0)
x_18 = l_Lean_Elab_addNonRec(x_1, x_17, x_15, x_2, x_3, x_15, x_16, x_8, x_9, x_10, x_11, x_12, x_13);
if (lean_obj_tag(x_18) == 0)
{
lean_object* x_18; size_t x_19; size_t x_20;
x_18 = lean_ctor_get(x_17, 0);
lean_inc(x_18);
lean_dec_ref(x_17);
x_19 = 1;
x_20 = lean_usize_add(x_5, x_19);
x_5 = x_20;
x_7 = x_18;
lean_object* x_19; size_t x_20; size_t x_21;
x_19 = lean_ctor_get(x_18, 0);
lean_inc(x_19);
lean_dec_ref(x_18);
x_20 = 1;
x_21 = lean_usize_add(x_5, x_20);
x_5 = x_21;
x_7 = x_19;
goto _start;
}
else
@ -711,12 +631,12 @@ lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_2);
lean_dec_ref(x_1);
return x_17;
return x_18;
}
}
else
{
lean_object* x_22;
lean_object* x_23;
lean_dec(x_13);
lean_dec_ref(x_12);
lean_dec(x_11);
@ -725,9 +645,9 @@ lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_2);
lean_dec_ref(x_1);
x_22 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_22, 0, x_7);
return x_22;
x_23 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_23, 0, x_7);
return x_23;
}
}
}
@ -777,307 +697,317 @@ return x_2;
LEAN_EXPORT lean_object* l_Lean_Elab_Mutual_addPreDefsFromUnary(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
_start:
{
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; uint8_t x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_77; lean_object* x_78; uint8_t x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; uint8_t x_97; lean_object* x_98; uint8_t x_99; lean_object* x_100; uint8_t x_101; lean_object* x_122; lean_object* x_150; lean_object* x_152; uint8_t x_153;
x_13 = ((lean_object*)(l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__0));
lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; lean_object* x_43; lean_object* x_44; uint8_t x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; 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; uint8_t x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_101; uint8_t x_122;
x_13 = lean_ctor_get(x_4, 3);
x_14 = l_Lean_Elab_instInhabitedPreDefinition_default;
lean_inc_ref(x_4);
x_15 = l_Lean_Elab_PreDefinition_filterAttrs(x_4, x_13);
lean_inc_ref(x_2);
x_16 = lean_array_to_list(x_2);
x_17 = lean_box(0);
x_18 = l_List_mapTR_loop___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__0(x_16, x_17);
x_19 = lean_unsigned_to_nat(0u);
x_152 = lean_array_get_size(x_2);
x_153 = lean_nat_dec_lt(x_19, x_152);
if (x_153 == 0)
x_15 = lean_unsigned_to_nat(0u);
x_16 = lean_array_get_borrowed(x_14, x_2, x_15);
x_17 = lean_ctor_get(x_16, 3);
x_18 = lean_st_ref_get(x_11);
x_19 = lean_ctor_get(x_10, 0);
lean_inc_ref(x_19);
x_20 = lean_ctor_get(x_10, 1);
lean_inc_ref(x_20);
x_21 = lean_ctor_get(x_10, 2);
lean_inc_ref(x_21);
x_22 = lean_ctor_get(x_10, 3);
lean_inc(x_22);
x_23 = lean_ctor_get(x_10, 5);
lean_inc(x_23);
x_24 = lean_ctor_get(x_10, 6);
lean_inc(x_24);
x_25 = lean_ctor_get(x_10, 7);
lean_inc(x_25);
x_26 = lean_ctor_get(x_10, 8);
lean_inc(x_26);
x_27 = lean_ctor_get(x_10, 9);
lean_inc(x_27);
x_28 = lean_ctor_get(x_10, 10);
lean_inc(x_28);
x_29 = lean_ctor_get(x_10, 11);
lean_inc(x_29);
x_30 = lean_ctor_get(x_10, 12);
lean_inc(x_30);
x_31 = lean_ctor_get_uint8(x_10, sizeof(void*)*14 + 1);
x_32 = lean_ctor_get(x_10, 13);
lean_inc_ref(x_32);
if (lean_is_exclusive(x_10)) {
lean_ctor_release(x_10, 0);
lean_ctor_release(x_10, 1);
lean_ctor_release(x_10, 2);
lean_ctor_release(x_10, 3);
lean_ctor_release(x_10, 4);
lean_ctor_release(x_10, 5);
lean_ctor_release(x_10, 6);
lean_ctor_release(x_10, 7);
lean_ctor_release(x_10, 8);
lean_ctor_release(x_10, 9);
lean_ctor_release(x_10, 10);
lean_ctor_release(x_10, 11);
lean_ctor_release(x_10, 12);
lean_ctor_release(x_10, 13);
x_33 = x_10;
} else {
lean_dec_ref(x_10);
x_33 = lean_box(0);
}
x_34 = lean_ctor_get(x_18, 0);
lean_inc_ref(x_34);
lean_dec(x_18);
x_35 = ((lean_object*)(l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__0));
x_36 = lean_name_eq(x_13, x_17);
x_37 = l_Lean_Elab_PreDefinition_filterAttrs(x_4, x_35);
x_38 = lean_array_to_list(x_2);
x_39 = lean_box(0);
x_40 = l_List_mapTR_loop___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__0(x_38, x_39);
x_41 = l_Lean_allowUnsafeReducibility;
x_42 = 1;
x_43 = l_Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1(x_21, x_41, x_42);
x_44 = l_Lean_diagnostics;
x_45 = l_Lean_Option_get___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__2(x_43, x_44);
x_122 = l_Lean_Kernel_isDiagnosticsEnabled(x_34);
lean_dec_ref(x_34);
if (x_122 == 0)
{
x_122 = lean_box(0);
goto block_149;
if (x_45 == 0)
{
x_46 = x_19;
x_47 = x_20;
x_48 = x_22;
x_49 = x_23;
x_50 = x_24;
x_51 = x_25;
x_52 = x_26;
x_53 = x_27;
x_54 = x_28;
x_55 = x_29;
x_56 = x_30;
x_57 = x_31;
x_58 = x_32;
x_59 = x_11;
x_60 = lean_box(0);
goto block_100;
}
else
{
lean_object* x_154; uint8_t x_155;
x_154 = lean_box(0);
x_155 = lean_nat_dec_le(x_152, x_152);
if (x_155 == 0)
{
if (x_153 == 0)
{
x_122 = lean_box(0);
goto block_149;
}
else
{
size_t x_156; size_t x_157; lean_object* x_158;
x_156 = 0;
x_157 = lean_usize_of_nat(x_152);
x_158 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(x_2, x_156, x_157, x_154, x_11);
x_150 = x_158;
goto block_151;
x_101 = x_122;
goto block_121;
}
}
else
{
size_t x_159; size_t x_160; lean_object* x_161;
x_159 = 0;
x_160 = lean_usize_of_nat(x_152);
x_161 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(x_2, x_159, x_160, x_154, x_11);
x_150 = x_161;
goto block_151;
x_101 = x_45;
goto block_121;
}
block_100:
{
lean_object* x_61; lean_object* x_62; lean_object* x_63;
x_61 = l_Lean_maxRecDepth;
x_62 = l_Lean_Option_get___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__3(x_43, x_61);
if (lean_is_scalar(x_33)) {
x_63 = lean_alloc_ctor(0, 14, 2);
} else {
x_63 = x_33;
}
block_76:
lean_ctor_set(x_63, 0, x_46);
lean_ctor_set(x_63, 1, x_47);
lean_ctor_set(x_63, 2, x_43);
lean_ctor_set(x_63, 3, x_48);
lean_ctor_set(x_63, 4, x_62);
lean_ctor_set(x_63, 5, x_49);
lean_ctor_set(x_63, 6, x_50);
lean_ctor_set(x_63, 7, x_51);
lean_ctor_set(x_63, 8, x_52);
lean_ctor_set(x_63, 9, x_53);
lean_ctor_set(x_63, 10, x_54);
lean_ctor_set(x_63, 11, x_55);
lean_ctor_set(x_63, 12, x_56);
lean_ctor_set(x_63, 13, x_58);
lean_ctor_set_uint8(x_63, sizeof(void*)*14, x_45);
lean_ctor_set_uint8(x_63, sizeof(void*)*14 + 1, x_57);
if (x_36 == 0)
{
lean_object* x_38; lean_object* x_39; lean_object* x_40;
x_38 = l_Lean_maxRecDepth;
x_39 = l_Lean_Option_get___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__3(x_21, x_38);
x_40 = lean_alloc_ctor(0, 14, 2);
lean_ctor_set(x_40, 0, x_23);
lean_ctor_set(x_40, 1, x_24);
lean_ctor_set(x_40, 2, x_21);
lean_ctor_set(x_40, 3, x_25);
lean_ctor_set(x_40, 4, x_39);
lean_ctor_set(x_40, 5, x_26);
lean_ctor_set(x_40, 6, x_27);
lean_ctor_set(x_40, 7, x_28);
lean_ctor_set(x_40, 8, x_29);
lean_ctor_set(x_40, 9, x_30);
lean_ctor_set(x_40, 10, x_31);
lean_ctor_set(x_40, 11, x_32);
lean_ctor_set(x_40, 12, x_33);
lean_ctor_set(x_40, 13, x_35);
lean_ctor_set_uint8(x_40, sizeof(void*)*14, x_20);
lean_ctor_set_uint8(x_40, sizeof(void*)*14 + 1, x_34);
if (x_22 == 0)
{
lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47;
x_41 = lean_ctor_get(x_15, 3);
lean_inc(x_41);
x_42 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_42, 0, x_41);
lean_ctor_set(x_42, 1, x_17);
x_43 = lean_box(x_22);
x_44 = lean_box(x_5);
x_45 = lean_box(x_22);
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_64 = lean_ctor_get(x_37, 3);
lean_inc(x_64);
x_65 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_65, 0, x_64);
lean_ctor_set(x_65, 1, x_39);
x_66 = lean_box(x_36);
x_67 = lean_box(x_5);
x_68 = lean_box(x_36);
x_69 = lean_box(x_42);
lean_inc_ref(x_1);
x_46 = lean_alloc_closure((void*)(l_Lean_Elab_addNonRec___boxed), 13, 6);
lean_closure_set(x_46, 0, x_1);
lean_closure_set(x_46, 1, x_15);
lean_closure_set(x_46, 2, x_43);
lean_closure_set(x_46, 3, x_42);
lean_closure_set(x_46, 4, x_44);
lean_closure_set(x_46, 5, x_45);
lean_inc(x_36);
lean_inc_ref(x_40);
x_70 = lean_alloc_closure((void*)(l_Lean_Elab_addNonRec___boxed), 14, 7);
lean_closure_set(x_70, 0, x_1);
lean_closure_set(x_70, 1, x_37);
lean_closure_set(x_70, 2, x_66);
lean_closure_set(x_70, 3, x_65);
lean_closure_set(x_70, 4, x_67);
lean_closure_set(x_70, 5, x_68);
lean_closure_set(x_70, 6, x_69);
lean_inc(x_59);
lean_inc_ref(x_63);
lean_inc(x_9);
lean_inc_ref(x_8);
lean_inc(x_7);
lean_inc_ref(x_6);
x_47 = l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4___redArg(x_22, x_46, x_6, x_7, x_8, x_9, x_40, x_36);
if (lean_obj_tag(x_47) == 0)
x_71 = l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__4___redArg(x_36, x_70, x_6, x_7, x_8, x_9, x_63, x_59);
if (lean_obj_tag(x_71) == 0)
{
uint8_t x_48;
x_48 = !lean_is_exclusive(x_47);
if (x_48 == 0)
uint8_t x_72;
x_72 = !lean_is_exclusive(x_71);
if (x_72 == 0)
{
lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52;
x_49 = lean_ctor_get(x_47, 0);
lean_dec(x_49);
x_50 = lean_array_get_size(x_3);
x_51 = lean_box(0);
x_52 = lean_nat_dec_lt(x_19, x_50);
if (x_52 == 0)
lean_object* x_73; lean_object* x_74; lean_object* x_75; uint8_t x_76;
x_73 = lean_ctor_get(x_71, 0);
lean_dec(x_73);
x_74 = lean_array_get_size(x_3);
x_75 = lean_box(0);
x_76 = lean_nat_dec_lt(x_15, x_74);
if (x_76 == 0)
{
lean_dec_ref(x_40);
lean_dec(x_36);
lean_dec(x_18);
lean_dec_ref(x_63);
lean_dec(x_59);
lean_dec(x_40);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
lean_ctor_set(x_47, 0, x_51);
return x_47;
lean_ctor_set(x_71, 0, x_75);
return x_71;
}
else
{
uint8_t x_53;
x_53 = lean_nat_dec_le(x_50, x_50);
if (x_53 == 0)
uint8_t x_77;
x_77 = lean_nat_dec_le(x_74, x_74);
if (x_77 == 0)
{
if (x_52 == 0)
if (x_76 == 0)
{
lean_dec_ref(x_40);
lean_dec(x_36);
lean_dec(x_18);
lean_dec_ref(x_63);
lean_dec(x_59);
lean_dec(x_40);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
lean_ctor_set(x_47, 0, x_51);
return x_47;
lean_ctor_set(x_71, 0, x_75);
return x_71;
}
else
{
size_t x_54; size_t x_55; lean_object* x_56;
lean_free_object(x_47);
x_54 = 0;
x_55 = lean_usize_of_nat(x_50);
x_56 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_18, x_5, x_3, x_54, x_55, x_51, x_6, x_7, x_8, x_9, x_40, x_36);
return x_56;
size_t x_78; size_t x_79; lean_object* x_80;
lean_free_object(x_71);
x_78 = 0;
x_79 = lean_usize_of_nat(x_74);
x_80 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_40, x_5, x_3, x_78, x_79, x_75, x_6, x_7, x_8, x_9, x_63, x_59);
return x_80;
}
}
else
{
size_t x_57; size_t x_58; lean_object* x_59;
lean_free_object(x_47);
x_57 = 0;
x_58 = lean_usize_of_nat(x_50);
x_59 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_18, x_5, x_3, x_57, x_58, x_51, x_6, x_7, x_8, x_9, x_40, x_36);
return x_59;
size_t x_81; size_t x_82; lean_object* x_83;
lean_free_object(x_71);
x_81 = 0;
x_82 = lean_usize_of_nat(x_74);
x_83 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_40, x_5, x_3, x_81, x_82, x_75, x_6, x_7, x_8, x_9, x_63, x_59);
return x_83;
}
}
}
else
{
lean_object* x_60; lean_object* x_61; uint8_t x_62;
lean_dec(x_47);
x_60 = lean_array_get_size(x_3);
x_61 = lean_box(0);
x_62 = lean_nat_dec_lt(x_19, x_60);
if (x_62 == 0)
lean_object* x_84; lean_object* x_85; uint8_t x_86;
lean_dec(x_71);
x_84 = lean_array_get_size(x_3);
x_85 = lean_box(0);
x_86 = lean_nat_dec_lt(x_15, x_84);
if (x_86 == 0)
{
lean_object* x_63;
lean_dec_ref(x_40);
lean_dec(x_36);
lean_dec(x_18);
lean_object* x_87;
lean_dec_ref(x_63);
lean_dec(x_59);
lean_dec(x_40);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
x_63 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_63, 0, x_61);
return x_63;
x_87 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_87, 0, x_85);
return x_87;
}
else
{
uint8_t x_64;
x_64 = lean_nat_dec_le(x_60, x_60);
if (x_64 == 0)
uint8_t x_88;
x_88 = lean_nat_dec_le(x_84, x_84);
if (x_88 == 0)
{
if (x_62 == 0)
if (x_86 == 0)
{
lean_object* x_65;
lean_dec_ref(x_40);
lean_dec(x_36);
lean_dec(x_18);
lean_object* x_89;
lean_dec_ref(x_63);
lean_dec(x_59);
lean_dec(x_40);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
x_65 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_65, 0, x_61);
return x_65;
x_89 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_89, 0, x_85);
return x_89;
}
else
{
size_t x_66; size_t x_67; lean_object* x_68;
x_66 = 0;
x_67 = lean_usize_of_nat(x_60);
x_68 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_18, x_5, x_3, x_66, x_67, x_61, x_6, x_7, x_8, x_9, x_40, x_36);
return x_68;
size_t x_90; size_t x_91; lean_object* x_92;
x_90 = 0;
x_91 = lean_usize_of_nat(x_84);
x_92 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_40, x_5, x_3, x_90, x_91, x_85, x_6, x_7, x_8, x_9, x_63, x_59);
return x_92;
}
}
else
{
size_t x_69; size_t x_70; lean_object* x_71;
x_69 = 0;
x_70 = lean_usize_of_nat(x_60);
x_71 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_18, x_5, x_3, x_69, x_70, x_61, x_6, x_7, x_8, x_9, x_40, x_36);
size_t x_93; size_t x_94; lean_object* x_95;
x_93 = 0;
x_94 = lean_usize_of_nat(x_84);
x_95 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__5(x_1, x_40, x_5, x_3, x_93, x_94, x_85, x_6, x_7, x_8, x_9, x_63, x_59);
return x_95;
}
}
}
}
else
{
lean_dec_ref(x_63);
lean_dec(x_59);
lean_dec(x_40);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
return x_71;
}
}
}
}
else
{
lean_dec_ref(x_40);
lean_dec(x_36);
lean_dec(x_18);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_1);
return x_47;
lean_object* x_96; uint8_t x_97; lean_object* x_98; lean_object* x_99;
lean_dec(x_40);
x_96 = lean_ctor_get(x_37, 3);
lean_inc(x_96);
x_97 = 0;
x_98 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_98, 0, x_96);
lean_ctor_set(x_98, 1, x_39);
x_99 = l_Lean_Elab_addNonRec(x_1, x_37, x_97, x_98, x_5, x_97, x_42, x_6, x_7, x_8, x_9, x_63, x_59);
return x_99;
}
}
else
{
lean_object* x_72; uint8_t x_73; lean_object* x_74; lean_object* x_75;
lean_dec(x_18);
x_72 = lean_ctor_get(x_15, 3);
lean_inc(x_72);
x_73 = 0;
x_74 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_74, 0, x_72);
lean_ctor_set(x_74, 1, x_17);
x_75 = l_Lean_Elab_addNonRec(x_1, x_15, x_73, x_74, x_5, x_73, x_6, x_7, x_8, x_9, x_40, x_36);
return x_75;
}
}
block_96:
{
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; uint8_t x_94; lean_object* x_95;
x_83 = lean_ctor_get(x_80, 0);
lean_inc_ref(x_83);
x_84 = lean_ctor_get(x_80, 1);
lean_inc_ref(x_84);
x_85 = lean_ctor_get(x_80, 3);
lean_inc(x_85);
x_86 = lean_ctor_get(x_80, 5);
lean_inc(x_86);
x_87 = lean_ctor_get(x_80, 6);
lean_inc(x_87);
x_88 = lean_ctor_get(x_80, 7);
lean_inc(x_88);
x_89 = lean_ctor_get(x_80, 8);
lean_inc(x_89);
x_90 = lean_ctor_get(x_80, 9);
lean_inc(x_90);
x_91 = lean_ctor_get(x_80, 10);
lean_inc(x_91);
x_92 = lean_ctor_get(x_80, 11);
lean_inc(x_92);
x_93 = lean_ctor_get(x_80, 12);
lean_inc(x_93);
x_94 = lean_ctor_get_uint8(x_80, sizeof(void*)*14 + 1);
x_95 = lean_ctor_get(x_80, 13);
lean_inc_ref(x_95);
lean_dec_ref(x_80);
x_20 = x_77;
x_21 = x_78;
x_22 = x_79;
x_23 = x_83;
x_24 = x_84;
x_25 = x_85;
x_26 = x_86;
x_27 = x_87;
x_28 = x_88;
x_29 = x_89;
x_30 = x_90;
x_31 = x_91;
x_32 = x_92;
x_33 = x_93;
x_34 = x_94;
x_35 = x_95;
x_36 = x_81;
x_37 = lean_box(0);
goto block_76;
}
block_121:
{
if (x_101 == 0)
@ -1091,18 +1021,27 @@ lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107;
x_104 = lean_ctor_get(x_102, 0);
x_105 = lean_ctor_get(x_102, 5);
lean_dec(x_105);
x_106 = l_Lean_Kernel_enableDiag(x_104, x_97);
x_106 = l_Lean_Kernel_enableDiag(x_104, x_45);
x_107 = l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__3;
lean_ctor_set(x_102, 5, x_107);
lean_ctor_set(x_102, 0, x_106);
x_108 = lean_st_ref_set(x_11, x_102);
x_77 = x_97;
x_78 = x_98;
x_79 = x_99;
x_80 = x_10;
x_81 = x_11;
x_82 = lean_box(0);
goto block_96;
x_46 = x_19;
x_47 = x_20;
x_48 = x_22;
x_49 = x_23;
x_50 = x_24;
x_51 = x_25;
x_52 = x_26;
x_53 = x_27;
x_54 = x_28;
x_55 = x_29;
x_56 = x_30;
x_57 = x_31;
x_58 = x_32;
x_59 = x_11;
x_60 = lean_box(0);
goto block_100;
}
else
{
@ -1124,7 +1063,7 @@ lean_inc(x_111);
lean_inc(x_110);
lean_inc(x_109);
lean_dec(x_102);
x_117 = l_Lean_Kernel_enableDiag(x_109, x_97);
x_117 = l_Lean_Kernel_enableDiag(x_109, x_45);
x_118 = l_Lean_Elab_Mutual_addPreDefsFromUnary___closed__3;
x_119 = lean_alloc_ctor(0, 9, 0);
lean_ctor_set(x_119, 0, x_117);
@ -1137,145 +1076,42 @@ lean_ctor_set(x_119, 6, x_114);
lean_ctor_set(x_119, 7, x_115);
lean_ctor_set(x_119, 8, x_116);
x_120 = lean_st_ref_set(x_11, x_119);
x_77 = x_97;
x_78 = x_98;
x_79 = x_99;
x_80 = x_10;
x_81 = x_11;
x_82 = lean_box(0);
goto block_96;
x_46 = x_19;
x_47 = x_20;
x_48 = x_22;
x_49 = x_23;
x_50 = x_24;
x_51 = x_25;
x_52 = x_26;
x_53 = x_27;
x_54 = x_28;
x_55 = x_29;
x_56 = x_30;
x_57 = x_31;
x_58 = x_32;
x_59 = x_11;
x_60 = lean_box(0);
goto block_100;
}
}
else
{
x_77 = x_97;
x_78 = x_98;
x_79 = x_99;
x_80 = x_10;
x_81 = x_11;
x_82 = lean_box(0);
goto block_96;
}
}
block_149:
{
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; uint8_t x_139; lean_object* x_140; lean_object* x_141; uint8_t x_142; lean_object* x_143; uint8_t x_144; lean_object* x_145; lean_object* x_146; uint8_t x_147; uint8_t x_148;
x_123 = lean_ctor_get(x_4, 3);
lean_inc(x_123);
lean_dec_ref(x_4);
x_124 = lean_array_get(x_14, x_2, x_19);
lean_dec_ref(x_2);
x_125 = lean_ctor_get(x_124, 3);
lean_inc(x_125);
lean_dec(x_124);
x_126 = lean_st_ref_get(x_11);
x_127 = lean_ctor_get(x_10, 0);
x_128 = lean_ctor_get(x_10, 1);
x_129 = lean_ctor_get(x_10, 2);
x_130 = lean_ctor_get(x_10, 3);
x_131 = lean_ctor_get(x_10, 5);
x_132 = lean_ctor_get(x_10, 6);
x_133 = lean_ctor_get(x_10, 7);
x_134 = lean_ctor_get(x_10, 8);
x_135 = lean_ctor_get(x_10, 9);
x_136 = lean_ctor_get(x_10, 10);
x_137 = lean_ctor_get(x_10, 11);
x_138 = lean_ctor_get(x_10, 12);
x_139 = lean_ctor_get_uint8(x_10, sizeof(void*)*14 + 1);
x_140 = lean_ctor_get(x_10, 13);
x_141 = lean_ctor_get(x_126, 0);
lean_inc_ref(x_141);
lean_dec(x_126);
x_142 = lean_name_eq(x_123, x_125);
lean_dec(x_125);
lean_dec(x_123);
x_143 = l_Lean_allowUnsafeReducibility;
x_144 = 1;
lean_inc_ref(x_129);
x_145 = l_Lean_Option_set___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__1(x_129, x_143, x_144);
x_146 = l_Lean_diagnostics;
x_147 = l_Lean_Option_get___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__2(x_145, x_146);
x_148 = l_Lean_Kernel_isDiagnosticsEnabled(x_141);
lean_dec_ref(x_141);
if (x_148 == 0)
{
if (x_147 == 0)
{
lean_inc_ref(x_140);
lean_inc(x_138);
lean_inc(x_137);
lean_inc(x_136);
lean_inc(x_135);
lean_inc(x_134);
lean_inc(x_133);
lean_inc(x_132);
lean_inc(x_131);
lean_inc(x_130);
lean_inc_ref(x_128);
lean_inc_ref(x_127);
lean_dec_ref(x_10);
x_20 = x_147;
x_21 = x_145;
x_22 = x_142;
x_23 = x_127;
x_24 = x_128;
x_25 = x_130;
x_26 = x_131;
x_27 = x_132;
x_28 = x_133;
x_29 = x_134;
x_30 = x_135;
x_31 = x_136;
x_32 = x_137;
x_33 = x_138;
x_34 = x_139;
x_35 = x_140;
x_36 = x_11;
x_37 = lean_box(0);
goto block_76;
}
else
{
x_97 = x_147;
x_98 = x_145;
x_99 = x_142;
x_100 = lean_box(0);
x_101 = x_148;
goto block_121;
}
}
else
{
x_97 = x_147;
x_98 = x_145;
x_99 = x_142;
x_100 = lean_box(0);
x_101 = x_147;
goto block_121;
}
}
block_151:
{
if (lean_obj_tag(x_150) == 0)
{
lean_dec_ref(x_150);
x_122 = lean_box(0);
goto block_149;
}
else
{
lean_dec(x_18);
lean_dec_ref(x_15);
lean_dec(x_11);
lean_dec_ref(x_10);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_4);
lean_dec_ref(x_2);
lean_dec_ref(x_1);
return x_150;
x_46 = x_19;
x_47 = x_20;
x_48 = x_22;
x_49 = x_23;
x_50 = x_24;
x_51 = x_25;
x_52 = x_26;
x_53 = x_27;
x_54 = x_28;
x_55 = x_29;
x_56 = x_30;
x_57 = x_31;
x_58 = x_32;
x_59 = x_11;
x_60 = lean_box(0);
goto block_100;
}
}
}
@ -1330,33 +1166,6 @@ x_12 = l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Mutual_addPreDefsFromUn
return x_12;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6(lean_object* x_1, size_t x_2, size_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) {
_start:
{
lean_object* x_12;
x_12 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___redArg(x_1, x_2, x_3, x_4, x_10);
return x_12;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
_start:
{
size_t x_12; size_t x_13; lean_object* x_14;
x_12 = lean_unbox_usize(x_2);
lean_dec(x_2);
x_13 = lean_unbox_usize(x_3);
lean_dec(x_3);
x_14 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Mutual_addPreDefsFromUnary_spec__6(x_1, x_12, x_13, x_4, x_5, x_6, x_7, x_8, x_9, x_10);
lean_dec(x_10);
lean_dec_ref(x_9);
lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec(x_6);
lean_dec_ref(x_5);
lean_dec_ref(x_1);
return x_14;
}
}
LEAN_EXPORT lean_object* l_Lean_Elab_Mutual_cleanPreDef(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) {
_start:
{

View file

@ -490,25 +490,22 @@ lean_object* l_Lean_enableRealizationsForConst(lean_object*, lean_object*, lean_
lean_object* l_Lean_Meta_generateEagerEqns(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_forIn_x27Unsafe_loop___at___00Lean_Elab_Structural_structuralRecursion_spec__2___redArg(lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_forIn_x27Unsafe_loop___at___00Lean_Elab_Structural_structuralRecursion_spec__2___redArg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Meta_markAsRecursive___redArg(lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_indentD(lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1(lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0(lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__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*);
static const lean_string_object l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__0_value = {.m_header = {.m_rc = 0, .m_cs_sz = 0, .m_other = 0, .m_tag = 249}, .m_size = 58, .m_capacity = 58, .m_length = 57, .m_data = "structural recursion failed, produced type incorrect term"};
static const lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__0 = (const lean_object*)&l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__0_value;
static lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__1;
static lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__2;
lean_object* l_Lean_Elab_eraseRecAppSyntax(lean_object*, lean_object*, lean_object*);
uint8_t l_Lean_Elab_DefKind_isTheorem(uint8_t);
lean_object* l_Lean_Meta_mapErrorImp___redArg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4(lean_object*, lean_object*, lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_forIn_x27Unsafe_loop___at___00Lean_Elab_Structural_structuralRecursion_spec__1(lean_object*, lean_object*, lean_object*, lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
uint8_t l_Lean_Elab_DefKind_isTheorem(uint8_t);
lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_abstractNestedProofs(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_Structural_registerEqnsInfo(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
@ -9107,73 +9104,7 @@ lean_dec_ref(x_1);
return x_12;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) {
_start:
{
if (x_1 == 0)
{
lean_object* x_11;
x_11 = l_Lean_Meta_markAsRecursive___redArg(x_2, x_9);
if (lean_obj_tag(x_11) == 0)
{
lean_object* x_12; lean_object* x_13;
x_12 = lean_ctor_get(x_11, 0);
lean_inc(x_12);
lean_dec_ref(x_11);
x_13 = lean_apply_8(x_3, x_12, x_4, x_5, x_6, x_7, x_8, x_9, lean_box(0));
return x_13;
}
else
{
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec(x_5);
lean_dec_ref(x_4);
lean_dec_ref(x_3);
return x_11;
}
}
else
{
lean_object* x_14; lean_object* x_15;
lean_dec(x_2);
x_14 = lean_box(0);
x_15 = lean_apply_8(x_3, x_14, x_4, x_5, x_6, x_7, x_8, x_9, lean_box(0));
return x_15;
}
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) {
_start:
{
uint8_t x_11; lean_object* x_12;
x_11 = lean_unbox(x_1);
x_12 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2(x_11, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9);
return x_12;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
_start:
{
lean_object* x_13; uint8_t x_14; lean_object* x_15;
x_13 = lean_array_to_list(x_1);
x_14 = 1;
x_15 = l_Lean_Elab_addNonRec(x_2, x_3, x_4, x_13, x_14, x_4, x_6, x_7, x_8, x_9, x_10, x_11);
return x_15;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) {
_start:
{
uint8_t x_13; lean_object* x_14;
x_13 = lean_unbox(x_4);
x_14 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0(x_1, x_2, x_3, x_13, x_5, x_6, x_7, x_8, x_9, x_10, x_11);
return x_14;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1(lean_object* x_1, lean_object* x_2) {
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0(lean_object* x_1, lean_object* x_2) {
_start:
{
lean_object* x_3; lean_object* x_4;
@ -9184,6 +9115,24 @@ lean_ctor_set(x_4, 1, x_3);
return x_4;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
_start:
{
lean_object* x_13;
x_13 = l_Lean_Elab_addNonRec(x_1, x_2, x_3, x_4, x_5, x_3, x_5, x_6, x_7, x_8, x_9, x_10, x_11);
return x_13;
}
}
LEAN_EXPORT lean_object* l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) {
_start:
{
uint8_t x_13; uint8_t x_14; lean_object* x_15;
x_13 = lean_unbox(x_3);
x_14 = lean_unbox(x_5);
x_15 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1(x_1, x_2, x_13, x_4, x_14, x_6, x_7, x_8, x_9, x_10, x_11);
return x_15;
}
}
static lean_object* _init_l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__1() {
_start:
{
@ -9198,7 +9147,7 @@ _start:
{
lean_object* x_1; lean_object* x_2;
x_1 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__1;
x_2 = lean_alloc_closure((void*)(l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1), 2, 1);
x_2 = lean_alloc_closure((void*)(l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0), 2, 1);
lean_closure_set(x_2, 0, x_1);
return x_2;
}
@ -9217,49 +9166,44 @@ lean_inc_ref(x_11);
x_16 = l_Lean_Elab_eraseRecAppSyntax(x_15, x_11, x_12);
if (lean_obj_tag(x_16) == 0)
{
lean_object* x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26;
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;
x_17 = lean_ctor_get(x_16, 0);
lean_inc(x_17);
lean_dec_ref(x_16);
x_18 = lean_ctor_get_uint8(x_17, sizeof(void*)*9);
x_19 = lean_ctor_get(x_17, 3);
lean_inc(x_19);
x_20 = lean_box(x_14);
lean_inc_ref(x_2);
x_18 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__2;
lean_inc_ref(x_1);
x_21 = lean_alloc_closure((void*)(l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__0___boxed), 12, 4);
lean_closure_set(x_21, 0, x_1);
lean_closure_set(x_21, 1, x_2);
lean_closure_set(x_21, 2, x_17);
lean_closure_set(x_21, 3, x_20);
x_22 = l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___closed__2;
x_23 = l_Lean_Elab_DefKind_isTheorem(x_18);
x_24 = lean_box(x_23);
x_19 = lean_array_to_list(x_1);
x_20 = 1;
x_21 = lean_box(x_14);
x_22 = lean_box(x_20);
lean_inc(x_8);
lean_inc_ref(x_7);
x_25 = lean_alloc_closure((void*)(l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__2___boxed), 10, 5);
lean_closure_set(x_25, 0, x_24);
lean_closure_set(x_25, 1, x_19);
lean_closure_set(x_25, 2, x_21);
lean_closure_set(x_25, 3, x_7);
lean_closure_set(x_25, 4, x_8);
lean_inc_ref(x_2);
x_23 = lean_alloc_closure((void*)(l___private_Init_Data_Array_Basic_0__Array_foldlMUnsafe_fold___at___00Lean_Elab_Structural_structuralRecursion_spec__4___lam__1___boxed), 12, 7);
lean_closure_set(x_23, 0, x_2);
lean_closure_set(x_23, 1, x_17);
lean_closure_set(x_23, 2, x_21);
lean_closure_set(x_23, 3, x_19);
lean_closure_set(x_23, 4, x_22);
lean_closure_set(x_23, 5, x_7);
lean_closure_set(x_23, 6, x_8);
lean_inc(x_12);
lean_inc_ref(x_11);
lean_inc(x_10);
lean_inc_ref(x_9);
x_26 = l_Lean_Meta_mapErrorImp___redArg(x_25, x_22, x_9, x_10, x_11, x_12);
if (lean_obj_tag(x_26) == 0)
x_24 = l_Lean_Meta_mapErrorImp___redArg(x_23, x_18, x_9, x_10, x_11, x_12);
if (lean_obj_tag(x_24) == 0)
{
if (lean_obj_tag(x_26) == 0)
if (lean_obj_tag(x_24) == 0)
{
lean_object* x_27; size_t x_28; size_t x_29;
x_27 = lean_ctor_get(x_26, 0);
lean_inc(x_27);
lean_dec_ref(x_26);
x_28 = 1;
x_29 = lean_usize_add(x_4, x_28);
x_4 = x_29;
x_6 = x_27;
lean_object* x_25; size_t x_26; size_t x_27;
x_25 = lean_ctor_get(x_24, 0);
lean_inc(x_25);
lean_dec_ref(x_24);
x_26 = 1;
x_27 = lean_usize_add(x_4, x_26);
x_4 = x_27;
x_6 = x_25;
goto _start;
}
else
@ -9272,12 +9216,12 @@ lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec_ref(x_2);
lean_dec_ref(x_1);
return x_26;
return x_24;
}
}
else
{
uint8_t x_31;
uint8_t x_29;
lean_dec(x_12);
lean_dec_ref(x_11);
lean_dec(x_10);
@ -9286,26 +9230,26 @@ lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec_ref(x_2);
lean_dec_ref(x_1);
x_31 = !lean_is_exclusive(x_26);
if (x_31 == 0)
x_29 = !lean_is_exclusive(x_24);
if (x_29 == 0)
{
return x_26;
return x_24;
}
else
{
lean_object* x_32; lean_object* x_33;
x_32 = lean_ctor_get(x_26, 0);
lean_inc(x_32);
lean_dec(x_26);
x_33 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_33, 0, x_32);
return x_33;
lean_object* x_30; lean_object* x_31;
x_30 = lean_ctor_get(x_24, 0);
lean_inc(x_30);
lean_dec(x_24);
x_31 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_31, 0, x_30);
return x_31;
}
}
}
else
{
uint8_t x_34;
uint8_t x_32;
lean_dec(x_12);
lean_dec_ref(x_11);
lean_dec(x_10);
@ -9314,26 +9258,26 @@ lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec_ref(x_2);
lean_dec_ref(x_1);
x_34 = !lean_is_exclusive(x_16);
if (x_34 == 0)
x_32 = !lean_is_exclusive(x_16);
if (x_32 == 0)
{
return x_16;
}
else
{
lean_object* x_35; lean_object* x_36;
x_35 = lean_ctor_get(x_16, 0);
lean_inc(x_35);
lean_object* x_33; lean_object* x_34;
x_33 = lean_ctor_get(x_16, 0);
lean_inc(x_33);
lean_dec(x_16);
x_36 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_36, 0, x_35);
return x_36;
x_34 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_34, 0, x_33);
return x_34;
}
}
}
else
{
lean_object* x_37;
lean_object* x_35;
lean_dec(x_12);
lean_dec_ref(x_11);
lean_dec(x_10);
@ -9342,9 +9286,9 @@ lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec_ref(x_2);
lean_dec_ref(x_1);
x_37 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_37, 0, x_6);
return x_37;
x_35 = lean_alloc_ctor(0, 1, 0);
lean_ctor_set(x_35, 0, x_6);
return x_35;
}
}
}

View file

@ -250,9 +250,9 @@ extern lean_object* l_Lean_Elab_instInhabitedModifiers_default;
lean_object* l_Lean_Name_str___override(lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDefAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDefAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
lean_object* l_Lean_Elab_addNonRec(lean_object*, lean_object*, uint8_t, lean_object*, uint8_t, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(lean_object*, lean_object*, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___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_st_ref_take(lean_object*);
lean_object* lean_st_ref_set(lean_object*, lean_object*);
LEAN_EXPORT lean_object* l_Lean_Elab_enableInfoTree___at___00Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Structural_addSmartUnfoldingDef_spec__0_spec__0___redArg(uint8_t, lean_object*);
@ -4849,65 +4849,66 @@ x_8 = l_Lean_Elab_Structural_addSmartUnfoldingDefAux(x_1, x_2, x_3, x_4, x_5, x_
return x_8;
}
}
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) {
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
_start:
{
lean_object* x_12;
lean_inc(x_10);
lean_inc_ref(x_9);
lean_inc(x_8);
lean_inc_ref(x_7);
x_12 = l_Lean_Elab_Structural_addSmartUnfoldingDefAux(x_1, x_2, x_7, x_8, x_9, x_10);
if (lean_obj_tag(x_12) == 0)
lean_object* x_13;
lean_inc(x_11);
lean_inc_ref(x_10);
lean_inc(x_9);
lean_inc_ref(x_8);
x_13 = l_Lean_Elab_Structural_addSmartUnfoldingDefAux(x_1, x_2, x_8, x_9, x_10, x_11);
if (lean_obj_tag(x_13) == 0)
{
lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17;
x_13 = lean_ctor_get(x_12, 0);
lean_inc(x_13);
lean_dec_ref(x_12);
x_14 = lean_ctor_get(x_13, 3);
x_15 = lean_box(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_16 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_16, 0, x_14);
lean_ctor_set(x_16, 1, x_15);
x_17 = l_Lean_Elab_addNonRec(x_3, x_13, x_4, x_16, x_4, x_4, x_5, x_6, x_7, x_8, x_9, x_10);
return x_17;
lean_dec_ref(x_13);
x_15 = lean_ctor_get(x_14, 3);
x_16 = lean_box(0);
lean_inc(x_15);
x_17 = lean_alloc_ctor(1, 2, 0);
lean_ctor_set(x_17, 0, x_15);
lean_ctor_set(x_17, 1, x_16);
x_18 = l_Lean_Elab_addNonRec(x_3, x_14, x_4, x_17, x_4, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11);
return x_18;
}
else
{
uint8_t x_18;
lean_dec(x_10);
lean_dec_ref(x_9);
lean_dec(x_8);
lean_dec_ref(x_7);
lean_dec(x_6);
lean_dec_ref(x_5);
uint8_t x_19;
lean_dec(x_11);
lean_dec_ref(x_10);
lean_dec(x_9);
lean_dec_ref(x_8);
lean_dec(x_7);
lean_dec_ref(x_6);
lean_dec_ref(x_3);
x_18 = !lean_is_exclusive(x_12);
if (x_18 == 0)
x_19 = !lean_is_exclusive(x_13);
if (x_19 == 0)
{
return x_12;
return x_13;
}
else
{
lean_object* x_19; lean_object* x_20;
x_19 = lean_ctor_get(x_12, 0);
lean_inc(x_19);
lean_dec(x_12);
x_20 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_20, 0, x_19);
return x_20;
lean_object* x_20; lean_object* x_21;
x_20 = lean_ctor_get(x_13, 0);
lean_inc(x_20);
lean_dec(x_13);
x_21 = lean_alloc_ctor(1, 1, 0);
lean_ctor_set(x_21, 0, x_20);
return x_21;
}
}
}
}
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) {
LEAN_EXPORT lean_object* l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) {
_start:
{
uint8_t x_12; lean_object* x_13;
x_12 = lean_unbox(x_4);
x_13 = l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(x_1, x_2, x_3, x_12, x_5, x_6, x_7, x_8, x_9, x_10);
return x_13;
uint8_t x_13; uint8_t x_14; lean_object* x_15;
x_13 = lean_unbox(x_4);
x_14 = lean_unbox(x_5);
x_15 = l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0(x_1, x_2, x_3, x_13, x_14, x_6, x_7, x_8, x_9, x_10, x_11);
return x_15;
}
}
LEAN_EXPORT lean_object* l_Lean_Elab_enableInfoTree___at___00Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Structural_addSmartUnfoldingDef_spec__0_spec__0___redArg(uint8_t x_1, lean_object* x_2) {
@ -5139,11 +5140,13 @@ uint8_t x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x
lean_free_object(x_12);
x_16 = 1;
x_17 = lean_box(x_16);
x_18 = lean_alloc_closure((void*)(l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed), 11, 4);
lean_inc(x_14);
x_18 = lean_alloc_closure((void*)(l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed), 12, 5);
lean_closure_set(x_18, 0, x_2);
lean_closure_set(x_18, 1, x_3);
lean_closure_set(x_18, 2, x_1);
lean_closure_set(x_18, 3, x_17);
lean_closure_set(x_18, 4, x_14);
x_19 = lean_unbox(x_14);
lean_dec(x_14);
x_20 = l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Structural_addSmartUnfoldingDef_spec__0___redArg(x_19, x_18, x_4, x_5, x_6, x_7, x_8, x_9);
@ -5179,11 +5182,13 @@ if (x_23 == 0)
uint8_t x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28;
x_24 = 1;
x_25 = lean_box(x_24);
x_26 = lean_alloc_closure((void*)(l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed), 11, 4);
lean_inc(x_22);
x_26 = lean_alloc_closure((void*)(l_Lean_Elab_Structural_addSmartUnfoldingDef___lam__0___boxed), 12, 5);
lean_closure_set(x_26, 0, x_2);
lean_closure_set(x_26, 1, x_3);
lean_closure_set(x_26, 2, x_1);
lean_closure_set(x_26, 3, x_25);
lean_closure_set(x_26, 4, x_22);
x_27 = lean_unbox(x_22);
lean_dec(x_22);
x_28 = l_Lean_Elab_withEnableInfoTree___at___00Lean_Elab_Structural_addSmartUnfoldingDef_spec__0___redArg(x_27, x_26, x_4, x_5, x_6, x_7, x_8, x_9);