Python Swig-绑定返回对控制器类指针的引用的方法

Python Swig-绑定返回对控制器类指针的引用的方法,python,c++,swig,Python,C++,Swig,好的,标题有点长,但我想不出一个较短的:)让我解释一下 我有一个C++代码库,在这里我们有一些容器类。这些类具有通过引用或常量引用返回项的访问方法。然后在代码库的另一部分中,我有堆分配的对象的容器,它们使用director特性 我不知道如何为对象专门化我们的容器类:对于所有返回项引用的容器方法(在本例中是对对象指针的引用),Swig生成一个包装器代码,该代码由于无效的动态转换而无法编译(基本上,它尝试将对象**强制转换为Swig::Director*) 我用下面的代码重现了这个问题 测试h #i

好的,标题有点长,但我想不出一个较短的:)让我解释一下

我有一个C++代码库,在这里我们有一些容器类。这些类具有通过引用或常量引用返回项的访问方法。然后在代码库的另一部分中,我有堆分配的

对象的容器,它们使用director特性

我不知道如何为
对象
专门化我们的容器类:对于所有返回项引用的容器方法(在本例中是对
对象
指针的引用),Swig生成一个包装器代码,该代码由于无效的动态转换而无法编译(基本上,它尝试将
对象**
强制转换为
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
如果我像这样手动修复它:

  director = SWIG_DIRECTOR_CAST(*result);
然后模块正确编译,一切正常

所以基本上我的问题是:这是Swig中的一个bug吗?我做错了吗?在转换到
Swig::Director*
之前,是否有一个解决方法来告诉Swig正确地取消引用我的
Foo**
结果


感谢您的帮助:)

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

在某些情况下,使用director功能和本机RTTI会生成代码,而这些代码不会立即编译,例如,在使用Python中的
distutils


对于您的示例来说,一种解决方案是在编译代码时定义
SWIG_DIRECTOR_NORTTI
,例如,对于GNU编译器,将
-DSWIG_DIRECTOR_NORTTI
添加到
cxflags

我遇到过一些类似的情况,其中我有
\ifndef SWIG_VERSION
跳过某些函数。您是否尝试过将say
int
Vector
包装起来,以查看它是否与
导演相关,还是与一般演员问题相关。另一件事-为什么要使用控制器,我看不到任何Python类实现
Foo
。包装
Vector
未使用
director
功能的类型可以正常工作(无效的
dynamic\u cast
仅在与此功能相关的生成部分)因此,为
int
专门化
Vector
效果很好。你看不到实现
Foo
的Python类,因为
%feature(director)
是在用Python定义实现
Foo
的类时使用的(至少在我的例子中,这是我需要的),我没有提供使用示例模块的示例Python脚本,因为模块甚至不编译,所以它不是真正相关的。如果您通过添加编译选项
-DSWIG\u DIRECTOR\u NORTTI来跳过本机RTTI的使用,您的示例将编译。您是一个救生员!它可以编译,我的示例用例可以按预期工作!我觉得有点傻,因为我没有想过要定义这个宏(我记得在生成的包装器代码中看到它,并想知道它的用途是什么)如果你想添加这个作为一个正确的答案,我可以接受它(也许它会在将来帮助其他人:)我会这样做。。。
  director = SWIG_DIRECTOR_CAST(result);
  director = SWIG_DIRECTOR_CAST(*result);