Swig - 绑定返回对控制器类指针的引用的方法
Swig - binding a method returning a reference to a pointer of a director class
好吧,标题有点长,但我找不到更短的标题:)所以让我解释一下。
我有一个C++代码库,其中有一些容器类。这些类具有通过引用或常量引用返回项的访问方法。然后在代码库的另一部分,我分配了堆容器object
,这些容器正在使用控制器功能。
而且我不知道如何为object
专门化我们的容器类:对于所有返回对项目的引用的容器方法(在本例中是对object
指针的引用),Swig 生成了一个包装器代码,由于无效dynamic_cast而无法编译(基本上它试图将object **
转换为Swig::Director *
)
我设法使用以下代码重现了该问题。
测试.h
#ifndef TEST_H
#define TEST_H
template< typename T >
class Vector
{
public:
inline Vector(void)
: m_Data(nullptr)
, m_Size(0)
{
}
inline ~Vector(void)
{
delete [] m_Data;
}
inline void add(const T & item)
{
T * data = new T [m_Size + 1];
for (int i = 0; i < m_Size; ++i)
{
data[i] = std::move(m_Data[i]);
}
delete [] m_Data;
m_Data = data;
m_Data[m_Size++] = item;
}
inline const T& item(int index) const
{
return m_Data[index];
}
inline int count(void) const
{
return m_Size;
}
private:
T * m_Data;
int m_Size;
};
class Foo
{
public:
Foo(void) = default;
virtual ~Foo(void) = default;
virtual const char * method(void) const
{
return "Foo::method";
}
};
class Cache
{
public:
static void add(Foo * item = nullptr)
{
m_Cache.add(item == nullptr ? new Foo() : item);
}
static const Vector< Foo * > & get(void)
{
return m_Cache;
}
static Foo * get(int index)
{
return m_Cache.item(index);
}
private:
static Vector< Foo * > m_Cache;
};
Vector< Foo * > Cache::m_Cache;
#endif // TEST_H
核心.i
%module(directors="1") core
// we want to be able to inherit Foo in Python
%feature("director") Foo;
// generate wrappers
%include "Test.h"
// specialize Vector for Foo
%template(FooVector) Vector<Foo*>;
// when compiling the wrapper code, include those
%{
#include "Test.h"
%}
如果生成 Python 模块 (swig.exe -python -c++ core.i
),它工作正常,但生成的core_wrap.cxx
文件无法构建,因为生成的Vector::item
包装代码包含从Foo **
到Swig::Director *
的无效dynamic_cast
违规行是(其中结果类型为Foo **
)
director = SWIG_DIRECTOR_CAST(result);
如果我像这样手动修复它:
director = SWIG_DIRECTOR_CAST(*result);
然后模块正确编译,一切正常。
所以基本上我的问题是:这是 Swig 中的错误吗?我做错了吗?有没有解决方法可以告诉 Swig 在投射到Swig::Director *
之前正确取消引用我的Foo **
结果?
任何帮助表示赞赏:)
我找到了解决您问题的方法。
在某些情况下,使用控制器功能和本机RTTI会导致代码,该代码不会开箱即用地编译,例如,当使用来自Python的distutils
时。
适用于您的示例的解决方案是在编译代码时定义SWIG_DIRECTOR_NORTTI
,例如,对于 GNU 编译器,将-DSWIG_DIRECTOR_NORTTI
添加到CXXFLAGS
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用