Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/menuc Document return values from menu items opt_act...



details:   https://anonhg.NetBSD.org/src/rev/08961659f9a6
branches:  trunk
changeset: 996983:08961659f9a6
user:      martin <martin%NetBSD.org@localhost>
date:      Sat Feb 16 18:57:21 2019 +0000

description:
Document return values from menu items opt_action functions, add a
new variant: -1 when functions have fundamentally changed the menu
definition on the fly and the processing functions needs to restart
without looking at the old state (or stale cached pointers).

diffstat:

 usr.bin/menuc/menu_sys.def |  13 +++++++++----
 usr.bin/menuc/menuc.1      |  26 +++++++++++++++++++++++++-
 2 files changed, 34 insertions(+), 5 deletions(-)

diffs (74 lines):

diff -r a011a7d7aa83 -r 08961659f9a6 usr.bin/menuc/menu_sys.def
--- a/usr.bin/menuc/menu_sys.def        Sat Feb 16 17:56:57 2019 +0000
+++ b/usr.bin/menuc/menu_sys.def        Sat Feb 16 18:57:21 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: menu_sys.def,v 1.65 2019/02/06 20:08:15 martin Exp $   */
+/*     $NetBSD: menu_sys.def,v 1.66 2019/02/16 18:57:21 martin Exp $   */
 
 /*
  * Copyright 1997 Piermont Information Systems Inc.
@@ -688,7 +688,7 @@
 process_menu(int num, void *arg)
 {
        int sel = 0;
-       int req;
+       int req, rv;
        menu_ent *opt;
 
        menudesc *m;
@@ -754,8 +754,13 @@
                        continue;
                if (opt->opt_flags & OPT_ENDWIN)
                        endwin();
-               if (opt->opt_action && (*opt->opt_action)(m, arg))
-                       break;
+               if (opt->opt_action) {
+                       rv = (*opt->opt_action)(m, arg);
+                       if (rv == -1)
+                               continue;
+                       else if (rv != 0)
+                               break;
+               }
 
                if (opt->opt_menu != -1) {
                        if (!(opt->opt_flags & OPT_SUB)) {
diff -r a011a7d7aa83 -r 08961659f9a6 usr.bin/menuc/menuc.1
--- a/usr.bin/menuc/menuc.1     Sat Feb 16 17:56:57 2019 +0000
+++ b/usr.bin/menuc/menuc.1     Sat Feb 16 18:57:21 2019 +0000
@@ -1,4 +1,4 @@
-.\"    $NetBSD: menuc.1,v 1.34 2019/01/04 15:27:19 martin Exp $
+.\"    $NetBSD: menuc.1,v 1.35 2019/02/16 18:57:21 martin Exp $
 .\"
 .\" Copyright 1997 Piermont Information Systems Inc.
 .\" All rights reserved.
@@ -539,6 +539,30 @@
 If it's null, string
 .Dq Exit
 is used.
+.Sh MENU ITEM ACTIONS
+When creating dynamic menus, the programer supplies function pointers
+for the menu items
+.Dv opt_action
+member.
+This functions return one of three possible values:
+.Bl -tag -width "-1" -compact
+.It 0
+process sub menu (if set) and continue with the current (or new) menu
+as usual.
+.It 1
+exit the current menu.
+This is equivalen to specifying
+.Dq exit
+in a non-dynamic menu specification.
+.It -1
+do not handle the current item any further and restart handling the (same)
+menu.
+This return value is used when actions modify the menu definition on the
+fly, e.g. adding or removing additional menu items.
+The action may set
+.Dq cur_sel
+to jump to an arbitrary menu item (in the modified menu).
+.El
 .Sh MENU ITEM EXPANSION
 With the
 .Ic enable expansion



Home | Main Index | Thread Index | Old Index