aboutsummaryrefslogtreecommitdiffstats
path: root/c_src/sdl_texture.c
diff options
context:
space:
mode:
Diffstat (limited to 'c_src/sdl_texture.c')
-rw-r--r--c_src/sdl_texture.c23
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));
+}