From 4a7bea789410599b4d54eb991e5d59b9d1857a30 Mon Sep 17 00:00:00 2001 From: Dag Sverre Seljebotn <dagss@student.matnat.uio.no> Date: Thu, 21 Aug 2008 15:22:37 +0200 Subject: [PATCH] Backed out changeset a4bd0ff1da10 --- Cython/Compiler/Errors.py | 10 ++------- Cython/Compiler/Main.py | 45 +++++++++++++++------------------------ tests/errors/e_switch.pyx | 2 +- 3 files changed, 20 insertions(+), 37 deletions(-) diff --git a/Cython/Compiler/Errors.py b/Cython/Compiler/Errors.py index db0572eba..a8ad03aff 100644 --- a/Cython/Compiler/Errors.py +++ b/Cython/Compiler/Errors.py @@ -63,16 +63,11 @@ class InternalError(Exception): def __init__(self, message): Exception.__init__(self, "Internal compiler error: %s" % message) - -class AbortCompilationError(Exception): - """ - Raised in order to abort compilation. - """ + listing_file = None num_errors = 0 echo_file = None -last_error = None def open_listing_file(path, echo_to_stderr = 1): # Begin a new error listing. If path is None, no file @@ -95,7 +90,7 @@ def close_listing_file(): listing_file = None def report_error(err): - global num_errors, last_error + global num_errors # See Main.py for why dual reporting occurs. Quick fix for now. if err.reported: return err.reported = True @@ -105,7 +100,6 @@ def report_error(err): if echo_file: echo_file.write(line) num_errors = num_errors + 1 - last_error = err def error(position, message): #print "Errors.error:", repr(position), repr(message) ### diff --git a/Cython/Compiler/Main.py b/Cython/Compiler/Main.py index 10e9049e5..2d8c3dd60 100644 --- a/Cython/Compiler/Main.py +++ b/Cython/Compiler/Main.py @@ -84,11 +84,6 @@ class Context: from Buffer import IntroduceBufferAuxiliaryVars from ModuleNode import check_c_classes - def abort_if_errors(t): - if Errors.num_errors > 0: - raise Errors.AbortCompilationError() - return t - if pxd: _check_c_classes = None _specific_post_parse = PxdPostParse(self) @@ -128,10 +123,10 @@ class Context: # (this seems strange -- I believe the right concept is to split # ModuleNode into a ModuleNode and a CodeGenerator, and tell that # CodeGenerator to generate code both from the pyx and pxd ModuleNodes. - stats.append(statlistnode) - # Until utility code is moved to code generation phase everywhere, - # we need to copy it over to the main scope - module_node.scope.utility_code_list.extend(scope.utility_code_list) + stats.append(statlistnode) + # Until utility code is moved to code generation phase everywhere, + # we need to copy it over to the main scope + module_node.scope.utility_code_list.extend(scope.utility_code_list) return module_node return ([ @@ -172,16 +167,10 @@ class Context: for phase in pipeline: if phase is not None: data = phase(data) - print Errors.num_errors except CompileError, err: - print "hello", err + # err is set Errors.report_error(err) - raise err - except Errors.AbortCompilationError: - print "abort", Errors.num_errors - pass - print "normal" - return data + return (err, data) def find_module(self, module_name, relative_to = None, pos = None, need_pxd = 1): @@ -238,7 +227,10 @@ class Context: if debug_find_module: print("Context.find_module: Parsing %s" % pxd_pathname) source_desc = FileSourceDescriptor(pxd_pathname) - pxd_codenodes, pxd_scope = self.process_pxd(source_desc, scope, module_name) + err, result = self.process_pxd(source_desc, scope, module_name) + if err: + raise err + (pxd_codenodes, pxd_scope) = result self.pxds[module_name] = (pxd_codenodes, pxd_scope) except CompileError: pass @@ -407,7 +399,7 @@ class Context: except UnicodeDecodeError, msg: error((source_desc, 0, 0), "Decoding error, missing or incorrect coding=<encoding-name> at top of source (%s)" % msg) if Errors.num_errors > 0: - raise Errors.AbortCompilationError() + raise CompileError return tree def extract_module_name(self, path, options): @@ -437,13 +429,15 @@ class Context: else: Errors.open_listing_file(None) - def teardown_errors(self, options, result): + def teardown_errors(self, err, options, result): source_desc = result.compilation_source.source_desc if not isinstance(source_desc, FileSourceDescriptor): raise RuntimeError("Only file sources for code supported") Errors.close_listing_file() result.num_errors = Errors.num_errors - if result.num_errors > 0 and result.c_file: + if result.num_errors > 0: + err = True + if err and result.c_file: try: Utils.castrate_file(result.c_file, os.stat(source_desc.filename)) except EnvironmentError: @@ -504,13 +498,8 @@ def run_pipeline(source, options, full_module_name = None): pipeline = context.create_pyx_pipeline(options, result) context.setup_errors(options) - try: - enddata = context.run_pipeline(pipeline, source) - except Errors.CompileError: - pass - except Errors.AbortCompilationError: - pass - context.teardown_errors(options, result) + err, enddata = context.run_pipeline(pipeline, source) + context.teardown_errors(err, options, result) return result #------------------------------------------------------------------------ diff --git a/tests/errors/e_switch.pyx b/tests/errors/e_switch.pyx index 9d0b4453d..405fd0109 100644 --- a/tests/errors/e_switch.pyx +++ b/tests/errors/e_switch.pyx @@ -8,5 +8,5 @@ elif x == 4: print 34 _ERRORS = """ -3:19: undeclared name not builtin: NONEXISTING +4:23: undeclared name not builtin: NONEXISTING """ -- 2.30.9