diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2021-11-05 22:09:15 -0700 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2021-11-05 22:09:15 -0700 |
commit | dd434b2e1c4e7bf027d620575f7d697ff872cacb (patch) | |
tree | ab7d9f94ac96c5bfa0583ade18c7bf48be59180c | |
parent | 4ad3390ce39ed7525a073990c1655e7b1e14ce6b (diff) | |
download | teliva-dd434b2e1c4e7bf027d620575f7d697ff872cacb.tar.gz |
drop test array data structure
-rw-r--r-- | src/lua.c | 82 |
1 files changed, 0 insertions, 82 deletions
diff --git a/src/lua.c b/src/lua.c index 0bbcd47..6eca245 100644 --- a/src/lua.c +++ b/src/lua.c @@ -368,79 +368,6 @@ static int pmain (lua_State *L) { } -typedef struct NumArray { - int size; - double values[0]; /* variable part */ -} NumArray; - - -static int newarray (lua_State *L) { - int n = luaL_checkint(L, 1); - size_t nbytes = sizeof(NumArray) + n*sizeof(double); - NumArray *a = (NumArray *)lua_newuserdata(L, nbytes); - - luaL_getmetatable(L, "array"); - lua_setmetatable(L, -2); - - a->size = n; - return 1; /* new userdatum is already on the stack */ -} - - -/* ensure bottom of stack is an array */ -static NumArray *checkarray (lua_State *L) { - void *ud = luaL_checkudata(L, 1, "array"); - luaL_argcheck(L, ud != NULL, 1, "`array' expected"); - return (NumArray *)ud; -} - - -static int setarray (lua_State *L) { - NumArray *a = checkarray(L); - int index = luaL_checkint(L, 2); - double value = luaL_checknumber(L, 3); - - luaL_argcheck(L, 1 <= index && index <= a->size, 2, - "index out of range"); - - a->values[index-1] = value; - return 0; -} - - -static int getarray (lua_State *L) { - NumArray *a = checkarray(L); - int index = luaL_checkint(L, 2); - - luaL_argcheck(L, 1 <= index && index <= a->size, 2, - "index out of range"); - - lua_pushnumber(L, a->values[index-1]); - return 1; -} - - -static int getsize (lua_State *L) { - NumArray *a = checkarray(L); - luaL_argcheck(L, a != NULL, 1, "`array' expected"); - lua_pushnumber(L, a->size); - return 1; -} - - -static const struct luaL_Reg arraylib_functions [] = { - {"new", newarray}, - {NULL, NULL} -}; - -static const struct luaL_Reg array_methods [] = { - {"set", setarray}, - {"get", getarray}, - {"size", getsize}, - {NULL, NULL} -}; - - void draw_menu(void); @@ -452,15 +379,6 @@ int main (int argc, char **argv) { l_message(argv[0], "cannot create state: not enough memory"); return EXIT_FAILURE; } - luaL_newmetatable(L, "array"); - /* stack: metatable */ - lua_pushstring(L, "__index"); - /* stack: metatable "__index" */ - lua_pushvalue(L, -2); /* metatable */ - lua_settable(L, -3); /* metatable.__index = metatable */ - /* stack: metatable */ - luaL_register(L, NULL, array_methods); /* register array_methods in metatable */ - luaL_register(L, "array", arraylib_functions); initscr(); start_color(); draw_menu(); |