【发布时间】:2017-11-09 09:45:35
【问题描述】:
简介
我的典型 swig 接口文件类似如下:
%{ //COPY THIS BLOCK AS IS
#include <headers.h>
static CppClass* get_CppClass_from_swig_object(PyObject* obj)
{
void* self_obj = nullptr;
int ok = SWIG_Python_ConvertPtr(obj, &self_obj, SWIGTYPE_p_CppClass, 0);
if(!SWIG_IsOK(ok))
{
PyErr_SetString(PyExc_TypeError, "Object must be a CppClass");
return nullptr;
}
return reinterpret_cast<CppClass*>(self_obj);
}
static CppClass convert_to_CppClass(PyObject* py_obj)
{
CppClass* converted_ptr = get_CppClass_from_swig_object(py_obj);
if(converted_ptr==nullptr)
throw std::runtime_error("Python object is not a CppClass");
return CppClass(*converted_ptr);
}
%}
%typemap(in) std::vector<CppClass>& (std::vector<CppClass> temp) {
try{
temp = SequenceConverter::to_vector<CppClass>($input, convert_to_CppClass);
$1 = &temp;
}catch(std::exception& e){
PyErr_SetString(PyExc_RuntimeError, e.what());
SWIG_fail;
}
}
%typemap(typecheck, precedence=SWIG_TYPECHECK_CPPCLASS_VECTOR) std::vector<CppClass>& {
$1 = 0;
if(PyTuple_Check($input))
$1 = 1;
else if(PyList_Check($input))
$1 = 1;
}
class CppClass
{
public:
CppClass();
CppClass(const CppClass& other);
//other methods
};
但我想避免在get_CppClass_from_swig_object 中明确使用SWIGTYPE_p_CppClass。
照原样,不可能像我想的那样使用$descriptor(CppClass) swig 宏,因为%{ ... %} 块被复制为-is 而不是被swig 解释,因此$descriptor swig 宏会不被解释。另一方面,如果我删除% 并使用{ ... } 块,swig 将尝试包装整个get_CppClass_from_swig_object 和convert_to_CppClass 类,而不是简单地定义它们以便它们可以在类型映射中使用。
问题
如何更改我的文件结构并允许在转换助手中使用 $descriptor 宏?
TL;DR
-
%{...%}块既不预处理也不被 swig 包装 -
{...}块都经过预处理和包装(但可以防止小块通过前面的%进行预处理) - 如何进行 swig 预处理但不包装一段代码?
【问题讨论】: