# HG changeset patch # User albeu # Date 1143319776 0 # Node ID a6b11b35892a9377badadc90fa64c2146674e1cf # Parent 6ff3bdf986b86ba345dd7ccece065e2af48ecec7 Turn the preferences menu in something usefull using the new property API. diff -r 6ff3bdf986b8 -r a6b11b35892a etc/menu.conf --- a/etc/menu.conf Sat Mar 25 19:24:36 2006 +0000 +++ b/etc/menu.conf Sat Mar 25 20:49:36 2006 +0000 @@ -12,80 +12,54 @@ - - - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + - - - - - + + + + + + + + + + + - - - - - - - - - - - - - - - - - + + + + + + + - - + + diff -r 6ff3bdf986b8 -r a6b11b35892a libmenu/menu_param.c --- a/libmenu/menu_param.c Sat Mar 25 19:24:36 2006 +0000 +++ b/libmenu/menu_param.c Sat Mar 25 20:49:36 2006 +0000 @@ -1,3 +1,5 @@ + +#include "config.h" #include #include @@ -8,12 +10,12 @@ #include #include - -#include "config.h" +#include "mp_msg.h" +#include "help_mp.h" #include "m_struct.h" #include "m_option.h" -#include "m_config.h" +#include "m_property.h" #include "asxparser.h" #include "img_format.h" @@ -26,34 +28,66 @@ struct list_entry_s { struct list_entry p; + char* name; m_option_t* opt; + char* menu; }; struct menu_priv_s { menu_list_priv_t p; - char* edit; - int edit_len; + char* ptr; + int edit; /// Cfg fields + char* na; + int hide_na; }; static struct menu_priv_s cfg_dflt = { MENU_LIST_PRIV_DFLT, NULL, - 0 + 0, + "N/A", + 1 }; static m_option_t cfg_fields[] = { MENU_LIST_PRIV_FIELDS, { "title", M_ST_OFF(menu_list_priv_t,title), CONF_TYPE_STRING, 0, 0, 0, NULL }, + { "na", M_ST_OFF(struct menu_priv_s,na), CONF_TYPE_STRING, 0, 0, 0, NULL }, + { "hide-na", M_ST_OFF(struct menu_priv_s,hide_na), CONF_TYPE_FLAG, CONF_RANGE, 0, 1, NULL }, { NULL, NULL, NULL, 0,0,0,NULL } }; #define mpriv (menu->priv) -extern m_config_t* mconfig; +m_option_t* mp_property_find(char* name); + +static void entry_set_text(menu_t* menu, list_entry_t* e) { + char* val = m_property_print(e->opt); + int l,edit = (mpriv->edit && e == mpriv->p.current); + if(!val) { + if(mpriv->hide_na) { + e->p.hide = 1; + return; + } + val = strdup(mpriv->na); + } else if(mpriv->hide_na) + e->p.hide = 0; + l = strlen(e->name) + 2 + strlen(val) + (edit ? 4 : 0) + 1; + if(e->p.txt) free(e->p.txt); + e->p.txt = malloc(l); + sprintf(e->p.txt,"%s: %s%s%s",e->name,edit ? "> " : "",val,edit ? " <" : ""); + free(val); +} + +static void update_entries(menu_t* menu) { + list_entry_t* e; + for(e = mpriv->p.menu ; e ; e = e->p.next) + if(e->opt) entry_set_text(menu,e); +} static int parse_args(menu_t* menu,char* args) { - char *element,*body, **attribs, *name, *ok, *cancel; + char *element,*body, **attribs, *name; list_entry_t* m = NULL; int r; m_option_t* opt; @@ -63,33 +97,51 @@ while(1) { r = asx_get_element(parser,&args,&element,&body,&attribs); if(r < 0) { - printf("Syntax error at line %d\n",parser->line); + mp_msg(MSGT_OSD_MENU,MSGL_ERR,"Syntax error at line %d\n",parser->line); asx_parser_free(parser); return -1; } else if(r == 0) { asx_parser_free(parser); if(!m) - printf("No entry found in the menu definition\n"); - return m ? 1 : 0; + mp_msg(MSGT_OSD_MENU,MSGL_WARN,"No entry found in the menu definition\n"); + m = calloc(1,sizeof(struct list_entry_s)); + m->p.txt = strdup("Back"); + menu_list_add_entry(menu,m); + return 1; } - // Has it a name ? - name = asx_get_attrib("name",attribs); - opt = name ? m_config_get_option(mconfig,name) : NULL; + if(!strcmp(element,"menu")) { + name = asx_get_attrib("menu",attribs); + if(!name) { + mp_msg(MSGT_OSD_MENU,MSGL_WARN,"Submenu definition need a 'menu' attribut.\n"); + goto next_element; + } + m = calloc(1,sizeof(struct list_entry_s)); + m->menu = name; + name = NULL; // we want to keep it + m->p.txt = asx_get_attrib("name",attribs); + if(!m->p.txt) m->p.txt = strdup(m->menu); + menu_list_add_entry(menu,m); + goto next_element; + } + + name = asx_get_attrib("property",attribs); + opt = name ? mp_property_find(name) : NULL; if(!opt) { - printf("Pref menu entry definitions need a valid name attribut (line %d)\n",parser->line); - free(element); - if(name) free(name); - if(body) free(body); - asx_free_attribs(attribs); - continue; + mp_msg(MSGT_OSD_MENU,MSGL_WARN,"Pref menu entry definitions need a valid 'property'" + " attribut (line %d)\n",parser->line); + goto next_element; } m = calloc(1,sizeof(struct list_entry_s)); - m->p.txt = name; m->opt = opt; + m->name = asx_get_attrib("name",attribs); + if(!m->name) m->name = strdup(opt->name); + entry_set_text(menu,m); menu_list_add_entry(menu,m); + next_element: free(element); if(body) free(body); + if(name) free(name); asx_free_attribs(attribs); } } @@ -98,50 +150,101 @@ menu_list_read_key(menu,c,0); } +static void read_cmd(menu_t* menu,int cmd) { + list_entry_t* e = mpriv->p.current; + + if(e->opt) { + switch(cmd) { + case MENU_CMD_UP: + if(!mpriv->edit) break; + case MENU_CMD_RIGHT: + if(m_property_do(e->opt,M_PROPERTY_STEP_UP,NULL) > 0) + update_entries(menu); + return; + case MENU_CMD_DOWN: + if(!mpriv->edit) break; + case MENU_CMD_LEFT: + if(m_property_do(e->opt,M_PROPERTY_STEP_DOWN,NULL) > 0) + update_entries(menu); + return; + + case MENU_CMD_OK: + // check that the property is writable + if(m_property_do(e->opt,M_PROPERTY_SET,NULL) < 0) return; + // shortcut for flags + if(e->opt->type == CONF_TYPE_FLAG) { + if(m_property_do(e->opt,M_PROPERTY_STEP_UP,NULL) > 0) + update_entries(menu); + return; + } + // switch + mpriv->edit = !mpriv->edit; + // update the menu + update_entries(menu); + // switch the pointer + if(mpriv->edit) { + mpriv->ptr = mpriv->p.ptr; + mpriv->p.ptr = NULL; + } else + mpriv->p.ptr = mpriv->ptr; + return; + case MENU_CMD_CANCEL: + if(!mpriv->edit) break; + mpriv->edit = 0; + update_entries(menu); + mpriv->p.ptr = mpriv->ptr; + return; + } + } else if(e->menu) { + switch(cmd) { + case MENU_CMD_RIGHT: + case MENU_CMD_OK: { + mp_cmd_t* c; + char* txt = malloc(10 + strlen(e->menu) + 1); + sprintf(txt,"set_menu %s",e->menu); + c = mp_input_parse_cmd(txt); + if(c) mp_input_queue_cmd(c); + return; + } + } + } else { + switch(cmd) { + case MENU_CMD_RIGHT: + case MENU_CMD_OK: + menu->show = 0; + menu->cl = 1; + return; + } + } + menu_list_read_cmd(menu,cmd); +} + static void free_entry(list_entry_t* entry) { free(entry->p.txt); + if(entry->name) free(entry->name); + if(entry->menu) free(entry->menu); free(entry); } static void closeMenu(menu_t* menu) { menu_list_uninit(menu,free_entry); - if(mpriv->edit) - free(mpriv->edit); } static int openMenu(menu_t* menu, char* args) { - list_entry_t* e; menu->draw = menu_list_draw; - menu->read_cmd = menu_list_read_cmd; + menu->read_cmd = read_cmd; menu->read_key = read_key; menu->close = closeMenu; if(!args) { - printf("Pref menu need an argument\n"); + mp_msg(MSGT_OSD_MENU,MSGL_ERR,"Pref menu need an argument\n"); return 0; } menu_list_init(menu); - if(!parse_args(menu,args)) - return 0; - - for(e = mpriv->p.menu ; e ; e = e->p.next) { - int l; - char* val = m_option_print(e->opt,e->opt->p); - if((int)val == -1) { - printf("Can't get value of option %s\n",e->opt->name); - continue; - } else if(!val) - val = strdup("NULL"); - l = strlen(e->opt->name) + 2 + strlen(val) + 1; - e->p.txt = malloc(l); - sprintf(e->p.txt,"%s: %s",e->opt->name,val); - free(val); - } - - return 1; + return parse_args(menu,args); } const menu_info_t menu_info_pref = {