Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Xavier Thompson
cython
Commits
e77528ab
Commit
e77528ab
authored
Sep 11, 2017
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use a context manager for holding back compile errors.
parent
0c6c64c0
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
39 additions
and
25 deletions
+39
-25
Cython/Compiler/Errors.py
Cython/Compiler/Errors.py
+16
-0
Cython/Compiler/ExprNodes.py
Cython/Compiler/ExprNodes.py
+23
-25
No files found.
Cython/Compiler/Errors.py
View file @
e77528ab
...
...
@@ -10,6 +10,7 @@ except ImportError:
any_string_type
=
(
bytes
,
str
)
import
sys
from
contextlib
import
contextmanager
from
..Utils
import
open_new_file
from
.
import
DebugFlags
...
...
@@ -228,19 +229,34 @@ def warn_once(position, message, level=0):
error_stack
=
[]
def
hold_errors
():
error_stack
.
append
([])
def
release_errors
(
ignore
=
False
):
held_errors
=
error_stack
.
pop
()
if
not
ignore
:
for
err
in
held_errors
:
report_error
(
err
)
def
held_errors
():
return
error_stack
[
-
1
]
# same as context manager:
@
contextmanager
def
local_errors
(
ignore
=
False
):
errors
=
[]
error_stack
.
append
(
errors
)
try
:
yield
errors
finally
:
release_errors
(
ignore
=
ignore
)
# this module needs a redesign to support parallel cythonisation, but
# for now, the following works at least in sequential compiler runs
...
...
Cython/Compiler/ExprNodes.py
View file @
e77528ab
...
...
@@ -7,7 +7,7 @@ from __future__ import absolute_import
import
cython
cython
.
declare
(
error
=
object
,
warning
=
object
,
warn_once
=
object
,
InternalError
=
object
,
CompileError
=
object
,
UtilityCode
=
object
,
TempitaUtilityCode
=
object
,
StringEncoding
=
object
,
operator
=
object
,
Options
=
object
,
StringEncoding
=
object
,
operator
=
object
,
local_errors
=
object
,
report_error
=
object
,
Naming
=
object
,
Nodes
=
object
,
PyrexTypes
=
object
,
py_object_type
=
object
,
list_type
=
object
,
tuple_type
=
object
,
set_type
=
object
,
dict_type
=
object
,
unicode_type
=
object
,
str_type
=
object
,
bytes_type
=
object
,
type_type
=
object
,
...
...
@@ -21,13 +21,12 @@ import copy
import
os.path
import
operator
from
.Errors
import
error
,
warning
,
warn_once
,
InternalError
,
CompileError
from
.Errors
import
hold_errors
,
release_errors
,
held_errors
,
report_error
from
.Errors
import
(
error
,
warning
,
InternalError
,
CompileError
,
report_error
,
local_errors
)
from
.Code
import
UtilityCode
,
TempitaUtilityCode
from
.
import
StringEncoding
from
.
import
Naming
from
.
import
Nodes
from
.
import
Options
from
.Nodes
import
Node
,
utility_code_for_imports
,
analyse_type_annotation
from
.
import
PyrexTypes
from
.PyrexTypes
import
py_object_type
,
c_long_type
,
typecast
,
error_type
,
\
...
...
@@ -1363,17 +1362,16 @@ def _analyse_name_as_type(name, pos, env):
type
=
PyrexTypes
.
parse_basic_type
(
name
)
if
type
is
not
None
:
return
type
hold_errors
()
from
.TreeFragment
import
TreeFragment
pos
=
(
pos
[
0
],
pos
[
1
],
pos
[
2
]
-
7
)
try
:
declaration
=
TreeFragment
(
u"sizeof(%s)"
%
name
,
name
=
pos
[
0
].
filename
,
initial_pos
=
pos
)
except
CompileError
:
sizeof_node
=
None
else
:
sizeof_node
=
declaration
.
root
.
stats
[
0
].
expr
sizeof_node
=
sizeof_node
.
analyse_types
(
env
)
release_errors
(
ignore
=
True
)
with
local_errors
(
ignore
=
True
):
from
.TreeFragment
import
TreeFragment
pos
=
(
pos
[
0
],
pos
[
1
],
pos
[
2
]
-
7
)
try
:
declaration
=
TreeFragment
(
u"sizeof(%s)"
%
name
,
name
=
pos
[
0
].
filename
,
initial_pos
=
pos
)
except
CompileError
:
sizeof_node
=
None
else
:
sizeof_node
=
declaration
.
root
.
stats
[
0
].
expr
sizeof_node
=
sizeof_node
.
analyse_types
(
env
)
if
isinstance
(
sizeof_node
,
SizeofTypeNode
):
return
sizeof_node
.
arg_type
return
None
...
...
@@ -7755,11 +7753,10 @@ class ListNode(SequenceNode):
return
node
.
coerce_to_pyobject
(
env
)
def
analyse_types
(
self
,
env
):
hold_errors
()
self
.
original_args
=
list
(
self
.
args
)
node
=
SequenceNode
.
analyse_types
(
self
,
env
)
node
.
obj_conversion_errors
=
held_errors
()
release_errors
(
ignore
=
True
)
with
local_errors
(
ignore
=
True
)
as
errors
:
self
.
original_args
=
list
(
self
.
args
)
node
=
SequenceNode
.
analyse_types
(
self
,
env
)
node
.
obj_conversion_errors
=
errors
if
env
.
is_module_scope
:
self
.
in_module_scope
=
True
node
=
node
.
_create_merge_node_if_necessary
(
env
)
...
...
@@ -8407,11 +8404,12 @@ class DictNode(ExprNode):
return
dict_type
def
analyse_types
(
self
,
env
):
hold_errors
()
self
.
key_value_pairs
=
[
item
.
analyse_types
(
env
)
for
item
in
self
.
key_value_pairs
]
self
.
obj_conversion_errors
=
held_errors
()
release_errors
(
ignore
=
True
)
with
local_errors
(
ignore
=
True
)
as
errors
:
self
.
key_value_pairs
=
[
item
.
analyse_types
(
env
)
for
item
in
self
.
key_value_pairs
]
self
.
obj_conversion_errors
=
errors
return
self
def
may_be_none
(
self
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment