Lua Lib在VC下的编译/用BCB6编译LUA库

Lua提供了源代码以便于用户自己编译。用户可以将之编译成静态库,也可以编译成为动态库。但Lua没有提供工程文件,需要用户自己添加,对新手而言,带来诸多不便。
一、Lua静态库
编译为静态库很简单,有人已经写过,现摘录如下:
Lua 包含core lib和standard lib,详细情况可以查阅文档,为了简单起见,我们将其放到一个lib中,我们需要建立一个静态库的工程,然后将其源文件加入到工程中,包含以下文件
core lib: lapi.c lcode.c ldebug.c ldo.c ldump.c lfunc.c lgc.c llex.c lmem.c lobject.c lopcodes.c lp***r.c lstate.c lstring.c ltable.c ltests.c ltm.c lundump.c lvm.c lzio.c
standard lib: lauxlib.c lbaselib.c ldblib.c liolib.c lmathlib.c ltablib.c
lstrlib.c loadlib.c
并将其输出路径设置到lib下
二、Lua动态库
编译动态库,首先需要修改一下Lua.h头文件。如下:
/* mark for all API functions */
//#ifndef LUA_API
//#define LUA_API extern
//#endif
#ifdef LUA502_EXPORTS // 根据自己的项目而定
#define LUA_API __declspec(dllexport)
#else
#define LUA_API __declspec(dllimport)
#endif
然后用vc建立一个win32 dll,包含*.h和*.c文件(参考一),编译即可。
三、关于LuaBind
LuaBind是对Lua的包装,以便于与C++的交互。同样,LuaBind只提供源代码。在VC下使用它,无需编译成动态库或dll,只需在项目中包含LuaBind的*.cpp文件。LuaBind6 使用了Boost 1.30.0,因此需要下之(高版本的Boost是不行的)。
另外在VC6 sp5下使用LuaBind会出现种种问题,因此还是使用高版本的VC为妙。

------------------------------------------------------------------------------------------

Lua是一种完全免费的脚本语言,即可以单独使用也可以嵌入到时C/C++语言中作为嵌入式脚本使用。
可以到它的官方网站http://www.lua.org下载最新的lua的源码,本文的makefile是针对lua-5.1.3的。

下载后是一个tar.gz文件,解压后没发现针对BCB的编译方法。后来的网上找到“猛禽”大师的一个解决方案:http://mental.we8log.com/entry/89。鄙人于是参考“猛禽”大大的方案写了这个makefile。

使用方法,拷贝下面文本并保存为makefile.bcc,存放到lua/src子目录中。

在命令行方式下进入lua/src目录,输入命令:
make -f makefile.bcc
即可生成lua_bc.dll,lua_bc.lib,lua_bc.exe.luac_bc.exe。

如果想生成静态库,输入命令:
make -f makefile.bcc -DSTATIC
即可生成liblua_bc.lib,lua_bc.exe.luac_bc.exe。

makefile.bcc内容如下:

# Makefile for Borland C++ 5.5

# usage:
# build lua with dll:                make -f makefile.bcc
# build lua with static library:     make -f makefile.bcc -DSTATIC

# write by: Mao yongjun (mao_yj@msn.com)

# makefile for building Lua
# see ../INSTALL for installation instructions
# see ../Makefile and luaconf.h for further customization

# == CHANGE THE SETTINGS BELOW TO SUIT YOUR ENVIRONMENT =======================

CC         = bcc32
CFLAGS     = -DNDEBUG -DNO_STRICT;_NO_VCL -Hc -w-par -O2 -b- -k- -vi -tWM -c -P-
CFLAGSEXE  = -D_isatty=isatty $(CFLAGS)
CLINK      = ilink32
CLFLAGS    = -Gn -j -x
DLLOBJS    = c0d32.obj
EXEOBJS    = c0x32.obj
STDLIBS    = import32.lib cw32mt.lib
LIB        = tlib
RM         = del /F

# == END OF USER SETTINGS. NO NEED TO CHANGE ANYTHING BELOW THIS LINE =========

LUA_D= lua_bc.dll
LUA_DA = $(LUA_D:.dll=.lib)
LUA_SA= liblua_bc.lib

!ifdef STATIC 
LUA_A= $(LUA_SA)
!else
LUA_A= $(LUA_DA)
CFLAGS= -DLUA_BUILD_AS_DLL $(CFLAGS)
CFLAGSEXE= -DLUA_BUILD_AS_DLL $(CFLAGSEXE)
!endif

CORE_O= lapi.obj lcode.obj ldebug.obj ldo.obj ldump.obj lfunc.obj lgc.obj llex.obj lmem.obj /
lobject.obj lopcodes.obj lparser.obj lstate.obj lstring.obj ltable.obj ltm.obj  /
lundump.obj lvm.obj lzio.obj
LIB_O= lauxlib.obj lbaselib.obj ldblib.obj liolib.obj lmathlib.obj loslib.obj ltablib.obj /
lstrlib.obj loadlib.obj linit.obj
LINK_O= $(CORE_O) $(LIB_O)

PLINK_O= +lapi.obj +lcode.obj +ldebug.obj +ldo.obj +ldump.obj +lfunc.obj +lgc.obj +llex.obj +lmem.obj /
+lobject.obj +lopcodes.obj +lparser.obj +lstate.obj +lstring.obj +ltable.obj +ltm.obj /
+lundump.obj +lvm.obj +lzio.obj /
+lauxlib.obj +lbaselib.obj +ldblib.obj +liolib.obj +lmathlib.obj +loslib.obj +ltablib.obj /
+lstrlib.obj +loadlib.obj +linit.obj

LUA_T= lua_bc.exe
LUA_O= lua.obj

LUAC_T= luac_bc.exe
LUAC_O= luac.obj print.obj $(CORE_O)

ALL_O= $(CORE_O) $(LIB_O) $(LUA_O) $(LUAC_O)
ALL_A= $(LUA_A)
ALL_T= $(ALL_A) $(LUA_T) $(LUAC_T)

all: $(ALL_T)
    $(RM) $(ALL_O) *.tds
o: $(ALL_O)

a: $(ALL_A)

$(LUA_DA): $(LUA_D)

$(LUA_SA): $(LINK_O)
    $(LIB) $@ $(PLINK_O)

$(LUA_D): $(LINK_O)
    $(CLINK) $(CLFLAGS) -Tpd -Gi $(DLLOBJS) $(LINK_O),$@,$(STDLIBS),

$(LUA_T): $(LUA_O) $(LUA_A)
    $(CLINK) $(CLFLAGS) -Tpe $(EXEOBJS) $(LUA_O),$(STDLIBS) $(LUA_A),

$(LUAC_T): $(LUAC_O) $(LUA_A)
    $(CLINK) $(CLFLAGS) -Tpe $(EXEOBJS) $(LUAC_O),

clean:
$(RM) $(ALL_T) $(ALL_O) $(LUA_D) *.tds

.PHONY : clean all o a

# DO NOT DELETE
lapi.obj: lapi.c lua.h luaconf.h lapi.h lobject.h llimits.h ldebug.h /
  lstate.h ltm.h lzio.h lmem.h ldo.h lfunc.h lgc.h lstring.h ltable.h /
  lundump.h lvm.h
    $(CC) $(CFLAGS) lapi.c
lauxlib.obj: lauxlib.c lua.h luaconf.h lauxlib.h
    $(CC) $(CFLAGS) lauxlib.c
lbaselib.obj: lbaselib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) lbaselib.c
lcode.obj: lcode.c lua.h luaconf.h lcode.h llex.h lobject.h llimits.h /
  lzio.h lmem.h lopcodes.h lparser.h ldebug.h lstate.h ltm.h ldo.h lgc.h /
  ltable.h
    $(CC) $(CFLAGS) lcode.c
ldblib.obj: ldblib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) ldblib.c
ldebug.obj: ldebug.c lua.h luaconf.h lapi.h lobject.h llimits.h lcode.h /
  llex.h lzio.h lmem.h lopcodes.h lparser.h ldebug.h lstate.h ltm.h ldo.h /
  lfunc.h lstring.h lgc.h ltable.h lvm.h
    $(CC) $(CFLAGS) ldebug.c
ldo.obj: ldo.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h ltm.h /
  lzio.h lmem.h ldo.h lfunc.h lgc.h lopcodes.h lparser.h lstring.h /
  ltable.h lundump.h lvm.h
    $(CC) $(CFLAGS) ldo.c
ldump.obj: ldump.c lua.h luaconf.h lobject.h llimits.h lstate.h ltm.h /
  lzio.h lmem.h lundump.h
    $(CC) $(CFLAGS) ldump.c
lfunc.obj: lfunc.c lua.h luaconf.h lfunc.h lobject.h llimits.h lgc.h lmem.h /
  lstate.h ltm.h lzio.h
    $(CC) $(CFLAGS) lfunc.c
lgc.obj: lgc.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h ltm.h /
  lzio.h lmem.h ldo.h lfunc.h lgc.h lstring.h ltable.h
    $(CC) $(CFLAGS) lgc.c
linit.obj: linit.c lua.h luaconf.h lualib.h lauxlib.h
    $(CC) $(CFLAGS) linit.c
liolib.obj: liolib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) liolib.c
llex.obj: llex.c lua.h luaconf.h ldo.h lobject.h llimits.h lstate.h ltm.h /
  lzio.h lmem.h llex.h lparser.h lstring.h lgc.h ltable.h
    $(CC) $(CFLAGS) llex.c
lmathlib.obj: lmathlib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) lmathlib.c
lmem.obj: lmem.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h /
  ltm.h lzio.h lmem.h ldo.h
    $(CC) $(CFLAGS) lmem.c
loadlib.obj: loadlib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) loadlib.c
lobject.obj: lobject.c lua.h luaconf.h ldo.h lobject.h llimits.h lstate.h /
  ltm.h lzio.h lmem.h lstring.h lgc.h lvm.h
    $(CC) $(CFLAGS) lobject.c

>   
lopcodes.obj: lopcodes.c lopcodes.h llimits.h lua.h luaconf.h
    $(CC) $(CFLAGS) lopcodes.c
loslib.obj: loslib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) loslib.c
lparser.obj: lparser.c lua.h luaconf.h lcode.h llex.h lobject.h llimits.h /
  lzio.h lmem.h lopcodes.h lparser.h ldebug.h lstate.h ltm.h ldo.h /
  lfunc.h lstring.h lgc.h ltable.h
    $(CC) $(CFLAGS) lparser.c
lstate.obj: lstate.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h /
  ltm.h lzio.h lmem.h ldo.h lfunc.h lgc.h llex.h lstring.h ltable.h
    $(CC) $(CFLAGS) lstate.c
lstring.obj: lstring.c lua.h luaconf.h lmem.h llimits.h lobject.h lstate.h /
  ltm.h lzio.h lstring.h lgc.h
    $(CC) $(CFLAGS) lstring.c
lstrlib.obj: lstrlib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) lstrlib.c
ltable.obj: ltable.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h /
  ltm.h lzio.h lmem.h ldo.h lgc.h ltable.h
    $(CC) $(CFLAGS) ltable.c
ltablib.obj: ltablib.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGS) ltablib.c
ltm.obj: ltm.c lua.h luaconf.h lobject.h llimits.h lstate.h ltm.h lzio.h /
  lmem.h lstring.h lgc.h ltable.h
    $(CC) $(CFLAGS) ltm.c
lua.obj: lua.c lua.h luaconf.h lauxlib.h lualib.h
    $(CC) $(CFLAGSEXE) lua.c
luac.obj: luac.c lua.h luaconf.h lauxlib.h ldo.h lobject.h llimits.h /
  lstate.h ltm.h lzio.h lmem.h lfunc.h lopcodes.h lstring.h lgc.h /
  lundump.h
    $(CC) $(CFLAGSEXE) luac.c

lundump.obj: lundump.c lua.h luaconf.h ldebug.h lstate.h lobject.h /
  llimits.h ltm.h lzio.h lmem.h ldo.h lfunc.h lstring.h lgc.h lundump.h
    $(CC) $(CFLAGS) lundump.c

lvm.obj: lvm.c lua.h luaconf.h ldebug.h lstate.h lobject.h llimits.h ltm.h /
  lzio.h lmem.h ldo.h lfunc.h lgc.h lopcodes.h lstring.h ltable.h lvm.h
    $(CC) $(CFLAGS) lvm.c

lzio.obj: lzio.c lua.h luaconf.h llimits.h lmem.h lstate.h lobject.h ltm.h /
  lzio.h
    $(CC) $(CFLAGS) lzio.c

print.obj: print.c ldebug.h lstate.h lua.h luaconf.h lobject.h llimits.h /
  ltm.h lzio.h lmem.h lopcodes.h lundump.h
    $(CC) $(CFLAGSEXE) print.c

# (end of Makefile)

