Commit 6cb460b6 authored by Robert Bradshaw's avatar Robert Bradshaw

merge 0.10.2

parents d9376736 779b34dd
...@@ -5,3 +5,4 @@ a09347d7b470290076b983aef98707921445a038 0.9.8.1 ...@@ -5,3 +5,4 @@ a09347d7b470290076b983aef98707921445a038 0.9.8.1
82084a7b654e2a133ab64ceb47e03d6e7a204990 0.9.9.2.beta 82084a7b654e2a133ab64ceb47e03d6e7a204990 0.9.9.2.beta
a89b05b78236a27a654f3004bdffc7b8a56311a7 0.10 a89b05b78236a27a654f3004bdffc7b8a56311a7 0.10
ef9d2c680684d0df7d81f529cda29e9e1741f575 cython-0.10.1 ef9d2c680684d0df7d81f529cda29e9e1741f575 cython-0.10.1
92baafe0edf3cea00deb7ce1e31e337bb485af1a 0.10.2
...@@ -710,7 +710,11 @@ def use_py2_buffer_functions(env): ...@@ -710,7 +710,11 @@ def use_py2_buffer_functions(env):
# Search all types for __getbuffer__ overloads # Search all types for __getbuffer__ overloads
types = [] types = []
visited_scopes = set()
def find_buffer_types(scope): def find_buffer_types(scope):
if scope in visited_scopes:
return
visited_scopes.add(scope)
for m in scope.cimported_modules: for m in scope.cimported_modules:
find_buffer_types(m) find_buffer_types(m)
for e in scope.type_entries: for e in scope.type_entries:
......
...@@ -794,11 +794,30 @@ class CStructOrUnionDefNode(StatNode): ...@@ -794,11 +794,30 @@ class CStructOrUnionDefNode(StatNode):
self.entry = env.declare_struct_or_union( self.entry = env.declare_struct_or_union(
self.name, self.kind, scope, self.typedef_flag, self.pos, self.name, self.kind, scope, self.typedef_flag, self.pos,
self.cname, visibility = self.visibility) self.cname, visibility = self.visibility)
need_typedef_indirection = False
if self.attributes is not None: if self.attributes is not None:
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)
for attr in scope.var_entries:
type = attr.type
while type.is_array:
type = type.base_type
if type == self.entry.type:
error(attr.pos, "Struct cannot contain itself as a member.")
if self.typedef_flag:
while type.is_ptr:
type = type.base_type
if type == self.entry.type:
need_typedef_indirection = True
if need_typedef_indirection and self.visibility != 'extern':
# C can't handle typedef structs that refer to themselves.
struct_entry = self.entry
cname = env.new_const_cname()
self.entry = env.declare_typedef(self.name, struct_entry.type, self.pos, cname = self.cname, visibility='ignore')
struct_entry.type.typedef_flag = False
struct_entry.cname = struct_entry.type.cname = env.new_const_cname()
def analyse_expressions(self, env): def analyse_expressions(self, env):
pass pass
......
version = '0.10.1' version = '0.10.2'
...@@ -7,3 +7,6 @@ cdef order order1 ...@@ -7,3 +7,6 @@ cdef order order1
order1.spam = 7 order1.spam = 7
order1.eggs = 2 order1.eggs = 2
ctypedef struct linked:
int a
linked *next
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