#include "emu.h"
#include "menu_pico.h"
+#include "input_pico.h"
#include <version.h>
-#include <revision.h>
#include <pico/pico.h>
#include <pico/patch.h>
+// FIXME
+#define REVISION "0"
+
+static const char *rom_exts[] = {
+ "zip", "bin", "smd", "gen",
+ "iso", "cso", "cue", NULL
+};
+
// rrrr rggg gggb bbbb
static unsigned short fname2color(const char *fname)
{
const char *ext = fname + strlen(fname) - 3;
- static const char *rom_exts[] = { "zip", "bin", "smd", "gen", "iso", "cso", "cue" };
static const char *other_exts[] = { "gmv", "pat" };
int i;
if (ext < fname) ext = fname;
- for (i = 0; i < array_size(rom_exts); i++)
+ for (i = 0; rom_exts[i] != NULL; i++)
if (strcasecmp(ext, rom_exts[i]) == 0) return 0xbdff; // FIXME: mk defines
for (i = 0; i < array_size(other_exts); i++)
if (strcasecmp(ext, other_exts[i]) == 0) return 0xaff5;
return 0xffff;
}
-static const char *filter_exts[] = {
- ".mp3", ".MP3", ".srm", ".brm", "s.gz", ".mds", "bcfg", ".txt", ".htm", "html",
- ".jpg", ".gpe"
-};
-
-#include "menu.c"
+#include "../libpicofe/menu.c"
/* platform specific options and handlers */
#if defined(__GP2X__)
if (len > g_menuscreen_w)
len = g_menuscreen_w;
- menu_draw_begin(0);
+ menu_draw_begin(0, 1);
dst = (unsigned short *)g_menuscreen_ptr + g_menuscreen_w * me_sfont_h * 2;
for (ln = me_sfont_h - 2; ln > 0; ln--, dst += g_menuscreen_w)
memset(dst, 0xff, len * 2);
int ln, len = percent * g_menuscreen_w / 100;
unsigned short *dst;
- menu_draw_begin(0);
+ menu_draw_begin(0, 1);
dst = (unsigned short *)g_menuscreen_ptr + g_menuscreen_w * me_sfont_h * 2;
memset(dst, 0xff, g_menuscreen_w * (me_sfont_h - 2) * 2);
/* fill all buffers, callbacks won't update in full */
for (i = 0; i < 3; i++) {
- menu_draw_begin(1);
+ menu_draw_begin(1, 1);
smalltext_out16(1, 1, "Loading", 0xffff);
smalltext_out16(1, me_sfont_h, p, 0xffff);
menu_draw_end();
PicoCartLoadProgressCB = NULL;
PicoCDLoadProgressCB = NULL;
- menu_draw_begin(0);
+ menu_draw_begin(0, 1);
smalltext_out16(1, (cdload_called ? 6 : 3) * me_sfont_h,
"Starting emulation...", 0xffff);
menu_draw_end();
max_cnt = g_menuscreen_h / me_sfont_h;
start = max_cnt / 2 - sel;
- menu_draw_begin(1);
+ menu_draw_begin(1, 0);
for (i = 0; i < PicoPatchCount; i++) {
pos = start + i;
case MA_OPT_SAVECFG:
case MA_OPT_SAVECFG_GAME:
if (emu_write_config(id == MA_OPT_SAVECFG_GAME ? 1 : 0))
- me_update_msg("config saved");
+ menu_update_msg("config saved");
else
- me_update_msg("failed to write config");
+ menu_update_msg("failed to write config");
break;
case MA_OPT_LOADCFG:
ret = emu_read_config(rom_fname_loaded, 1);
if (!ret) ret = emu_read_config(NULL, 1);
- if (ret) me_update_msg("config loaded");
- else me_update_msg("failed to load config");
+ if (ret) menu_update_msg("config loaded");
+ else menu_update_msg("failed to load config");
break;
default:
return 0;
static int mh_restore_defaults(int id, int keys)
{
emu_set_defconfig();
- me_update_msg("defaults restored");
+ menu_update_msg("defaults restored");
return 1;
}
while (1)
{
- menu_draw_begin(1);
+ menu_draw_begin(1, 0);
switch (mode)
{
case 0: tmp = PDebugMain();
" Lordus, Exophase, Rokas,\n"
" Nemesis, Tasco Deluxe";
-static char *romsel_run(void)
+static const char *romsel_run(void)
{
- char *ret, *sel_name;
+ const char *ret;
+ char *sel_name;
sel_name = malloc(sizeof(rom_fname_loaded));
if (sel_name == NULL)
return NULL;
strcpy(sel_name, rom_fname_loaded);
- ret = menu_loop_romsel(sel_name, sizeof(rom_fname_loaded));
+ ret = menu_loop_romsel(sel_name, sizeof(rom_fname_loaded), rom_exts, NULL);
free(sel_name);
return ret;
}
static int main_menu_handler(int id, int keys)
{
- char *ret_name;
+ const char *ret_name;
switch (id)
{
if (rom_loaded && PicoPatches) {
menu_loop_patches();
PicoPatchApply();
- me_update_msg("Patches applied");
+ menu_update_msg("Patches applied");
}
break;
default:
static int mh_tray_load_cd(int id, int keys)
{
- char *ret_name;
+ const char *ret_name;
ret_name = romsel_run();
if (ret_name == NULL)
return ret;
}
-void me_update_msg(const char *msg)
+void menu_update_msg(const char *msg)
{
strncpy(menu_error_msg, msg, sizeof(menu_error_msg));
menu_error_msg[sizeof(menu_error_msg) - 1] = 0;
return me_list_i;
}
+void menu_init(void)
+{
+ menu_init_base();
+}