1
0
mirror of https://github.com/lua/lua.git synced 2025-01-14 05:43:00 +08:00

new API does not need tests that complex

This commit is contained in:
Roberto Ierusalimschy 2000-08-29 16:05:11 -03:00
parent 808525e417
commit 4135f4f586

217
ltests.c
View File

@ -1,5 +1,5 @@
/*
** $Id: ltests.c,v 1.35 2000/08/28 17:57:04 roberto Exp roberto $
** $Id: ltests.c,v 1.36 2000/08/29 14:57:10 roberto Exp roberto $
** Internal Module for Debugging of the Lua Implementation
** See Copyright Notice in lua.h
*/
@ -239,6 +239,89 @@ static int string_query (lua_State *L) {
}
static int tref (lua_State *L) {
luaL_checktype(L, 1, "any");
lua_pushobject(L, 1);
lua_pushnumber(L, lua_ref(L, luaL_opt_int(L, 2, 1)));
return 1;
}
static int getref (lua_State *L) {
if (lua_getref(L, luaL_check_int(L, 1)))
return 1;
else
return 0;
}
static int unref (lua_State *L) {
lua_unref(L, luaL_check_int(L, 1));
return 0;
}
static int newuserdata (lua_State *L) {
lua_pushusertag(L, (void *)luaL_check_int(L, 1), luaL_check_int(L, 2));
return 1;
}
static int udataval (lua_State *L) {
luaL_checktype(L, 1, "userdata");
lua_pushnumber(L, (int)lua_touserdata(L, 1));
return 1;
}
static int newstate (lua_State *L) {
lua_State *L1 = lua_newstate(luaL_check_int(L, 1), luaL_check_int(L, 2));
if (L1)
lua_pushuserdata(L, L1);
else
lua_pushnil(L);
return 1;
}
static int closestate (lua_State *L) {
luaL_checktype(L, 1, "userdata");
lua_close((lua_State *)lua_touserdata(L, 1));
return 0;
}
static int doremote (lua_State *L) {
lua_State *L1;
const char *code = luaL_check_string(L, 2);
int status;
luaL_checktype(L, 1, "userdata");
L1 = (lua_State *)lua_touserdata(L, 1);
status = lua_dostring(L1, code);
if (status != 0) {
lua_pushnil(L);
lua_pushnumber(L, status);
return 2;
}
else {
int i = 0;
while (!lua_isnull(L1, ++i))
lua_pushstring(L, lua_tostring(L1, i));
return i-1;
}
}
static int settagmethod (lua_State *L) {
luaL_checktype(L, 3, "any");
lua_settagmethod(L, luaL_check_int(L, 1), luaL_check_string(L, 2));
return 1;
}
static int pushbool (lua_State *L, int b) {
if (b) lua_pushnumber(L, 1);
else lua_pushnil(L);
return 1;
}
static int equal (lua_State *L) {
return pushbool(L, lua_equal(L, 1, 2));
}
/*
** {======================================================
** function to test the API with C. It interprets a kind of "assembler"
@ -321,34 +404,9 @@ static int testC (lua_State *L) {
else if EQ("pushnum") {
lua_pushnumber(L, getnum);
}
else if EQ("newtable") {
lua_newtable(L);
}
else if EQ("pushobject") {
lua_pushobject(L, getnum);
}
else if EQ("getglobal") {
lua_getglobal(L, getname);
}
else if EQ("getglobals") {
lua_getglobals(L);
}
else if EQ("ref") {
reg[getreg] = lua_ref(L, 0);
}
else if EQ("reflock") {
reg[getreg] = lua_ref(L, 1);
}
else if EQ("getref") {
int n = getreg;
reg[n] = lua_getref(L, getnum);
}
else if EQ("unref") {
lua_unref(L, getnum);
}
else if EQ("setglobal") {
lua_setglobal(L, getname);
}
else if EQ("pushstring") {
lua_pushstring(L, getname);
}
@ -357,98 +415,9 @@ static int testC (lua_State *L) {
int nres = getnum;
if (lua_call(L, narg, nres)) lua_error(L, NULL);
}
else if EQ("gettable") {
lua_gettable(L);
}
else if EQ("rawget") {
lua_rawget(L);
}
else if EQ("settable") {
lua_settable(L);
}
else if EQ("rawset") {
lua_rawset(L);
}
else if EQ("tag") {
int n = getreg;
reg[n] = lua_tag(L, getnum);
}
else if EQ("type") {
lua_pushstring(L, lua_type(L, getnum));
}
else if EQ("isnil") {
lua_pushnumber(L, lua_isnil(L, getnum));
}
else if EQ("isnull") {
lua_pushnumber(L, lua_isnull(L, getnum));
}
else if EQ("isnumber") {
lua_pushnumber(L, lua_isnumber(L, getnum));
}
else if EQ("isstring") {
lua_pushnumber(L, lua_isstring(L, getnum));
}
else if EQ("istable") {
lua_pushnumber(L, lua_istable(L, getnum));
}
else if EQ("isfunction") {
lua_pushnumber(L, lua_isfunction(L, getnum));
}
else if EQ("iscfunction") {
lua_pushnumber(L, lua_iscfunction(L, getnum));
}
else if EQ("isuserdata") {
lua_pushnumber(L, lua_isuserdata(L, getnum));
}
else if EQ("equal") {
int n1 = getreg;
int n2 = getnum;
int n3 = getnum;
reg[n1] = lua_equal(L, n2, n3);
}
else if EQ("pushusertag") {
int val = getnum;
int tag = getnum;
lua_pushusertag(L, (void *)val, tag);
}
else if EQ("udataval") {
int n = getreg;
reg[n] = (int)lua_touserdata(L, getnum);
}
else if EQ("settagmethod") {
int n = getnum;
lua_settagmethod(L, n, getname);
}
else if EQ("newstate") {
int stacksize = getnum;
lua_State *L1 = lua_newstate(stacksize, getnum);
if (L1)
lua_pushuserdata(L, L1);
else
lua_pushnil(L);
}
else if EQ("closestate") {
(lua_close)((lua_State *)lua_touserdata(L, getnum));
}
else if EQ("doremote") {
int ol1 = getnum;
int str = getnum;
lua_State *L1;
int status;
if (!lua_isuserdata(L, ol1) || !lua_isstring(L, str))
lua_error(L, "bad arguments for `doremote'");
L1 = (lua_State *)lua_touserdata(L, ol1);
status = lua_dostring(L1, lua_tostring(L, str));
if (status != 0) {
lua_pushnil(L);
lua_pushnumber(L, status);
}
else {
int i = 0;
while (!lua_isnull(L1, ++i))
lua_pushstring(L, lua_tostring(L1, i));
}
}
else luaL_verror(L, "unknown instruction %.30s", buff);
}
return 0;
@ -467,12 +436,28 @@ static const struct luaL_reg tests_funcs[] = {
{"querystr", string_query},
{"querytab", table_query},
{"testC", testC},
{"ref", tref},
{"getref", getref},
{"unref", unref},
{"newuserdata", newuserdata},
{"udataval", udataval},
{"newstate", newstate},
{"closestate", closestate},
{"doremote", doremote},
{"settagmethod", settagmethod},
{"equal", equal},
{"totalmem", mem_query}
};
void luaB_opentests (lua_State *L) {
luaL_openl(L, tests_funcs);
lua_newtable(L);
lua_getglobals(L);
lua_pushobject(L, -2);
lua_setglobals(L);
luaL_openl(L, tests_funcs); /* open functions inside new table */
lua_setglobals(L); /* restore old table of globals */
lua_setglobal(L, "T"); /* set new table as global T */
}
#endif