Commit fe2191ac authored by Mark Florisson's avatar Mark Florisson

Fix a little bug

parent 8ff5f8b8
...@@ -3008,7 +3008,8 @@ class SimpleCallNode(CallNode): ...@@ -3008,7 +3008,8 @@ class SimpleCallNode(CallNode):
if overloaded_entry: if overloaded_entry:
if self.function.type.is_fused: if self.function.type.is_fused:
alternatives = [] alternatives = []
self.function.type.map_with_specific_entries(alternatives.append) PyrexTypes.map_with_specific_entries(self.function.entry,
alternatives.append)
else: else:
alternatives = overloaded_entry.all_alternatives() alternatives = overloaded_entry.all_alternatives()
......
...@@ -156,8 +156,10 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -156,8 +156,10 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
f.close() f.close()
def generate_public_declaration(self, entry, h_code, i_code): def generate_public_declaration(self, entry, h_code, i_code):
entry.type.map_with_specific_entries(self._generate_public_declaration, PyrexTypes.map_with_specific_entries(entry,
h_code, i_code) self._generate_public_declaration,
h_code,
i_code)
def _generate_public_declaration(self, entry, h_code, i_code): def _generate_public_declaration(self, entry, h_code, i_code):
h_code.putln("%s %s;" % ( h_code.putln("%s %s;" % (
...@@ -990,9 +992,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -990,9 +992,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
dll_linkage = "DL_EXPORT", definition = definition) dll_linkage = "DL_EXPORT", definition = definition)
def generate_cfunction_predeclarations(self, env, code, definition): def generate_cfunction_predeclarations(self, env, code, definition):
func = self._generate_cfunction_predeclaration
for entry in env.cfunc_entries: for entry in env.cfunc_entries:
entry.type.map_with_specific_entries( PyrexTypes.map_with_specific_entries(entry, func, code, definition)
self._generate_cfunction_predeclaration, code, definition)
def _generate_cfunction_predeclaration(self, entry, code, definition): def _generate_cfunction_predeclaration(self, entry, code, definition):
if entry.inline_func_in_pxd or (not entry.in_cinclude and (definition if entry.inline_func_in_pxd or (not entry.in_cinclude and (definition
...@@ -2050,7 +2052,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -2050,7 +2052,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
for entry in env.cfunc_entries: for entry in env.cfunc_entries:
from_fused = entry.type.is_fused from_fused = entry.type.is_fused
if entry.api or entry.defined_in_pxd: if entry.api or entry.defined_in_pxd:
entry.type.map_with_specific_entries(func, env, code, from_fused) PyrexTypes.map_with_specific_entries(entry, func, env,
code, from_fused)
def _generate_c_function_export_code(self, entry, env, code, from_fused): def _generate_c_function_export_code(self, entry, env, code, from_fused):
env.use_utility_code(function_export_utility_code) env.use_utility_code(function_export_utility_code)
...@@ -2094,7 +2097,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -2094,7 +2097,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
code.error_goto(self.pos))) code.error_goto(self.pos)))
for entry in entries: for entry in entries:
entry.type.map_with_specific_entries(self._import_cdef_func, PyrexTypes.map_with_specific_entries(entry,
self._import_cdef_func,
code, code,
temp, temp,
entry.type.is_fused) entry.type.is_fused)
......
...@@ -2056,26 +2056,28 @@ class CFuncType(CType): ...@@ -2056,26 +2056,28 @@ class CFuncType(CType):
fused_cname, fused_cname,
self.entry.func_cname) self.entry.func_cname)
def map_with_specific_entries(self, func, *args, **kwargs):
"""
Call func for every specific function instance. If this is not a
signature with fused types, call it with the entry for this cdef
function.
"""
entry = self.entry
def map_with_specific_entries(entry, func, *args, **kwargs):
"""
Call func for every specific function instance. If this is not a
signature with fused types, call it with the entry for this cdef
function.
"""
type = entry.type
if type.is_cfunction and (entry.fused_cfunction or type.is_fused):
if entry.fused_cfunction: if entry.fused_cfunction:
# cdef with fused types defined in this file # cdef with fused types defined in this file
for cfunction in entry.fused_cfunction.nodes: for cfunction in entry.fused_cfunction.nodes:
func(cfunction.entry, *args, **kwargs) func(cfunction.entry, *args, **kwargs)
elif entry.type.is_fused: else:
# cdef with fused types defined in another file, create their # cdef with fused types defined in another file, create their
# signatures # signatures
for func_type in self.get_all_specific_function_types(): for func_type in type.get_all_specific_function_types():
func(func_type.entry, *args, **kwargs) func(func_type.entry, *args, **kwargs)
else: else:
# a normal cdef # a normal cdef or not a c function
return func(entry, *args, **kwargs) func(entry, *args, **kwargs)
def get_all_specific_permutations(fused_types, id="0", f2s=()): def get_all_specific_permutations(fused_types, id="0", f2s=()):
fused_type = fused_types[0] fused_type = fused_types[0]
......
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