aboutsummaryrefslogtreecommitdiffstats
path: root/c_src/sdl.c
blob: 02e8150c3c29597b040ba1e348e6e29f63bb3a86 (plain) (blame)
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);
}