Commit 8c755a42 authored by Xavier Thompson's avatar Xavier Thompson

Fix type declarations with template-dependent namespaces needing 'typename'

parent d4bff67b
...@@ -431,7 +431,7 @@ class CTypedefType(BaseType): ...@@ -431,7 +431,7 @@ class CTypedefType(BaseType):
else: else:
base_code = public_decl(self.typedef_cname, dll_linkage) base_code = public_decl(self.typedef_cname, dll_linkage)
if self.typedef_namespace is not None and not pyrex: if self.typedef_namespace is not None and not pyrex:
base_code = "%s::%s" % (self.typedef_namespace.empty_declaration_code(), base_code) base_code = "%s::%s" % (namespace_declaration_code(self.typedef_namespace), base_code)
return self.base_declaration_code(base_code, entity_code) return self.base_declaration_code(base_code, entity_code)
def as_argument_type(self): def as_argument_type(self):
...@@ -4014,10 +4014,7 @@ class CppClassType(CType): ...@@ -4014,10 +4014,7 @@ class CppClassType(CType):
else: else:
base_code = "%s%s" % (self.cname, templates) base_code = "%s%s" % (self.cname, templates)
if self.namespace is not None: if self.namespace is not None:
base_code = "%s::%s" % (self.namespace.empty_declaration_code(), base_code) base_code = "%s::%s" % (namespace_declaration_code(self.namespace), base_code)
if (self.namespace.templates is not None
and any(isinstance(t, TemplatePlaceholderType) for t in self.namespace.templates)):
base_code = "typename %s" % base_code
base_code = public_decl(base_code, dll_linkage) base_code = public_decl(base_code, dll_linkage)
return self.base_declaration_code(base_code, entity_code) return self.base_declaration_code(base_code, entity_code)
...@@ -4373,7 +4370,7 @@ class CEnumType(CIntLike, CType): ...@@ -4373,7 +4370,7 @@ class CEnumType(CIntLike, CType):
else: else:
if self.namespace: if self.namespace:
base_code = "%s::%s" % ( base_code = "%s::%s" % (
self.namespace.empty_declaration_code(), self.cname) namespace_declaration_code(self.namespace), self.cname)
elif self.typedef_flag: elif self.typedef_flag:
base_code = self.cname base_code = self.cname
else: else:
...@@ -5225,3 +5222,14 @@ def cap_length(s, max_prefix=63, max_len=1024): ...@@ -5225,3 +5222,14 @@ def cap_length(s, max_prefix=63, max_len=1024):
return s return s
else: else:
return '%x__%s__etc' % (abs(hash(s)) % (1<<20), s[:max_len-17]) return '%x__%s__etc' % (abs(hash(s)) % (1<<20), s[:max_len-17])
def namespace_declaration_code(namespace):
"""
Add 'typename' to the beginning of the declaration code when the namespace is template-dependent
"""
base_code = namespace.empty_declaration_code()
if not base_code.startswith("typename "):
if hasattr(namespace, 'templates') and namespace.templates is not None:
if any(isinstance(t, TemplatePlaceholderType) for t in namespace.templates):
base_code = "typename %s" % base_code
return base_code
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