gpt4 book ai didi

python - Swig - 绑定(bind)一个方法,该方法返回对导向器类指针的引用

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:03:30 25 4
gpt4 key购买 nike

好吧,标题有点长,但我想不出一个更短的:) 所以让我解释一下。

我有一个 C++ 代码库,其中有一些容器类。这些类具有通过引用或 const 引用返回项目的访问方法。然后在代码库的另一部分,我有堆分配的 object 的容器,它们使用了 director 特性。

而且我无法弄清楚如何为 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 ** 结果?

感谢任何帮助:)

最佳答案

我找到了解决您问题的方法。

在某些情况下,使用 director 功能和 native RTTI 会生成无法立即编译的代码,例如在 Python 中使用 distutils 时。

适用于您的示例的解决方案是在编译代码时定义 SWIG_DIRECTOR_NORTTI,例如对于 GNU 编译器,将 -DSWIG_DIRECTOR_NORTTI 添加到 CXXFLAGS

关于python - Swig - 绑定(bind)一个方法,该方法返回对导向器类指针的引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55139832/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com