input: in_gp2x refactoring
[libpicofe.git] / common / menu.h
index 64a70a7..79b8278 100644 (file)
@@ -1,6 +1,12 @@
-// (c) Copyright 2006-2009 notaz, All rights reserved.
-
-#include "port_config.h"
+/*
+ * (C) GraÅžvydas "notaz" Ignotas, 2006-2010
+ *
+ * This work is licensed under the terms of any of these licenses
+ * (at your option):
+ *  - GNU GPL, version 2 or later.
+ *  - GNU LGPL, version 2.1 or later.
+ * See the COPYING file in the top-level directory.
+ */
 
 typedef enum
 {
@@ -13,103 +19,11 @@ typedef enum
        MB_OPT_ENUM,
 } menu_behavior;
 
-typedef enum
-{
-       MA_NONE = 1,
-       MA_MAIN_RESUME_GAME,
-       MA_MAIN_SAVE_STATE,
-       MA_MAIN_LOAD_STATE,
-       MA_MAIN_RESET_GAME,
-       MA_MAIN_LOAD_ROM,
-       MA_MAIN_CONTROLS,
-       MA_MAIN_CREDITS,
-       MA_MAIN_PATCHES,
-       MA_MAIN_EXIT,
-       MA_OPT_RENDERER,
-       MA_OPT_SCALING,
-       MA_OPT_ACC_SPRITES,
-       MA_OPT_SHOW_FPS,
-       MA_OPT_FRAMESKIP,
-       MA_OPT_ENABLE_SOUND,
-       MA_OPT_SOUND_QUALITY,
-       MA_OPT_ARM940_SOUND,
-       MA_OPT_6BUTTON_PAD,
-       MA_OPT_REGION,
-       MA_OPT_SRAM_STATES,
-       MA_OPT_CONFIRM_STATES,
-       MA_OPT_SAVE_SLOT,
-       MA_OPT_CPU_CLOCKS,
-       MA_OPT_SCD_OPTS,
-       MA_OPT_ADV_OPTS,
-       MA_OPT_DISP_OPTS,       /* psp */
-       MA_OPT_SAVECFG,
-       MA_OPT_SAVECFG_GAME,
-       MA_OPT_LOADCFG,
-       MA_OPT_INTERLACED,      /* giz */
-       MA_OPT_ROTATION,        /* uiq */
-       MA_OPT_TEARING_FIX,     /* wiz */
-       MA_OPT2_GAMMA,
-       MA_OPT2_A_SN_GAMMA,
-       MA_OPT2_DBLBUFF,        /* giz */
-       MA_OPT2_VSYNC,
-       MA_OPT2_ENABLE_Z80,
-       MA_OPT2_ENABLE_YM2612,
-       MA_OPT2_ENABLE_SN76496,
-       MA_OPT2_GZIP_STATES,
-       MA_OPT2_NO_LAST_ROM,
-       MA_OPT2_RAMTIMINGS,     /* gp2x */
-       MA_OPT2_SQUIDGEHACK,    /* gp2x */
-       MA_OPT2_STATUS_LINE,    /* psp */
-       MA_OPT2_NO_FRAME_LIMIT, /* psp */
-       MA_OPT2_SVP_DYNAREC,
-       MA_OPT2_NO_SPRITE_LIM,
-       MA_OPT2_NO_IDLE_LOOPS,
-       MA_OPT2_DONE,
-       MA_OPT3_SCALE,          /* psp (all OPT3) */
-       MA_OPT3_HSCALE32,
-       MA_OPT3_HSCALE40,
-       MA_OPT3_PRES_NOSCALE,
-       MA_OPT3_PRES_SCALE43,
-       MA_OPT3_PRES_FULLSCR,
-       MA_OPT3_FILTERING,
-       MA_OPT3_VSYNC,
-       MA_OPT3_GAMMAA,
-       MA_OPT3_BLACKLVL,
-       MA_OPT3_LAYER_X,
-       MA_OPT3_LAYER_Y,
-       MA_OPT3_LAYER_W,
-       MA_OPT3_LAYER_H,
-       MA_OPT3_DONE,
-       MA_CDOPT_TESTBIOS_USA,
-       MA_CDOPT_TESTBIOS_EUR,
-       MA_CDOPT_TESTBIOS_JAP,
-       MA_CDOPT_LEDS,
-       MA_CDOPT_CDDA,
-       MA_CDOPT_PCM,
-       MA_CDOPT_READAHEAD,
-       MA_CDOPT_SAVERAM,
-       MA_CDOPT_SCALEROT_CHIP,
-       MA_CDOPT_BETTER_SYNC,
-       MA_CDOPT_DONE,
-       MA_32XOPT_ENABLE_32X,
-       MA_32XOPT_RENDERER,
-       MA_32XOPT_PWM,
-       MA_32XOPT_MSH2_CYCLES,
-       MA_32XOPT_SSH2_CYCLES,
-       MA_CTRL_PLAYER1,
-       MA_CTRL_PLAYER2,
-       MA_CTRL_EMU,
-       MA_CTRL_TURBO_RATE,
-       MA_CTRL_DEV_FIRST,
-       MA_CTRL_DEV_NEXT,
-       MA_CTRL_DONE,
-} menu_id;
-
 typedef struct
 {
        const char *name;
        menu_behavior beh;
-       menu_id id;
+       int id;
        void *var;              /* for on-off/range settings */
        int mask;               /* bit to toggle for on/off */
        signed short min;       /* for ranged integer settings, to be sign-extended */
@@ -117,18 +31,24 @@ typedef struct
        unsigned int enabled:1;
        unsigned int need_to_save:1;
        unsigned int selectable:1;
-       int (*handler)(menu_id id, int keys);
-       const char * (*generate_name)(menu_id id, int *offs);
+       int (*handler)(int id, int keys);
+       const char * (*generate_name)(int id, int *offs);
        const void *data;
        const char *help;
 } menu_entry;
 
