From fa5e7eca92e37289138f78ffff131d7a2cf735ec Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Thu, 3 Apr 2014 15:32:42 +0200 Subject: Add sdl_window:set_bordered/2 --- c_src/sdl_window.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'c_src/sdl_window.c') diff --git a/c_src/sdl_window.c b/c_src/sdl_window.c index 936792b..adaa9eb 100644 --- a/c_src/sdl_window.c +++ b/c_src/sdl_window.c @@ -428,3 +428,30 @@ NIF_FUNCTION(restore_window) return nif_thread_cast(env, thread_restore_window, 1, NIF_RES_GET(Window, window_res)); } + +// set_window_bordered + +NIF_CAST_HANDLER(thread_set_window_bordered) +{ + SDL_SetWindowBordered(args[0], (long)args[1]); +} + +NIF_FUNCTION(set_window_bordered) +{ + void* window_res; + char buf[MAX_ATOM_LENGTH]; + SDL_bool b; + + BADARG_IF(!enif_get_resource(env, argv[0], res_Window, &window_res)); + BADARG_IF(!enif_get_atom(env, argv[1], buf, MAX_ATOM_LENGTH, ERL_NIF_LATIN1)); + + if (!strcmp(buf, "true")) + b = SDL_TRUE; + else { + BADARG_IF(0 != strcmp(buf, "false")); + b = SDL_FALSE; + } + + return nif_thread_cast(env, thread_set_window_bordered, 2, + NIF_RES_GET(Window, window_res), b); +} -- cgit v1.2.3