脚本编程语言

源代码在线查看: package.lua

软件大小: 68 K
上传用户: a974555392
关键词: 脚本 编程语言
下载地址: 免注册下载 普通下载 VIP

相关代码

				-- tolua: package class				-- Written by Waldemar Celes				-- TeCGraf/PUC-Rio				-- Jul 1998				-- $Id: $								-- This code is free software; you can redistribute it and/or modify it.				-- The software provided hereunder is on an "as is" basis, and				-- the author has no obligation to provide maintenance, support, updates,				-- enhancements, or modifications. 																-- Package class				-- Represents the whole package being bound.				-- The following fields are stored:				--    {i} = list of objects in the package.				classPackage = {				 classtype = 'package'				}				classPackage.__index = classPackage				setmetatable(classPackage,classContainer)								-- Print method				function classPackage:print ()				 print("Package: "..self.name)				 local i=1				 while self[i] do				  self[i]:print("","")				  i = i+1				 end				end								function classPackage:preprocess ()				 -- avoid preprocessing embedded Lua code				 local L = {}				 self.code = gsub(self.code,"\n%s*%$%[","\1") -- deal with embedded C code				 self.code = gsub(self.code,"\n%s*%$%]","\2")				 self.code = gsub(self.code,"(%b\1\2)",       function (c)				                                               tinsert(L,c)				                                               return "\n#["..getn(L).."]#" 				                                              end)				 -- avoid preprocessing embedded C code				 local C = {}				 self.code = gsub(self.code,"\n%s*%$%				 self.code = gsub(self.code,"\n%s*%$%>","\4")				 self.code = gsub(self.code,"(%b\3\4)",       function (c)				                                               tinsert(C,c)				                                               return "\n##" 				                                              end)								 -- avoid preprocessing verbatim lines				 local V = {}				 self.code = gsub(self.code,"\n(%s*%$[^%[%]][^\n]*)",function (v)				                                               tinsert(V,v)				                                               return "\n#"..getn(V).."#" 				                                              end)				 -- perform global substitution								 self.code = gsub(self.code,"(//[^\n]*)","")     -- eliminate C++ comments				 self.code = gsub(self.code,"/%*","\1")				 self.code = gsub(self.code,"%*/","\2")				 self.code = gsub(self.code,"%b\1\2","")				 self.code = gsub(self.code,"\1","/%*")				 self.code = gsub(self.code,"\2","%*/")				 self.code = gsub(self.code,"%s*@%s*","@") -- eliminate spaces beside @				 self.code = gsub(self.code,"%s?inline(%s)","%1") -- eliminate 'inline' keyword				 self.code = gsub(self.code,"%s?extern(%s)","%1") -- eliminate 'extern' keyword				 self.code = gsub(self.code,"%s?virtual(%s)","%1") -- eliminate 'virtual' keyword				 self.code = gsub(self.code,"public:","") -- eliminate 'public:' keyword				 self.code = gsub(self.code,"([^%w_])void%s*%*","%1_userdata ") -- substitute 'void*'				 self.code = gsub(self.code,"([^%w_])void%s*%*","%1_userdata ") -- substitute 'void*'				 self.code = gsub(self.code,"([^%w_])char%s*%*","%1_cstring ")  -- substitute 'char*'								 -- restore embedded code				 self.code = gsub(self.code,"%#%[(%d+)%]%#",function (n)				                                             return L[tonumber(n)]				                                            end)				 -- restore embedded code				 self.code = gsub(self.code,"%#%%#",function (n)				                                             return C[tonumber(n)]				                                            end)				 -- restore verbatim lines				 self.code = gsub(self.code,"%#(%d+)%#",function (n)				                                         return V[tonumber(n)]				                                        end)				end								-- translate verbatim				function classPackage:preamble ()				 output('/*\n')				 output('** Lua binding: '..self.name..'\n')				 output('** Generated automatically by '..TOLUA_VERSION..' on '..date()..'.\n')				 output('*/\n\n')									output('#ifndef __cplusplus\n')					output('#include "stdlib.h"\n')					output('#endif\n')					output('#include "string.h"\n\n')				 output('#include "tolua.h"\n\n')								 if not flags.h then				  output('/* Exported function */')				  output('TOLUA_API int  tolua_'..self.name..'_open (lua_State* tolua_S);')				  output('LUALIB_API int  luaopen_'..self.name..' (lua_State* tolua_S);')				  output('\n')				 end								 local i=1				 while self[i] do				  self[i]:preamble()				  i = i+1				 end																	if self:requirecollection(_collect) then						output('\n')						output('/* function to release collected object */')						output('#ifdef __cplusplus\n')						for i,v in pairs(_collect) do						 output('static int tolua_collect_'..v..' (lua_State* tolua_S)')							output('{')							output(' '..i..'* self = ('..i..'*) tolua_tousertype(tolua_S,1,0);')							output('	delete self;')							output('	return 0;')							output('}\n')						end						output('#else\nstatic int tolua_collect (lua_State* tolua_S)')						output('{')						output('	void* self = tolua_tousertype(tolua_S,1,0);')						output('	free(self);')						output('	return 0;')						output('}')						output('#endif\n\n')					end								 output('\n')				 output('/* function to register type */')				 output('static void tolua_reg_types (lua_State* tolua_S)')				 output('{')				 foreach(_usertype,function(n,v) output(' tolua_usertype(tolua_S,"',v,'");') end)				 output('}')				 output('\n')				end								-- register package				-- write package open function				function classPackage:register ()				 push(self)								 output("/* Open lib function */")				 output('LUALIB_API int  luaopen_'..self.name..' (lua_State* tolua_S)')				 output("{")				 output(" tolua_open(tolua_S);")				 output(" tolua_reg_types(tolua_S);")				 output(" tolua_module(tolua_S,NULL,",self:hasvar(),");")				 output(" tolua_beginmodule(tolua_S,NULL);")				 local i=1				 while self[i] do				  self[i]:register()				  i = i+1				 end				 output(" tolua_endmodule(tolua_S);")				 output(" return 1;")				 output("}")								 output("/* Open tolua function */")				 output("TOLUA_API int tolua_"..self.name.."_open (lua_State* tolua_S)")				 output("{")				 output("  lua_pushcfunction(tolua_S, luaopen_"..self.name..");")				 output('  lua_pushstring(tolua_S, "'..self.name..'");')				 output("  lua_call(tolua_S, 1, 0);")				 output("  return 1;")				 output("}")								 pop()				end								-- write header file				function classPackage:header ()				 output('/*\n') output('** Lua binding: '..self.name..'\n')				 output('** Generated automatically by '..TOLUA_VERSION..' on '..date()..'.\n')				 output('*/\n\n')								 if not flags.h then				  output('/* Exported function */')				  output('TOLUA_API int  tolua_'..self.name..'_open (lua_State* tolua_S);')				  output('LUALIB_API int  luaopen_'..self.name..' (lua_State* tolua_S);')				  output('\n')				 end				end								-- Internal constructor				function _Package (self)				 setmetatable(self,classPackage)				 return self				end								-- Parse C header file with tolua directives				-- *** Thanks to Ariel Manzur for fixing bugs in nested directives ***				function extract_code(fn,s)					local code = '\n$#include "'..fn..'"\n'					s= "\n" .. s .. "\n" -- add blank lines as sentinels					local _,e,c,t = strfind(s, "\n([^\n]-)[Tt][Oo][Ll][Uu][Aa]_([^%s]*)[^\n]*\n")					while e do						t = strlower(t)						if t == "begin" then							_,e,c = strfind(s,"(.-)\n[^\n]*[Tt][Oo][Ll][Uu][Aa]_[Ee][Nn][Dd][^\n]*\n",e)							if not e then							 tolua_error("Unbalanced 'tolua_begin' directive in header file")							end						end						code = code .. c .. "\n"					 _,e,c,t = strfind(s, "\n([^\n]-)[Tt][Oo][Ll][Uu][Aa]_([^%s]*)[^\n]*\n",e)					end					return code				end								-- Constructor				-- Expects the package name, the file extension, and the file text.				function Package (name,fn)				 local ext = "pkg"								 -- open input file, if any				 if fn then				  local st, msg = readfrom(flags.f)				  if not st then				   error('#'..msg)				  end						local _; _, _, ext = strfind(fn,".*%.(.*)$")				 end				 local code = "\n" .. read('*a')					if ext == 'h' or ext == 'hpp' then					 code = extract_code(fn,code)					end								 -- close file				 if fn then				  readfrom()				 end								 -- deal with renaming directive					code = gsub(code,'\n%s*%$renaming%s*(.-)%s*\n', function (r) appendrenaming(r) return "\n" end)								 -- deal with include directive				 local nsubst				 repeat				  code,nsubst = gsub(code,'\n%s*%$(.)file%s*"(.-)"%s*\n',						                   function (kind,fn)				                      local _, _, ext = strfind(fn,".*%.(.*)$")				                      local fp,msg = openfile(fn,'r')				                      if not fp then				                       error('#'..msg..': '..fn)				                      end				                      local s = read(fp,'*a')				                      closefile(fp)																										if kind == 'c' or kind == 'h' then													              return extract_code(fn,s)																										elseif kind == 'p' then				                       return "\n\n" .. s																										elseif kind == 'l' then																										 return "\n$[\n" .. s .. "\n$]\n"																										else																										 error('#Invalid include directive (use $cfile, $pfile or $lfile)')				                      end																									end)				 until nsubst==0								 local t = _Package(_Container{name=name, code=code})				 push(t)				 t:preprocess()				 t:parse(t.code)				 pop()				 return t				end															

相关资源