From d822cf5b786776788cace9c3f9b2be9df41812e9 Mon Sep 17 00:00:00 2001 From: sanine Date: Tue, 27 Sep 2022 17:00:46 -0500 Subject: fix uninitialized memory bug in mesh loading and add suzanne.dae --- src/image/image.c | 3 ++- src/import/import.c | 37 +++++++++++++++++++++++++++++++++++++ src/import/import.h | 6 ++++++ src/main.c | 2 ++ 4 files changed, 47 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/image/image.c b/src/image/image.c index cf08625..a8a0502 100644 --- a/src/image/image.c +++ b/src/image/image.c @@ -1,6 +1,7 @@ #include #include -#define STB_IMAGE_IMPLEMENTATION +/* assimp provides its own stb_image implementation */ +/*#define STB_IMAGE_IMPLEMENTATION*/ #include "stb_image.h" #include "image.h" diff --git a/src/import/import.c b/src/import/import.c index 306601e..a093068 100644 --- a/src/import/import.c +++ b/src/import/import.c @@ -1,9 +1,41 @@ #include #include #include +#include +#include #include "import.h" +#ifndef LILY_TEST_H + +static void push_scene(lua_State *L, struct aiScene *scene); + +int import_file(lua_State *L) +{ + char *filename; + hs_parse_args(L, hs_str(filename)); + + const struct aiScene *scene = aiImportFile(filename, aiProcess_Triangulate | aiProcess_FlipUVs); + if (scene == NULL) + hs_throw_error(L, "failed to load file '%s'", filename); + + push_scene(L, (struct aiScene*) scene); + return 1; +} + + +void setup_import(lua_State *L, int honey_tbl) +{ + hs_create_table(L, + hs_str_cfunc("importFile", import_file), + ); + + lua_setfield(L, honey_tbl, "import"); +} + +#endif + + static void push_vector(lua_State *L, struct aiVector3D vec) { hs_create_table(L, @@ -119,6 +151,8 @@ static void push_mesh(lua_State *L, struct aiMesh *mesh) lua_pushinteger(L, mesh->mNumUVComponents[i]); lua_rawseti(L, uv_components, i+1); } + else + uv_channels[i] = 0; } /* --=== populate vertices ===-- */ @@ -251,3 +285,6 @@ static void push_scene(lua_State *L, struct aiScene *scene) hs_str_tbl("meshes", meshtbl), ); } + + + diff --git a/src/import/import.h b/src/import/import.h index e69de29..a1bb081 100644 --- a/src/import/import.h +++ b/src/import/import.h @@ -0,0 +1,6 @@ +#ifndef HONEY_IMPORT_H +#define HONEY_IMPORT_H + +void setup_import(lua_State *L, int honey_tbl); + +#endif diff --git a/src/main.c b/src/main.c index e11a0c6..618b30c 100644 --- a/src/main.c +++ b/src/main.c @@ -6,6 +6,7 @@ #include "gl/gl.h" #include "glm/glm.h" #include "image/image.h" +#include "import/import.h" #include "logging/logging.h" #include "options/options.h" @@ -29,6 +30,7 @@ int main(int argc, char **argv) setup_gl(L, honey_index); setup_glm(L, honey_index); setup_image(L, honey_index); + setup_import(L, honey_index); setup_logging(L, honey_index); setup_window(L, honey_index); lua_setglobal(L, "honey"); -- cgit v1.2.1