diff options
Diffstat (limited to 'src/image')
-rw-r--r-- | src/image/image.c | 34 |
1 files changed, 20 insertions, 14 deletions
diff --git a/src/image/image.c b/src/image/image.c index 183ff46..feea51a 100644 --- a/src/image/image.c +++ b/src/image/image.c @@ -1,8 +1,9 @@ #include <lua.h> -#include <honeysuckle.h> -/* assimp provides its own stb_image implementation */ +#include <lauxlib.h> +/* nanovg provides its own stb_image implementation */ /*#define STB_IMAGE_IMPLEMENTATION*/ #include "stb_image.h" +#include "util/util.h" #include "image.h" @@ -13,13 +14,14 @@ int free_image(lua_State *L); void setup_image(lua_State *L, int honey_index) { - hs_create_table(L, + struct honey_tbl_t image[] = { /* basic images */ - hs_str_cfunc("null", empty), - hs_str_cfunc("load", load_image), - hs_str_cfunc("destroy", free_image), - ); - + H_FUNC("null", empty), + H_FUNC("load", load_image), + H_FUNC("destroy", free_image), + H_END + }; + create_table(L, image); lua_setfield(L, honey_index, "image"); } @@ -32,16 +34,18 @@ int empty(lua_State *L) return 1; } + int load_image(lua_State *L) { - char *filename; - lua_Integer requested_channels; - hs_parse_args(L, hs_str(filename), hs_int(requested_channels)); + const char *filename = luaL_checkstring(L, 1); + int requested_channels = luaL_checkinteger(L, 2); int width, height, channels; unsigned char *data = stbi_load(filename, &width, &height, &channels, requested_channels); - if (data == NULL) hs_throw_error(L, "failed to load image '%s'", filename); + if (data == NULL) { + return luaL_error(L, "failed to load image '%s'", filename); + } lua_pushlightuserdata(L, data); lua_pushinteger(L, width); @@ -53,8 +57,10 @@ int load_image(lua_State *L) int free_image(lua_State *L) { - void *data; - hs_parse_args(L, hs_light(data)); + void *data = lua_touserdata(L, 1); + if (data == NULL) { + return luaL_typerror(L, 1, "userdata"); + } stbi_image_free(data); return 0; } |