diff options
author | Loïc Hoguin <[email protected]> | 2014-03-18 12:04:46 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2014-03-18 12:16:53 +0100 |
commit | 608acbb03f976b0fbf23877d8b4b6ad7529e1d53 (patch) | |
tree | f6ba7f0b5a37d270bfc64e07d02ebb0992631d8e /src/esdl2.erl | |
download | esdl2-608acbb03f976b0fbf23877d8b4b6ad7529e1d53.tar.gz esdl2-608acbb03f976b0fbf23877d8b4b6ad7529e1d53.tar.bz2 esdl2-608acbb03f976b0fbf23877d8b4b6ad7529e1d53.zip |
Initial commit
Diffstat (limited to 'src/esdl2.erl')
-rw-r--r-- | src/esdl2.erl | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/src/esdl2.erl b/src/esdl2.erl new file mode 100644 index 0000000..a786685 --- /dev/null +++ b/src/esdl2.erl @@ -0,0 +1,111 @@ +%% 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. + +-module(esdl2). + +%% sdl +-export([init/1]). +-export([init_subsystem/1]). +-export([quit/0]). +-export([quit_subsystem/1]). +-export([set_main_ready/0]). +-export([was_init/1]). + +%% sdl_events +-export([poll_event/0]). + +%% sdl_renderer +-export([create_renderer/3]). +-export([render_clear/1]). +-export([render_copy/4]). +-export([render_present/1]). +-export([set_render_draw_color/5]). + +%% sdl_surface +-export([img_load/1]). + +%% sdl_texture +-export([create_texture_from_surface/2]). + +%% sdl_window +-export([create_window/6]). + +%% @todo We probably want to accept an env variable or somthing for the location. +-on_load(on_load/0). +on_load() -> + PrivDir = case code:priv_dir(?MODULE) of + {error, _} -> + AppPath = filename:dirname(filename:dirname(code:which(?MODULE))), + filename:join(AppPath, "priv"); + Path -> + Path + end, + erlang:load_nif(filename:join(PrivDir, atom_to_list(?MODULE)), 0). + +%% sdl + +init(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +init_subsystem(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +quit() -> + erlang:nif_error({not_loaded, ?MODULE}). + +quit_subsystem(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +set_main_ready() -> + erlang:nif_error({not_loaded, ?MODULE}). + +was_init(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +%% sdl_events + +poll_event() -> + erlang:nif_error({not_loaded, ?MODULE}). + +%% sdl_renderer + +create_renderer(_, _, _) -> + erlang:nif_error({not_loaded, ?MODULE}). + +render_clear(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +render_copy(_, _, _, _) -> + erlang:nif_error({not_loaded, ?MODULE}). + +render_present(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +set_render_draw_color(_, _, _, _, _) -> + erlang:nif_error({not_loaded, ?MODULE}). + +%% sdl_surface + +img_load(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + +%% sdl_texture + +create_texture_from_surface(_, _) -> + erlang:nif_error({not_loaded, ?MODULE}). + +%% sdl_window + +create_window(_, _, _, _, _, _) -> + erlang:nif_error({not_loaded, ?MODULE}). |