作者:上善若水纯_310 | 来源:互联网 | 2023-09-24 10:35
我正在考虑使用python作为一个嵌入式脚本语言的想法,我正在努力的项目,并使大多数工作.但是我似乎无法将python扩展对象转换回本机c指针.所以这是我的班级:
我正在考虑使用python作为一个嵌入式脚本语言的想法,我正在努力的项目,并使大多数工作.但是我似乎无法将python扩展对象转换回本机c指针.
所以这是我的班级:
class CGEGameModeBase
{
public:
virtual void FunctionCall()=0;
virtual const char* StringReturn()=0;
};
class CGEPYGameMode : public CGEGameModeBase, public boost::python::wrapper
{
public:
virtual void FunctionCall()
{
if (override f = this->get_override("FunctionCall"))
f();
}
virtual const char* StringReturn()
{
if (override f = this->get_override("StringReturn"))
return f();
return "FAILED TO CALL";
}
};
提升包装:
BOOST_PYTHON_MODULE(GEGameMode)
{
class_("CGEGameModeBase", no_init);
class_ >("CGEPYGameMode", no_init)
.def("FunctionCall", &CGEPYGameMode::FunctionCall)
.def("StringReturn", &CGEPYGameMode::StringReturn);
}
和python代码:
import GEGameMode
def Ident():
return "Alpha"
def NewGamePlay():
return "NewAlpha"
def NewAlpha():
import GEGameMode
import GEUtil
class Alpha(GEGameMode.CGEPYGameMode):
def __init__(self):
print "Made new Alpha!"
def FunctionCall(self):
GEUtil.Msg("This is function test Alpha!")
def StringReturn(self):
return "This is return test Alpha!"
return Alpha()
现在我可以通过执行以下操作来调用第一个函数:
const char* ident = extract( GetLocalDict()["Ident"]() );
const char* newgameplay = extract( GetLocalDict()["NewGamePlay"]() );
printf("Loading Script: %s\n", ident);
CGEPYGameMode* m_pGameMode = extract( GetLocalDict()[newgameplay]() );
但是,当我尝试将Alpha类转换回其基类(上面的最后一行)时,我得到一个提升错误:
TypeError: No registered converter was able to extract a C++ pointer to type class CGEPYGameMode from this Python object of type Alpha
我已经在网上做了很多搜索,但无法解决如何将Alpha对象转换为其基类指针.我可以把它作为一个对象,而不是它作为一个指针,所以一些非python意识的代码可以使用它.有任何想法吗?
解决方法:
感谢来自python c mailling列表的Stefan,我失踪了
super(Alpha, self).__init__()
从构造函数调用意味着它从未成为父类.认为这是自动的:D
我只有其他问题是将新的类实例保存为全局var,否则它会在超出范围时被清除.
现在好开心