Commit 729310a8 authored by Stefan Behnel's avatar Stefan Behnel

fix C compiler warning about unused variable

parent 3f8cf084
......@@ -6392,14 +6392,17 @@ class TryFinallyStatNode(StatNode):
finally_clause = copy.deepcopy(self.finally_clause)
preserve_error = self.preserve_exception and code.label_used(new_error_label)
needs_success_cleanup = not finally_clause.is_terminator
if preserve_error:
if self.is_try_finally_in_nogil:
code.declare_gilstate()
code.putln("PyObject *%s, *%s, *%s;" % Naming.exc_vars)
if needs_success_cleanup:
code.putln("int %s;" % Naming.exc_lineno_name)
exc_var_init_zero = ''.join(
["%s = 0; " % var for var in Naming.exc_vars])
if needs_success_cleanup:
exc_var_init_zero += '%s = 0;' % Naming.exc_lineno_name
else:
exc_var_init_zero = None
......@@ -6409,6 +6412,7 @@ class TryFinallyStatNode(StatNode):
if exc_var_init_zero:
code.putln(exc_var_init_zero)
self.finally_clause.generate_execution_code(code)
if not finally_clause.is_terminator:
code.put_goto(catch_label)
code.putln('}')
......@@ -6416,14 +6420,15 @@ class TryFinallyStatNode(StatNode):
code.putln('/*exception exit:*/{')
code.put('%s: ' % new_error_label)
code.putln(exc_var_init_zero)
self.put_error_catcher(code, temps_to_clean_up)
self.put_error_catcher(
code, temps_to_clean_up, include_lineno=needs_success_cleanup)
finally_old_labels = code.all_new_labels()
code.putln('{')
copy.deepcopy(finally_clause).generate_execution_code(code)
code.putln('}')
if not finally_clause.is_terminator:
if needs_success_cleanup:
self.put_error_uncatcher(code)
code.put_goto(old_error_label)
......@@ -6460,7 +6465,7 @@ class TryFinallyStatNode(StatNode):
self.body.generate_function_definitions(env, code)
self.finally_clause.generate_function_definitions(env, code)
def put_error_catcher(self, code, temps_to_clean_up):
def put_error_catcher(self, code, temps_to_clean_up, include_lineno):
code.globalstate.use_utility_code(restore_exception_utility_code)
if self.is_try_finally_in_nogil:
......@@ -6470,6 +6475,7 @@ class TryFinallyStatNode(StatNode):
code.put_xdecref_clear(temp_name, type)
code.putln("__Pyx_ErrFetch(&%s, &%s, &%s);" % Naming.exc_vars)
if include_lineno:
code.putln("%s = %s;" % (Naming.exc_lineno_name, Naming.lineno_cname))
if self.is_try_finally_in_nogil:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment