--- lbbs/include/menu.h 2025/05/25 06:53:29 1.22 +++ lbbs/include/menu.h 2025/10/18 12:06:10 1.31 @@ -17,18 +17,17 @@ #ifndef _MENU_H_ #define _MENU_H_ +#include "bbs_cmd.h" #include "common.h" #include "trie_dict.h" -#include "bbs_cmd.h" #include -#include #define MAX_MENU_NAME_LENGTH 30 #define MAX_ITEMS_PER_MENU 256 #define MAX_MENUITEM_NAME_LENGTH 256 -#define MAX_MENUITEM_TEXT_LENGTH 100 +#define MAX_MENUITEM_TEXT_LENGTH 200 #define MAX_MENUITEM_ACTION_LENGTH 30 -#define MAX_MENUTITLE_TEXT_LENGTH 50 +#define MAX_MENUTITLE_TEXT_LENGTH 100 #define MAX_MENU_SCR_NAME_LENGTH 20 #define MAX_MENU_SCR_BUF_LENGTH 2000 #define MAX_MENUS 256 @@ -80,6 +79,8 @@ struct menu_t int16_t item_count; int16_t page_row, page_col; int16_t page_item_limit; + int8_t use_filter; + bbs_cmd_handler filter_handler; }; typedef struct menu_t MENU; @@ -104,17 +105,21 @@ struct menu_set_t int16_t menu_item_r_row[MAX_ITEMS_PER_MENU]; int16_t menu_item_r_col[MAX_ITEMS_PER_MENU]; int16_t menu_item_page_id[MAX_ITEMS_PER_MENU]; + int8_t allow_exit; }; typedef struct menu_set_t MENU_SET; -extern MENU_SET *p_bbs_menu; +extern MENU_SET bbs_menu; +extern MENU_SET top10_menu; extern int load_menu(MENU_SET *p_menu_set, const char *conf_file); extern int unload_menu(MENU_SET *p_menu_set); +extern int get_menu_shm_readonly(MENU_SET *p_menu_set); extern int set_menu_shm_readonly(MENU_SET *p_menu_set); extern int detach_menu_shm(MENU_SET *p_menu_set); +extern int display_menu_cursor(MENU_SET *p_menu_set, int show); extern int menu_control(MENU_SET *p_menu_set, int key); extern int display_menu(MENU_SET *p_menu_set); @@ -134,7 +139,7 @@ inline MENU *get_menu_by_id(MENU_SET *p_ return NULL; } - return (p_menu_set->p_menu_pool + sizeof(MENU) * menu_id); + return (MENU *)((char *)(p_menu_set->p_menu_pool) + sizeof(MENU) * menu_id); } inline MENU_ITEM *get_menu_item_by_id(MENU_SET *p_menu_set, MENU_ITEM_ID menu_item_id) @@ -144,7 +149,7 @@ inline MENU_ITEM *get_menu_item_by_id(ME return NULL; } - return (p_menu_set->p_menu_item_pool + sizeof(MENU_ITEM) * menu_item_id); + return (MENU_ITEM *)((char *)(p_menu_set->p_menu_item_pool) + sizeof(MENU_ITEM) * menu_item_id); } inline MENU_SCREEN *get_menu_screen_by_id(MENU_SET *p_menu_set, MENU_SCREEN_ID menu_screen_id) @@ -154,7 +159,7 @@ inline MENU_SCREEN *get_menu_screen_by_i return NULL; } - return (p_menu_set->p_menu_screen_pool + sizeof(MENU_ITEM) * menu_screen_id); + return (MENU_SCREEN *)((char *)(p_menu_set->p_menu_screen_pool) + sizeof(MENU_ITEM) * menu_screen_id); } #endif //_MENU_H_