diff options
Diffstat (limited to 'c_src/sdl_texture.c')
-rw-r--r-- | c_src/sdl_texture.c | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/c_src/sdl_texture.c b/c_src/sdl_texture.c index daf5b93..4741bb6 100644 --- a/c_src/sdl_texture.c +++ b/c_src/sdl_texture.c @@ -19,17 +19,14 @@ void dtor_Texture(ErlNifEnv* env, void* obj) SDL_DestroyTexture(NIF_RES_GET(Texture, obj)); } -NIF_FUNCTION(create_texture_from_surface) +// create_texture_from_surface + +NIF_CALL_HANDLER(thread_create_texture_from_surface) { - void* renderer_res; - void* surface_res; SDL_Texture* texture; ERL_NIF_TERM term; - BADARG_IF(!enif_get_resource(env, argv[0], res_Renderer, &renderer_res)); - BADARG_IF(!enif_get_resource(env, argv[1], res_Surface, &surface_res)); - - texture = SDL_CreateTextureFromSurface(NIF_RES_GET(Renderer, renderer_res), NIF_RES_GET(Surface, surface_res)); + texture = SDL_CreateTextureFromSurface(args[0], args[1]); if (!texture) return sdl_error_tuple(env); @@ -40,3 +37,15 @@ NIF_FUNCTION(create_texture_from_surface) term ); } + +NIF_FUNCTION(create_texture_from_surface) +{ + void* renderer_res; + void* surface_res; + + BADARG_IF(!enif_get_resource(env, argv[0], res_Renderer, &renderer_res)); + BADARG_IF(!enif_get_resource(env, argv[1], res_Surface, &surface_res)); + + return nif_thread_call(env, thread_create_texture_from_surface, 2, + NIF_RES_GET(Renderer, renderer_res), NIF_RES_GET(Surface, surface_res)); +} |