C++混合编程之idlcpp教程Lua篇(4)
上一篇在这 C++混合编程之idlcpp教程Lua篇(3)
与前面的工程相似,工程LuaTutorial2中,同样加入了三个文件 LuaTutorial2.cpp, Tutorial2.i, tutorial2.lua。其中LuaTutorial2.cpp的内容基本和LuaTutorial1.cpp雷同,不再赘述。 首先看一下Tutorial2.i的内容:
namespace tutorial
{
struct Point
{
float x;
float y;
nocode Point();
nocode Point(float a, float b);
#{
Point()
{}
Point(float a, float b)
{
x = a;
y = b;
}
#}
}; struct Rectangle
{
Point m_min;
Point m_max; float left set get;
float right set get; nocode float bottom set get;
nocode float top set get;
nocode float area get;
nocode float getArea(); Rectangle(const Point& min, const Point& max);
Rectangle();
nocode Rectangle(const Rectangle& pt);
#{
void set_bottom(float bottom)
{
m_min.y = bottom;
}
float get_bottom()
{
return m_min.y;
}
void set_top(float top)
{
m_max.y = top;
}
float get_top()
{
return m_max.y;
}
float get_area()
{
return (m_max.x - m_min.x)*(m_max.y - m_min.y);
}
float getArea()
{
return (m_max.x - m_min.x)*(m_max.y - m_min.y);
}
#}
};
#{
inline Rectangle::Rectangle(const Point& min, const Point& max) : m_min(min), m_max(max)
{
}
inline Rectangle::Rectangle()
{}
inline float Rectangle::get_left()
{
return m_min.x;
}
inline void Rectangle::set_left(float left)
{
m_min.x = left;
}
inline float Rectangle::get_right()
{
return m_max.x;
}
inline void Rectangle::set_right(float right)
{
m_max.x = right;
}
#}
}
在这里仍然有 struct Point
与LuaTutorial1中的struct Point相比,除了原来的默认构造函数外,多了一个带两个参数的构造函数
Point(float a, float b);
两个构造函数都有nocode修饰中,所以idlcpp不会在Tutorial2.h中生成对应的函数声明,所在直接在后面的#{#}写上构造函数的实现代码,这些代码会插入到Tutorial2.h中的对应位置。当然也可以不使用nocode,这样的话这两个构造函数的声明部分就会出现在Tutorial2.h的struct Point中,那么实现代码就要写在外面了。
在struct Point后添加了一个新的类型struct Rectangle
前两行
Point m_min;
Point m_max;
声明了两个数据成员。
然后是
float left set get;
float right set get;
这里又出现了新的语法:属性。属性语法来自于C#。
形式为: 类型 + 名称 + 可选的set和get。在C++中实际上是生成了两个对应的成员函数,函数名分别为set_ + 属性名称,get_ + 属性名称,比如为属性left生成的两个成员函数为:
void set_left(float) 和 float get_left()。
然后还有三个属性的声明
float bottom set get;
float top set get;
float area get;
其中属性area是只读属性,即只生成float get_area()成员函数。然后是
float getArea();
这是一个成员函数,在C++生成中的函数形式和这里是一样的。 然后是
Rectangle(const Point& min, const Point& max);
Rectangle();
nocode Rectangle(const Rectangle& pt);
此处一共三个构造函数,其中最后一个是拷贝构造函数,对于此类来说,拷贝构造函数可以不写。所以加了nocode前缀。于是在头文件只会有两个构造函数声明,但是在元数据中静态函数New共有三个重载函数。分别对于上面三个构造函数。
后面就是具体函数的实现代码。都放在#{#}中以便复制到头文件中。
编译后生成的Tutorial2.h的内容如下:
//DO NOT EDIT THIS FILE, it is generated by idlcpp
//http://www.idlcpp.org #pragma once #include "./Tutorial2.h"
namespace tutorial{ struct Rectangle; } namespace tutorial
{
struct Point
{
public: float x;
float y; Point()
{}
Point(float a, float b)
{
x = a;
y = b;
} }; struct Rectangle
{
public: Point m_min;
Point m_max; void set_left( float);
float get_left();
void set_right( float);
float get_right(); Rectangle(const Point& min,const Point& max);
Rectangle();
void set_bottom(float bottom)
{
m_min.y = bottom;
}
float get_bottom()
{
return m_min.y;
}
void set_top(float top)
{
m_max.y = top;
}
float get_top()
{
return m_max.y;
}
float get_area()
{
return (m_max.x - m_min.x)*(m_max.y - m_min.y);
}
float getArea()
{
return (m_max.x - m_min.x)*(m_max.y - m_min.y);
} }; inline Rectangle::Rectangle(const Point& min, const Point& max) : m_min(min), m_max(max)
{
}
inline Rectangle::Rectangle()
{}
inline float Rectangle::get_left()
{
return m_min.x;
}
inline void Rectangle::set_left(float left)
{
m_min.x = left;
}
inline float Rectangle::get_right()
{
return m_max.x;
}
inline void Rectangle::set_right(float right)
{
m_max.x = right;
} }
内容基本上都是和Tutorial2.i中一一对应的。
然后看一下脚本tutorial2.lua的内容:
rect1 = paf.tutorial.Rectangle();
rect1.m_min.x = ;
rect1.m_min.y = ; print(rect1.left._);
print(rect1.bottom._); rect1.right = ;
rect1.top = ; print(rect1.m_max.x._);
print(rect1.m_max.y._); print(rect1.area._); rect2 = paf.tutorial.Rectangle(rect1.m_min, paf.tutorial.Point(,));
print(rect2:getArea()._); rect3 = paf.tutorial.Rectangle.New(rect2);
print(rect3:getArea()._); .
rect1 = paf.tutorial.Rectangle();
这是rect1 = paf.tutorial.Rectangle.New(); 的简化写法。
后面分别用数据成员和属性来操作rect1。
rect2 = paf.tutorial.Rectangle(rect1.m_min, paf.tutorial.Point(5,5));
调用了Rectangle带参数的构造函数(实际上是静态函数New)。
rect3 = paf.tutorial.Rectangle.New(rect2);
相当于C++中的 Rectangle* rect3 = new Rectangle(*rect2);
或者这一句可以利用lua的语法特点简写为 rect3 = rect2:New();
编译运行结果如下图:

