草庐IT

内包装

全部标签

c++ - 将 C++ 对象包装到 Node 插件中的 v8 对象

我目前正在用C++编写一个Node插件,我遇到了一个问题,我需要创建并返回一个v8数组,其中填充了v8包装的C++对象实例。目前,代码看起来像这样v8::HandleController::nodeArray(constv8::Arguments&args){v8::HandleScopescope;Controller*controller=ObjectWrap::Unwrap(args.This());conststd::vector*foobars=controller->getFoobars();unsignedintfoobarCount=foobars->size();v8

C++ 用可变参数包装一个包装器宏?

问题我有一个方法可以通过用宏替换函数来包装函数,这样我就可以记录调用和返回代码。这是一个有效的示例:intrc;intfoo(inta,intb);intbar(inta,char*b,int*c);voidLogRet(char*fn,char*file,char*from,intln,intret){printf("%s.%s.%d:%s()ret:%08x\n",file,from,ln,fn,ret);}#definefoo(args,...)(rc=(foo)(args,##__VA_ARGS__),LogRet("foo",__FILE__,__FUNCTION__,__L

python - 使用 SWIG 打印为 Python 包装的 C++ 类时不调用 __str__()

我正在尝试使用SWIG打印我为Python包装的C++类。我遵循了文档和这个问题:Howtostringfyaswigmatrixobjectinpython扩展的__str__函数在那里,但是当我从Python打印对象时它没有被调用。让我举一个最小的例子:测试类.h#includeclassTestClass{private:intmy_int;public:TestClass():my_int(0){}friendstd::ostream&operator测试类.cpp#include"TestClass.h"intmain(){usingnamespacestd;TestClas

python - 使用 SWIG 为 Python 包装 C++。 'vector' 未声明

我正在尝试包装一个创建3Dvector的C++,以便我可以从Python调用它并可视化数据。我正在尝试使用SWIG包装,但是当我这样做时,我收到了错误消息'vector’wasnotdeclaredinthisscope并且在我能想到的每个文件中都包含了“vector”,但我不确定我必须做什么才能包含它。我已经创建了一组非常基本的测试函数来尝试查看问题出在哪里,它与我尝试运行的真实代码大致相似。测试.cpp#include#includeusingnamespacestd;vectortestfunction(vector&value){cout测试.h#ifndefTEST_H_//

c++ - 编译包装器时出现 SWIG [C++ to Lisp(CFFI)] 错误

我是C++和Lisp与SWIG之间接口(interface)的初学者。我遵循了SWIG的文档,但遇到了问题。这是我想要接口(interface)的简单程序(它可以很容易地在Lisp中完成,但它是为了了解如何将C++代码导入Lisp):测试.cpp:#include"test.hpp"inttest(intx,inty){std::cout测试.hpp:#includeinttest(intx,inty);为了使用SWIG,我创建了接口(interface)文件:测试.i:%moduletest%include然后,我执行了以下命令行:$swig-c++-cffitest.i$c++-c

c++ - 如何创建用捕获的变量包装 lambda 的仿函数?

如何更改下面的仿函数以用作lambda包装器?templateclassF{Tf;public:F(Tt){f=t;}T&operator()(){returnf;}};intmain(){intx=5;Ff([x](inta,intb){returna+b;});return0;}编译器说error:nomatchingfunctionforcallto'F::F(main()::)'Ff([x](inta,intb){returna+b;}); 最佳答案 它更复杂......在内部捕获变量的lambda函数本身不是函数,而是数据

如何在不包装的情况下包含所有内部UL宽度

我想创建一个像这样的面包屑结构:nav1>nav2>NAV3等因此,将每个NAV1,NAV2和NAV3作为Li,它包含在DIV中。就像下面一样:ul.nice-menu,ul.nice-menuul{list-style:none;padding:0;margin:0;border-top:1pxsolid#ccc;/*position:relative;*/white-space:nowrap;overflow:hidden;}#zone-menuul>li{/*width:20%;*/box-sizing:border-box;-moz-box-sizing:border-bo

c++ - 如何将用 swig 包装的 c++ 类的实例推送到 lua 堆栈上?

我有一个用swig包装并用lua注册的类。我可以在lua脚本中创建此类的实例,一切正常。但是假设我在我的C++代码中创建了一个类的实例,并调用了新的X,并且我有lalua_stateL,其中有一个我想调用的函数,它接受一个参数,一个X的实例...我该如何调用该函数。这是(一些)有问题的代码(我省略了错误处理的东西):主要.cppclassGuiInst;extern"C"{intluaopen_engine(lua_State*L);}intmain(){GuiInstgui=newGuiInst;lua_State*L=luaL_newstate();luaopen_engine(L

c# - 为非托管 (C++) 代码编写托管包装器 - 自定义类型/结构

faacEncConfigurationPtrFAACAPIfaacEncGetCurrentConfiguration(faacEncHandlehEncoder);我正在尝试为这个C++库设计一个简单的包装器;我以前从未做过比非常简单的p/invoke互操作更多的事情——比如一个带有原始参数的函数调用。那么,以上面的C++函数为例,我应该如何处理返回类型和参数呢?FAACAPI定义为:#defineFAACAPI__stdcallfaacEncConfigurationPtr定义:typedefstructfaacEncConfiguration{intversion;char*n

c++ - Swig:如何包装 double&(double 通过引用传递)?

我正在使用SWIG从Python访问C++代码。我如何优雅地包装一个函数,该函数返回通过引用传递的变量中的值voidset(double&a){a=42.;}我不知道该怎么做。在最好的情况下,我将能够在Python中使用带有Pythonfloat的函数:>>>b=2.>>>set(b)>>>printb42.0目前它给了我一个TypeError:inmethod'TestDouble_set',argument2oftype'double&'。 最佳答案 这样做:你的swig接口(interface)文件:%include%appl