Scripting: More table scaffolding

This commit is contained in:
Vicki Pfau 2022-05-10 21:43:03 -07:00
parent c6e18b2a59
commit bbf6d94fe2
3 changed files with 70 additions and 1 deletions

View File

@ -631,6 +631,7 @@ struct mScriptValue* mScriptStringCreateFromUTF8(const char* string);
bool mScriptTableInsert(struct mScriptValue* table, struct mScriptValue* key, struct mScriptValue* value);
bool mScriptTableRemove(struct mScriptValue* table, struct mScriptValue* key);
struct mScriptValue* mScriptTableLookup(struct mScriptValue* table, struct mScriptValue* key);
bool mScriptTableClear(struct mScriptValue* table);
void mScriptFrameInit(struct mScriptFrame* frame);
void mScriptFrameDeinit(struct mScriptFrame* frame);

View File

@ -38,6 +38,7 @@ static int _luaThunk(lua_State* lua);
static int _luaGetObject(lua_State* lua);
static int _luaSetObject(lua_State* lua);
static int _luaGcObject(lua_State* lua);
static int _luaGetTable(lua_State* lua);
#if LUA_VERSION_NUM < 503
#define lua_pushinteger lua_pushnumber
@ -96,6 +97,11 @@ static const luaL_Reg _mSTStruct[] = {
{ NULL, NULL }
};
static const luaL_Reg _mSTTable[] = {
{ "__index", _luaGetTable },
{ NULL, NULL }
};
struct mScriptEngineContext* _luaCreate(struct mScriptEngine2* engine, struct mScriptContext* context) {
UNUSED(engine);
struct mScriptEngineContextLua* luaContext = calloc(1, sizeof(*luaContext));
@ -122,6 +128,14 @@ struct mScriptEngineContext* _luaCreate(struct mScriptEngine2* engine, struct mS
#endif
lua_pop(luaContext->lua, 1);
luaL_newmetatable(luaContext->lua, "mSTTable");
#if LUA_VERSION_NUM < 502
luaL_register(luaContext->lua, NULL, _mSTTable);
#else
luaL_setfuncs(luaContext->lua, _mSTTable, 0);
#endif
lua_pop(luaContext->lua, 1);
return &luaContext->d;
}
@ -268,6 +282,15 @@ bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue* v
lua_pushstring(luaContext->lua, ((struct mScriptString*) value->value.opaque)->buffer);
mScriptValueDeref(value);
break;
case mSCRIPT_TYPE_TABLE:
newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue));
if (needsWeakref) {
*newValue = mSCRIPT_MAKE(WEAKREF, weakref);
} else {
mScriptValueWrap(value, newValue);
}
luaL_setmetatable(luaContext->lua, "mSTTable");
break;
case mSCRIPT_TYPE_FUNCTION:
newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue));
newValue->type = value->type;
@ -537,7 +560,6 @@ int _luaGetObject(lua_State* lua) {
return 1;
}
int _luaSetObject(lua_State* lua) {
struct mScriptEngineContextLua* luaContext = _luaGetContext(lua);
char key[MAX_KEY_SIZE];
@ -583,3 +605,35 @@ static int _luaGcObject(lua_State* lua) {
mScriptValueDeref(val);
return 0;
}
int _luaGetTable(lua_State* lua) {
struct mScriptEngineContextLua* luaContext = _luaGetContext(lua);
char key[MAX_KEY_SIZE];
const char* keyPtr = lua_tostring(lua, -1);
struct mScriptValue* obj = lua_touserdata(lua, -2);
if (!keyPtr) {
lua_pop(lua, 2);
return 0;
}
strlcpy(key, keyPtr, sizeof(key));
lua_pop(lua, 2);
obj = mScriptContextAccessWeakref(luaContext->d.context, obj);
if (!obj) {
lua_pushliteral(lua, "Invalid object");
lua_error(lua);
}
struct mScriptValue keyVal = mSCRIPT_MAKE_CHARP(key);
struct mScriptValue* val = mScriptTableLookup(obj, &keyVal);
if (!val) {
return 0;
}
if (!_luaWrap(luaContext, val)) {
lua_pushliteral(lua, "Invalid value");
lua_error(lua);
}
return 1;
}

View File

@ -751,6 +751,15 @@ struct mScriptValue* mScriptTableLookup(struct mScriptValue* table, struct mScri
return HashTableLookupCustom(t, key);
}
bool mScriptTableClear(struct mScriptValue* table) {
if (table->type != mSCRIPT_TYPE_MS_TABLE) {
return false;
}
struct Table* t = table->value.opaque;
HashTableClear(t);
return true;
}
void mScriptFrameInit(struct mScriptFrame* frame) {
mScriptListInit(&frame->arguments, 4);
mScriptListInit(&frame->returnValues, 1);
@ -874,6 +883,11 @@ static bool _accessRawMember(struct mScriptClassMember* member, void* raw, bool
return false;
}
break;
case mSCRIPT_TYPE_TABLE:
val->refs = mSCRIPT_VALUE_UNREF;
val->type = mSCRIPT_TYPE_MS_WRAPPER;
val->value.opaque = raw;
break;
case mSCRIPT_TYPE_FUNCTION:
val->refs = mSCRIPT_VALUE_UNREF;
val->flags = 0;