使用 SWIG 类型映射通过字符串转换类型

0 投票
1 回答
699 浏览
提问于 2025-04-20 13:00

我正在使用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;
    }
}

撰写回答