Commit 41f28704 authored by Xavier Thompson's avatar Xavier Thompson

Avoid wrapping cypclass methods with Python-incompatible argument types

parent b28ba79c
...@@ -1645,7 +1645,7 @@ class CppClassNode(CStructOrUnionDefNode, BlockNode): ...@@ -1645,7 +1645,7 @@ class CppClassNode(CStructOrUnionDefNode, BlockNode):
cfunc_declarator = cfunc_method.cfunc_declarator cfunc_declarator = cfunc_method.cfunc_declarator
# C++ methods have an implict 'this', so the 'self' argument is skipped in the declarator # > c++ methods have an implict 'this', so the 'self' argument is skipped in the declarator
skipped_self = cfunc_declarator.skipped_self skipped_self = cfunc_declarator.skipped_self
if not skipped_self: if not skipped_self:
return # if this ever happens (?), skip non-static methods without a self argument return # if this ever happens (?), skip non-static methods without a self argument
...@@ -1653,10 +1653,18 @@ class CppClassNode(CStructOrUnionDefNode, BlockNode): ...@@ -1653,10 +1653,18 @@ class CppClassNode(CStructOrUnionDefNode, BlockNode):
cfunc_type = cfunc_method.type cfunc_type = cfunc_method.type
cfunc_return_type = cfunc_type.return_type cfunc_return_type = cfunc_type.return_type
# > TODO: the Python-incompatibility is too conservative:
# some types have not yet resolved that they can coerce to PyObject
# in particular, any cypclass not yet examined ?
# we pass the global scope as argument, should not affect the result (?) # we pass the global scope as argument, should not affect the result (?)
if not cfunc_return_type.can_coerce_to_pyobject(env.global_scope()): if not cfunc_return_type.can_coerce_to_pyobject(env.global_scope()):
return # skip c methods with Python-incompatible return types return # skip c methods with Python-incompatible return types
for argtype in cfunc_type.args:
if not argtype.type.can_coerce_to_pyobject(env.global_scope()):
return # skip c methods with Python-incompatible argument types
from .CypclassWrapper import underlying_name from .CypclassWrapper import underlying_name
from . import ExprNodes from . import ExprNodes
......
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