--- lbbs/include/menu.h 2025/05/15 05:14:57 1.16 +++ lbbs/include/menu.h 2025/11/04 13:49:50 1.32 @@ -1,32 +1,25 @@ -/*************************************************************************** - menu.h - description - ------------------- - Copyright : (C) 2004-2025 by Leaflet - Email : leaflet@leafok.com - ***************************************************************************/ - -/*************************************************************************** - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 3 of the License, or * - * (at your option) any later version. * - * * - ***************************************************************************/ +/* SPDX-License-Identifier: GPL-3.0-or-later */ +/* + * menu + * - configurable user interactive menu feature + * + * Copyright (C) 2004-2025 by Leaflet + */ #ifndef _MENU_H_ #define _MENU_H_ +#include "bbs_cmd.h" #include "common.h" #include "trie_dict.h" #include -#include -#define MAX_MENUITEM_LENGTH 50 -#define MAX_ITEMS_PER_MENU 30 -#define MAX_MENUNAME_LENGTH 256 -#define MAX_MENUACTION_LENGTH 20 -#define MAX_MENUTITLE_LENGTH 50 +#define MAX_MENU_NAME_LENGTH 30 +#define MAX_ITEMS_PER_MENU 256 +#define MAX_MENUITEM_NAME_LENGTH 256 +#define MAX_MENUITEM_TEXT_LENGTH 200 +#define MAX_MENUITEM_ACTION_LENGTH 30 +#define MAX_MENUTITLE_TEXT_LENGTH 100 #define MAX_MENU_SCR_NAME_LENGTH 20 #define MAX_MENU_SCR_BUF_LENGTH 2000 #define MAX_MENUS 256 @@ -39,13 +32,14 @@ typedef uint64_t MENU_SCREEN_ID; struct menu_item_t { - int16_t row, col, r_row, r_col; - char action[MAX_MENUACTION_LENGTH]; + int16_t row, col; + char action[MAX_MENUITEM_ACTION_LENGTH]; MENU_ID action_menu_id; - int8_t submenu, display; + bbs_cmd_handler action_cmd_handler; + int8_t submenu; int priv, level; - char name[MAX_MENUNAME_LENGTH]; - char text[MAX_MENUITEM_LENGTH]; + char name[MAX_MENUITEM_NAME_LENGTH]; + char text[MAX_MENUITEM_TEXT_LENGTH]; }; typedef struct menu_item_t MENU_ITEM; @@ -53,7 +47,7 @@ struct menu_title_t { int16_t row, col; int8_t show; - char text[MAX_MENUTITLE_LENGTH]; + char text[MAX_MENUTITLE_TEXT_LENGTH]; }; typedef struct menu_title_t MENU_TITLE; @@ -67,13 +61,18 @@ typedef struct menu_screen_t MENU_SCREEN struct menu_t { - char name[MAX_MENUNAME_LENGTH]; + char name[MAX_MENU_NAME_LENGTH]; MENU_TITLE title; + char screen_name[MAX_MENU_SCR_NAME_LENGTH]; MENU_SCREEN_ID screen_id; int8_t screen_show; int16_t screen_row, screen_col; MENU_ITEM_ID items[MAX_ITEMS_PER_MENU]; 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; @@ -94,17 +93,25 @@ struct menu_set_t MENU_ID menu_id_path[MAX_MENU_DEPTH]; int16_t menu_item_pos[MAX_MENU_DEPTH]; int16_t choose_step; + int8_t menu_item_display[MAX_ITEMS_PER_MENU]; + 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 load_menu_shm(MENU_SET *p_menu_set); -extern int unload_menu_shm(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); @@ -124,7 +131,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) @@ -134,7 +141,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) @@ -144,7 +151,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_