'package.loaders' -> 'package.searchers'
This commit is contained in:
52
loadlib.c
52
loadlib.c
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: loadlib.c,v 1.97 2011/03/01 17:01:53 roberto Exp roberto $
|
** $Id: loadlib.c,v 1.98 2011/04/08 19:17:36 roberto Exp roberto $
|
||||||
** Dynamic library loader for Lua
|
** Dynamic library loader for Lua
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
**
|
**
|
||||||
@@ -376,7 +376,7 @@ static int checkload (lua_State *L, int stat, const char *filename) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int loader_Lua (lua_State *L) {
|
static int searcher_Lua (lua_State *L) {
|
||||||
const char *filename;
|
const char *filename;
|
||||||
const char *name = luaL_checkstring(L, 1);
|
const char *name = luaL_checkstring(L, 1);
|
||||||
filename = findfile(L, name, "path");
|
filename = findfile(L, name, "path");
|
||||||
@@ -403,7 +403,7 @@ static int loadfunc (lua_State *L, const char *filename, const char *modname) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int loader_C (lua_State *L) {
|
static int searcher_C (lua_State *L) {
|
||||||
const char *name = luaL_checkstring(L, 1);
|
const char *name = luaL_checkstring(L, 1);
|
||||||
const char *filename = findfile(L, name, "cpath");
|
const char *filename = findfile(L, name, "cpath");
|
||||||
if (filename == NULL) return 1; /* module not found in this path */
|
if (filename == NULL) return 1; /* module not found in this path */
|
||||||
@@ -411,7 +411,7 @@ static int loader_C (lua_State *L) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int loader_Croot (lua_State *L) {
|
static int searcher_Croot (lua_State *L) {
|
||||||
const char *filename;
|
const char *filename;
|
||||||
const char *name = luaL_checkstring(L, 1);
|
const char *name = luaL_checkstring(L, 1);
|
||||||
const char *p = strchr(name, '.');
|
const char *p = strchr(name, '.');
|
||||||
@@ -434,7 +434,7 @@ static int loader_Croot (lua_State *L) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int loader_preload (lua_State *L) {
|
static int searcher_preload (lua_State *L) {
|
||||||
const char *name = luaL_checkstring(L, 1);
|
const char *name = luaL_checkstring(L, 1);
|
||||||
lua_getfield(L, LUA_REGISTRYINDEX, "_PRELOAD");
|
lua_getfield(L, LUA_REGISTRYINDEX, "_PRELOAD");
|
||||||
lua_getfield(L, -1, name);
|
lua_getfield(L, -1, name);
|
||||||
@@ -452,30 +452,30 @@ static int ll_require (lua_State *L) {
|
|||||||
lua_getfield(L, 2, name);
|
lua_getfield(L, 2, name);
|
||||||
if (lua_toboolean(L, -1)) /* is it there? */
|
if (lua_toboolean(L, -1)) /* is it there? */
|
||||||
return 1; /* package is already loaded */
|
return 1; /* package is already loaded */
|
||||||
/* else must load it; iterate over available loaders */
|
/* else must load it; iterate over available seachers to find a loader */
|
||||||
lua_getfield(L, lua_upvalueindex(1), "loaders");
|
lua_getfield(L, lua_upvalueindex(1), "searchers");
|
||||||
if (!lua_istable(L, -1))
|
if (!lua_istable(L, -1))
|
||||||
luaL_error(L, LUA_QL("package.loaders") " must be a table");
|
luaL_error(L, LUA_QL("package.searchers") " must be a table");
|
||||||
lua_pushliteral(L, ""); /* error message accumulator */
|
lua_pushliteral(L, ""); /* error message accumulator */
|
||||||
for (i=1; ; i++) {
|
for (i=1; ; i++) {
|
||||||
lua_rawgeti(L, -2, i); /* get a loader */
|
lua_rawgeti(L, -2, i); /* get a seacher */
|
||||||
if (lua_isnil(L, -1))
|
if (lua_isnil(L, -1)) /* no more searchers? */
|
||||||
luaL_error(L, "module " LUA_QS " not found:%s",
|
luaL_error(L, "module " LUA_QS " not found:%s",
|
||||||
name, lua_tostring(L, -2));
|
name, lua_tostring(L, -2));
|
||||||
lua_pushstring(L, name);
|
lua_pushstring(L, name);
|
||||||
lua_call(L, 1, 2); /* call it */
|
lua_call(L, 1, 2); /* call it */
|
||||||
if (lua_isfunction(L, -2)) /* did it find module? */
|
if (lua_isfunction(L, -2)) /* did it find a loader? */
|
||||||
break; /* module loaded successfully */
|
break; /* module loader found */
|
||||||
else if (lua_isstring(L, -2)) { /* loader returned error message? */
|
else if (lua_isstring(L, -2)) { /* searcher returned error message? */
|
||||||
lua_pop(L, 1); /* remove extra return */
|
lua_pop(L, 1); /* remove extra return */
|
||||||
lua_concat(L, 2); /* accumulate error message */
|
lua_concat(L, 2); /* accumulate error message */
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
lua_pop(L, 2); /* remove both returns */
|
lua_pop(L, 2); /* remove both returns */
|
||||||
}
|
}
|
||||||
lua_pushstring(L, name); /* pass name as argument to module */
|
lua_pushstring(L, name); /* pass name as argument to module loader */
|
||||||
lua_insert(L, -2); /* name is 1st argument (before search data) */
|
lua_insert(L, -2); /* name is 1st argument (before search data) */
|
||||||
lua_call(L, 2, 1); /* run loaded module */
|
lua_call(L, 2, 1); /* run loader to load module */
|
||||||
if (!lua_isnil(L, -1)) /* non-nil return? */
|
if (!lua_isnil(L, -1)) /* non-nil return? */
|
||||||
lua_setfield(L, 2, name); /* _LOADED[name] = returned value */
|
lua_setfield(L, 2, name); /* _LOADED[name] = returned value */
|
||||||
lua_getfield(L, 2, name);
|
lua_getfield(L, 2, name);
|
||||||
@@ -622,8 +622,8 @@ static const luaL_Reg ll_funcs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static const lua_CFunction loaders[] =
|
static const lua_CFunction searchers[] =
|
||||||
{loader_preload, loader_Lua, loader_C, loader_Croot, NULL};
|
{searcher_preload, searcher_Lua, searcher_C, searcher_Croot, NULL};
|
||||||
|
|
||||||
|
|
||||||
LUAMOD_API int luaopen_package (lua_State *L) {
|
LUAMOD_API int luaopen_package (lua_State *L) {
|
||||||
@@ -634,15 +634,19 @@ LUAMOD_API int luaopen_package (lua_State *L) {
|
|||||||
lua_setfield(L, -2, "__gc");
|
lua_setfield(L, -2, "__gc");
|
||||||
/* create `package' table */
|
/* create `package' table */
|
||||||
luaL_newlib(L, pk_funcs);
|
luaL_newlib(L, pk_funcs);
|
||||||
/* create `loaders' table */
|
/* create 'searchers' table */
|
||||||
lua_createtable(L, sizeof(loaders)/sizeof(loaders[0]) - 1, 0);
|
lua_createtable(L, sizeof(searchers)/sizeof(searchers[0]) - 1, 0);
|
||||||
/* fill it with pre-defined loaders */
|
/* fill it with pre-defined searchers */
|
||||||
for (i=0; loaders[i] != NULL; i++) {
|
for (i=0; searchers[i] != NULL; i++) {
|
||||||
lua_pushvalue(L, -2); /* set 'package' as upvalue for all loaders */
|
lua_pushvalue(L, -2); /* set 'package' as upvalue for all searchers */
|
||||||
lua_pushcclosure(L, loaders[i], 1);
|
lua_pushcclosure(L, searchers[i], 1);
|
||||||
lua_rawseti(L, -2, i+1);
|
lua_rawseti(L, -2, i+1);
|
||||||
}
|
}
|
||||||
lua_setfield(L, -2, "loaders"); /* put it in field `loaders' */
|
#if defined(LUA_COMPAT_LOADERS)
|
||||||
|
lua_pushvalue(L, -1); /* make a copy of 'searchers' table */
|
||||||
|
lua_setfield(L, -3, "loaders"); /* put it in field `loaders' */
|
||||||
|
#endif
|
||||||
|
lua_setfield(L, -2, "searchers"); /* put it in field 'searchers' */
|
||||||
/* set field 'path' */
|
/* set field 'path' */
|
||||||
setpath(L, "path", LUA_PATHVERSION, LUA_PATH, LUA_PATH_DEFAULT);
|
setpath(L, "path", LUA_PATHVERSION, LUA_PATH, LUA_PATH_DEFAULT);
|
||||||
/* set field 'cpath' */
|
/* set field 'cpath' */
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: luaconf.h,v 1.158 2011/05/26 16:09:40 roberto Exp roberto $
|
** $Id: luaconf.h,v 1.159 2011/06/13 14:13:06 roberto Exp roberto $
|
||||||
** Configuration file for Lua
|
** Configuration file for Lua
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
@@ -245,6 +245,12 @@
|
|||||||
*/
|
*/
|
||||||
#define LUA_COMPAT_UNPACK
|
#define LUA_COMPAT_UNPACK
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ LUA_COMPAT_LOADERS controls the presence of table 'package.loaders'.
|
||||||
|
** You can replace it with 'package.searchers'.
|
||||||
|
*/
|
||||||
|
#define LUA_COMPAT_LOADERS
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ macro 'lua_cpcall' emulates deprecated function lua_cpcall.
|
@@ macro 'lua_cpcall' emulates deprecated function lua_cpcall.
|
||||||
** You can call your C function directly (with light C functions).
|
** You can call your C function directly (with light C functions).
|
||||||
|
|||||||
Reference in New Issue
Block a user