luaA_init: use Lua C API to add paths to package.path

This is cleaner and it should be a bit faster than using
luaL_dostring().

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Ali Polatel 2009-05-09 11:09:21 +03:00 committed by Julien Danjou
parent 99f763d833
commit 238dc06ae4
1 changed files with 33 additions and 21 deletions

54
luaa.c
View File

@ -679,20 +679,25 @@ luaA_init(xdgHandle* xdg)
/* Export root lib */ /* Export root lib */
luaL_register(L, "root", awesome_root_lib); luaL_register(L, "root", awesome_root_lib);
lua_pop(L, 1); /* luaL_register() leaves the table on stack */
/* Export hooks lib */ /* Export hooks lib */
luaL_register(L, "hooks", awesome_hooks_lib); luaL_register(L, "hooks", awesome_hooks_lib);
lua_pop(L, 1); /* luaL_register() leaves the table on stack */
#ifdef WITH_DBUS #ifdef WITH_DBUS
/* Export D-Bus lib */ /* Export D-Bus lib */
luaL_register(L, "dbus", awesome_dbus_lib); luaL_register(L, "dbus", awesome_dbus_lib);
lua_pop(L, 1); /* luaL_register() leaves the table on stack */
#endif #endif
/* Export keygrabber lib */ /* Export keygrabber lib */
luaL_register(L, "keygrabber", awesome_keygrabber_lib); luaL_register(L, "keygrabber", awesome_keygrabber_lib);
lua_pop(L, 1); /* luaL_register() leaves the table on stack */
/* Export mousegrabber lib */ /* Export mousegrabber lib */
luaL_register(L, "mousegrabber", awesome_mousegrabber_lib); luaL_register(L, "mousegrabber", awesome_mousegrabber_lib);
lua_pop(L, 1); /* luaL_register() leaves the table on stack */
/* Export screen */ /* Export screen */
luaA_openlib(L, "screen", awesome_screen_methods, awesome_screen_meta); luaA_openlib(L, "screen", awesome_screen_methods, awesome_screen_meta);
@ -740,34 +745,41 @@ luaA_init(xdgHandle* xdg)
#endif #endif
/* add Lua lib path (/usr/share/awesome/lib by default) */ /* add Lua lib path (/usr/share/awesome/lib by default) */
luaA_dostring(L, "package.path = package.path .. \";" AWESOME_LUA_LIB_PATH "/?.lua\""); lua_getglobal(L, "package");
luaA_dostring(L, "package.path = package.path .. \";" AWESOME_LUA_LIB_PATH "/?/init.lua\""); if (LUA_TTABLE != lua_type(L, 1))
{
warn("package is not a table");
return;
}
lua_getfield(L, 1, "path");
if (LUA_TSTRING != lua_type(L, 2))
{
warn("package.path is not a string");
lua_pop(L, 1);
return;
}
lua_pushliteral(L, ";" AWESOME_LUA_LIB_PATH "/?.lua");
lua_pushliteral(L, ";" AWESOME_LUA_LIB_PATH "/?/init.lua");
lua_concat(L, 3); /* concatenate with package.path */
/* add XDG_CONFIG_DIR as include path */ /* add XDG_CONFIG_DIR as include path */
const char * const *xdgconfigdirs = xdgSearchableConfigDirectories(xdg); const char * const *xdgconfigdirs = xdgSearchableConfigDirectories(xdg);
buffer_t buf;
int prev_len = 0;
buffer_init(&buf);
#define A_LUAA_FIRST_STRING "package.path = package.path .. \";"
#define A_LUAA_SECOND_STRING "/awesome/?.lua;"
#define A_LUAA_FULL_STRING A_LUAA_FIRST_STRING A_LUAA_SECOND_STRING "/awesome/?/init.lua\""
buffer_addsl(&buf, A_LUAA_FULL_STRING);
for(; *xdgconfigdirs; xdgconfigdirs++) for(; *xdgconfigdirs; xdgconfigdirs++)
{ {
size_t len = a_strlen(*xdgconfigdirs); size_t len = a_strlen(*xdgconfigdirs);
buffer_splice(&buf, sizeof(A_LUAA_FIRST_STRING) - 1, prev_len, *xdgconfigdirs, len); lua_pushliteral(L, ";");
buffer_splice(&buf, lua_pushlstring(L, *xdgconfigdirs, len);
sizeof(A_LUAA_FIRST_STRING) - 1 lua_pushliteral(L, "/awesome/?.lua");
+ len lua_concat(L, 3);
+ sizeof(A_LUAA_SECOND_STRING) - 1,
prev_len, *xdgconfigdirs, len); lua_pushliteral(L, ";");
luaA_dostring(L, buf.s); lua_pushlstring(L, *xdgconfigdirs, len);
prev_len = len; lua_pushliteral(L, "/awesome/?/init.lua");
lua_concat(L, 3);
lua_concat(L, 3); /* concatenate with package.path */
} }
#undef A_LUAA_FIRST_STRING lua_setfield(L, 1, "path"); /* package.path = "concatenated string" */
#undef A_LUAA_SECOND_STRING
#undef A_LUAA_FULL_STRING
buffer_wipe(&buf);
} }
static bool static bool