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
Gwenaël Samain
cython
Commits
9bac9c2e
Commit
9bac9c2e
authored
Jun 10, 2008
by
Robert Bradshaw
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Finish porting circular import patch from Pyrex.
parent
5f13fdb2
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
55 additions
and
17 deletions
+55
-17
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+32
-4
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+15
-9
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+8
-4
No files found.
Cython/Compiler/Nodes.py
View file @
9bac9c2e
...
@@ -3656,8 +3656,8 @@ class CImportStatNode(StatNode):
...
@@ -3656,8 +3656,8 @@ class CImportStatNode(StatNode):
class
FromCImportStatNode
(
StatNode
):
class
FromCImportStatNode
(
StatNode
):
# from ... cimport statement
# from ... cimport statement
#
#
# module_name string Qualified name of module
# module_name string
Qualified name of module
# imported_names [(pos, name, as_name)] Names to be imported
# imported_names [(pos, name, as_name
, kind
)] Names to be imported
child_attrs
=
[]
child_attrs
=
[]
...
@@ -3667,15 +3667,43 @@ class FromCImportStatNode(StatNode):
...
@@ -3667,15 +3667,43 @@ class FromCImportStatNode(StatNode):
return
return
module_scope
=
env
.
find_module
(
self
.
module_name
,
self
.
pos
)
module_scope
=
env
.
find_module
(
self
.
module_name
,
self
.
pos
)
env
.
add_imported_module
(
module_scope
)
env
.
add_imported_module
(
module_scope
)
for
pos
,
name
,
as_name
in
self
.
imported_names
:
for
pos
,
name
,
as_name
,
kind
in
self
.
imported_names
:
if
name
==
"*"
:
if
name
==
"*"
:
for
local_name
,
entry
in
module_scope
.
entries
.
items
():
for
local_name
,
entry
in
module_scope
.
entries
.
items
():
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
else
:
else
:
entry
=
module_scope
.
find
(
name
,
pos
)
entry
=
module_scope
.
lookup
(
name
)
if
entry
:
if
kind
and
not
self
.
declaration_matches
(
entry
,
kind
):
entry
.
redeclared
(
pos
)
else
:
if
kind
==
'struct'
or
kind
==
'union'
:
entry
=
module_scope
.
declare_struct_or_union
(
name
,
kind
=
kind
,
scope
=
None
,
typedef_flag
=
0
,
pos
=
pos
)
elif
kind
==
'class'
:
entry
=
module_scope
.
declare_c_class
(
name
,
pos
=
pos
,
module_name
=
self
.
module_name
)
else
:
error
(
pos
,
"Name '%s' not declared in module '%s'"
%
(
name
,
self
.
module_name
))
if
entry
:
if
entry
:
local_name
=
as_name
or
name
local_name
=
as_name
or
name
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
def
declaration_matches
(
self
,
entry
,
kind
):
if
not
entry
.
is_type
:
return
0
type
=
entry
.
type
if
kind
==
'class'
:
if
not
type
.
is_extension_type
:
return
0
else
:
if
not
type
.
is_struct_or_union
:
return
0
if
kind
<>
type
.
kind
:
return
0
return
1
def
analyse_expressions
(
self
,
env
):
def
analyse_expressions
(
self
,
env
):
pass
pass
...
...
Cython/Compiler/Parsing.py
View file @
9bac9c2e
...
@@ -959,21 +959,21 @@ def p_from_import_statement(s, first_statement = 0):
...
@@ -959,21 +959,21 @@ def p_from_import_statement(s, first_statement = 0):
s
.
next
()
s
.
next
()
else
:
else
:
s
.
error
(
"Expected 'import' or 'cimport'"
)
s
.
error
(
"Expected 'import' or 'cimport'"
)
is_cimport
=
kind
==
'cimport'
if
s
.
sy
==
'*'
:
if
s
.
sy
==
'*'
:
# s.error("'import *' not supported")
imported_names
=
[(
s
.
position
(),
"*"
,
None
,
None
)]
imported_names
=
[(
s
.
position
(),
"*"
,
None
)]
s
.
next
()
s
.
next
()
else
:
else
:
imported_names
=
[
p_imported_name
(
s
)]
imported_names
=
[
p_imported_name
(
s
,
is_cimport
)]
while
s
.
sy
==
','
:
while
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
imported_names
.
append
(
p_imported_name
(
s
))
imported_names
.
append
(
p_imported_name
(
s
,
is_cimport
))
dotted_name
=
Utils
.
EncodedString
(
dotted_name
)
dotted_name
=
Utils
.
EncodedString
(
dotted_name
)
if
dotted_name
==
'__future__'
:
if
dotted_name
==
'__future__'
:
if
not
first_statement
:
if
not
first_statement
:
s
.
error
(
"from __future__ imports must occur at the beginning of the file"
)
s
.
error
(
"from __future__ imports must occur at the beginning of the file"
)
else
:
else
:
for
(
name_pos
,
name
,
as_name
)
in
imported_names
:
for
(
name_pos
,
name
,
as_name
,
kind
)
in
imported_names
:
try
:
try
:
directive
=
getattr
(
Future
,
name
)
directive
=
getattr
(
Future
,
name
)
except
AttributeError
:
except
AttributeError
:
...
@@ -982,7 +982,7 @@ def p_from_import_statement(s, first_statement = 0):
...
@@ -982,7 +982,7 @@ def p_from_import_statement(s, first_statement = 0):
s
.
context
.
future_directives
.
add
(
directive
)
s
.
context
.
future_directives
.
add
(
directive
)
return
Nodes
.
PassStatNode
(
pos
)
return
Nodes
.
PassStatNode
(
pos
)
elif
kind
==
'cimport'
:
elif
kind
==
'cimport'
:
for
(
name_pos
,
name
,
as_name
)
in
imported_names
:
for
(
name_pos
,
name
,
as_name
,
kind
)
in
imported_names
:
local_name
=
as_name
or
name
local_name
=
as_name
or
name
s
.
add_type_name
(
local_name
)
s
.
add_type_name
(
local_name
)
return
Nodes
.
FromCImportStatNode
(
pos
,
return
Nodes
.
FromCImportStatNode
(
pos
,
...
@@ -991,7 +991,7 @@ def p_from_import_statement(s, first_statement = 0):
...
@@ -991,7 +991,7 @@ def p_from_import_statement(s, first_statement = 0):
else
:
else
:
imported_name_strings
=
[]
imported_name_strings
=
[]
items
=
[]
items
=
[]
for
(
name_pos
,
name
,
as_name
)
in
imported_names
:
for
(
name_pos
,
name
,
as_name
,
kind
)
in
imported_names
:
encoded_name
=
Utils
.
EncodedString
(
name
)
encoded_name
=
Utils
.
EncodedString
(
name
)
imported_name_strings
.
append
(
imported_name_strings
.
append
(
ExprNodes
.
IdentifierStringNode
(
name_pos
,
value
=
encoded_name
))
ExprNodes
.
IdentifierStringNode
(
name_pos
,
value
=
encoded_name
))
...
@@ -1008,11 +1008,17 @@ def p_from_import_statement(s, first_statement = 0):
...
@@ -1008,11 +1008,17 @@ def p_from_import_statement(s, first_statement = 0):
name_list
=
import_list
),
name_list
=
import_list
),
items
=
items
)
items
=
items
)
def
p_imported_name
(
s
):
imported_name_kinds
=
(
'class'
,
'struct'
,
'union'
)
def
p_imported_name
(
s
,
is_cimport
):
pos
=
s
.
position
()
pos
=
s
.
position
()
kind
=
None
if
is_cimport
and
s
.
systring
in
imported_name_kinds
:
kind
=
s
.
systring
s
.
next
()
name
=
p_ident
(
s
)
name
=
p_ident
(
s
)
as_name
=
p_as_name
(
s
)
as_name
=
p_as_name
(
s
)
return
(
pos
,
name
,
as_name
)
return
(
pos
,
name
,
as_name
,
kind
)
def
p_dotted_name
(
s
,
as_allowed
):
def
p_dotted_name
(
s
,
as_allowed
):
pos
=
s
.
position
()
pos
=
s
.
position
()
...
...
Cython/Compiler/Symtab.py
View file @
9bac9c2e
...
@@ -123,6 +123,9 @@ class Entry:
...
@@ -123,6 +123,9 @@ class Entry:
self.pos = pos
self.pos = pos
self.init = init
self.init = init
def redeclared(self, pos):
error(pos, "'%s'
does
not
match
previous
declaration
" % self.name)
error(self.pos, "
Previous
declaration
is
here
")
class Scope:
class Scope:
# name string Unqualified name
# name string Unqualified name
...
@@ -310,7 +313,8 @@ class Scope:
...
@@ -310,7 +313,8 @@ class Scope:
visibility = visibility, defining = scope is not None)
visibility = visibility, defining = scope is not None)
self.sue_entries.append(entry)
self.sue_entries.append(entry)
else:
else:
if not (entry.is_type and entry.type.is_struct_or_union):
if not (entry.is_type and entry.type.is_struct_or_union
and entry.type.kind == kind):
warning(pos, "'%s'
redeclared
" % name, 0)
warning(pos, "'%s'
redeclared
" % name, 0)
elif scope and entry.type.scope:
elif scope and entry.type.scope:
warning(pos, "'%s'
already
defined
(
ignoring
second
definition
)
" % name, 0)
warning(pos, "'%s'
already
defined
(
ignoring
second
definition
)
" % name, 0)
...
@@ -902,9 +906,9 @@ class ModuleScope(Scope):
...
@@ -902,9 +906,9 @@ class ModuleScope(Scope):
return
return
self.utility_code_used.append(new_code)
self.utility_code_used.append(new_code)
def declare_c_class(self, name, pos, defining
, implementing
,
def declare_c_class(self, name, pos, defining
= 0, implementing = 0
,
module_name
, base_type, objstruct_cname, typeobj_cnam
e,
module_name
= None, base_type = None, objstruct_cname = Non
e,
visibility, typedef_flag, api
):
typeobj_cname = None, visibility = 'private', typedef_flag = 0, api = 0
):
#
#
# Look for previous declaration as a type
# Look for previous declaration as a type
#
#
...
...
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