Construct CallCompiledObjectMethodPosArgsConstant6

Performance Diagrams

Construct CallCompiledObjectMethodPosArgsConstant6 002000000020000000400000004000000060000000600000008000000080000000100000000100000000120000000120000000140000000140000000160000000160000000180000000180000000200000000200000000220000000220000000240000000240000000260000000260000000CPython 2.7Nuitka (historic)Nuitka (master)Nuitka (develop)Nuitka (factory)26472891572.9230769230769257.0CPython 2.7104953611194.46153846153845406.14477967017694Nuitka (historic)88057775316.0421.916464495533Nuitka (master)88057665437.53846153846143421.9165671767694Nuitka (develop)88007835559.0769230769231421.9630817768666Nuitka (factory)Construct CallCompiledObjectMethodPosArgsConstant6Ticks Construct CallCompiledObjectMethodPosArgsConstant6 002000000020000000400000004000000060000000600000008000000080000000100000000100000000120000000120000000140000000140000000160000000160000000180000000180000000200000000200000000220000000220000000240000000240000000CPython 3.5Nuitka (historic)Nuitka (master)Nuitka (develop)Nuitka (factory)25075366172.9230769230769257.0CPython 3.50194.46153846153845504.11538461538464Nuitka (historic)86715616316.0418.6579571363896Nuitka (master)86713204437.53846153846143418.6603341398013Nuitka (develop)85434656559.0769230769231419.9203312202397Nuitka (factory)Construct CallCompiledObjectMethodPosArgsConstant6Ticks

Source Code with Construct

from __future__ import print_function

class C(object):
    def compiled_method(self, a,b,c,d,e,f):
        return a, b, c, d, e, f

def calledRepeatedly():
    inst = C()

    # This is supposed to make a call to a non-compiled function, which is
    # being optimized separately.
# construct_begin
    inst.compiled_method("some", "random", "values", "to", "check", "call")
    inst.compiled_method("some", "other", "values", "to", "check", "call")
    inst.compiled_method("some", "new", "values", "to", "check", "call")

# construct_alternative



for x in xrange(50000):
    calledRepeatedly()

print("OK.")

Source Code without Construct

from __future__ import print_function

class C(object):
    def compiled_method(self, a,b,c,d,e,f):
        return a, b, c, d, e, f

def calledRepeatedly():
    inst = C()

    # This is supposed to make a call to a non-compiled function, which is
    # being optimized separately.
# construct_begin




# construct_alternative
    pass
# construct_end

for x in xrange(50000):
    calledRepeatedly()

print("OK.")

Context Diff of Source Code


Construct
Baseline
27     inst = C() 27     inst = C()
28 28
29     # This is supposed to make a call to a non-compiled function, which is 29     # This is supposed to make a call to a non-compiled function, which is
30     # being optimized separately. 30     # being optimized separately.
31 # construct_begin 31 # construct_begin
n 32     inst.compiled_method("some", "random", "values", "to", "check", "call") n 32  
33     inst.compiled_method("some", "other", "values", "to", "check", "call") 33  
34     inst.compiled_method("some", "new", "values", "to", "check", "call") 34  
35 35
36 # construct_alternative 36 # construct_alternative
t 37   t 37     pass
38   38 # construct_end
39 39
40 for x in xrange(50000): 40 for x in xrange(50000):
41     calledRepeatedly() 41     calledRepeatedly()
42 42
43 print("OK.") 43 print("OK.")

Context Diff of Generated Code


Construct
Baseline
29 29
30 PyObject *module___main__; 30 PyObject *module___main__;
31 PyDictObject *moduledict___main__; 31 PyDictObject *moduledict___main__;
32 32
33 /* The module constants used, if any. */ 33 /* The module constants used, if any. */
n 34 static PyObject *const_str_plain_to; n
35 static PyObject *const_str_plain_b; 34 static PyObject *const_str_plain_b;
36 extern PyObject *const_str_plain___module__; 35 extern PyObject *const_str_plain___module__;
37 static PyObject *const_str_plain_metaclass; 36 static PyObject *const_str_plain_metaclass;
38 static PyObject *const_str_plain___package__; 37 static PyObject *const_str_plain___package__;
39 static PyObject *const_str_plain_compiled_method; 38 static PyObject *const_str_plain_compiled_method;
40 static PyObject *const_str_digest_757227af6dac5c01686d3bbc7671f8bf; 39 static PyObject *const_str_digest_757227af6dac5c01686d3bbc7671f8bf;
n 41 static PyObject *const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple; n
42 static PyObject *const_str_plain___qualname__; 40 static PyObject *const_str_plain___qualname__;
43 static PyObject *const_str_plain_f; 41 static PyObject *const_str_plain_f;
n 44 static PyObject *const_str_plain_values; n 42 extern PyObject *const_int_pos_1;
45 extern PyObject *const_dict_empty; 43 extern PyObject *const_dict_empty;
n 46 extern PyObject *const_int_pos_1; n
47 static PyObject *const_str_plain_object; 44 static PyObject *const_str_plain_object;
48 extern PyObject *const_str_plain___file__; 45 extern PyObject *const_str_plain___file__;
n 49 static PyObject *const_str_plain_other; n
50 extern PyObject *const_int_0; 46 extern PyObject *const_int_0;
n 51 static PyObject *const_str_plain_check; n
52 static PyObject *const_xrange_0_50000; 47 static PyObject *const_xrange_0_50000;
53 extern PyObject *const_str_plain_print; 48 extern PyObject *const_str_plain_print;
54 static PyObject *const_str_plain___prepare__; 49 static PyObject *const_str_plain___prepare__;
55 static PyObject *const_str_plain_a; 50 static PyObject *const_str_plain_a;
n 56 static PyObject *const_str_plain_call; n
57 static PyObject *const_int_pos_50000; 51 static PyObject *const_int_pos_50000;
58 static PyObject *const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple; 52 static PyObject *const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple;
n 59 static PyObject *const_str_plain_random; n
60 static PyObject *const_str_plain_self; 53 static PyObject *const_str_plain_self;
61 static PyObject *const_str_plain_inst; 54 static PyObject *const_str_plain_inst;
62 static PyObject *const_str_plain_e; 55 static PyObject *const_str_plain_e;
63 static PyObject *const_str_plain_calledRepeatedly; 56 static PyObject *const_str_plain_calledRepeatedly;
64 static PyObject *const_str_angle_module; 57 static PyObject *const_str_angle_module;
67 static PyObject *const_str_plain_C; 60 static PyObject *const_str_plain_C;
68 extern PyObject *const_tuple_empty; 61 extern PyObject *const_tuple_empty;
69 static PyObject *const_str_plain_c; 62 static PyObject *const_str_plain_c;
70 static PyObject *const_str_digest_5ed1392909ad16e6227b8230f4582352; 63 static PyObject *const_str_digest_5ed1392909ad16e6227b8230f4582352;
71 static PyObject *const_tuple_str_plain_inst_tuple; 64 static PyObject *const_tuple_str_plain_inst_tuple;
n 72 static PyObject *const_str_plain_some; n
73 static PyObject *const_str_plain_new;
74 extern PyObject *const_str_plain___loader__; 65 extern PyObject *const_str_plain___loader__;
75 extern PyObject *const_str_plain___main__; 66 extern PyObject *const_str_plain___main__;
76 extern PyObject *const_str_plain_type; 67 extern PyObject *const_str_plain_type;
n 77 static PyObject *const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple; n
78 static PyObject *const_tuple_ca2f155a28955fc472d4376e2721d689_tuple;
79 static PyObject *const_str_digest_d1767378229509203095aadd5847e1e5; 68 static PyObject *const_str_digest_d1767378229509203095aadd5847e1e5;
80 static PyObject *const_str_plain_d; 69 static PyObject *const_str_plain_d;
81 extern PyObject *const_str_plain___doc__; 70 extern PyObject *const_str_plain___doc__;
82 extern PyObject *const_str_plain___cached__; 71 extern PyObject *const_str_plain___cached__;
83 static PyObject *module_filename_obj; 72 static PyObject *module_filename_obj;
84 73
85 static bool constants_created = false; 74 static bool constants_created = false;
86 75
87 static void createModuleConstants( void ) 76 static void createModuleConstants( void )
88 { 77 {
n 89     const_str_plain_to = UNSTREAM_STRING( &constant_bin[ 0 ], 2, 1 ); n
90     const_str_plain_b = UNSTREAM_STRING( &constant_bin[ 2 ], 1, 1 ); 78     const_str_plain_b = UNSTREAM_STRING( &constant_bin[ 0 ], 1, 1 );
91     const_str_plain_metaclass = UNSTREAM_STRING( &constant_bin[ 3 ], 9, 1 ); 79     const_str_plain_metaclass = UNSTREAM_STRING( &constant_bin[ 1 ], 9, 1 );
92     const_str_plain___package__ = UNSTREAM_STRING( &constant_bin[ 12 ], 11, 1 ); 80     const_str_plain___package__ = UNSTREAM_STRING( &constant_bin[ 10 ], 11, 1 );
93     const_str_plain_compiled_method = UNSTREAM_STRING( &constant_bin[ 23 ], 15, 1 ); 81     const_str_plain_compiled_method = UNSTREAM_STRING( &constant_bin[ 21 ], 15, 1 );
94     const_str_digest_757227af6dac5c01686d3bbc7671f8bf = UNSTREAM_STRING( &constant_bin[ 38 ], 17, 0 ); 82     const_str_digest_757227af6dac5c01686d3bbc7671f8bf = UNSTREAM_STRING( &constant_bin[ 36 ], 17, 0 );
95     const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple = PyTuple_New( 6 );
96     const_str_plain_some = UNSTREAM_STRING( &constant_bin[ 55 ], 4, 1 );
97     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 0, const_str_plain_some ); Py_INCREF( const_str_plain_some );
98     const_str_plain_new = UNSTREAM_STRING( &constant_bin[ 59 ], 3, 1 );
99     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 1, const_str_plain_new ); Py_INCREF( const_str_plain_new );
100     const_str_plain_values = UNSTREAM_STRING( &constant_bin[ 62 ], 6, 1 );
101     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 2, const_str_plain_values ); Py_INCREF( const_str_plain_values );
102     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 3, const_str_plain_to ); Py_INCREF( const_str_plain_to );
103     const_str_plain_check = UNSTREAM_STRING( &constant_bin[ 68 ], 5, 1 );
104     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 4, const_str_plain_check ); Py_INCREF( const_str_plain_check );
105     const_str_plain_call = UNSTREAM_STRING( &constant_bin[ 73 ], 4, 1 );
106     PyTuple_SET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 5, const_str_plain_call ); Py_INCREF( const_str_plain_call );
107     const_str_plain___qualname__ = UNSTREAM_STRING( &constant_bin[ 77 ], 12, 1 ); 83     const_str_plain___qualname__ = UNSTREAM_STRING( &constant_bin[ 53 ], 12, 1 );
108     const_str_plain_f = UNSTREAM_STRING( &constant_bin[ 89 ], 1, 1 ); 84     const_str_plain_f = UNSTREAM_STRING( &constant_bin[ 65 ], 1, 1 );
109     const_str_plain_object = UNSTREAM_STRING( &constant_bin[ 90 ], 6, 1 ); 85     const_str_plain_object = UNSTREAM_STRING( &constant_bin[ 66 ], 6, 1 );
110     const_str_plain_other = UNSTREAM_STRING( &constant_bin[ 96 ], 5, 1 );
111     const_int_pos_50000 = PyLong_FromUnsignedLong( 50000ul ); 86     const_int_pos_50000 = PyLong_FromUnsignedLong( 50000ul );
112     const_xrange_0_50000 = BUILTIN_XRANGE3( const_int_0, const_int_pos_50000, const_int_pos_1 ); 87     const_xrange_0_50000 = BUILTIN_XRANGE3( const_int_0, const_int_pos_50000, const_int_pos_1 );
n 113     const_str_plain___prepare__ = UNSTREAM_STRING( &constant_bin[ 101 ], 11, 1 ); n 88     const_str_plain___prepare__ = UNSTREAM_STRING( &constant_bin[ 72 ], 11, 1 );
114     const_str_plain_a = UNSTREAM_STRING( &constant_bin[ 6 ], 1, 1 ); 89     const_str_plain_a = UNSTREAM_STRING( &constant_bin[ 4 ], 1, 1 );
115     const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple = PyTuple_New( 1 ); 90     const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple = PyTuple_New( 1 );
n 116     const_str_digest_5ed1392909ad16e6227b8230f4582352 = UNSTREAM_STRING( &constant_bin[ 112 ], 3, 0 ); n 91     const_str_digest_5ed1392909ad16e6227b8230f4582352 = UNSTREAM_STRING( &constant_bin[ 83 ], 3, 0 );
117     PyTuple_SET_ITEM( const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple, 0, const_str_digest_5ed1392909ad16e6227b8230f4582352 ); Py_INCREF( const_str_digest_5ed1392909ad16e6227b8230f4582352 ); 92     PyTuple_SET_ITEM( const_tuple_str_digest_5ed1392909ad16e6227b8230f4582352_tuple, 0, const_str_digest_5ed1392909ad16e6227b8230f4582352 ); Py_INCREF( const_str_digest_5ed1392909ad16e6227b8230f4582352 );
n 118     const_str_plain_random = UNSTREAM_STRING( &constant_bin[ 115 ], 6, 1 ); n
119     const_str_plain_self = UNSTREAM_STRING( &constant_bin[ 121 ], 4, 1 ); 93     const_str_plain_self = UNSTREAM_STRING( &constant_bin[ 86 ], 4, 1 );
120     const_str_plain_inst = UNSTREAM_STRING( &constant_bin[ 125 ], 4, 1 ); 94     const_str_plain_inst = UNSTREAM_STRING( &constant_bin[ 90 ], 4, 1 );
121     const_str_plain_e = UNSTREAM_STRING( &constant_bin[ 4 ], 1, 1 ); 95     const_str_plain_e = UNSTREAM_STRING( &constant_bin[ 2 ], 1, 1 );
122     const_str_plain_calledRepeatedly = UNSTREAM_STRING( &constant_bin[ 129 ], 16, 1 ); 96     const_str_plain_calledRepeatedly = UNSTREAM_STRING( &constant_bin[ 94 ], 16, 1 );
123     const_str_angle_module = UNSTREAM_STRING( &constant_bin[ 145 ], 8, 0 ); 97     const_str_angle_module = UNSTREAM_STRING( &constant_bin[ 110 ], 8, 0 );
124     const_tuple_ba58284e993f645f647ff630deb3d552_tuple = PyTuple_New( 7 ); 98     const_tuple_ba58284e993f645f647ff630deb3d552_tuple = PyTuple_New( 7 );
125     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 0, const_str_plain_self ); Py_INCREF( const_str_plain_self ); 99     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 0, const_str_plain_self ); Py_INCREF( const_str_plain_self );
126     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 1, const_str_plain_a ); Py_INCREF( const_str_plain_a ); 100     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 1, const_str_plain_a ); Py_INCREF( const_str_plain_a );
127     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 2, const_str_plain_b ); Py_INCREF( const_str_plain_b ); 101     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 2, const_str_plain_b ); Py_INCREF( const_str_plain_b );
n 128     const_str_plain_c = UNSTREAM_STRING( &constant_bin[ 7 ], 1, 1 ); n 102     const_str_plain_c = UNSTREAM_STRING( &constant_bin[ 5 ], 1, 1 );
129     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 3, const_str_plain_c ); Py_INCREF( const_str_plain_c ); 103     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 3, const_str_plain_c ); Py_INCREF( const_str_plain_c );
n 130     const_str_plain_d = UNSTREAM_STRING( &constant_bin[ 30 ], 1, 1 ); n 104     const_str_plain_d = UNSTREAM_STRING( &constant_bin[ 28 ], 1, 1 );
131     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 4, const_str_plain_d ); Py_INCREF( const_str_plain_d ); 105     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 4, const_str_plain_d ); Py_INCREF( const_str_plain_d );
132     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 5, const_str_plain_e ); Py_INCREF( const_str_plain_e ); 106     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 5, const_str_plain_e ); Py_INCREF( const_str_plain_e );
133     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 6, const_str_plain_f ); Py_INCREF( const_str_plain_f ); 107     PyTuple_SET_ITEM( const_tuple_ba58284e993f645f647ff630deb3d552_tuple, 6, const_str_plain_f ); Py_INCREF( const_str_plain_f );
n 134     const_str_plain_x = UNSTREAM_STRING( &constant_bin[ 153 ], 1, 1 ); n 108     const_str_plain_x = UNSTREAM_STRING( &constant_bin[ 118 ], 1, 1 );
135     const_str_plain_C = UNSTREAM_STRING( &constant_bin[ 38 ], 1, 1 ); 109     const_str_plain_C = UNSTREAM_STRING( &constant_bin[ 36 ], 1, 1 );
136     const_tuple_str_plain_inst_tuple = PyTuple_New( 1 ); 110     const_tuple_str_plain_inst_tuple = PyTuple_New( 1 );
137     PyTuple_SET_ITEM( const_tuple_str_plain_inst_tuple, 0, const_str_plain_inst ); Py_INCREF( const_str_plain_inst ); 111     PyTuple_SET_ITEM( const_tuple_str_plain_inst_tuple, 0, const_str_plain_inst ); Py_INCREF( const_str_plain_inst );
n 138     const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple = PyTuple_New( 6 ); n
139     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 0, const_str_plain_some ); Py_INCREF( const_str_plain_some );
140     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 1, const_str_plain_random ); Py_INCREF( const_str_plain_random );
141     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 2, const_str_plain_values ); Py_INCREF( const_str_plain_values );
142     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 3, const_str_plain_to ); Py_INCREF( const_str_plain_to );
143     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 4, const_str_plain_check ); Py_INCREF( const_str_plain_check );
144     PyTuple_SET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 5, const_str_plain_call ); Py_INCREF( const_str_plain_call );
145     const_tuple_ca2f155a28955fc472d4376e2721d689_tuple = PyTuple_New( 6 );
146     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 0, const_str_plain_some ); Py_INCREF( const_str_plain_some );
147     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 1, const_str_plain_other ); Py_INCREF( const_str_plain_other );
148     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 2, const_str_plain_values ); Py_INCREF( const_str_plain_values );
149     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 3, const_str_plain_to ); Py_INCREF( const_str_plain_to );
150     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 4, const_str_plain_check ); Py_INCREF( const_str_plain_check );
151     PyTuple_SET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 5, const_str_plain_call ); Py_INCREF( const_str_plain_call );
152     const_str_digest_d1767378229509203095aadd5847e1e5 = UNSTREAM_STRING( &constant_bin[ 154 ], 98, 0 ); 112     const_str_digest_d1767378229509203095aadd5847e1e5 = UNSTREAM_STRING( &constant_bin[ 119 ], 98, 0 );
153 113
154     constants_created = true; 114     constants_created = true;
155 } 115 }
156 116
157 #ifndef __NUITKA_NO_ASSERT__ 117 #ifndef __NUITKA_NO_ASSERT__
494     PyObject *exception_keeper_type_1; 454     PyObject *exception_keeper_type_1;
495     PyObject *exception_keeper_value_1; 455     PyObject *exception_keeper_value_1;
496     PyTracebackObject *exception_keeper_tb_1; 456     PyTracebackObject *exception_keeper_tb_1;
497     NUITKA_MAY_BE_UNUSED int exception_keeper_lineno_1; 457     NUITKA_MAY_BE_UNUSED int exception_keeper_lineno_1;
498     PyObject *tmp_assign_source_1; 458     PyObject *tmp_assign_source_1;
n 499     PyObject *tmp_called_instance_1; n
500     PyObject *tmp_called_instance_2;
501     PyObject *tmp_called_instance_3;
502     PyObject *tmp_called_name_1; 459     PyObject *tmp_called_name_1;
503     PyObject *tmp_return_value; 460     PyObject *tmp_return_value;
n 504     NUITKA_MAY_BE_UNUSED PyObject *tmp_unused; n
505     static struct Nuitka_FrameObject *cache_frame_function = NULL; 461     static struct Nuitka_FrameObject *cache_frame_function = NULL;
506 462
507     struct Nuitka_FrameObject *frame_function; 463     struct Nuitka_FrameObject *frame_function;
508 464
509     char const *type_description; 465     char const *type_description;
557         goto frame_exception_exit_1; 513         goto frame_exception_exit_1;
558     } 514     }
559     assert( var_inst == NULL ); 515     assert( var_inst == NULL );
560     var_inst = tmp_assign_source_1; 516     var_inst = tmp_assign_source_1;
561 517
n 562     tmp_called_instance_1 = var_inst; n
563  
564     frame_function->m_frame.f_lineno = 32;
565     tmp_unused = CALL_METHOD_WITH_ARGS6( tmp_called_instance_1, const_str_plain_compiled_method, &PyTuple_GET_ITEM( const_tuple_78e2f1ad354bdb7db1a0fda186168ee0_tuple, 0 ) );
566  
567     if ( tmp_unused == NULL )
568     {
569         assert( ERROR_OCCURRED() );
570  
571         FETCH_ERROR_OCCURRED( &exception_type, &exception_value, &exception_tb );
572  
573  
574         exception_lineno = 32;
575         type_description = "o";
576         goto frame_exception_exit_1;
577     }
578     Py_DECREF( tmp_unused );
579     tmp_called_instance_2 = var_inst;
580  
581     if ( tmp_called_instance_2 == NULL )
582     {
583  
584         exception_type = PyExc_UnboundLocalError;
585         Py_INCREF( exception_type );
586         exception_value = PyUnicode_FromFormat( "local variable '%s' referenced before assignment", "inst" );
587         exception_tb = NULL;
588         NORMALIZE_EXCEPTION( &exception_type, &exception_value, &exception_tb );
589         CHAIN_EXCEPTION( exception_value );
590  
591         exception_lineno = 33;
592         type_description = "o";
593         goto frame_exception_exit_1;
594     }
595  
596     frame_function->m_frame.f_lineno = 33;
597     tmp_unused = CALL_METHOD_WITH_ARGS6( tmp_called_instance_2, const_str_plain_compiled_method, &PyTuple_GET_ITEM( const_tuple_ca2f155a28955fc472d4376e2721d689_tuple, 0 ) );
598  
599     if ( tmp_unused == NULL )
600     {
601         assert( ERROR_OCCURRED() );
602  
603         FETCH_ERROR_OCCURRED( &exception_type, &exception_value, &exception_tb );
604  
605  
606         exception_lineno = 33;
607         type_description = "o";
608         goto frame_exception_exit_1;
609     }
610     Py_DECREF( tmp_unused );
611     tmp_called_instance_3 = var_inst;
612  
613     if ( tmp_called_instance_3 == NULL )
614     {
615  
616         exception_type = PyExc_UnboundLocalError;
617         Py_INCREF( exception_type );
618         exception_value = PyUnicode_FromFormat( "local variable '%s' referenced before assignment", "inst" );
619         exception_tb = NULL;
620         NORMALIZE_EXCEPTION( &exception_type, &exception_value, &exception_tb );
621         CHAIN_EXCEPTION( exception_value );
622  
623         exception_lineno = 34;
624         type_description = "o";
625         goto frame_exception_exit_1;
626     }
627  
628     frame_function->m_frame.f_lineno = 34;
629     tmp_unused = CALL_METHOD_WITH_ARGS6( tmp_called_instance_3, const_str_plain_compiled_method, &PyTuple_GET_ITEM( const_tuple_4cee4124c8df2995a8a82b981e580f5e_tuple, 0 ) );
630  
631     if ( tmp_unused == NULL )
632     {
633         assert( ERROR_OCCURRED() );
634  
635         FETCH_ERROR_OCCURRED( &exception_type, &exception_value, &exception_tb );
636  
637  
638         exception_lineno = 34;
639         type_description = "o";
640         goto frame_exception_exit_1;
641     }
642     Py_DECREF( tmp_unused );
643 518
644 #if 0 519 #if 0
645     RESTORE_FRAME_EXCEPTION( frame_function ); 520     RESTORE_FRAME_EXCEPTION( frame_function );
646 #endif 521 #endif
647 522
691     // tried codes exits in all cases 566     // tried codes exits in all cases
692     NUITKA_CANNOT_GET_HERE( __main__$$$function_1_calledRepeatedly ); 567     NUITKA_CANNOT_GET_HERE( __main__$$$function_1_calledRepeatedly );
693     return NULL; 568     return NULL;
694     // Return handler code: 569     // Return handler code:
695     try_return_handler_1:; 570     try_return_handler_1:;
n n 571     CHECK_OBJECT( (PyObject *)var_inst );
696     Py_XDECREF( var_inst ); 572     Py_DECREF( var_inst );
697     var_inst = NULL; 573     var_inst = NULL;
698 574
699     goto function_return_exit; 575     goto function_return_exit;
700     // Exception handler code: 576     // Exception handler code:
701     try_except_handler_1:; 577     try_except_handler_1:;
705     exception_keeper_lineno_1 = exception_lineno; 581     exception_keeper_lineno_1 = exception_lineno;
706     exception_type = NULL; 582     exception_type = NULL;
707     exception_value = NULL; 583     exception_value = NULL;
708     exception_tb = NULL; 584     exception_tb = NULL;
709     exception_lineno = -1; 585     exception_lineno = -1;
t 710   t
711     Py_XDECREF( var_inst );
712     var_inst = NULL;
713 586
714     // Re-raise. 587     // Re-raise.
715     exception_type = exception_keeper_type_1; 588     exception_type = exception_keeper_type_1;
716     exception_value = exception_keeper_value_1; 589     exception_value = exception_keeper_value_1;
717     exception_tb = exception_keeper_tb_1; 590     exception_tb = exception_keeper_tb_1;