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
Boxiang Sun
cython
Commits
533ae132
Commit
533ae132
authored
Jun 17, 2009
by
Danilo Freitas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Declaring and using inherited attributes
parent
907de12e
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
57 additions
and
39 deletions
+57
-39
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+4
-0
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+4
-2
Cython/Compiler/Parsing.pxd
Cython/Compiler/Parsing.pxd
+2
-0
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+0
-1
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+8
-6
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+39
-30
No files found.
Cython/Compiler/ModuleNode.py
View file @
533ae132
...
@@ -390,6 +390,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -390,6 +390,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
self
.
generate_typedef
(
entry
,
code
)
self
.
generate_typedef
(
entry
,
code
)
elif
type
.
is_struct_or_union
:
elif
type
.
is_struct_or_union
:
self
.
generate_struct_union_definition
(
entry
,
code
)
self
.
generate_struct_union_definition
(
entry
,
code
)
elif
type
.
is_cpp_class
:
self
.
generate_cpp_class_definition
(
entry
,
code
)
elif
type
.
is_enum
:
elif
type
.
is_enum
:
self
.
generate_enum_definition
(
entry
,
code
)
self
.
generate_enum_definition
(
entry
,
code
)
elif
type
.
is_extension_type
and
entry
not
in
vtabslot_entries
:
elif
type
.
is_extension_type
and
entry
not
in
vtabslot_entries
:
...
@@ -637,6 +639,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -637,6 +639,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
self
.
generate_typedef
(
entry
,
code
)
self
.
generate_typedef
(
entry
,
code
)
elif
type
.
is_struct_or_union
:
elif
type
.
is_struct_or_union
:
self
.
generate_struct_union_definition
(
entry
,
code
)
self
.
generate_struct_union_definition
(
entry
,
code
)
elif
type
.
is_cpp_class
:
self
.
generate_cpp_class_definition
(
entry
,
code
)
elif
type
.
is_enum
:
elif
type
.
is_enum
:
self
.
generate_enum_definition
(
entry
,
code
)
self
.
generate_enum_definition
(
entry
,
code
)
elif
type
.
is_extension_type
:
elif
type
.
is_extension_type
:
...
...
Cython/Compiler/Nodes.py
View file @
533ae132
...
@@ -916,8 +916,10 @@ class CppClassNode(CStructOrUnionDefNode):
...
@@ -916,8 +916,10 @@ class CppClassNode(CStructOrUnionDefNode):
def
analyse_declarations
(
self
,
env
):
def
analyse_declarations
(
self
,
env
):
scope
=
None
scope
=
None
if
self
.
attributes
is
not
None
:
if
len
(
self
.
attributes
)
!=
0
:
scope
=
CppClassScope
(
self
.
name
)
scope
=
CppClassScope
(
self
.
name
)
else
:
self
.
attributes
=
None
self
.
entry
=
env
.
declare_cpp_class
(
self
.
entry
=
env
.
declare_cpp_class
(
self
.
name
,
"cppclass"
,
scope
,
0
,
self
.
pos
,
self
.
name
,
"cppclass"
,
scope
,
0
,
self
.
pos
,
self
.
cname
,
self
.
base_classes
,
self
.
namespace
,
visibility
=
self
.
visibility
)
self
.
cname
,
self
.
base_classes
,
self
.
namespace
,
visibility
=
self
.
visibility
)
...
@@ -925,7 +927,7 @@ class CppClassNode(CStructOrUnionDefNode):
...
@@ -925,7 +927,7 @@ class CppClassNode(CStructOrUnionDefNode):
if
self
.
in_pxd
and
not
env
.
in_cinclude
:
if
self
.
in_pxd
and
not
env
.
in_cinclude
:
self
.
entry
.
defined_in_pxd
=
1
self
.
entry
.
defined_in_pxd
=
1
for
attr
in
self
.
attributes
:
for
attr
in
self
.
attributes
:
attr
.
analyse_declarations
(
env
,
scope
)
attr
.
analyse_declarations
(
env
,
scope
)
class
CEnumDefNode
(
StatNode
):
class
CEnumDefNode
(
StatNode
):
# name string or None
# name string or None
...
...
Cython/Compiler/Parsing.pxd
View file @
533ae132
...
@@ -149,3 +149,5 @@ cpdef p_doc_string(PyrexScanner s)
...
@@ -149,3 +149,5 @@ cpdef p_doc_string(PyrexScanner s)
cpdef
p_code
(
PyrexScanner
s
,
level
=
*
)
cpdef
p_code
(
PyrexScanner
s
,
level
=
*
)
cpdef
p_compiler_directive_comments
(
PyrexScanner
s
)
cpdef
p_compiler_directive_comments
(
PyrexScanner
s
)
cpdef
p_module
(
PyrexScanner
s
,
pxd
,
full_module_name
)
cpdef
p_module
(
PyrexScanner
s
,
pxd
,
full_module_name
)
cpdef
p_cpp_class_definition
(
PyrexScanner
s
,
ctx
)
Cython/Compiler/Parsing.py
View file @
533ae132
...
@@ -2564,7 +2564,6 @@ def p_cpp_class_definition(s, pos, ctx):
...
@@ -2564,7 +2564,6 @@ def p_cpp_class_definition(s, pos, ctx):
if s.sy == '[':
if s.sy == '[':
error(s.position(), "
Name
options
not
allowed
for
C
++
class
")
error(s.position(), "
Name
options
not
allowed
for
C
++
class
")
if s.sy == ':':
if s.sy == ':':
attributes = None
s.next()
s.next()
s.expect('NEWLINE')
s.expect('NEWLINE')
s.expect_indent()
s.expect_indent()
...
...
Cython/Compiler/PyrexTypes.py
View file @
533ae132
...
@@ -1372,7 +1372,7 @@ class CppClassType(CType):
...
@@ -1372,7 +1372,7 @@ class CppClassType(CType):
has_attributes
=
1
has_attributes
=
1
base_classes
=
[]
base_classes
=
[]
namespace
=
None
namespace
=
None
def
__init__
(
self
,
name
,
kind
,
scope
,
typedef_flag
,
cname
,
base_classes
,
def
__init__
(
self
,
name
,
kind
,
scope
,
typedef_flag
,
cname
,
base_classes
,
namespace
=
None
,
packed
=
False
):
namespace
=
None
,
packed
=
False
):
self
.
name
=
name
self
.
name
=
name
...
@@ -1396,16 +1396,18 @@ class CppClassType(CType):
...
@@ -1396,16 +1396,18 @@ class CppClassType(CType):
return
"%s %s"
%
(
name
,
entity_code
)
return
"%s %s"
%
(
name
,
entity_code
)
def
is_subclass
(
self
,
other_type
):
def
is_subclass
(
self
,
other_type
):
if
not
base_classes
.
empty
():
for
base_class
in
self
.
base_classes
:
for
base_class
in
self
.
base_classes
:
if
base_class
.
is_subclass
(
other_type
):
if
base_class
.
is_subclass
(
other_type
):
return
1
return
1
return
0
return
0
def
assignable_from_resolved_type
(
self
,
other_type
):
def
assignable_from_resolved_type
(
self
,
other_type
):
print
self
.
same_as_resolved_type
(
other_type
)
print
self
.
same_as
(
other_type
)
print
other_type
.
is_subclass
(
self
)
if
self
.
same_as_resolved_type
(
other_type
):
if
self
.
same_as_resolved_type
(
other_type
):
return
1
return
1
if
other
.
is_subclass
(
self
)
or
self
.
same_as
(
other_type
):
if
other
_type
.
is_subclass
(
self
)
or
self
.
same_as
(
other_type
):
return
1
return
1
return
0
return
0
...
...
Cython/Compiler/Symtab.py
View file @
533ae132
...
@@ -384,34 +384,6 @@ class Scope(object):
...
@@ -384,34 +384,6 @@ class Scope(object):
self.check_for_illegal_incomplete_ctypedef(typedef_flag, pos)
self.check_for_illegal_incomplete_ctypedef(typedef_flag, pos)
return entry
return entry
def declare_cpp_class(self, name, kind, scope,
typedef_flag, pos, cname = None, base_classes = [], namespace = None,
visibility = 'extern', packed = False):
if visibility != 'extern':
error(pos, "
C
++
classes
may
only
be
extern
")
if cname is None:
cname = name
entry = self.lookup(name)
if not entry:
type = PyrexTypes.CppClassType(
name, kind, scope, typedef_flag, cname, base_classes, namespace, packed)
entry = self.declare_type(name, type, pos, cname,
visibility = visibility, defining = scope is not None)
else:
if not (entry.is_type and entry.type.is_cpp_class
and entry.type.kind == kind):
warning(pos, "'%s'
redeclared
" % name, 0)
elif scope and entry.type.scope:
warning(pos, "'%s'
already
defined
(
ignoring
second
definition
)
" % name, 0)
else:
self.check_previous_typedef_flag(entry, typedef_flag, pos)
if scope:
entry.type.scope = scope
self.type_entries.append(entry)
if not scope and not entry.type.scope:
self.check_for_illegal_incomplete_ctypedef(typedef_flag, pos)
return entry
def check_previous_typedef_flag(self, entry, typedef_flag, pos):
def check_previous_typedef_flag(self, entry, typedef_flag, pos):
if typedef_flag != entry.type.typedef_flag:
if typedef_flag != entry.type.typedef_flag:
error(pos, "'%s'
previously
declared
using
'%s'" % (
error(pos, "'%s'
previously
declared
using
'%s'" % (
...
@@ -1122,6 +1094,44 @@ class ModuleScope(Scope):
...
@@ -1122,6 +1094,44 @@ class ModuleScope(Scope):
#
#
return entry
return entry
def declare_cpp_class(self, name, kind, scope,
typedef_flag, pos, cname = None, base_classes = [], namespace = None,
visibility = '
extern
', packed = False):
def declare_inherited_attributes(entry, base_entry):
if base_entry:
for base_class in base_entry.type.base_classes:
new_entry = self.lookup(base_class)
if base_entry:
declare_inherited_attributes(entry, new_entry)
entry.type.scope.declare_inherited_cpp_attributes(new_entry.type.scope)
if visibility != '
extern
':
error(pos, "C++ classes may only be extern")
if cname is None:
cname = name
entry = self.lookup(name)
if not entry:
type = PyrexTypes.CppClassType(
name, kind, scope, typedef_flag, cname, base_classes, namespace, packed)
entry = self.declare_type(name, type, pos, cname,
visibility = visibility, defining = scope is not None)
else:
if not (entry.is_type and entry.type.is_cpp_class
and entry.type.kind == kind):
warning(pos, "'
%
s
' redeclared " % name, 0)
elif scope and entry.type.scope:
warning(pos, "'
%
s
' already defined (ignoring second definition)" % name, 0)
else:
self.check_previous_typedef_flag(entry, typedef_flag, pos)
if scope:
entry.type.scope = scope
self.type_entries.append(entry)
if not scope and not entry.type.scope:
self.check_for_illegal_incomplete_ctypedef(typedef_flag, pos)
entry.type.scope = CppClassScope(name)
declare_inherited_attributes(entry, entry)
return entry
def check_for_illegal_incomplete_ctypedef(self, typedef_flag, pos):
def check_for_illegal_incomplete_ctypedef(self, typedef_flag, pos):
if typedef_flag and not self.in_cinclude:
if typedef_flag and not self.in_cinclude:
error(pos, "Forward-referenced type must use '
cdef
', not '
ctypedef
'")
error(pos, "Forward-referenced type must use '
cdef
', not '
ctypedef
'")
...
@@ -1582,6 +1592,7 @@ class CClassScope(ClassScope):
...
@@ -1582,6 +1592,7 @@ class CClassScope(ClassScope):
class
CppClassScope
(
Scope
):
class
CppClassScope
(
Scope
):
# Namespace of a C++ class.
# Namespace of a C++ class.
inherited_var_entries
=
[]
def
__init__
(
self
,
name
=
"?"
):
def
__init__
(
self
,
name
=
"?"
):
Scope
.
__init__
(
self
,
name
,
None
,
None
)
Scope
.
__init__
(
self
,
name
,
None
,
None
)
...
@@ -1591,8 +1602,6 @@ class CppClassScope(Scope):
...
@@ -1591,8 +1602,6 @@ class CppClassScope(Scope):
# Add an entry for an attribute.
# Add an entry for an attribute.
if
not
cname
:
if
not
cname
:
cname
=
name
cname
=
name
if
visibility
!=
'extern'
:
error
(
pos
,
"Visibility for C++ class member are extern only"
)
if
type
.
is_cfunction
:
if
type
.
is_cfunction
:
type
=
PyrexTypes
.
CPtrType
(
type
)
type
=
PyrexTypes
.
CPtrType
(
type
)
entry
=
self
.
declare
(
name
,
cname
,
type
,
pos
,
visibility
)
entry
=
self
.
declare
(
name
,
cname
,
type
,
pos
,
visibility
)
...
...
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