Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/tolua/lua/basic.lua @ 2110

Last change on this file since 2110 was 2087, checked in by landauf, 16 years ago

merged objecthierarchy branch back to trunk

  • Property svn:eol-style set to native
File size: 7.5 KB
Line 
1-- tolua: basic utility functions
2-- Written by Waldemar Celes
3-- TeCGraf/PUC-Rio
4-- Jul 1998
5-- Last update: Apr 2003
6-- $Id: $
7
8-- This code is free software; you can redistribute it and/or modify it.
9-- The software provided hereunder is on an "as is" basis, and
10-- the author has no obligation to provide maintenance, support, updates,
11-- enhancements, or modifications.
12
13
14-- Basic C types and their corresponding Lua types
15-- All occurrences of "char*" will be replaced by "_cstring",
16-- and all occurrences of "void*" will be replaced by "_userdata"
17_basic = {
18 ['void'] = '',
19 ['char'] = 'number',
20 ['int'] = 'number',
21 ['short'] = 'number',
22 ['long'] = 'number',
23 ['unsigned'] = 'number',
24 ['float'] = 'number',
25 ['double'] = 'number',
26 ['_cstring'] = 'string',
27 ['_userdata'] = 'userdata',
28 ['char*'] = 'string',
29 ['void*'] = 'userdata',
30 ['bool'] = 'boolean',
31 ['lua_Object'] = 'value',
32 ['LUA_VALUE'] = 'value',    -- for compatibility with tolua 4.0
33 ['lua_State*'] = 'state',
34 ['_lstate'] = 'state',
35 ['lua_Function'] = 'value',
36}
37
38_basic_ctype = {
39 number = "lua_Number",
40 string = "const char*",
41 userdata = "void*",
42 boolean = "bool",
43 value = "int",
44 state = "lua_State*",
45}
46
47-- functions the are used to do a 'raw push' of basic types
48_basic_raw_push = {}
49
50-- List of user defined types
51-- Each type corresponds to a variable name that stores its tag value.
52_usertype = {}
53
54-- List of types that have to be collected
55_collect = {}
56
57-- List of types
58_global_types = {n=0}
59_global_types_hash = {}
60
61-- list of classes
62_global_classes = {}
63
64-- List of enum constants
65_global_enums = {}
66
67-- List of auto renaming
68_renaming = {}
69function appendrenaming (s)
70 local b,e,old,new = strfind(s,"%s*(.-)%s*@%s*(.-)%s*$")
71        if not b then
72         error("#Invalid renaming syntax; it should be of the form: pattern@pattern")
73        end
74        tinsert(_renaming,{old=old, new=new})
75end
76
77function applyrenaming (s)
78        for i=1,getn(_renaming) do
79         local m,n = gsub(s,_renaming[i].old,_renaming[i].new)
80                if n ~= 0 then
81                 return m
82                end
83        end
84        return nil
85end
86
87-- Error handler
88function tolua_error (s,f)
89if _curr_code then
90        print("***curr code for error is "..tostring(_curr_code))
91        print(debug.traceback())
92end
93 local out = _OUTPUT
94 _OUTPUT = _STDERR
95 if strsub(s,1,1) == '#' then
96  write("\n** tolua: "..strsub(s,2)..".\n\n")
97  if _curr_code then
98   local _,_,s = strfind(_curr_code,"^%s*(.-\n)") -- extract first line
99   if s==nil then s = _curr_code end
100   s = gsub(s,"_userdata","void*") -- return with 'void*'
101   s = gsub(s,"_cstring","char*")  -- return with 'char*'
102   s = gsub(s,"_lstate","lua_State*")  -- return with 'lua_State*'
103   write("Code being processed:\n"..s.."\n")
104  end
105 else
106 if not f then f = "(f is nil)" end
107  print("\n** tolua internal error: "..f..s..".\n\n")
108  return
109 end
110 _OUTPUT = out
111end
112
113function warning (msg)
114 local out = _OUTPUT
115 _OUTPUT = _STDERR
116 write("\n** tolua warning: "..msg..".\n\n")
117 _OUTPUT = out
118end
119
120-- register an user defined type: returns full type
121function regtype (t)
122        --if isbasic(t) then
123        --      return t
124        --end
125        local ft = findtype(t)
126
127        if not _usertype[ft] then
128                return appendusertype(t)
129        end
130        return ft
131end
132
133-- return type name: returns full type
134function typevar(type)
135        if type == '' or type == 'void' then
136                return type
137        else
138                local ft = findtype(type)
139                if ft then
140                        return ft
141                end
142                _usertype[type] = type
143                return type
144        end
145end
146
147-- check if basic type
148function isbasic (type)
149 local t = gsub(type,'const ','')
150 local m,t = applytypedef('', t)
151 local b = _basic[t]
152 if b then
153  return b,_basic_ctype[b]
154 end
155 return nil
156end
157
158-- split string using a token
159function split (s,t)
160 local l = {n=0}
161 local f = function (s)
162  l.n = l.n + 1
163  l[l.n] = s
164  return ""
165 end
166 local p = "%s*(.-)%s*"..t.."%s*"
167 s = gsub(s,"^%s+","")
168 s = gsub(s,"%s+$","")
169 s = gsub(s,p,f)
170 l.n = l.n + 1
171 l[l.n] = gsub(s,"(%s%s*)$","")
172 return l
173end
174
175-- splits a string using a pattern, considering the spacial cases of C code (templates, function parameters, etc)
176-- pattern can't contain the '^' (as used to identify the begining of the line)
177-- also strips whitespace
178function split_c_tokens(s, pat)
179
180        s = string.gsub(s, "^%s*", "")
181        s = string.gsub(s, "%s*$", "")
182
183        local token_begin = 1
184        local token_end = 1
185        local ofs = 1
186        local ret = {n=0}
187
188        function add_token(ofs)
189
190                local t = string.sub(s, token_begin, ofs)
191                t = string.gsub(t, "^%s*", "")
192                t = string.gsub(t, "%s*$", "")
193                ret.n = ret.n + 1
194                ret[ret.n] = t
195        end
196
197        while ofs <= string.len(s) do
198
199                local sub = string.sub(s, ofs, -1)
200                local b,e = string.find(sub, "^"..pat)
201                if b then
202                        add_token(ofs-1)
203                        ofs = ofs+e
204                        token_begin = ofs
205                else
206                        local char = string.sub(s, ofs, ofs)
207                        if char == "(" or char == "<" then
208
209                                local block
210                                if char == "(" then block = "^%b()" end
211                                if char == "<" then block = "^%b<>" end
212
213                                b,e = string.find(sub, block)
214                                if not b then
215                                        -- unterminated block?
216                                        ofs = ofs+1
217                                else
218                                        ofs = ofs + e
219                                end
220
221                        else
222                                ofs = ofs+1
223                        end
224                end
225
226        end
227        add_token(ofs)
228        --if ret.n == 0 then
229
230        --      ret.n=1
231        --      ret[1] = ""
232        --end
233
234        return ret
235
236end
237
238-- concatenate strings of a table
239function concat (t,f,l,jstr)
240        jstr = jstr or " "
241 local s = ''
242 local i=f
243 while i<=l do
244  s = s..t[i]
245  i = i+1
246  if i <= l then s = s..jstr end
247 end
248 return s
249end
250
251-- concatenate all parameters, following output rules
252function concatparam (line, ...)
253 local i=1
254 while i<=arg.n do
255  if _cont and not strfind(_cont,'[%(,"]') and
256     strfind(arg[i],"^[%a_~]") then
257            line = line .. ' '
258  end
259  line = line .. arg[i]
260  if arg[i] ~= '' then
261   _cont = strsub(arg[i],-1,-1)
262  end
263  i = i+1
264 end
265 if strfind(arg[arg.n],"[%/%)%;%{%}]$") then
266  _cont=nil line = line .. '\n'
267 end
268        return line
269end
270
271-- output line
272function output (...)
273 local i=1
274 while i<=arg.n do
275  if _cont and not strfind(_cont,'[%(,"]') and
276     strfind(arg[i],"^[%a_~]") then
277            write(' ')
278  end
279  write(arg[i])
280  if arg[i] ~= '' then
281   _cont = strsub(arg[i],-1,-1)
282  end
283  i = i+1
284 end
285 if strfind(arg[arg.n],"[%/%)%;%{%}]$") then
286  _cont=nil write('\n')
287 end
288end
289
290function get_property_methods(ptype, name)
291
292        if get_property_methods_hook and get_property_methods_hook(ptype,name) then
293                return get_property_methods_hook(ptype, name)
294        end
295
296        if ptype == "default" then -- get_name, set_name
297                return "get_"..name, "set_"..name
298        end
299
300        if ptype == "qt" then -- name, setName
301                return name, "set"..string.upper(string.sub(name, 1, 1))..string.sub(name, 2, -1)
302        end
303
304        if ptype == "overload" then -- name, name
305                return name,name
306        end
307
308        return nil
309end
310
311-------------- the hooks
312
313-- called right after processing the $[ichl]file directives,
314-- right before processing anything else
315-- takes the package object as the parameter
316function preprocess_hook(p)
317        -- p.code has all the input code from the pkg
318end
319
320
321-- called for every $ifile directive
322-- takes a table with a string called 'code' inside, the filename, and any extra arguments
323-- passed to $ifile. no return value
324function include_file_hook(t, filename, ...)
325
326end
327
328-- called after processing anything that's not code (like '$renaming', comments, etc)
329-- and right before parsing the actual code.
330-- takes the Package object with all the code on the 'code' key. no return value
331function preparse_hook(package)
332
333end
334
335
336-- called after writing all the output.
337-- takes the Package object
338function post_output_hook(package)
339
340end
341
342
343-- called from 'get_property_methods' to get the methods to retrieve a property
344-- according to its type
345function get_property_methods_hook(property_type, name)
346
347end
348
349-- called from ClassContainer:doparse with the string being parsed
350-- return nil, or a substring
351function parser_hook(s)
352
353        return nil
354end
355
356
Note: See TracBrowser for help on using the repository browser.