C++混合编程之idlcpp教程Lua篇(4)的更多相关文章
- C++混合编程之idlcpp教程Lua篇(9)
上一篇在这 C++混合编程之idlcpp教程Lua篇(8) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相比,工程LuaTutorial7中除了四个文件LuaTutorial7.c ...
- C++混合编程之idlcpp教程Lua篇(8)
上一篇在这 C++混合编程之idlcpp教程Lua篇(7) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相似,工程LuaTutorial6中,同样加入了四个文件:LuaTutori ...
- C++混合编程之idlcpp教程Lua篇(7)
上一篇在这 C++混合编程之idlcpp教程Lua篇(6) 第一篇在这 C++混合编程之idlcpp教程(一) 与LuaTutorial4工程相似,工程LuaTutorial5中,同样加入了四个文件: ...
- C++混合编程之idlcpp教程Lua篇(6)
上一篇在这 C++混合编程之idlcpp教程Lua篇(5) 第一篇在这 C++混合编程之idlcpp教程(一) 工程LuaTutorial4中加入了四个文件:LuaTutorial4.cpp, Tut ...
- C++混合编程之idlcpp教程Lua篇(5)
上一篇在这 C++混合编程之idlcpp教程Lua篇(4) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相似,工程LuaTutorial3中,同样加入了三个文件:LuaTutori ...
- C++混合编程之idlcpp教程Lua篇(3)
上一篇 C++混合编程之idlcpp教程Lua篇(2) 是一个 hello world 的例子,仅仅涉及了静态函数的调用.这一篇会有新的内容. 与LuaTutorial0相似,工程LuaTutoria ...
- C++混合编程之idlcpp教程Lua篇(2)
在上一篇 C++混合编程之idlcpp教程(一) 中介绍了 idlcpp 工具的使用.现在对 idlcpp 所带的示例教程进行讲解,这里针对的 Lua 语言的例子.首先看第一个示例程序 LuaTuto ...
- C++混合编程之idlcpp教程Python篇(7)
上一篇在这 C++混合编程之idlcpp教程Python篇(6) 第一篇在这 C++混合编程之idlcpp教程(一) 与PythonTutorial4工程相似,工程PythonTutorial5中,同 ...
- C++混合编程之idlcpp教程Python篇(6)
上一篇在这 C++混合编程之idlcpp教程Python篇(5) 第一篇在这 C++混合编程之idlcpp教程(一) 工程PythonTutorial4中加入了四个文件:PythonTutorial4 ...
随机推荐
- jquery tmpl遍历
最近发现大家用模板渲染一些顺带逻辑功能代码块时,用jquery tmpl较多,遇到了一些问题,现在就个人以前研究过的一切常用功能作介绍,主要针对遍历,其它的大家可以自行浏览一起网站,如:http:// ...
- webview中的页面兼容iphone6和6+
其实写这篇文章的本不该是我,而应该是开发ios的小伙伴,但作为一个前端,我想我还是有必要做一下记录的! 首先我想说下在iphone6或者6+中webview内嵌套的页面宽度已经不在是320px,而是3 ...
- WinServer2008R2 部署.NET4.0程序 注意事项
部署注意事项: 1.IIS应用程序池 集成模式 2.在web.config中的system.webServer下,添加 <modules runAllManagedModulesForA ...
- Eclipse JSP/Servlet 环境搭建
Eclipse JSP/Servlet 环境搭建 本文假定你已安装了 JDK 环境,如未安装,可参阅 Java 开发环境配置. 我们可以使用 Eclipse 来搭建 JSP 开发环境,首先我们分别下载 ...
- java应用死循环排查方法或查找程序消耗资源的线程方法(面试)
今天遇到一个面试,怎么在一堆线程中查找一个死循环? 如果遇到线上应用cpu飙升,并出现OutOfMemery怎么办? 首先线上应用的jvm配置要养成良好的习惯,增加一下配置则可以在jvm发生 oom的 ...
- Windows 7 下如何设置机器级别的DCOM权限
Windows 7 下如何设置机器级别的DCOM权限 To grant Remote Activation permissions to the SMS Admins group From the S ...
- UVa 490 - Rotating Sentences
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=94&page=s ...
- 【微博SDK调用逻辑】微博SDK的调用逻辑,最好自己还是写一个例子,试一下!!!
逻辑是这样的,谢谢给我讲东西的开发哥哥,嘻嘻~~~ 1.点击微博登录,SDK会打开微博客户端,然后点击登陆(如果已经登录了会出现一个当前app跟微博交互的图片界面,然后提示“正在获取授权信息”,如果 ...
- EF联合查询的新用法
用EF很多年了,做联合查询时,只知道linq和lambda两种语法,今天朋友发了一个链接,打开看后发现是EF内置的新的关于联合查询的方法,赶紧抄录下来,以备后用. 现在先把这几种方法,各写一个例子,便 ...
- .NET Remoting获取配置通道:
接上文: public static string ChannelManagerUrl { get { retu ...