2003-10-16 10:19:11 +04:00
|
|
|
/* $NetBSD: sushi.c,v 1.15 2003/10/16 06:19:11 itojun Exp $ */
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2000 The NetBSD Foundation, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2000 Tim Rightnour <garbled@netbsd.org>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by the NetBSD
|
|
|
|
* Foundation, Inc. and its contributors.
|
|
|
|
* 4. Neither the name of The NetBSD Foundation nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived
|
|
|
|
* from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
|
|
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/queue.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <err.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
#include <cdk/cdk.h>
|
|
|
|
#include <form.h>
|
|
|
|
|
|
|
|
#include "sushi.h"
|
|
|
|
#include "menutree.h"
|
|
|
|
#include "scandir.h"
|
|
|
|
#include "formtree.h"
|
|
|
|
#include "handlers.h"
|
|
|
|
#include "blabel.h"
|
|
|
|
|
|
|
|
MTREE_ENTRY *navigate_menu __P((struct cqMenu *, char *, char *));
|
|
|
|
MTREE_ENTRY *navigate_submenu __P((MTREE_ENTRY *));
|
|
|
|
MTREE_ENTRY *display_menu __P((struct cqMenu *, char *, char *));
|
2001-01-10 13:00:29 +03:00
|
|
|
void parse_config __P((void));
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
|
|
|
CDKSCREEN *cdkscreen;
|
|
|
|
int scripting;
|
|
|
|
int logging;
|
|
|
|
FILE *logfile;
|
|
|
|
FILE *script;
|
|
|
|
WINDOW *funcwin;
|
|
|
|
struct winsize ws;
|
|
|
|
nl_catd catalog;
|
|
|
|
char *lang_id;
|
|
|
|
char **searchpaths;
|
2001-01-10 13:00:29 +03:00
|
|
|
char *keylabel[10];
|
|
|
|
chtype keybinding[10];
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
char *p;
|
|
|
|
int i;
|
|
|
|
MTREE_ENTRY *mte = NULL;
|
|
|
|
|
|
|
|
catalog = catopen("sushi", 0);
|
|
|
|
if (getenv("LANG") == NULL)
|
|
|
|
lang_id = NULL;
|
|
|
|
else
|
|
|
|
lang_id = strdup(getenv("LANG"));
|
|
|
|
|
2002-08-13 22:21:25 +04:00
|
|
|
if (initscr() == NULL)
|
|
|
|
errx(1, "%s", "Cannot initialize curses");
|
|
|
|
|
|
|
|
cdkscreen = initCDKScreen(stdscr);
|
|
|
|
|
|
|
|
ioctl(0, TIOCGWINSZ, &ws);
|
|
|
|
|
2002-11-25 12:11:35 +03:00
|
|
|
use_default_colors();
|
|
|
|
|
2002-08-13 22:21:25 +04:00
|
|
|
initCDKColor();
|
|
|
|
raw();
|
|
|
|
|
2001-01-10 13:00:29 +03:00
|
|
|
parse_config();
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
tree_init();
|
|
|
|
i = 0;
|
|
|
|
for (p = searchpaths[i]; p != NULL; i++) {
|
|
|
|
p = searchpaths[i];
|
|
|
|
scan_dir(cqMenuHeadp, p);
|
|
|
|
}
|
|
|
|
if (argc > 1) {
|
|
|
|
mte = tree_gettreebyname(cqMenuHeadp, argv[1]);
|
|
|
|
if (!mte) {
|
|
|
|
printf("QuickName %s not found in any menus.\n",
|
|
|
|
argv[1]);
|
2001-01-09 00:19:31 +03:00
|
|
|
catclose(catalog);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mte == NULL)
|
2001-01-09 12:41:41 +03:00
|
|
|
navigate_menu(cqMenuHeadp, "sushi_topmenu",
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
catgets(catalog, 4, 5, "<C></5>Sushi\n\n"));
|
|
|
|
else
|
|
|
|
navigate_submenu(mte);
|
|
|
|
|
2001-01-09 00:19:31 +03:00
|
|
|
destroyCDKScreen(cdkscreen);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
endCDK();
|
|
|
|
endwin();
|
|
|
|
#ifdef DEBUG
|
|
|
|
tree_printtree(cqMenuHeadp);
|
|
|
|
#endif
|
2001-01-09 00:19:31 +03:00
|
|
|
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
catclose(catalog);
|
2001-01-10 06:05:48 +03:00
|
|
|
return(EXIT_SUCCESS);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
}
|
|
|
|
|
2001-01-10 13:00:29 +03:00
|
|
|
static char *
|
|
|
|
next_word(char **line)
|
|
|
|
{
|
|
|
|
char *word, *p;
|
|
|
|
|
|
|
|
p = *line;
|
|
|
|
while (*++p && isspace((unsigned char)*p));
|
|
|
|
word = p;
|
|
|
|
for (; *p != '\0' && !isspace((unsigned char)*p); ++p);
|
|
|
|
*p = '\0';
|
|
|
|
*line = p;
|
|
|
|
return(word);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static chtype
|
|
|
|
parse_keybinding(char *key)
|
|
|
|
{
|
|
|
|
if (tolower(key[0]) == 'f' && isdigit(key[1]))
|
|
|
|
/* we have an F key */
|
|
|
|
return(KEY_F(atoi(key + 1)));
|
|
|
|
else if (key[0] == '^')
|
|
|
|
return((chtype)(toupper(key[1]) & ~0x40));
|
|
|
|
else if (isalpha(key[0]))
|
|
|
|
/* we have an insane user */
|
|
|
|
return((chtype)tolower(key[0]));
|
|
|
|
|
|
|
|
bailout("%s: %s", catgets(catalog, 1, 20, "Bad keybinding"), key);
|
|
|
|
/* NOTREACHED */
|
|
|
|
return(0);
|
|
|
|
}
|
|
|
|
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
void
|
2001-01-10 13:00:29 +03:00
|
|
|
parse_config(void)
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
{
|
|
|
|
FILE *conf;
|
|
|
|
size_t len;
|
|
|
|
int i, j;
|
2001-01-10 13:00:29 +03:00
|
|
|
char *p, *t, *word;
|
|
|
|
char *key;
|
2003-10-16 10:19:11 +04:00
|
|
|
char **n;
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
|
|
|
conf = fopen("/etc/sushi.conf", "r");
|
|
|
|
if (conf == NULL) {
|
|
|
|
searchpaths = (char **)malloc(sizeof(char *) * 6);
|
|
|
|
if (searchpaths == NULL)
|
|
|
|
bailout("malloc: %s", strerror(errno));
|
|
|
|
searchpaths[0] = "/usr/share/sushi";
|
|
|
|
searchpaths[1] = "/usr/pkg/share/sushi";
|
|
|
|
searchpaths[2] = "/usr/X11R6/share/sushi";
|
|
|
|
searchpaths[3] = "/etc/sushi";
|
2002-07-25 16:39:26 +04:00
|
|
|
i = 4;
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
} else {
|
|
|
|
searchpaths = (char **)malloc(sizeof(char *));
|
|
|
|
if (searchpaths == NULL)
|
|
|
|
bailout("malloc: %s", strerror(errno));
|
|
|
|
i = 0;
|
|
|
|
while ((p = fgetln(conf, &len))) {
|
2001-01-10 13:00:29 +03:00
|
|
|
if (len == 1 || p[len - 1] == '#' || p[len - 1] != '\n')
|
|
|
|
continue;
|
|
|
|
p[len - 1] = '\0';
|
|
|
|
for (; *p != '\0' && isspace((unsigned char)*p); ++p);
|
|
|
|
if (*p == '\0' || *p == '#')
|
|
|
|
continue;
|
|
|
|
for (t = p; *t && !isspace((unsigned char)*t); ++t);
|
|
|
|
if (*t == '\0')
|
|
|
|
continue;
|
|
|
|
*t = '\0';
|
|
|
|
word = p;
|
|
|
|
while (*++p && !isspace((unsigned char)*p));
|
|
|
|
key = strdup(word);
|
|
|
|
if (strcmp(key, "searchpath") == 0) {
|
|
|
|
word = next_word(&p);
|
2003-10-16 10:19:11 +04:00
|
|
|
n = (char **)realloc(searchpaths,
|
2001-01-10 13:00:29 +03:00
|
|
|
sizeof(char *) * (i + 2));
|
2003-10-16 10:19:11 +04:00
|
|
|
if (n == NULL)
|
2001-01-10 13:00:29 +03:00
|
|
|
bailout("malloc: %s", strerror(errno));
|
2003-10-16 10:19:11 +04:00
|
|
|
searchpaths = n;
|
2001-01-10 13:00:29 +03:00
|
|
|
searchpaths[i] = (char *)malloc(sizeof(char)
|
|
|
|
* len + 1);
|
|
|
|
if (searchpaths[i] == NULL)
|
|
|
|
bailout("malloc: %s", strerror(errno));
|
|
|
|
searchpaths[i] = strdup(word);
|
|
|
|
for (j = 0; j < len; j++)
|
|
|
|
if (searchpaths[i][j] == '\n' ||
|
|
|
|
searchpaths[i][j] == '\r')
|
|
|
|
searchpaths[i][j] = '\0';
|
|
|
|
i++;
|
|
|
|
} else if (strcmp(key, "bind") == 0) {
|
|
|
|
word = next_word(&p);
|
|
|
|
word++;
|
|
|
|
j = atoi(word);
|
|
|
|
j--;
|
|
|
|
/* now get the character */
|
|
|
|
word = next_word(&p);
|
|
|
|
keybinding[j] = parse_keybinding(word);
|
|
|
|
/* now get the string */
|
|
|
|
word = next_word(&p);
|
|
|
|
keylabel[j] = strdup(word);
|
|
|
|
} else {
|
|
|
|
bailout("%s: %s", catgets(catalog, 1, 21,
|
|
|
|
"Bad keyword in config file"), key);
|
|
|
|
}
|
|
|
|
} /* while */
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
}
|
|
|
|
searchpaths[i] = (char *)malloc(sizeof(char) * PATH_MAX);
|
|
|
|
if (searchpaths[i] == NULL)
|
|
|
|
bailout("malloc: %s", strerror(errno));
|
|
|
|
if (getenv("HOME") != NULL) {
|
2003-06-13 11:26:41 +04:00
|
|
|
strlcpy(searchpaths[i], getenv("HOME"), PATH_MAX);
|
|
|
|
strlcat(searchpaths[i], "/sushi", PATH_MAX);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
searchpaths[i] = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MTREE_ENTRY *
|
|
|
|
navigate_menu(struct cqMenu *cqm, char *basedir, char *ititle)
|
|
|
|
{
|
|
|
|
MTREE_ENTRY *mte;
|
|
|
|
char title[90];
|
|
|
|
|
|
|
|
mte = display_menu(cqm, ititle, basedir);
|
|
|
|
if(mte) {
|
|
|
|
if(!TREE_ISEMPTY(&mte->cqSubMenuHead)) {
|
|
|
|
snprintf(title, sizeof(title), "<C></5>%s\n\n",
|
|
|
|
mte->itemname);
|
|
|
|
navigate_menu(&mte->cqSubMenuHead, mte->path, title);
|
|
|
|
} else
|
|
|
|
for (;;)
|
|
|
|
if (handle_endpoint(mte->path) == 0)
|
|
|
|
break;
|
|
|
|
|
|
|
|
navigate_menu(cqm, basedir, ititle);
|
|
|
|
}
|
|
|
|
|
|
|
|
return(mte);
|
|
|
|
}
|
|
|
|
|
|
|
|
MTREE_ENTRY *
|
|
|
|
navigate_submenu(MTREE_ENTRY *mte)
|
|
|
|
{
|
|
|
|
char title[90];
|
|
|
|
MTREE_ENTRY *lastmte;
|
|
|
|
|
|
|
|
lastmte = mte;
|
|
|
|
|
|
|
|
if (TREE_ISEMPTY(&mte->cqSubMenuHead))
|
|
|
|
for (;;)
|
|
|
|
if (handle_endpoint(mte->path) == 0)
|
|
|
|
exit(EXIT_SUCCESS);
|
|
|
|
|
|
|
|
snprintf(title, sizeof(title), "<C></5>%s\n\n", mte->itemname);
|
|
|
|
mte = display_menu(&mte->cqSubMenuHead, title, mte->path);
|
|
|
|
if(mte) {
|
|
|
|
if(!TREE_ISEMPTY(&mte->cqSubMenuHead)) {
|
|
|
|
snprintf(title, sizeof(title), "<C></5>%s\n\n",
|
|
|
|
mte->itemname);
|
|
|
|
navigate_submenu(mte);
|
|
|
|
} else
|
|
|
|
for (;;)
|
|
|
|
if (handle_endpoint(mte->path) == 0)
|
|
|
|
break;
|
|
|
|
|
|
|
|
navigate_submenu(lastmte);
|
|
|
|
}
|
|
|
|
|
|
|
|
return(mte);
|
|
|
|
}
|
|
|
|
|
|
|
|
MTREE_ENTRY *
|
|
|
|
display_menu(cqm, title, basedir)
|
|
|
|
struct cqMenu *cqm;
|
|
|
|
char *title;
|
|
|
|
char *basedir;
|
|
|
|
{
|
2001-01-10 06:05:48 +03:00
|
|
|
CDKSCROLL *scrollp;
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
MTREE_ENTRY *mte;
|
|
|
|
char **menu;
|
|
|
|
int i, items, selection;
|
|
|
|
|
|
|
|
items = tree_entries(cqm);
|
|
|
|
if(!(menu = malloc(sizeof(char *) * (items+1))))
|
|
|
|
bailout("malloc: %s", strerror(errno));
|
|
|
|
|
|
|
|
items = 0;
|
|
|
|
for (mte = CIRCLEQ_FIRST(cqm); mte != (void *)cqm;
|
|
|
|
mte = CIRCLEQ_NEXT(mte, cqMenuEntries)){
|
|
|
|
if(!strcmp(mte->itemname, "BLANK")) {
|
|
|
|
if(!(menu[items] = strdup("")))
|
|
|
|
bailout("strdup: %s", strerror(errno));
|
|
|
|
} else {
|
|
|
|
if(!(menu[items] = strdup(mte->itemname)))
|
|
|
|
bailout("strdup: %s", strerror(errno));
|
|
|
|
}
|
|
|
|
++items;
|
|
|
|
}
|
|
|
|
|
2001-01-09 00:19:31 +03:00
|
|
|
if (items == 0) {
|
|
|
|
destroyCDKScreen(cdkscreen);
|
|
|
|
endCDK();
|
|
|
|
endwin();
|
|
|
|
(void)fprintf(stderr, "%s\n", catgets(catalog, 1, 19,
|
|
|
|
"No menu hierarchy found"));
|
|
|
|
catclose(catalog);
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
bottom_help(1);
|
|
|
|
|
2001-01-10 06:05:48 +03:00
|
|
|
scrollp = newCDKScroll(cdkscreen, CENTER, TOP, RIGHT,
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
ws.ws_row-3, ws.ws_col, title, menu, items, FALSE, A_REVERSE,
|
|
|
|
TRUE, FALSE);
|
|
|
|
|
2001-01-10 06:05:48 +03:00
|
|
|
if (scrollp == NULL)
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
bailout(catgets(catalog, 1, 16,
|
|
|
|
"Cannot allocate scroll widget"));
|
|
|
|
|
2001-01-10 06:05:48 +03:00
|
|
|
bind_menu(scrollp, basedir);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
2001-01-22 10:12:49 +03:00
|
|
|
loop:
|
2001-01-10 06:05:48 +03:00
|
|
|
selection = activateCDKScroll(scrollp, NULL);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
2001-01-22 10:12:49 +03:00
|
|
|
mte = tree_getentry(cqm, selection);
|
|
|
|
if (selection != -1 && strcmp(mte->filename, "BLANK") == 0)
|
|
|
|
goto loop;
|
|
|
|
|
2001-01-10 06:05:48 +03:00
|
|
|
destroyCDKScroll(scrollp);
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
|
|
|
|
for(i=0; i<items; i++)
|
|
|
|
free(menu[i]);
|
|
|
|
free(menu);
|
|
|
|
|
|
|
|
return(mte);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
bailout(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, fmt);
|
|
|
|
|
|
|
|
destroyCDKScreen(cdkscreen);
|
|
|
|
endCDK();
|
2001-02-21 02:51:59 +03:00
|
|
|
fprintf(stderr, "%s: ", getprogname());
|
Initial import of sushi.
Sushi is an interactive, menu-based program that is designed to aid
the user or administrator with administrative and complex tasks on thier
machines.
Sushi provides a menu of various functions that the user can perform on
his or her machine. Once the user selects a desired function, the
function is either performed outright, or in most cases, the user is
asked to fill in a simple form with required and option information,
which is then processed by sushi, and the action occurs.
The programming interface for sushi is very simple. There are
directories containing various files, such as menu indexes, or forms for
the user to fill out. These files are interpreted by sushi to generate
the menus the user sees on his/her screen. When the form is filled out
by the user, the entries are passed as command-line arguments to a
program, or script contained in one of the subdirectories. In this way,
it is possible to add new entries to the sushi menu structure, by simply
adding a new menu item, form and script, the binary does not need to be
recompiled to take advantage of this new menu.
2001-01-05 04:28:33 +03:00
|
|
|
if (fmt != NULL)
|
|
|
|
vfprintf(stderr, fmt, ap);
|
|
|
|
fprintf(stderr, "\n");
|
|
|
|
va_end(ap);
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|