Construct TupleCreation

Performance Diagrams

Construct TupleCreation 00200000020000004000000400000060000006000000800000080000001000000010000000120000001200000014000000140000001600000016000000CPython 2.7Nuitka (main)Nuitka (develop)Nuitka (factory)1750137588.95192307692307257.0CPython 2.78549359242.31730769230768383.400404363833Nuitka (main)8549359395.6826923076923383.400404363833Nuitka (develop)8549359549.0480769230769383.400404363833Nuitka (factory)Construct TupleCreationTicks Construct TupleCreation 00200000020000004000000400000060000006000000800000080000001000000010000000120000001200000014000000140000001600000016000000CPython 3.8Nuitka (main)Nuitka (develop)Nuitka (factory)1630128088.95192307692307257.0CPython 3.88899428242.31730769230768369.20661836654267Nuitka (main)8899415395.6826923076923369.20681543695673Nuitka (develop)8899415549.0480769230769369.20681543695673Nuitka (factory)Construct TupleCreationTicks

Source Code with Construct

module_value1 = 1000

def calledRepeatedly(tuple_value1):
    # Force frame and eliminate forward propagation (currently).
    module_value1

# construct_begin
    l = (
        tuple_value1,
        tuple_value1,
        tuple_value1,
        tuple_value1,
        tuple_value1
    )
# construct_alternative



    return l, tuple_value1

import itertools
for x in itertools.repeat(None, 50000):
    calledRepeatedly(module_value1)

print("OK.")

Source Code without Construct

module_value1 = 1000

def calledRepeatedly(tuple_value1):
    # Force frame and eliminate forward propagation (currently).
    module_value1

# construct_begin







# construct_alternative
    l = 1
# construct_end

    return l, tuple_value1

import itertools
for x in itertools.repeat(None, 50000):
    calledRepeatedly(module_value1)

print("OK.")

Context Diff of Source Code


Construct
Baseline
22 def calledRepeatedly(tuple_value1): 22 def calledRepeatedly(tuple_value1):
23     # Force frame and eliminate forward propagation (currently). 23     # Force frame and eliminate forward propagation (currently).
24     module_value1 24     module_value1
25 25
26 # construct_begin 26 # construct_begin
n 27     l = ( n
28         tuple_value1,
29         tuple_value1,
30         tuple_value1,
31         tuple_value1,
32         tuple_value1
33     )
34 # construct_alternative
35 27
36 28
t t 29  
30  
31  
32  
33  
34 # construct_alternative
35     l = 1
36 # construct_end
37 37
38     return l, tuple_value1 38     return l, tuple_value1
39 39
40 import itertools 40 import itertools
41 for x in itertools.repeat(None, 50000): 41 for x in itertools.repeat(None, 50000):

Context Diff of Generated Code


