0

我正在尝试为我的 Squirrel VM 和 SQRat 绑定开发一个包装器

绑定类的正常方法是调用:

Class<MyClass> myClass(vm,"myClass");
myClass.Func(_SC("Foo"), &MyClass::Foo);

我试图绑定的类看起来像这样:

class MyClass {
public:
    void Foo() { cout << bar; }
    int bar;
};

现在 iv 将 squirrel 包装到一个辅助类中,该类处理机器状态和错误,称为“SqEnvironment”

class SqEnvironment
{
public:
    SqEnvironment(unsigned int stacksize); //set up enviroment add callbacks ext.
template<class T>
SqurrelClass<T> bindClass(string classname);
HSQUIRRELVM v;
}

template<class T>
SqurrelClass<T> SqEnvironment::bindClass(string classname)
{
    return SqurrelClass<T>(classname,v);
}

在 main 中调用 bindclass 方法,如下所示:

int main(int argc, char* argv[])
{
    SqEnvironment e(1024);

    SqurrelClass<MyClass> myclass = e.bindClass<MyClass>("MyClass");
    myclass.bindFunction(&MyClass::Foo,"Foo"); //No idea.

    cin.get();
    return 0;
}

我只是不能完全理解绑定方法的实现。

template<class T>
class SqurrelClass
{
public:
    SqurrelClass(std::string classname, HSQUIRRELVM v);
    void bindFunction(void (T::*mymethod), std::string name); //Error   C2182   'mymethod': illegal use of type 'void'

    ~SqurrelClass();

private:
    Sqrat::Class<T>* myClass;
};

template<class T>
inline SqurrelClass<T>::SqurrelClass(std::string classname, HSQUIRRELVM v)
{
    myClass = new Sqrat::Class<T>(v, classname.c_str());
    Sqrat::RootTable(v).Bind(classname.c_str(), *myClass);
}

template<class T>
inline SqurrelClass<T>::~SqurrelClass()
{
    delete myClass;
}

现在iv看到了:c ++将类方法作为参数传递给带有模板的类方法

这是非常接近的,但是通过将类的实例添加到方法调用中来解决它,允许直接取消对类方法的引用。

但我不能完全做到这一点......永远不会制作我有权访问的实例。

那么我将如何去做这样的事情呢?

4

1 回答 1

0

我很笨。

忘记将 () 添加到参数的末尾;

方法必须是:

void bindFunction(void (T::*mymethod)(), std::string name);

然后另外对于变量:

template<typename J>
void bindVariable(J T::*myvar, std::string variable);
于 2017-08-11T19:17:46.527 回答