1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
// Copyright (c) 2014, Loïc Hoguin <[email protected]>
//
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice appear in all copies.
//
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include "esdl2.h"
#define INIT_FLAGS(F) \
F(timer, SDL_INIT_TIMER) \
F(audio, SDL_INIT_AUDIO) \
F(video, SDL_INIT_VIDEO) \
F(joystick, SDL_INIT_JOYSTICK) \
F(haptic, SDL_INIT_HAPTIC) \
F(game_controller, SDL_INIT_GAMECONTROLLER) \
F(events, SDL_INIT_EVENTS) \
F(everything, SDL_INIT_EVERYTHING) \
F(no_parachute, SDL_INIT_NOPARACHUTE)
NIF_LIST_TO_FLAGS_FUNCTION(list_to_init_flags, Uint32, INIT_FLAGS)
// init
NIF_CALL_HANDLER(thread_init)
{
if (SDL_Init((long)args[0]))
return sdl_error_tuple(env);
return atom_ok;
}
NIF_FUNCTION(init)
{
Uint32 flags = 0;
BADARG_IF(!list_to_init_flags(env, argv[0], &flags));
return nif_thread_call(env, thread_init, 1, flags);
}
// init_subsystem
NIF_CALL_HANDLER(thread_init_subsystem)
{
if (SDL_InitSubSystem((long)args[0]))
return sdl_error_tuple(env);
return atom_ok;
}
NIF_FUNCTION(init_subsystem)
{
Uint32 flags = 0;
BADARG_IF(!list_to_init_flags(env, argv[0], &flags));
return nif_thread_call(env, thread_init_subsystem, 1, flags);
}
// quit
NIF_CAST_HANDLER(thread_quit)
{
SDL_Quit();
}
NIF_FUNCTION(quit)
{
return nif_thread_cast(env, thread_quit, 0);;
}
// quit_subsystem
NIF_CAST_HANDLER(thread_quit_subsystem)
{
SDL_QuitSubSystem((long)args[0]);
}
NIF_FUNCTION(quit_subsystem)
{
Uint32 flags = 0;
BADARG_IF(!list_to_init_flags(env, argv[0], &flags));
return nif_thread_cast(env, thread_quit_subsystem, 1, flags);
}
// set_main_ready
NIF_CAST_HANDLER(thread_set_main_ready)
{
SDL_SetMainReady();
}
NIF_FUNCTION(set_main_ready)
{
return nif_thread_cast(env, thread_set_main_ready, 0);;
}
// was_init
// @todo Implement the case where we want to receive a list of everything init.
NIF_CALL_HANDLER(thread_was_init)
{
if (SDL_WasInit((long)args[0]))
return atom_true;
return atom_false;
}
NIF_FUNCTION(was_init)
{
unsigned int length;
Uint32 flags = 0;
BADARG_IF(!enif_get_list_length(env, argv[0], &length));
BADARG_IF(length == 0);
BADARG_IF(!list_to_init_flags(env, argv[0], &flags));
return nif_thread_call(env, thread_was_init, 1, flags);
}
|