文章出处:DIY部落(http://www.diybl.com/course/3_program/c++/cppjs/2008224/100888.html)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


1.github代码实践源代码是lua脚本语言,下载th之后运行thmain.lua-netTypevgg-savevgg_cifar10/-S0.0001,报错: 试看看安装lua:报错了,参考这篇文章:ubuntu18.04安装lua的步骤以及出现的问题_weixin_41355132的博客-CSDN博客问题解决,安装成功:情况并没有好转,出现相
此文为搬运帖,原帖地址https://www.cnblogs.com/zwywilliam/p/5999924.html前言在看了uwa之前发布的《Unity项目常见Lua解决方案性能比较》,决定动手写一篇关于lua+unity方案的性能优化文。整合lua是目前最强大的unity热更新方案,毕竟这是唯一可以支持ios热更新的办法。然而作
Rime输入法通过定义lua文件,可以实现获取当前时间日期的功能。1.TIMERime是一款可以高度自定义的输入法,相关教程可以查看往期文章,关于时间获取是指输入一个指定关键字,输出当前时间,效果如下(我定义了time关键字):实现如下:①在用户文件夹中新建一个rime.lua文件加入如下代码 ti
localfunctiongenerate_action(params)localscale_action=cc.ScaleTo:create(params.time,params.scale_x,params.scale_y)localfade_action=cc.FadeIn:create(params.time)returncc.Spawn:create(scale_action,fade_action)end
2022年1月11日13:57:45 官方:https://opm.openresty.org/官方文档:https://opm.openresty.org/docs#table-of-contents为什么建议使用opm不建议使用luarocks?http://openresty.org/cn/using-luarocks.html官方解释:请注意!LuaRocks并不是OpenResty官方推荐的装包方式。LuaRoc
在Lua中的table(表),就像c#中的HashMap(哈希表),key和value一一对应。元表:table的一个操作的拓展,里面包含关联了对应的方法,元方法就是其中一个。元方法:当你通过键来访问table的时候,如果这个键没有值,那么Lua就会寻找该table的metatable(假定有metatable)中的__index键。如果__inde
表排序:table.sort(list[,comp])参数list:指定表,可选参数comp:排序函数,无参数时通常按升序排序。排序函数针对表中连续的序列,其间不可以存在空洞或nil,排序函数需要两个形参(对应表中每次参加比较的两个数据),需要一个比较两个形参表达式的返回值,不能含有等于关系,例如>=,<=,==。do
一、安装lua环境1.1安装依赖包[root@centos7~]#yuminstallgccreadline-devel1.2下线lua源码包并解压[root@centos7~]#wgethttp://www.lua.org/ftp/lua-5.3.5.tar.gz[root@centos7~]#tarxvflua-5.3.5.tar.gz-C/usr/local/src1.3进行编译[root@centos7~]
官网OpenResty® 是一个基于 Nginx 与Lua的高性能Web平台,其内部集成了大量精良的Lua库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态Web应用、Web服务和动态网关。OpenResty® 通过汇聚各种设计精良的 Nginx 模块(主要由
表参考《lua程序设计》可以认为,表是一种动态分配的对象,程序只能操作指向表的引用(或指针)。除此以外,Lua语言不会进行隐藏的拷贝(hiddencopies)或创建新的表--创建表a={}--创建空表k="x"a[k]=10--键“x”值10a[20]="great"--键20值“great”print(a["x"])-->10
https://github.com/galenho/crossover.git一个跨平台的lua游戏服务器开发框架,该框架采用多线程并发来处理消息,开发者只需要调用相应的接口函数并绑定相应的回调函数即可,在逻辑层表现为单线程的开发模式,使开发者易用,易调试,易维护,易扩展,同时拥有快速的响应能力。   框架使用面
参考链接:https://www.runoob.com/lua/lua-metatables.htmlhttps://www.jianshu.com/p/cb945e7073a3 元表是一个table,可以让我们改变table的行为,每个行为有对应的元方法例如,对table进行设置键值,查找键值,运算等,就会触发对应的元方法1--__index:table被访问时,如果找不到这
https://github.com/yuin/gopher-luahttps://github.com/yuin/gopher-lua Lua5.1ReferenceManual-contentshttp://www.lua.org/manual/5.1/ go中使用luapackagemainimport( lua"github.com/yuin/gopher-lua")funcmain(){ l:=lua.NewState() d
编译问题不要留到运行时才跑出来啊。早上9:00-中午3:00,6个小时,服了自己了。 写了一个测试,springboot+redis+lua执行到redisTemplate.execute(redisScript,idList)的时候一直报错,integer无法转换为string。我一直以为是lua脚本写错了,翻文档翻过来又翻过去,写法变了又变,还是解
        。。是字符串连接符,字典用=号连接,  注意fordoend都是连一起,  注意ifthen,  如果local在函数里,是可以访问,非local出了函数一样能用,  doend代码块也是一样,    注意点号表示,只能key是字符串,  注意括号不是必须
C语言与Lua之间的相互调用详解写一个C调用Lua的Demo编译运行C语言调用Lua编译问题总结正确的编译命令问题1:缺少-lm参数问题2:缺少-ldl参数​1、为什么会出现undefinedreferenceto‘xxxxx’错误?​2、-l参数和-L参数写一个C调用Lua的Demo编译运行add.c内容//你需要
1、动态输出打开E:\study\openresty\openresty-1.19.9.1-win64目录下的confginx.conf文件在server中增加一下代码 location/hello{ default_typetext/html; content_by_lua'ngx.say("<p>hello,world</p>")'; }运行后,效果如下图localhost
参见:lipp/lua-websockets:WebsocketsforLua.(github.com)github网址可能需手动转换lipp.github.com/lua-websockets/>github.com/lipp/lua-websocketswebsockets为底层的类似于TCP、UDP的socket(实现上基于更底层的socket),不同于上层的webserver服务端(Service)需并行地支持多
lua发送消息到rabbitmq,我们选择类库lua-resty-rabbitmqstomp 来完成这个任务。类库安装:进入nginx.conf中 lua_package_path 中对应的目录下的resty目录(没有则创建),执行:wget-chttps:/aw.githubusercontent.com/wingify/lua-resty-rabbitmqstomp/master/libes
1Lua介绍Lua是一门以其性能著称的脚本语言,被广泛应用在很多方面。Lua一般用于嵌入式应用,现在越来越多应用于游戏当中,魔兽世界,愤怒的小鸟都有用到。优势Lua极易嵌入到其他程序,可当做一种配置语言。提升应用性能,比如:游戏脚本,nginx,wireshark的脚本兼容性强,可以直接使用C