diff options
author | sanine <sanine.not@pm.me> | 2022-09-18 15:44:23 -0500 |
---|---|---|
committer | sanine <sanine.not@pm.me> | 2022-09-18 15:44:23 -0500 |
commit | 33a88ffe0cdab355547573b0fc566adbf91b8d23 (patch) | |
tree | 82d419bb13273d0258123c889014c2e140907da2 /src/import/import.c | |
parent | 123b9e22cd4272ef7dcf6e519b03c3ca5ba73953 (diff) |
add face pushing
Diffstat (limited to 'src/import/import.c')
-rw-r--r-- | src/import/import.c | 33 |
1 files changed, 27 insertions, 6 deletions
diff --git a/src/import/import.c b/src/import/import.c index a4fc552..2debc3a 100644 --- a/src/import/import.c +++ b/src/import/import.c @@ -20,7 +20,8 @@ void push_face(lua_State *L, struct aiFace face) int tbl = lua_gettop(L); for (int i=0; i<face.mNumIndices; i++) { - lua_pushinteger(L, face.mIndices[i]); + /* add one to the index bc lua is 1-indexed */ + lua_pushinteger(L, face.mIndices[i]+1); lua_rawseti(L, tbl, i+1); } } @@ -34,26 +35,46 @@ void push_aistring(lua_State *L, struct aiString str) void push_mesh(lua_State *L, struct aiMesh mesh) { + /* create mesh table */ + lua_createtable(L, 0, 1); + int meshtbl = lua_gettop(L); + int count = mesh.mNumVertices; + int pop_count = 0; /* create tables */ lua_createtable(L, count, 0); int vertices = lua_gettop(L); + pop_count += 1; - /* populate */ + /* populate vertices */ for (int i=0; i<count; i++) { /* positions */ push_vector(L, mesh.mVertices[i]); lua_rawseti(L, vertices, i+1); } - /* create mesh table */ - lua_createtable(L, 0, 1); - int meshtbl = lua_gettop(L); + /* populate faces */ + int faces = 0; + if (mesh.mNumFaces != 0) { + lua_createtable(L, mesh.mNumFaces, 0); + faces = lua_gettop(L); + pop_count += 1; + for (int i=0; i<mesh.mNumFaces; i++) { + push_face(L, mesh.mFaces[i]); + lua_rawseti(L, faces, i+1); + } + } + /* assign values */ lua_pushvalue(L, vertices); lua_setfield(L, meshtbl, "vertices"); + if (faces) { + lua_pushvalue(L, faces); + lua_setfield(L, meshtbl, "faces"); + } + /* clean up */ - lua_remove(L, vertices); + lua_pop(L, pop_count); } |