+#define mee_handler_id_h(name, id, handler, help) \
+       { name, MB_NONE, id, NULL, 0, 0, 0, 1, 0, 1, handler, NULL, NULL, help }
+
 #define mee_handler_id(name, id, handler) \
-       { name, MB_NONE, id, NULL, 0, 0, 0, 1, 0, 1, handler, NULL, NULL, NULL }
+       mee_handler_id_h(name, id, handler, NULL)
 
 #define mee_handler(name, handler) \
        mee_handler_id(name, MA_NONE, handler)
 
+#define mee_handler_h(name, handler, help) \
+       mee_handler_id_h(name, MA_NONE, handler, help)
+
 #define mee_label(name) \
        { name, MB_NONE, MA_NONE, NULL, 0, 0, 0, 1, 0, 0, NULL, NULL, NULL, NULL }
 
@@ -141,8 +61,11 @@ typedef struct
 #define mee_onoff(name, id, var, mask) \
        mee_onoff_h(name, id, var, mask, NULL)
 
+#define mee_range_h(name, id, var, min, max, help) \
+       { name, MB_OPT_RANGE, id, &(var), 0, min, max, 1, 1, 1, NULL, NULL, NULL, help }
+
 #define mee_range(name, id, var, min, max) \
-       { name, MB_OPT_RANGE, id, &(var), 0, min, max, 1, 1, 1, NULL, NULL, NULL, NULL }
+       mee_range_h(name, id, var, min, max, NULL)
 
 #define mee_range_hide(name, id, var, min, max) \
        { name, MB_OPT_RANGE, id, &(var), 0, min, max, 0, 1, 0, NULL, NULL, NULL, NULL }
@@ -180,13 +103,13 @@ typedef struct
        int mask;
 } me_bind_action;
 
-extern me_bind_action me_ctrl_actions[15];
+extern me_bind_action me_ctrl_actions[];
 extern me_bind_action emuctrl_actions[];       // platform code
 
 extern void *g_menubg_src_ptr;
 extern void *g_menubg_ptr;
 extern void *g_menuscreen_ptr;
-#if SCREEN_SIZE_FIXED
+#if MSCREEN_SIZE_FIXED
 #define g_menuscreen_w MSCREEN_WIDTH
 #define g_menuscreen_h MSCREEN_HEIGHT
 #else
@@ -195,7 +118,6 @@ extern int g_menuscreen_h;
 #endif
 
 void menu_init(void);
-void menu_plat_setup(int is_wiz);
 void text_out16(int x, int y, const char *texto, ...);
 void me_update_msg(const char *msg);