可以简单的创建一个终端菜单的工具
您可以使用以下的方法来将cMENU添加至您的项目中
整个cMENU工具仅含有两个文件,您可以直接将 menu.h
和 menu.c
添加到您的项目中并开始使用.
可以使用如下方式来将cMENU添加至您的源代码中
#include "menu.h"
为了尽可能多的支持各种平台和编译器,cMENU是使用ANSI C (C89)标准编写。
cOPTION
代表了一个选项对象
cMENU
代表了一个菜单对象
/* The cOPTION structrue: */
typedef struct _one_option cOPTION;
typedef struct _one_option
{
char *text;
cMENU *parent_menu;
cMENU *next_menu;
int (*function)(void);
}cOPTION;
您可以使用 mk_option(char*,function)
函数来创建一个option对象(function参数为一个函数的函数名,且该函数为int类型,且无参数)
您可以使用以下方式来创建一个选项列表(选项列表是创建菜单的必要参数):
cOPTION option_list[N]={
mk_option("option1",func1),
mk_option("option2",func2),
...
mk_option("optionN",funcN),
}
/* The cMENU structrue */
typedef struct _menu cMENU;
typedef struct _menu
{
char *name;
char *text;
struct _menu *parent_menu;
cOPTION *options_list;
int option_number;
boolean back_available;
}cMENU;
您可以使用 mk_menu(char*,char*,cMENU*,cOPTION*,int,boolean)
函数来创建一个option对象(通常来说,推荐您在第三个参数处始终使用 NULL)
可以使用下述方式来创建一个菜单对象
cMENU menu = mk_menu("menu_title","menu_introduction",NULL,option_list,N,TRUE);
mk_menu
构建mk_option
构建cOPTION option_list[N] = {
mk_option,
mk_option,...
}
modify_system_speaker
modify_system_speaker(char*)
可以修改菜单系统对自己的说明默认为:<|系统提示|>
modify_menu_reminder
modify_menu_reminder(char*)
可以修改菜单中菜单说明的提示符,默认为: 菜单说明
modify_whether_remind
modify_whether_remind(char*)
可以修改在错误输入后对是否重新输入的提示符,默认为是否重新输入
modify_input_remind
modify_input_remind(char*)
可以修改系统对请求选项的提示符,默认为 请输入选项
modify_back_choice
modify_back_choice(char*)
可以修改系统对返回选项的描述,默认为 返回上层菜单
link_menu2option
如果您希望在选项执行结束后可以去到下一个菜单,请使用 link_menu2option
函数,将某个选项与某个菜单链接。这样在该选项执行结束后会跳转至该菜单。你可以创建函数给选项使用,在用户选择该选项后,会自动执行该函数.如果选项不需要执行某些功能,请在构造时将其功能函数参数处使用NONE_OPTION_FUNC
参数:mk_option("**",NONE_OPTION_FUNC)
(NONE_OPTION_FUNC).
功能函数编写规范.
int func_name(void)
{
statements;
return NORMAL;//如果返回值为NORMAL 则会正常进入下一级菜单
/*return BACK; //如果返回值为BACK 则会退回到原菜单
}
start
如果你已经完成了菜单的构建,并准备启动该菜单,您可以使用 start(cMENU*)
函数来启动菜单.该函数需要您指定最初的菜单.如果菜单正常结束. start
函数将会返回0 .MIT License
Copyright (c) 2009-2017 GuoZi
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
1. 开源生态
2. 协作、人、软件
3. 评估模型