2
0

lauxlib.pas 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. (******************************************************************************
  2. * *
  3. * File: lauxlib.pas *
  4. * Authors: TeCGraf (C headers + actual Lua libraries) *
  5. * Lavergne Thomas (original translation to Pascal) *
  6. * Bram Kuijvenhoven (update to Lua 5.1.1 for FreePascal) *
  7. * Description: Lua auxiliary library *
  8. * *
  9. ******************************************************************************)
  10. (*
  11. ** $Id: lauxlib.h,v 1.59 2003/03/18 12:25:32 roberto Exp $
  12. ** Auxiliary functions for building Lua libraries
  13. ** See Copyright Notice in lua.h
  14. *)
  15. (*
  16. ** Translated to pascal by Lavergne Thomas
  17. ** Notes :
  18. ** - Pointers type was prefixed with 'P'
  19. ** Bug reports :
  20. ** - [email protected]
  21. ** In french or in english
  22. *)
  23. {$IFDEF FPC}{$MODE OBJFPC}{$H+}{$ENDIF}
  24. {$IFNDEF FPC_DOTTEDUNITS}
  25. unit lauxlib;
  26. {$ENDIF FPC_DOTTEDUNITS}
  27. interface
  28. {$IFDEF FPC_DOTTEDUNITS}
  29. uses
  30. Lua;
  31. {$ELSE FPC_DOTTEDUNITS}
  32. uses
  33. Lua;
  34. {$ENDIF FPC_DOTTEDUNITS}
  35. // functions added for Pascal
  36. procedure lua_pushstring(L: Plua_State; const s: ansistring);
  37. // compatibilty macros
  38. function luaL_getn(L: Plua_State; n: Integer): Integer; // calls lua_objlen
  39. procedure luaL_setn(L: Plua_State; t, n: Integer); // does nothing!
  40. type
  41. luaL_reg = record
  42. name: PAnsiChar;
  43. func: lua_CFunction;
  44. end;
  45. PluaL_reg = ^luaL_reg;
  46. procedure luaL_openlib(L: Plua_State; const libname: PAnsiChar; const lr: PluaL_reg; nup: Integer); cdecl;
  47. procedure luaL_register(L: Plua_State; const libname: PAnsiChar; const lr: PluaL_reg); cdecl;
  48. function luaL_getmetafield(L: Plua_State; obj: Integer; const e: PAnsiChar): Integer; cdecl;
  49. function luaL_callmeta(L: Plua_State; obj: Integer; const e: PAnsiChar): Integer; cdecl;
  50. function luaL_typerror(L: Plua_State; narg: Integer; const tname: PAnsiChar): Integer; cdecl;
  51. function luaL_argerror(L: Plua_State; numarg: Integer; const extramsg: PAnsiChar): Integer; cdecl;
  52. function luaL_checklstring(L: Plua_State; numArg: Integer; l_: Psize_t): PAnsiChar; cdecl;
  53. function luaL_optlstring(L: Plua_State; numArg: Integer; const def: PAnsiChar; l_: Psize_t): PAnsiChar; cdecl;
  54. function luaL_checknumber(L: Plua_State; numArg: Integer): lua_Number; cdecl;
  55. function luaL_optnumber(L: Plua_State; nArg: Integer; def: lua_Number): lua_Number; cdecl;
  56. function luaL_checkinteger(L: Plua_State; numArg: Integer): lua_Integer; cdecl;
  57. function luaL_optinteger(L: Plua_State; nArg: Integer; def: lua_Integer): lua_Integer; cdecl;
  58. procedure luaL_checkstack(L: Plua_State; sz: Integer; const msg: PAnsiChar); cdecl;
  59. procedure luaL_checktype(L: Plua_State; narg, t: Integer); cdecl;
  60. procedure luaL_checkany(L: Plua_State; narg: Integer); cdecl;
  61. function luaL_newmetatable(L: Plua_State; const tname: PAnsiChar): Integer; cdecl;
  62. function luaL_checkudata(L: Plua_State; ud: Integer; const tname: PAnsiChar): Pointer; cdecl;
  63. procedure luaL_where(L: Plua_State; lvl: Integer); cdecl;
  64. function luaL_error(L: Plua_State; const fmt: PAnsiChar; args: array of const): Integer; cdecl; external LUA_LIB_NAME; // note: C's ... to array of const conversion is not portable to Delphi
  65. function luaL_checkoption(L: Plua_State; narg: Integer; def: PAnsiChar; lst: PPAnsiChar): Integer; cdecl;
  66. function luaL_ref(L: Plua_State; t: Integer): Integer; cdecl;
  67. procedure luaL_unref(L: Plua_State; t, ref: Integer); cdecl;
  68. function luaL_loadfile(L: Plua_State; const filename: PAnsiChar): Integer; cdecl;
  69. function luaL_loadbuffer(L: Plua_State; const buff: PAnsiChar; size: size_t; const name: PAnsiChar): Integer; cdecl;
  70. function luaL_loadstring(L: Plua_State; const s: PAnsiChar): Integer; cdecl;
  71. function luaL_newstate: Plua_State; cdecl;
  72. function lua_open: Plua_State; // compatibility; moved from unit lua to lauxlib because it needs luaL_newstate
  73. function luaL_gsub(L: Plua_State; const s, p, r: PAnsiChar): PAnsiChar; cdecl;
  74. function luaL_findtable(L: Plua_State; idx: Integer; const fname: PAnsiChar; szhint: Integer): PAnsiChar; cdecl;
  75. (*
  76. ** ===============================================================
  77. ** some useful macros
  78. ** ===============================================================
  79. *)
  80. procedure luaL_argcheck(L: Plua_State; cond: Boolean; numarg: Integer; extramsg: PAnsiChar);
  81. function luaL_checkstring(L: Plua_State; n: Integer): PAnsiChar;
  82. function luaL_optstring(L: Plua_State; n: Integer; d: PAnsiChar): PAnsiChar;
  83. function luaL_checkint(L: Plua_State; n: Integer): Integer;
  84. function luaL_checklong(L: Plua_State; n: Integer): LongInt;
  85. function luaL_optint(L: Plua_State; n: Integer; d: Double): Integer;
  86. function luaL_optlong(L: Plua_State; n: Integer; d: Double): LongInt;
  87. function luaL_typename(L: Plua_State; i: Integer): PAnsiChar;
  88. function lua_dofile(L: Plua_State; const filename: PAnsiChar): Integer;
  89. function lua_dostring(L: Plua_State; const str: PAnsiChar): Integer;
  90. procedure lua_Lgetmetatable(L: Plua_State; tname: PAnsiChar);
  91. // not translated:
  92. // #define luaL_opt(L,f,n,d) (lua_isnoneornil(L,(n)) ? (d) : f(L,(n)))
  93. (*
  94. ** =======================================================
  95. ** Generic Buffer manipulation
  96. ** =======================================================
  97. *)
  98. const
  99. // note: this is just arbitrary, as it related to the BUFSIZ defined in stdio.h ...
  100. LUAL_BUFFERSIZE = 4096;
  101. type
  102. luaL_Buffer = record
  103. p: PAnsiChar; (* current position in buffer *)
  104. lvl: Integer; (* number of strings in the stack (level) *)
  105. L: Plua_State;
  106. buffer: array [0..LUAL_BUFFERSIZE - 1] of AnsiChar; // warning: see note above about LUAL_BUFFERSIZE
  107. end;
  108. PluaL_Buffer = ^luaL_Buffer;
  109. procedure luaL_addchar(B: PluaL_Buffer; c: AnsiChar); // warning: see note above about LUAL_BUFFERSIZE
  110. (* compatibility only (alias for luaL_addchar) *)
  111. procedure luaL_putchar(B: PluaL_Buffer; c: AnsiChar); // warning: see note above about LUAL_BUFFERSIZE
  112. procedure luaL_addsize(B: PluaL_Buffer; n: Integer);
  113. procedure luaL_buffinit(L: Plua_State; B: PluaL_Buffer); cdecl;
  114. function luaL_prepbuffer(B: PluaL_Buffer): PAnsiChar; cdecl;
  115. procedure luaL_addlstring(B: PluaL_Buffer; const s: PAnsiChar; l: size_t); cdecl;
  116. procedure luaL_addstring(B: PluaL_Buffer; const s: PAnsiChar); cdecl;
  117. procedure luaL_addvalue(B: PluaL_Buffer); cdecl;
  118. procedure luaL_pushresult(B: PluaL_Buffer); cdecl;
  119. (* compatibility with ref system *)
  120. (* pre-defined references *)
  121. const
  122. LUA_NOREF = -2;
  123. LUA_REFNIL = -1;
  124. procedure lua_unref(L: Plua_State; ref: Integer);
  125. procedure lua_getref(L: Plua_State; ref: Integer);
  126. (*
  127. ** Compatibility macros and functions
  128. *)
  129. function luaL_check_lstr(L: Plua_State; numArg: Integer; len: Psize_t): PAnsiChar;
  130. function luaL_opt_lstr(L: Plua_State; numArg: Integer; const def: PAnsiChar; len: Psize_t): PAnsiChar;
  131. function luaL_check_number(L: Plua_State; numArg: Integer): lua_Number;
  132. function luaL_opt_number(L: Plua_State; nArg: Integer; def: lua_Number): lua_Number;
  133. procedure luaL_arg_check(L: Plua_State; cond: Boolean; numarg: Integer; extramsg: PAnsiChar);
  134. function luaL_check_string(L: Plua_State; n: Integer): PAnsiChar;
  135. function luaL_opt_string(L: Plua_State; n: Integer; d: PAnsiChar): PAnsiChar;
  136. function luaL_check_int(L: Plua_State; n: Integer): Integer;
  137. function luaL_check_long(L: Plua_State; n: Integer): LongInt;
  138. function luaL_opt_int(L: Plua_State; n: Integer; d: Double): Integer;
  139. function luaL_opt_long(L: Plua_State; n: Integer; d: Double): LongInt;
  140. implementation
  141. procedure lua_pushstring(L: Plua_State; const s: ansistring);
  142. begin
  143. lua_pushlstring(L, PAnsiChar(s), Length(s));
  144. end;
  145. function luaL_getn(L: Plua_State; n: Integer): Integer;
  146. begin
  147. Result := lua_objlen(L, n);
  148. end;
  149. procedure luaL_setn(L: Plua_State; t, n: Integer);
  150. begin
  151. // does nothing as this operation is deprecated
  152. end;
  153. procedure luaL_openlib(L: Plua_State; const libname: PAnsiChar; const lr: PluaL_reg; nup: Integer); cdecl; external LUA_LIB_NAME;
  154. procedure luaL_register(L: Plua_State; const libname: PAnsiChar; const lr: PluaL_reg); cdecl; external LUA_LIB_NAME;
  155. function luaL_getmetafield(L: Plua_State; obj: Integer; const e: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  156. function luaL_callmeta(L: Plua_State; obj: Integer; const e: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  157. function luaL_typerror(L: Plua_State; narg: Integer; const tname: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  158. function luaL_argerror(L: Plua_State; numarg: Integer; const extramsg: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  159. function luaL_checklstring(L: Plua_State; numArg: Integer; l_: Psize_t): PAnsiChar; cdecl; external LUA_LIB_NAME;
  160. function luaL_optlstring(L: Plua_State; numArg: Integer; const def: PAnsiChar; l_: Psize_t): PAnsiChar; cdecl; external LUA_LIB_NAME;
  161. function luaL_checknumber(L: Plua_State; numArg: Integer): lua_Number; cdecl; external LUA_LIB_NAME;
  162. function luaL_optnumber(L: Plua_State; nArg: Integer; def: lua_Number): lua_Number; cdecl; external LUA_LIB_NAME;
  163. function luaL_checkinteger(L: Plua_State; numArg: Integer): lua_Integer; cdecl; external LUA_LIB_NAME;
  164. function luaL_optinteger(L: Plua_State; nArg: Integer; def: lua_Integer): lua_Integer; cdecl; external LUA_LIB_NAME;
  165. procedure luaL_checkstack(L: Plua_State; sz: Integer; const msg: PAnsiChar); cdecl; external LUA_LIB_NAME;
  166. procedure luaL_checktype(L: Plua_State; narg, t: Integer); cdecl; external LUA_LIB_NAME;
  167. procedure luaL_checkany(L: Plua_State; narg: Integer); cdecl; external LUA_LIB_NAME;
  168. function luaL_newmetatable(L: Plua_State; const tname: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  169. function luaL_checkudata(L: Plua_State; ud: Integer; const tname: PAnsiChar): Pointer; cdecl; external LUA_LIB_NAME;
  170. procedure luaL_where(L: Plua_State; lvl: Integer); cdecl; external LUA_LIB_NAME;
  171. // function luaL_error(L: Plua_State; const fmt: PAnsiChar; args: array of const): Integer; cdecl; external LUA_LIB_NAME;
  172. function luaL_checkoption(L: Plua_State; narg: Integer; def: PAnsiChar; lst: PPAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  173. function luaL_ref(L: Plua_State; t: Integer): Integer; cdecl; external LUA_LIB_NAME;
  174. procedure luaL_unref(L: Plua_State; t, ref: Integer); cdecl; external LUA_LIB_NAME;
  175. function luaL_loadfile(L: Plua_State; const filename: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  176. function luaL_loadbuffer(L: Plua_State; const buff: PAnsiChar; size: size_t; const name: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  177. function luaL_loadstring(L: Plua_State; const s: PAnsiChar): Integer; cdecl; external LUA_LIB_NAME;
  178. function luaL_newstate: Plua_State; cdecl; external LUA_LIB_NAME;
  179. function lua_open: Plua_State;
  180. begin
  181. Result := luaL_newstate;
  182. end;
  183. function luaL_gsub(L: Plua_State; const s, p, r: PAnsiChar): PAnsiChar; cdecl; external LUA_LIB_NAME;
  184. function luaL_findtable(L: Plua_State; idx: Integer; const fname: PAnsiChar; szhint: Integer): PAnsiChar; cdecl; external LUA_LIB_NAME;
  185. function luaL_typename(L: Plua_State; i: Integer): PAnsiChar;
  186. begin
  187. Result := lua_typename(L, lua_type(L, i));
  188. end;
  189. function lua_dofile(L: Plua_State; const filename: PAnsiChar): Integer;
  190. begin
  191. Result := luaL_loadfile(L, filename);
  192. if Result = 0 then
  193. Result := lua_pcall(L, 0, LUA_MULTRET, 0);
  194. end;
  195. function lua_dostring(L: Plua_State; const str: PAnsiChar): Integer;
  196. begin
  197. Result := luaL_loadstring(L, str);
  198. if Result = 0 then
  199. Result := lua_pcall(L, 0, LUA_MULTRET, 0);
  200. end;
  201. procedure lua_Lgetmetatable(L: Plua_State; tname: PAnsiChar);
  202. begin
  203. lua_getfield(L, LUA_REGISTRYINDEX, tname);
  204. end;
  205. procedure luaL_argcheck(L: Plua_State; cond: Boolean; numarg: Integer; extramsg: PAnsiChar);
  206. begin
  207. if not cond then
  208. luaL_argerror(L, numarg, extramsg)
  209. end;
  210. function luaL_checkstring(L: Plua_State; n: Integer): PAnsiChar;
  211. begin
  212. Result := luaL_checklstring(L, n, nil)
  213. end;
  214. function luaL_optstring(L: Plua_State; n: Integer; d: PAnsiChar): PAnsiChar;
  215. begin
  216. Result := luaL_optlstring(L, n, d, nil)
  217. end;
  218. function luaL_checkint(L: Plua_State; n: Integer): Integer;
  219. begin
  220. Result := Integer(Trunc(luaL_checknumber(L, n)))
  221. end;
  222. function luaL_checklong(L: Plua_State; n: Integer): LongInt;
  223. begin
  224. Result := LongInt(Trunc(luaL_checknumber(L, n)))
  225. end;
  226. function luaL_optint(L: Plua_State; n: Integer; d: Double): Integer;
  227. begin
  228. Result := Integer(Trunc(luaL_optnumber(L, n, d)))
  229. end;
  230. function luaL_optlong(L: Plua_State; n: Integer; d: Double): LongInt;
  231. begin
  232. Result := LongInt(Trunc(luaL_optnumber(L, n, d)))
  233. end;
  234. procedure luaL_addchar(B: PluaL_Buffer; c: AnsiChar);
  235. begin
  236. if Cardinal(@(B^.p)) < (Cardinal(@(B^.buffer[0])) + LUAL_BUFFERSIZE) then
  237. luaL_prepbuffer(B);
  238. B^.p[1] := c;
  239. B^.p := B^.p + 1;
  240. end;
  241. procedure luaL_putchar(B: PluaL_Buffer; c: AnsiChar);
  242. begin
  243. luaL_addchar(B, c);
  244. end;
  245. procedure luaL_addsize(B: PluaL_Buffer; n: Integer);
  246. begin
  247. B^.p := B^.p + n;
  248. end;
  249. procedure luaL_buffinit(L: Plua_State ; B: PluaL_Buffer); cdecl; external LUA_LIB_NAME;
  250. function luaL_prepbuffer(B: PluaL_Buffer): PAnsiChar; cdecl; external LUA_LIB_NAME;
  251. procedure luaL_addlstring(B: PluaL_Buffer; const s: PAnsiChar; l: size_t); cdecl; external LUA_LIB_NAME;
  252. procedure luaL_addstring(B: PluaL_Buffer; const s: PAnsiChar); cdecl; external LUA_LIB_NAME;
  253. procedure luaL_addvalue(B: PluaL_Buffer); cdecl; external LUA_LIB_NAME;
  254. procedure luaL_pushresult(B: PluaL_Buffer); cdecl; external LUA_LIB_NAME;
  255. procedure lua_unref(L: Plua_State; ref: Integer);
  256. begin
  257. luaL_unref(L, LUA_REGISTRYINDEX, ref);
  258. end;
  259. procedure lua_getref(L: Plua_State; ref: Integer);
  260. begin
  261. lua_rawgeti(L, LUA_REGISTRYINDEX, ref);
  262. end;
  263. function luaL_check_lstr(L: Plua_State; numArg: Integer; len: Psize_t): PAnsiChar;
  264. begin
  265. Result := luaL_checklstring(L, numArg, len);
  266. end;
  267. function luaL_opt_lstr(L: Plua_State; numArg: Integer; const def: PAnsiChar; len: Psize_t): PAnsiChar;
  268. begin
  269. Result := luaL_optlstring(L, numArg, def, len);
  270. end;
  271. function luaL_check_number(L: Plua_State; numArg: Integer): lua_Number;
  272. begin
  273. Result := luaL_checknumber(L, numArg);
  274. end;
  275. function luaL_opt_number(L: Plua_State; nArg: Integer; def: lua_Number): lua_Number;
  276. begin
  277. Result := luaL_optnumber(L, nArg, def);
  278. end;
  279. procedure luaL_arg_check(L: Plua_State; cond: Boolean; numarg: Integer; extramsg: PAnsiChar);
  280. begin
  281. luaL_argcheck(L, cond, numarg, extramsg);
  282. end;
  283. function luaL_check_string(L: Plua_State; n: Integer): PAnsiChar;
  284. begin
  285. Result := luaL_checkstring(L, n);
  286. end;
  287. function luaL_opt_string(L: Plua_State; n: Integer; d: PAnsiChar): PAnsiChar;
  288. begin
  289. Result := luaL_optstring(L, n, d);
  290. end;
  291. function luaL_check_int(L: Plua_State; n: Integer): Integer;
  292. begin
  293. Result := luaL_checkint(L, n);
  294. end;
  295. function luaL_check_long(L: Plua_State; n: Integer): LongInt;
  296. begin
  297. Result := luaL_checklong(L, n);
  298. end;
  299. function luaL_opt_int(L: Plua_State; n: Integer; d: Double): Integer;
  300. begin
  301. Result := luaL_optint(L, n, d);
  302. end;
  303. function luaL_opt_long(L: Plua_State; n: Integer; d: Double): LongInt;
  304. begin
  305. Result := luaL_optlong(L, n, d);
  306. end;
  307. end.