1
0
Fork 0
mirror of https://github.com/ctruLua/ctruLua.git synced 2025-10-27 16:39:29 +00:00

Cleaned initialisation process

This commit is contained in:
Reuh 2015-08-22 20:37:45 +02:00
parent 8da0e47ae3
commit 0af33d0b3a
6 changed files with 70 additions and 58 deletions

View file

@ -5,13 +5,17 @@
#include <lua.h>
#include <lauxlib.h>
int load_gfx_lib(lua_State *L);
int load_news_lib(lua_State *L);
int load_ptm_lib(lua_State *L);
int load_hid_lib(lua_State *L);
int load_ir_lib(lua_State *L);
int load_fs_lib(lua_State *L);
int load_httpc_lib(lua_State *L);
void load_gfx_lib(lua_State *L);
void load_news_lib(lua_State *L);
void load_ptm_lib(lua_State *L);
void load_hid_lib(lua_State *L);
void load_ir_lib(lua_State *L);
void load_fs_lib(lua_State *L);
void load_httpc_lib(lua_State *L);
void unload_gfx_lib(lua_State *L);
void unload_hid_lib(lua_State *L);
void unload_fs_lib(lua_State *L);
static int ctr_run(lua_State *L) {
lua_pushboolean(L, aptMainLoop());
@ -33,14 +37,14 @@ static const struct luaL_Reg ctr_lib[] = {
};
// Subtables
struct { char *name; int (*load)(lua_State *L); } ctr_libs[] = {
{ "gfx", load_gfx_lib },
{ "news", load_news_lib },
{ "ptm", load_ptm_lib },
{ "hid", load_hid_lib },
{ "ir", load_ir_lib },
{ "fs", load_fs_lib },
{ "httpc", load_httpc_lib },
struct { char *name; void (*load)(lua_State *L); void (*unload)(lua_State *L) } ctr_libs[] = {
{ "gfx", load_gfx_lib, unload_gfx_lib },
{ "news", load_news_lib, NULL },
{ "ptm", load_ptm_lib, NULL },
{ "hid", load_hid_lib, unload_hid_lib },
{ "ir", load_ir_lib, NULL },
{ "fs", load_fs_lib, unload_fs_lib },
{ "httpc", load_httpc_lib, NULL },
{ NULL, NULL }
};
@ -58,3 +62,9 @@ int luaopen_ctr_lib(lua_State *L) {
void load_ctr_lib(lua_State *L) {
luaL_requiref(L, "ctr", luaopen_ctr_lib, 0);
}
void unload_ctr_lib(lua_State *L) {
for (int i = 0; ctr_libs[i].name; i++) {
if (ctr_libs[i].unload) ctr_libs[i].unload(L);
}
}

View file

@ -22,6 +22,6 @@ void load_font_lib(lua_State *L) {
luaL_requiref(L, "ctr.gfx.font", luaopen_font_lib, false);
}
void unload_font_lib() {
void unload_font_lib(lua_State *L) {
sftd_free_font(font_default); // Unload current font
}

View file

@ -71,7 +71,7 @@ int luaopen_fs_lib(lua_State *L) {
return 1;
}
int load_fs_lib(lua_State *L) {
void load_fs_lib(lua_State *L) {
fsInit();
fsuHandle = fsGetSessionHandle();
@ -81,8 +81,6 @@ int load_fs_lib(lua_State *L) {
FSUSER_OpenArchive(fsuHandle, &sdmcArchive);
luaL_requiref(L, "ctr.fs", luaopen_fs_lib, false);
return 0;
}
void unload_fs_lib(lua_State *L) {

View file

@ -6,10 +6,14 @@
#include <lua.h>
#include <lauxlib.h>
int load_color_lib(lua_State *L);
int load_font_lib(lua_State *L);
int load_texture_lib(lua_State *L);
int load_map_lib(lua_State *L);
bool isGfxInitialised = false;
void load_color_lib(lua_State *L);
void load_font_lib(lua_State *L);
void load_texture_lib(lua_State *L);
void load_map_lib(lua_State *L);
void unload_font_lib(lua_State *L);
u32 color_default;
sftd_font *font_default;
@ -153,11 +157,11 @@ struct { char *name; int value; } gfx_constants[] = {
};
// Subtables
struct { char *name; int (*load)(lua_State *L); } gfx_libs[] = {
{ "color", load_color_lib },
{ "font", load_font_lib },
{ "texture", load_texture_lib },
{ "map", load_map_lib },
struct { char *name; void (*load)(lua_State *L); void (*unload)(lua_State *L); } gfx_libs[] = {
{ "color", load_color_lib, NULL },
{ "font", load_font_lib, unload_font_lib },
{ "texture", load_texture_lib, NULL },
{ "map", load_map_lib, NULL },
{ NULL, NULL }
};
@ -178,5 +182,19 @@ int luaopen_gfx_lib(lua_State *L) {
}
void load_gfx_lib(lua_State *L) {
sf2d_init();
sftd_init();
isGfxInitialised = true;
luaL_requiref(L, "ctr.gfx", luaopen_gfx_lib, 0);
}
void unload_gfx_lib(lua_State *L) {
for (int i = 0; gfx_libs[i].name; i++) {
if (gfx_libs[i].unload) gfx_libs[i].unload(L);
}
sftd_fini();
sf2d_fini();
}

View file

@ -156,5 +156,13 @@ int luaopen_hid_lib(lua_State *L) {
}
void load_hid_lib(lua_State *L) {
HIDUSER_EnableAccelerometer();
HIDUSER_EnableGyroscope();
luaL_requiref(L, "ctr.hid", luaopen_hid_lib, false);
}
void unload_hid_lib(lua_State *L) {
HIDUSER_DisableAccelerometer();
HIDUSER_DisableGyroscope();
}

View file

@ -1,6 +1,4 @@
#include <3ds.h>
#include <sf2d.h>
#include <sftd.h>
#include <lua.h>
#include <lauxlib.h>
@ -8,15 +6,14 @@
#define BOOT_FILE "sdmc:/3ds/ctruLua/main.lua"
int load_ctr_lib(lua_State *L);
void unload_font_lib();
void unload_fs_lib();
void load_ctr_lib(lua_State *L);
void unload_ctr_lib(lua_State *L);
bool gfxinit = false;
bool isGfxInitialised;
// Display an error
void error(const char *error) {
if (!gfxinit) gfxInitDefault();
if (!isGfxInitialised) gfxInitDefault();
gfxSet3D(false);
consoleInit(GFX_TOP, NULL);
@ -33,7 +30,7 @@ void error(const char *error) {
gspWaitForVBlank();
}
if (!gfxinit) gfxExit();
if (!isGfxInitialised) gfxExit();
}
// Main loop
@ -44,16 +41,6 @@ int main() {
error("Memory allocation error while creating a new Lua state");
return 0;
}
// Init GFX
sf2d_init();
sftd_init();
gfxinit = true;
// Init accel/gyro
HIDUSER_EnableAccelerometer();
HIDUSER_EnableGyroscope();
// Load libs
luaL_openlibs(L);
@ -62,20 +49,11 @@ int main() {
// Do the actual thing
if (luaL_dofile(L, BOOT_FILE)) error(luaL_checkstring(L, -1));
// Unload libs
unload_ctr_lib(L);
// Unload Lua
lua_close(L);
// Unload libs
unload_font_lib();
unload_fs_lib();
// Disable accel/gyro
HIDUSER_DisableAccelerometer();
HIDUSER_DisableGyroscope();
// Uninit GFX
sftd_fini();
sf2d_fini();
return 0;
}