Construct
Baseline
31 31
32 PyObject *module___main__; 32 PyObject *module___main__;
33 PyDictObject *moduledict___main__; 33 PyDictObject *moduledict___main__;
34 34
35 /* The declarations of module constants used, if any. */ 35 /* The declarations of module constants used, if any. */
n 36 static PyObject *mod_consts[17]; n 36 static PyObject *mod_consts[18];
37 #ifndef __NUITKA_NO_ASSERT__ 37 #ifndef __NUITKA_NO_ASSERT__
n 38 static Py_hash_t mod_consts_hash[17]; n 38 static Py_hash_t mod_consts_hash[18];
39 #endif 39 #endif
40 40
41 static PyObject *module_filename_obj = NULL; 41 static PyObject *module_filename_obj = NULL;
42 42
43 /* Indicator if this modules private constants were created yet. */ 43 /* Indicator if this modules private constants were created yet. */
48     if (constants_created == false) { 48     if (constants_created == false) {
49         loadConstantsBlob(&mod_consts[0], UNTRANSLATE("__main__")); 49         loadConstantsBlob(&mod_consts[0], UNTRANSLATE("__main__"));
50         constants_created = true; 50         constants_created = true;
51 51
52 #ifndef __NUITKA_NO_ASSERT__ 52 #ifndef __NUITKA_NO_ASSERT__
n 53         for(int i = 0; i < 17; i++) { n 53         for(int i = 0; i < 18; i++) {
54             mod_consts_hash[i] = DEEP_HASH(mod_consts[i]); 54             mod_consts_hash[i] = DEEP_HASH(mod_consts[i]);
55         } 55         }
56 #endif 56 #endif
57     } 57     }
58 } 58 }
68 #ifndef __NUITKA_NO_ASSERT__ 68 #ifndef __NUITKA_NO_ASSERT__
69 void checkModuleConstants___main__(void) { 69 void checkModuleConstants___main__(void) {
70     // The module may not have been used at all, then ignore this. 70     // The module may not have been used at all, then ignore this.
71     if (constants_created == false) return; 71     if (constants_created == false) return;
72 72
n 73     for(int i = 0; i < 17; i++) { n 73     for(int i = 0; i < 18; i++) {
74         assert(mod_consts_hash[i] == DEEP_HASH(mod_consts[i])); 74         assert(mod_consts_hash[i] == DEEP_HASH(mod_consts[i]));
75         CHECK_OBJECT_DEEP(mod_consts[i]); 75         CHECK_OBJECT_DEEP(mod_consts[i]);
76     } 76     }
77 } 77 }
78 #endif 78 #endif
82 static PyCodeObject *codeobj_9e87838035ef80b02dfb743e2b04c4ec; 82 static PyCodeObject *codeobj_9e87838035ef80b02dfb743e2b04c4ec;
83 /* For use in "MainProgram.c". */ 83 /* For use in "MainProgram.c". */
84 PyCodeObject *codeobj_main = NULL; 84 PyCodeObject *codeobj_main = NULL;
85 85
86 static void createModuleCodeObjects(void) { 86 static void createModuleCodeObjects(void) {
n 87     module_filename_obj = mod_consts[2]; CHECK_OBJECT(module_filename_obj); n 87     module_filename_obj = mod_consts[3]; CHECK_OBJECT(module_filename_obj);
88     codeobj_5e2c9601d69e371b1eb3e623b6e39752 = MAKE_CODEOBJECT(module_filename_obj, 1, CO_NOFREE, mod_consts[15], NULL, NULL, 0, 0, 0); 88     codeobj_5e2c9601d69e371b1eb3e623b6e39752 = MAKE_CODEOBJECT(module_filename_obj, 1, CO_NOFREE, mod_consts[16], NULL, NULL, 0, 0, 0);
89     codeobj_9e87838035ef80b02dfb743e2b04c4ec = MAKE_CODEOBJECT(module_filename_obj, 22, CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE, mod_consts[7], mod_consts[16], NULL, 1, 0, 0); 89     codeobj_9e87838035ef80b02dfb743e2b04c4ec = MAKE_CODEOBJECT(module_filename_obj, 22, CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE, mod_consts[8], mod_consts[17], NULL, 1, 0, 0);
90 } 90 }
91 91
92 // The module function declarations. 92 // The module function declarations.
93 static PyObject *MAKE_FUNCTION___main__$$$function__1_calledRepeatedly(); 93 static PyObject *MAKE_FUNCTION___main__$$$function__1_calledRepeatedly();
94 94
100     NUITKA_MAY_BE_UNUSED bool had_error = ERROR_OCCURRED(); 100     NUITKA_MAY_BE_UNUSED bool had_error = ERROR_OCCURRED();
101 #endif 101 #endif
102 102
103     // Local variable declarations. 103     // Local variable declarations.
104     PyObject *par_tuple_value1 = python_pars[0]; 104     PyObject *par_tuple_value1 = python_pars[0];
n 105     PyObject *var_l = NULL; n
106     struct Nuitka_FrameObject *frame_9e87838035ef80b02dfb743e2b04c4ec; 105     struct Nuitka_FrameObject *frame_9e87838035ef80b02dfb743e2b04c4ec;
107     NUITKA_MAY_BE_UNUSED char const *type_description_1 = NULL; 106     NUITKA_MAY_BE_UNUSED char const *type_description_1 = NULL;
108     NUITKA_MAY_BE_UNUSED nuitka_void tmp_unused; 107     NUITKA_MAY_BE_UNUSED nuitka_void tmp_unused;
109     PyObject *exception_type = NULL; 108     PyObject *exception_type = NULL;
110     PyObject *exception_value = NULL; 109     PyObject *exception_value = NULL;
111     PyTracebackObject *exception_tb = NULL; 110     PyTracebackObject *exception_tb = NULL;
112     NUITKA_MAY_BE_UNUSED int exception_lineno = 0; 111     NUITKA_MAY_BE_UNUSED int exception_lineno = 0;
113     static struct Nuitka_FrameObject *cache_frame_9e87838035ef80b02dfb743e2b04c4ec = NULL; 112     static struct Nuitka_FrameObject *cache_frame_9e87838035ef80b02dfb743e2b04c4ec = NULL;
114     PyObject *tmp_return_value = NULL; 113     PyObject *tmp_return_value = NULL;
n 115     PyObject *exception_keeper_type_1; n
116     PyObject *exception_keeper_value_1;
117     PyTracebackObject *exception_keeper_tb_1;
118     NUITKA_MAY_BE_UNUSED int exception_keeper_lineno_1;
119 114
120     // Actual function body. 115     // Actual function body.
n 121     // Tried code: n
122     if (isFrameUnusable(cache_frame_9e87838035ef80b02dfb743e2b04c4ec)) { 116     if (isFrameUnusable(cache_frame_9e87838035ef80b02dfb743e2b04c4ec)) {
123         Py_XDECREF(cache_frame_9e87838035ef80b02dfb743e2b04c4ec); 117         Py_XDECREF(cache_frame_9e87838035ef80b02dfb743e2b04c4ec);
124 118
125 #if _DEBUG_REFCOUNTS 119 #if _DEBUG_REFCOUNTS
126         if (cache_frame_9e87838035ef80b02dfb743e2b04c4ec == NULL) { 120         if (cache_frame_9e87838035ef80b02dfb743e2b04c4ec == NULL) {
159 153
160             FETCH_ERROR_OCCURRED(&exception_type, &exception_value, &exception_tb); 154             FETCH_ERROR_OCCURRED(&exception_type, &exception_value, &exception_tb);
161 155
162 156
163             exception_lineno = 24; 157             exception_lineno = 24;
n 164             type_description_1 = "oo"; n 158             type_description_1 = "oN";
165             goto frame_exception_exit_1; 159             goto frame_exception_exit_1;
166         } 160         }
167     } 161     }
168 162
169 #if 0 163 #if 0
190     // Attaches locals to frame if any. 184     // Attaches locals to frame if any.
191     Nuitka_Frame_AttachLocals( 185     Nuitka_Frame_AttachLocals(
192         frame_9e87838035ef80b02dfb743e2b04c4ec, 186         frame_9e87838035ef80b02dfb743e2b04c4ec,
193         type_description_1, 187         type_description_1,
194         par_tuple_value1, 188         par_tuple_value1,
n 195         var_l n 189         NULL
196     ); 190     );
197 191
198 192
199     // Release cached frame if used for exception. 193     // Release cached frame if used for exception.
200     if (frame_9e87838035ef80b02dfb743e2b04c4ec == cache_frame_9e87838035ef80b02dfb743e2b04c4ec) { 194     if (frame_9e87838035ef80b02dfb743e2b04c4ec == cache_frame_9e87838035ef80b02dfb743e2b04c4ec) {
211 205
212     // Put the previous frame back on top. 206     // Put the previous frame back on top.
213     popFrameStack(); 207     popFrameStack();
214 208
215     // Return the error. 209     // Return the error.
n 216     goto try_except_handler_1; n 210     goto function_exception_exit;
217 211
218     frame_no_exception_1:; 212     frame_no_exception_1:;
219     { 213     {
n 220         PyObject *tmp_assign_source_1; n
221         PyObject *tmp_tuple_element_1; 214         PyObject *tmp_tuple_element_1;
n n 215         tmp_tuple_element_1 = mod_consts[1];
216         tmp_return_value = PyTuple_New(2);
217         PyTuple_SET_ITEM0(tmp_return_value, 0, tmp_tuple_element_1);
222         CHECK_OBJECT(par_tuple_value1); 218         CHECK_OBJECT(par_tuple_value1);
223         tmp_tuple_element_1 = par_tuple_value1; 219         tmp_tuple_element_1 = par_tuple_value1;
n 224         tmp_assign_source_1 = PyTuple_New(5); n
225         PyTuple_SET_ITEM0(tmp_assign_source_1, 0, tmp_tuple_element_1);
226         CHECK_OBJECT(par_tuple_value1);
227         tmp_tuple_element_1 = par_tuple_value1;
228         PyTuple_SET_ITEM0(tmp_assign_source_1, 1, tmp_tuple_element_1);
229         CHECK_OBJECT(par_tuple_value1);
230         tmp_tuple_element_1 = par_tuple_value1;
231         PyTuple_SET_ITEM0(tmp_assign_source_1, 2, tmp_tuple_element_1);
232         CHECK_OBJECT(par_tuple_value1);
233         tmp_tuple_element_1 = par_tuple_value1;
234         PyTuple_SET_ITEM0(tmp_assign_source_1, 3, tmp_tuple_element_1);
235         CHECK_OBJECT(par_tuple_value1);
236         tmp_tuple_element_1 = par_tuple_value1;
237         PyTuple_SET_ITEM0(tmp_assign_source_1, 4, tmp_tuple_element_1);
238         assert(var_l == NULL);
239         var_l = tmp_assign_source_1;
240     }
241     {
242         PyObject *tmp_tuple_element_2;
243         CHECK_OBJECT(var_l);
244         tmp_tuple_element_2 = var_l;
245         tmp_return_value = PyTuple_New(2);
246         PyTuple_SET_ITEM0(tmp_return_value, 0, tmp_tuple_element_2);
247         CHECK_OBJECT(par_tuple_value1);
248         tmp_tuple_element_2 = par_tuple_value1;
249         PyTuple_SET_ITEM0(tmp_return_value, 1, tmp_tuple_element_2); 220         PyTuple_SET_ITEM0(tmp_return_value, 1, tmp_tuple_element_1);
250         goto try_return_handler_1;
251     }
252     NUITKA_CANNOT_GET_HERE("tried codes exits in all cases");
253     return NULL;
254     // Return handler code:
255     try_return_handler_1:;
256     CHECK_OBJECT(var_l);
257     Py_DECREF(var_l);
258     var_l = NULL;
259     goto function_return_exit; 221         goto function_return_exit;
260     // Exception handler code: 222     }
261     try_except_handler_1:;
262     exception_keeper_type_1 = exception_type;
263     exception_keeper_value_1 = exception_value;
264     exception_keeper_tb_1 = exception_tb;
265     exception_keeper_lineno_1 = exception_lineno;
266     exception_type = NULL;
267     exception_value = NULL;
268     exception_tb = NULL;
269     exception_lineno = 0;
270  
271     // Re-raise.
272     exception_type = exception_keeper_type_1;
273     exception_value = exception_keeper_value_1;
274     exception_tb = exception_keeper_tb_1;
275     exception_lineno = exception_keeper_lineno_1;
276  
277     goto function_exception_exit;
278     // End of try:
279 223
280     NUITKA_CANNOT_GET_HERE("Return statement must have exited already."); 224     NUITKA_CANNOT_GET_HERE("Return statement must have exited already.");
281     return NULL; 225     return NULL;
282 226
283 function_exception_exit: 227 function_exception_exit:
302 246
303 247
304 static PyObject *MAKE_FUNCTION___main__$$$function__1_calledRepeatedly() { 248 static PyObject *MAKE_FUNCTION___main__$$$function__1_calledRepeatedly() {
305     struct Nuitka_FunctionObject *result = Nuitka_Function_New( 249     struct Nuitka_FunctionObject *result = Nuitka_Function_New(
306         impl___main__$$$function__1_calledRepeatedly, 250         impl___main__$$$function__1_calledRepeatedly,
n 307         mod_consts[7], n 251         mod_consts[8],
308 #if PYTHON_VERSION >= 0x300 252 #if PYTHON_VERSION >= 0x300
309         NULL, 253         NULL,
310 #endif 254 #endif
311         codeobj_9e87838035ef80b02dfb743e2b04c4ec, 255         codeobj_9e87838035ef80b02dfb743e2b04c4ec,
312         NULL, 256         NULL,
687 631
688     // Module code. 632     // Module code.
689     { 633     {
690         PyObject *tmp_assign_source_1; 634         PyObject *tmp_assign_source_1;
691         tmp_assign_source_1 = Py_None; 635         tmp_assign_source_1 = Py_None;
n 692         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[1], tmp_assign_source_1); n 636         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[2], tmp_assign_source_1);
693     } 637     }
694     { 638     {
695         PyObject *tmp_assign_source_2; 639         PyObject *tmp_assign_source_2;
n 696         tmp_assign_source_2 = mod_consts[2]; n 640         tmp_assign_source_2 = mod_consts[3];
697         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[3], tmp_assign_source_2); 641         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[4], tmp_assign_source_2);
698     } 642     }
699     { 643     {
700         PyObject *tmp_assign_source_3; 644         PyObject *tmp_assign_source_3;
701         tmp_assign_source_3 = Py_None; 645         tmp_assign_source_3 = Py_None;
n 702         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[4], tmp_assign_source_3); n 646         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[5], tmp_assign_source_3);
703     } 647     }
704     { 648     {
705         PyObject *tmp_assign_source_4; 649         PyObject *tmp_assign_source_4;
706         tmp_assign_source_4 = PyDict_New(); 650         tmp_assign_source_4 = PyDict_New();
n 707         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[5], tmp_assign_source_4); n 651         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[6], tmp_assign_source_4);
708     } 652     }
709     { 653     {
710         PyObject *tmp_assign_source_5; 654         PyObject *tmp_assign_source_5;
n 711         tmp_assign_source_5 = mod_consts[6]; n 655         tmp_assign_source_5 = mod_consts[7];
712         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[0], tmp_assign_source_5); 656         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[0], tmp_assign_source_5);
713     } 657     }
714     { 658     {
715         PyObject *tmp_assign_source_6; 659         PyObject *tmp_assign_source_6;
716 660
717 661
718         tmp_assign_source_6 = MAKE_FUNCTION___main__$$$function__1_calledRepeatedly(); 662         tmp_assign_source_6 = MAKE_FUNCTION___main__$$$function__1_calledRepeatedly();
719 663
n 720         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[7], tmp_assign_source_6); n 664         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[8], tmp_assign_source_6);
721     } 665     }
722     { 666     {
723         PyObject *tmp_assign_source_7; 667         PyObject *tmp_assign_source_7;
724         PyObject *tmp_name_value_1; 668         PyObject *tmp_name_value_1;
725         PyObject *tmp_globals_arg_value_1; 669         PyObject *tmp_globals_arg_value_1;
726         PyObject *tmp_locals_arg_value_1; 670         PyObject *tmp_locals_arg_value_1;
727         PyObject *tmp_fromlist_value_1; 671         PyObject *tmp_fromlist_value_1;
728         PyObject *tmp_level_value_1; 672         PyObject *tmp_level_value_1;
n 729         tmp_name_value_1 = mod_consts[8]; n 673         tmp_name_value_1 = mod_consts[9];
730         tmp_globals_arg_value_1 = (PyObject *)moduledict___main__; 674         tmp_globals_arg_value_1 = (PyObject *)moduledict___main__;
731         tmp_locals_arg_value_1 = Py_None; 675         tmp_locals_arg_value_1 = Py_None;
732         tmp_fromlist_value_1 = Py_None; 676         tmp_fromlist_value_1 = Py_None;
n 733         tmp_level_value_1 = mod_consts[9]; n 677         tmp_level_value_1 = mod_consts[10];
734         tmp_assign_source_7 = IMPORT_MODULE5(tmp_name_value_1, tmp_globals_arg_value_1, tmp_locals_arg_value_1, tmp_fromlist_value_1, tmp_level_value_1); 678         tmp_assign_source_7 = IMPORT_MODULE5(tmp_name_value_1, tmp_globals_arg_value_1, tmp_locals_arg_value_1, tmp_fromlist_value_1, tmp_level_value_1);
735         assert(!(tmp_assign_source_7 == NULL)); 679         assert(!(tmp_assign_source_7 == NULL));
n 736         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[8], tmp_assign_source_7); n 680         UPDATE_STRING_DICT1(moduledict___main__, (Nuitka_StringObject *)mod_consts[9], tmp_assign_source_7);
737     } 681     }
738     // Frame without reuse. 682     // Frame without reuse.
739     frame_5e2c9601d69e371b1eb3e623b6e39752 = MAKE_MODULE_FRAME(codeobj_5e2c9601d69e371b1eb3e623b6e39752, module___main__); 683     frame_5e2c9601d69e371b1eb3e623b6e39752 = MAKE_MODULE_FRAME(codeobj_5e2c9601d69e371b1eb3e623b6e39752, module___main__);
740 684
741     // Push the new frame as the currently active one, and we should be exclusively 685     // Push the new frame as the currently active one, and we should be exclusively
746     // Framed code: 690     // Framed code:
747     { 691     {
748         PyObject *tmp_assign_source_8; 692         PyObject *tmp_assign_source_8;
749         PyObject *tmp_iter_arg_1; 693         PyObject *tmp_iter_arg_1;
750         PyObject *tmp_called_instance_1; 694         PyObject *tmp_called_instance_1;
n 751         tmp_called_instance_1 = GET_STRING_DICT_VALUE(moduledict___main__, (Nuitka_StringObject *)mod_consts[8]); n 695         tmp_called_instance_1 = GET_STRING_DICT_VALUE(moduledict___main__, (Nuitka_StringObject *)mod_consts[9]);
752 696
753         if (unlikely(tmp_called_instance_1 == NULL)) { 697         if (unlikely(tmp_called_instance_1 == NULL)) {
n 754             tmp_called_instance_1 = GET_MODULE_VARIABLE_VALUE_FALLBACK(mod_consts[8]); n 698             tmp_called_instance_1 = GET_MODULE_VARIABLE_VALUE_FALLBACK(mod_consts[9]);
755         } 699         }
756 700
757         assert(!(tmp_called_instance_1 == NULL)); 701         assert(!(tmp_called_instance_1 == NULL));
758         frame_5e2c9601d69e371b1eb3e623b6e39752->m_frame.f_lineno = 41; 702         frame_5e2c9601d69e371b1eb3e623b6e39752->m_frame.f_lineno = 41;
759         tmp_iter_arg_1 = CALL_METHOD_WITH_ARGS2( 703         tmp_iter_arg_1 = CALL_METHOD_WITH_ARGS2(
760             tmp_called_instance_1, 704             tmp_called_instance_1,
n 761             mod_consts[10], n 705             mod_consts[11],
762             &PyTuple_GET_ITEM(mod_consts[11], 0) 706             &PyTuple_GET_ITEM(mod_consts[12], 0)
763         ); 707         );
764 708
765         if (tmp_iter_arg_1 == NULL) { 709         if (tmp_iter_arg_1 == NULL) {
766             assert(ERROR_OCCURRED()); 710             assert(ERROR_OCCURRED());
767 711
817     } 761     }
818     { 762     {
819         PyObject *tmp_assign_source_10; 763         PyObject *tmp_assign_source_10;
820         CHECK_OBJECT(tmp_for_loop_1__iter_value); 764         CHECK_OBJECT(tmp_for_loop_1__iter_value);
821         tmp_assign_source_10 = tmp_for_loop_1__iter_value; 765         tmp_assign_source_10 = tmp_for_loop_1__iter_value;
n 822         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[12], tmp_assign_source_10); n 766         UPDATE_STRING_DICT0(moduledict___main__, (Nuitka_StringObject *)mod_consts[13], tmp_assign_source_10);
823     } 767     }
824     { 768     {
825         PyObject *tmp_called_value_1; 769         PyObject *tmp_called_value_1;
826         PyObject *tmp_call_result_1; 770         PyObject *tmp_call_result_1;
827         PyObject *tmp_args_element_value_1; 771         PyObject *tmp_args_element_value_1;
n 828         tmp_called_value_1 = GET_STRING_DICT_VALUE(moduledict___main__, (Nuitka_StringObject *)mod_consts[7]); n 772         tmp_called_value_1 = GET_STRING_DICT_VALUE(moduledict___main__, (Nuitka_StringObject *)mod_consts[8]);
829 773
830         if (unlikely(tmp_called_value_1 == NULL)) { 774         if (unlikely(tmp_called_value_1 == NULL)) {
n 831             tmp_called_value_1 = GET_MODULE_VARIABLE_VALUE_FALLBACK(mod_consts[7]); n 775             tmp_called_value_1 = GET_MODULE_VARIABLE_VALUE_FALLBACK(mod_consts[8]);
832         } 776         }
833 777
834         if (tmp_called_value_1 == NULL) { 778         if (tmp_called_value_1 == NULL) {
835             assert(ERROR_OCCURRED()); 779             assert(ERROR_OCCURRED());
836 780
915     Py_DECREF(tmp_for_loop_1__for_iterator); 859     Py_DECREF(tmp_for_loop_1__for_iterator);
916     tmp_for_loop_1__for_iterator = NULL; 860     tmp_for_loop_1__for_iterator = NULL;
917     { 861     {
918         PyObject *tmp_called_value_2; 862         PyObject *tmp_called_value_2;
919         PyObject *tmp_call_result_2; 863         PyObject *tmp_call_result_2;
n 920         tmp_called_value_2 = LOOKUP_BUILTIN(mod_consts[13]); n 864         tmp_called_value_2 = LOOKUP_BUILTIN(mod_consts[14]);
921         assert(tmp_called_value_2 != NULL); 865         assert(tmp_called_value_2 != NULL);
922         frame_5e2c9601d69e371b1eb3e623b6e39752->m_frame.f_lineno = 44; 866         frame_5e2c9601d69e371b1eb3e623b6e39752->m_frame.f_lineno = 44;
t 923         tmp_call_result_2 = CALL_FUNCTION_WITH_POSARGS1(tmp_called_value_2, mod_consts[14]); t 867         tmp_call_result_2 = CALL_FUNCTION_WITH_POSARGS1(tmp_called_value_2, mod_consts[15]);
924 868
925         if (tmp_call_result_2 == NULL) { 869         if (tmp_call_result_2 == NULL) {
926             assert(ERROR_OCCURRED()); 870             assert(ERROR_OCCURRED());
927 871
928             FETCH_ERROR_OCCURRED(&exception_type, &exception_value, &exception_tb); 872             FETCH_ERROR_OCCURRED(&exception_type, &exception_value, &exception_tb);