From 81a8df3374e830acba184099f243e42174c02e2a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Fri, 4 Apr 2014 17:20:21 +0200 Subject: Add sdl_renderer:get_output_size/1 --- c_src/esdl2.h | 1 + c_src/sdl_renderer.c | 28 ++++++++++++++++++++++++++++ 2 files changed, 29 insertions(+) (limited to 'c_src') diff --git a/c_src/esdl2.h b/c_src/esdl2.h index f0e54c9..34871be 100644 --- a/c_src/esdl2.h +++ b/c_src/esdl2.h @@ -152,6 +152,7 @@ F(get_num_render_drivers, 0) \ F(get_render_draw_blend_mode, 1) \ F(get_render_draw_color, 1) \ + F(get_render_output_size, 1) \ F(render_clear, 1) \ F(render_copy, 4) \ F(render_present, 1) \ diff --git a/c_src/sdl_renderer.c b/c_src/sdl_renderer.c index 7787a3c..e3155ae 100644 --- a/c_src/sdl_renderer.c +++ b/c_src/sdl_renderer.c @@ -163,6 +163,34 @@ NIF_FUNCTION(get_render_draw_color) NIF_RES_GET(Renderer, renderer_res)); } +// get_render_output_size + +NIF_CALL_HANDLER(thread_get_render_output_size) +{ + int w, h; + + if (SDL_GetRendererOutputSize(args[0], &w, &h)) + return sdl_error_tuple(env); + + return enif_make_tuple2(env, + atom_ok, + enif_make_tuple2(env, + enif_make_int(env, w), + enif_make_int(env, h) + ) + ); +} + +NIF_FUNCTION(get_render_output_size) +{ + void* renderer_res; + + BADARG_IF(!enif_get_resource(env, argv[0], res_Renderer, &renderer_res)); + + return nif_thread_call(env, thread_get_render_output_size, 1, + NIF_RES_GET(Renderer, renderer_res)); +} + // render_clear NIF_CALL_HANDLER(thread_render_clear) -- cgit v1.2.3