使用 SWIG 类型映射通过字符串转换类型
我正在使用swig来为一些类生成包装器。其中有一个类需要一个QUuid的列表(std::list),具体见下文。这个类有一个toString方法,可以返回一个std::string字符串,Python也可以通过这个字符串来实例化它的uuid。我想知道如何生成一个类型映射(或者其他什么可能更好的方法),使得上述的转换可以在Python和C++之间进行。最好是这个方法能够不依赖于目标语言(至少我还需要为Ruby生成包装器)。
谢谢
IRPICurrentPositionsCommand.h:
class IRPICurrentPositionsCommand : public CommandBase
{
Q_OBJECT
COMMAND_IMPLEMENTATION_BASICS(IRPICurrentPositionsCommand, ir)
public:
std::list<QUuid> GetAxisIDs() const
{
return m_AxisIDs;
}
void SetAxisIDs(std::list<QUuid> arg)
{
m_AxisIDs = arg;
}
std::list<double> GetAxisPostions() const
{
return m_AxisPostions;
}
void SetAxisPostions(std::list<double> arg)
{
m_AxisPostions = arg;
}
private:
std::list<QUuid> m_AxisIDs;
std::list<double> m_AxisPostions;
protected:
/** @see ora::CommandBase::Serialize(QDataStream &stream) **/
virtual void Serialize(QDataStream &stream) const;
/** @see ora::CommandBase::Deserialize(QDataStream &stream) **/
virtual void Deserialize(QDataStream &stream);
};
1 个回答
0
这里有一个关于 std::list<QUuid>
对象的 SWIG/Python 模板。我对 Ruby 不太了解,但希望这能给你一些关于类型映射的启发。
// To use std::string
%include "std_string.i"
%typemap(out) std::list<QUuid>
{
PyObject* outList = PyList_New(0);
int error;
std::list<QUuid>::iterator it;
for ( it=$1.begin() ; it != $1.end(); it++ )
{
PyObject* pyQUuid = SWIG_NewPointerObj(new QUuid(*it), SWIGTYPE_p_QUuid, SWIG_POINTER_OWN );
error = PyList_Append(outList, pyQUuid);
Py_DECREF(pyQUuid);
if (error) SWIG_fail;
}
$result = outList;
}
%typemap(in) std::list<QUuid>
{
//$input is the PyObject
//$1 is the parameter
if (PyList_Check($input))
{
std::list<QUuid> listTemp;
for(int i = 0; i<PyList_Size($input); i++)
{
PyObject* pyListItem = PyList_GetItem($input, i);
QUuid* arg2 = (QUuid *) 0 ;
int res1 = 0;
void *argp1;
res1 = SWIG_ConvertPtr(pyListItem, &argp1, SWIGTYPE_p_QUuid, 0 | 0);
if (!SWIG_IsOK(res1))
{
PyErr_SetString(PyExc_TypeError,"List must only contain QUuid objects");
return NULL;
}
if (!argp1)
{
PyErr_SetString(PyExc_TypeError,"Invalid null reference for object QUuid");
return NULL;
}
arg2 = reinterpret_cast< QUuid * >(argp1);
listTemp.push_back(*arg2);
}
$1 = listTemp;
}
else
{
PyErr_SetString(PyExc_TypeError,"Wrong argument type, list expected");
return NULL;
}
}