[svn-commits] branch group/autoconf_and_menuselect r22160 - /team/group/autoconf_and_menuse...

svn-commits at lists.digium.com svn-commits at lists.digium.com
Sat Apr 22 22:05:32 MST 2006


Author: russell
Date: Sun Apr 23 00:05:32 2006
New Revision: 22160

URL: http://svn.digium.com/view/asterisk?rev=22160&view=rev
Log:
move the curses frontend code into its own file so that it will be easier
to write a different frontend if anyone chooses to do so

Added:
    team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c   (with props)
Modified:
    team/group/autoconf_and_menuselect/build_tools/Makefile
    team/group/autoconf_and_menuselect/build_tools/menuselect.c
    team/group/autoconf_and_menuselect/build_tools/menuselect.h

Modified: team/group/autoconf_and_menuselect/build_tools/Makefile
URL: http://svn.digium.com/view/asterisk/team/group/autoconf_and_menuselect/build_tools/Makefile?rev=22160&r1=22159&r2=22160&view=diff
==============================================================================
--- team/group/autoconf_and_menuselect/build_tools/Makefile (original)
+++ team/group/autoconf_and_menuselect/build_tools/Makefile Sun Apr 23 00:05:32 2006
@@ -1,11 +1,14 @@
-menuselect: menuselect.o
-	$(CC) -g -o menuselect menuselect.o ../mxml/libmxml.a -lcurses
+menuselect: menuselect.o menuselect_curses.o
+	$(CC) -g -o $@ $< menuselect_curses.o ../mxml/libmxml.a -lcurses
 
 menuselect.o: menuselect.c menuselect.h
-	$(CC) -D_GNU_SOURCE -g -o menuselect.o -c -I../ -I../include/ menuselect.c
+	$(CC) -D_GNU_SOURCE -g -c -o $@ -I../ -I../include/ $<
+
+menuselect_curses.o: menuselect_curses.c menuselect.h
+	$(CC) -D_GNU_SOURCE -g -c -o $@ -I../ -I../include/ $<
 
 clean:
-	rm -f menuselect menuselect.o
+	rm -f menuselect *.o
 
 dist-clean: clean
 	rm -f menuselect-deps

Modified: team/group/autoconf_and_menuselect/build_tools/menuselect.c
URL: http://svn.digium.com/view/asterisk/team/group/autoconf_and_menuselect/build_tools/menuselect.c?rev=22160&r1=22159&r2=22160&view=diff
==============================================================================
--- team/group/autoconf_and_menuselect/build_tools/menuselect.c (original)
+++ team/group/autoconf_and_menuselect/build_tools/menuselect.c Sun Apr 23 00:05:32 2006
@@ -24,39 +24,22 @@
  * \brief A console menu-driven system for Asterisk module selection
  */
 
+#include "autoconfig.h"
+
 #include <stdlib.h>
 #include <stdio.h>
 #include <string.h>
 #include <unistd.h>
-#include <signal.h>
-#include <curses.h>
 
 #include "mxml/mxml.h"
 #include "menuselect.h"
 
-#include "autoconfig.h"
+#include "asterisk.h"
 
 #include "asterisk/linkedlists.h"
 
-#define MIN_X		80
-#define MIN_Y		20
-
-#define PAGE_OFFSET	10
-
 #undef MENUSELECT_DEBUG
 
-/*!
-   The member and category structures are used to maintain our own list of all
-   of the categories and members in these categories that are specified in the
-   build options file.
-
-   The reason we need this is that we have to maintain information about which
-   options are enabled and disabled. This information is read from any existing
-   build configuration, and then changed as the user navigates the system. We
-   will then use this information to output a new build configuration file.
-
-  {
-*/
 struct depend {
 	/*! the name of the dependency */
 	const char *name;
@@ -71,42 +54,8 @@
 	AST_LIST_ENTRY(conflict) list;
 };
 
-struct member {
-	/*! What will be sent to the makeopts file */
-	const char *name;
-	/*! This module is currently selected */
-	int enabled;
-	/*! This module has failed dependencies */
-	int depsfailed;
-	/*! This module has failed conflicts */
-	int conflictsfailed;
-	/*! dependencies of this module */
-	AST_LIST_HEAD_NOLOCK(, depend) deps;
-	/*! conflicts of this module */
-	AST_LIST_HEAD_NOLOCK(, conflict) conflicts;
-	/*! for making a list of modules */
-	AST_LIST_ENTRY(member) list;
-};
-
-struct category {
-	/*! the Makefile variable */
-	const char *name;
-	/*! the name displayed in the menu */
-	const char *displayname;
-	/*! Display what is selected, as opposed to not selected */
-	int positive_output;
-	/*! Force a clean of the source tree if anything in this category changes */
-	int force_clean_on_change;
-	/*! the list of possible values to be set in this variable */
-	AST_LIST_HEAD_NOLOCK(, member) members;
-	/*! for linking */
-	AST_LIST_ENTRY(category) list;
-};
-
-/*! } */
-
 /*! The list of categories */
-AST_LIST_HEAD_NOLOCK_STATIC(categories, category);
+struct categories categories = AST_LIST_HEAD_NOLOCK_INIT_VALUE;
 
 /*!
    We have to maintain a pointer to the root of the trees generated from reading
@@ -125,10 +74,9 @@
 /*! The list of trees from makeopts.xml files */
 AST_LIST_HEAD_NOLOCK_STATIC(trees, tree);
 
-/*! Maximum number of characters horizontally */
-int max_x = 0;
-/*! Maximum number of characters vertically */
-int max_y = 0;
+const char * const makeopts_files[] = {
+	"makeopts.xml"
+};
 
 char *output_makeopts = OUTPUT_MAKEOPTS_DEFAULT;
 
@@ -152,12 +100,6 @@
 		fprintf(stderr, "Memory allocation error!\n");
 
 	return tmp;
-}
-
-/*! \brief returns non-zero if the string is not defined, or has zero length */
-static inline int strlen_zero(const char *s)
-{
-	return (!s || (*s == '\0'));
 }
 
 /*! \brief return a pointer to the first non-whitespace character */
@@ -622,32 +564,6 @@
 	}
 }
 
-/*! \brief Handle a window resize in xterm */
-void winch_handler(int sig)
-{
-	getmaxyx(stdscr, max_y, max_x);
-
-	if (max_x < MIN_X - 1 || max_y < MIN_Y - 1) {
-		fprintf(stderr, "Terminal must be at least 80 x 25.\n");
-		max_x = MIN_X - 1;
-		max_y = MIN_Y - 1;
-	}
-}
-
-/*! \brief Display help information */
-void show_help(WINDOW *win)
-{
-	int i;
-
-	wclear(win);
-	for (i = 0; i < (sizeof(help_info) / sizeof(help_info[0])); i++) {
-		wmove(win, i, max_x / 2 - 15);
-		waddstr(win, help_info[i]);
-	}
-	wrefresh(win);
-	getch(); /* display the help until the user hits a key */
-}
-
 /*! \brief Enable/Disable all members of a category as long as dependencies have been met and no conflicts are found */
 void set_all(struct category *cat, int val)
 {
@@ -659,30 +575,6 @@
 	}
 }
 
-void draw_main_menu(WINDOW *menu, int curopt)
-{
-	struct category *cat;
-	char buf[64];
-	int i = 0;
-
-	wclear(menu);
-
-	AST_LIST_TRAVERSE(&categories, cat, list) {
-		wmove(menu, i++, max_x / 2 - 10);
-		if (!strlen_zero(cat->displayname))
-			snprintf(buf, sizeof(buf), "%d.%s %s", i, i < 10 ? " " : "", cat->displayname);
-		else
-			snprintf(buf, sizeof(buf), "%d.%s %s", i, i < 10 ? " " : "", cat->name);
-		waddstr(menu, buf);
-	}
-
-	wmove(menu, curopt, (max_x / 2) - 15);
-	waddstr(menu, "--->");
-	wmove(menu, 0, 0);
-
-	wrefresh(menu);
-}
-
 int count_categories(void)
 {
 	struct category *cat;
@@ -703,194 +595,6 @@
 		count++;
 
 	return count;		
-}
-
-void draw_category_menu(WINDOW *menu, struct category *cat, int start, int end, int curopt)
-{
-	int i = 0;
-	int j = 0;
-	struct member *mem;
-	char buf[64];
-
-	wclear(menu);
-
-	AST_LIST_TRAVERSE(&cat->members, mem, list) {
-		if (i < start) {
-			i++;
-			continue;
-		}
-		wmove(menu, j++, max_x / 2 - 10);
-		i++;
-		if (mem->depsfailed)
-			snprintf(buf, sizeof(buf), "XXX %d.%s %s", i, i < 10 ? " " : "", mem->name);
-		else
-			snprintf(buf, sizeof(buf), "[%s] %d.%s %s", mem->enabled ? "*" : " ", i, i < 10 ? " " : "", mem->name);
-		waddstr(menu, buf);
-		if (i == end)
-			break;
-	}
-
-	wmove(menu, curopt - start, max_x / 2 - 9);
-
-	wrefresh(menu);
-}
-
-int run_category_menu(WINDOW *menu, int cat_num)
-{
-	struct category *cat;
-	int i = 0;
-	int start = 0;
-	int end = max_y - TITLE_HEIGHT - 2;
-	int c;
-	int curopt = 0;
-	int maxopt;
-
-	AST_LIST_TRAVERSE(&categories, cat, list) {
-		if (i++ == cat_num)
-			break;
-	}
-	if (!cat)
-		return -1;
-
-	maxopt = count_members(cat) - 1;
-
-	draw_category_menu(menu, cat, start, end, curopt);
-
-	while ((c = getch())) {
-		switch (c) {
-		case KEY_UP:
-			if (curopt > 0) {
-				curopt--;
-				if (curopt < start) {
-					start--;
-					end--;
-				}
-			}
-			break;
-		case KEY_DOWN:
-			if (curopt < maxopt) {
-				curopt++;
-				if (curopt > end - 1) {
-					start++;
-					end++;
-				}
-			}
-			break;
-		case KEY_NPAGE:
-			/* XXX Move down the list by PAGE_OFFSET */
-			break;
-		case KEY_PPAGE:
-			/* XXX Move up the list by PAGE_OFFSET */
-			break;
-		case KEY_LEFT:
-			return 0;
-		case KEY_RIGHT:
-		case KEY_ENTER:
-		case '\n':
-		case ' ':
-			toggle_enabled(cat, curopt);
-			break;
-		case 'h':
-		case 'H':
-			show_help(menu);
-			break;
-		case KEY_F(7):
-			set_all(cat, 0);
-			break;
-		case KEY_F(8):
-			set_all(cat, 1);
-		default:
-			break;	
-		}
-		if (c == 'x' || c == 'q')
-			break;	
-		draw_category_menu(menu, cat, start, end, curopt);
-	}
-
-	wrefresh(menu);
-
-	return c;
-}
-
-void draw_title_window(WINDOW *title)
-{
-	wmove(title, 1, (max_x / 2) - (strlen(MENU_TITLE1) / 2));
-	waddstr(title, MENU_TITLE1);
-	wmove(title, 2, (max_x / 2) - (strlen(MENU_TITLE2) / 2));
-	waddstr(title, MENU_TITLE2);
-	wmove(title, 3, (max_x / 2) - (strlen(MENU_TITLE3) / 2));
-	waddstr(title, MENU_TITLE3);
-	wmove(title, 0, 0);
-	wrefresh(title);
-}
-
-int run_menu(void)
-{
-	WINDOW *title;
-	WINDOW *menu;
-	int maxopt;
-	int curopt = 0;
-	int c;
-	int res = 0;
-
-	initscr();
-	getmaxyx(stdscr, max_y, max_x);
-	signal(SIGWINCH, winch_handler); /* handle window resizing in xterm */
-
-	if (max_x < MIN_X - 1 || max_y < MIN_Y - 1) {
-		fprintf(stderr, "Terminal must be at least %d x %d.\n", MIN_X, MIN_Y);
-		endwin();
-		return -1;
-	}
-
-	cbreak(); /* don't buffer input until the enter key is pressed */
-	noecho(); /* don't echo user input to the screen */
-	keypad(stdscr, TRUE); /* allow the use of arrow keys */
-	clear();
-	refresh();
-
-	maxopt = count_categories() - 1;
-	
-	/* We have two windows - the title window at the top, and the menu window gets the rest */
-	title = newwin(TITLE_HEIGHT, max_x, 0, 0);
-	menu = newwin(max_y - TITLE_HEIGHT, max_x, TITLE_HEIGHT, 0);
-	draw_title_window(title);	
-	draw_main_menu(menu, curopt);
-	
-	while ((c = getch())) {
-		switch (c) {
-		case KEY_UP:
-			if (curopt > 0)
-				curopt--;
-			break;
-		case KEY_DOWN:
-			if (curopt < maxopt)
-				curopt++;
-			break;
-		case KEY_RIGHT:
-		case KEY_ENTER:
-		case '\n':
-		case ' ':
-			c = run_category_menu(menu, curopt);
-			break;
-		case 'h':
-		case 'H':
-			show_help(menu);
-		default:
-			break;	
-		}
-		if (c == 'q') {
-			res = -1;
-			break;
-		}
-		if (c == 'x')
-			break;	
-		draw_main_menu(menu, curopt);
-	}
-
-	endwin();
-
-	return res;
 }
 
 int main(int argc, char *argv[])

Modified: team/group/autoconf_and_menuselect/build_tools/menuselect.h
URL: http://svn.digium.com/view/asterisk/team/group/autoconf_and_menuselect/build_tools/menuselect.h?rev=22160&r1=22159&r2=22160&view=diff
==============================================================================
--- team/group/autoconf_and_menuselect/build_tools/menuselect.h (original)
+++ team/group/autoconf_and_menuselect/build_tools/menuselect.h Sun Apr 23 00:05:32 2006
@@ -23,27 +23,61 @@
  *
  */
 
-#define MENU_TITLE1	"*************************************"
-#define MENU_TITLE2	"*     Asterisk Module Selection     *"
-#define MENU_TITLE3	"*************************************"
+#ifndef MENUSELECT_H
+#define MENUSELECT_H
 
-#define TITLE_HEIGHT	5
+#include "asterisk/linkedlists.h"
 
 #define OUTPUT_MAKEOPTS_DEFAULT "menuselect.makeopts"
-#define MENUSELECT_DEPS		"build_tools/menuselect-deps"
+#define MENUSELECT_DEPS         "build_tools/menuselect-deps"
 
-const char * const help_info[] = {
-	"scroll        => up/down arrows",
-	"(de)select    => Enter",
-	"select all    => F8",
-	"deselect all  => F7",
-	"back          => left arrow",
-	"quit          => q",
-	"save and quit => x",
-	"",
-	"XXX means dependencies have not been met"
+struct depend;
+struct conflict;
+
+struct member {
+	/*! What will be sent to the makeopts file */
+	const char *name;
+	/*! This module is currently selected */
+	int enabled;
+	/*! This module has failed dependencies */
+	int depsfailed;
+	/*! This module has failed conflicts */
+	int conflictsfailed;
+	/*! dependencies of this module */
+	AST_LIST_HEAD_NOLOCK(, depend) deps;
+	/*! conflicts of this module */
+	AST_LIST_HEAD_NOLOCK(, conflict) conflicts;
+	/*! for making a list of modules */
+	AST_LIST_ENTRY(member) list;
 };
 
-const char * const makeopts_files[] = {
-	"makeopts.xml"
+struct category {
+	/*! the Makefile variable */
+	const char *name;
+	/*! the name displayed in the menu */
+	const char *displayname;
+	/*! Display what is selected, as opposed to not selected */
+	int positive_output;
+	/*! Force a clean of the source tree if anything in this category changes */
+	int force_clean_on_change;
+	/*! the list of possible values to be set in this variable */
+	AST_LIST_HEAD_NOLOCK(, member) members;
+	/*! for linking */
+	AST_LIST_ENTRY(category) list;
 };
+
+extern AST_LIST_HEAD_NOLOCK(categories, category) categories;
+
+/*! This is implemented by the frontend */
+int run_menu(void);
+
+int count_categories(void);
+int count_members(struct category *cat);
+
+/*! \brief returns non-zero if the string is not defined, or has zero length */
+static inline int strlen_zero(const char *s)
+{
+	return (!s || (*s == '\0'));
+}
+
+#endif /* MENUSELECT_H */

Added: team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c
URL: http://svn.digium.com/view/asterisk/team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c?rev=22160&view=auto
==============================================================================
--- team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c (added)
+++ team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c Sun Apr 23 00:05:32 2006
@@ -1,0 +1,278 @@
+#include "autoconfig.h"
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+#include <signal.h>
+#include <curses.h>
+
+#include "menuselect.h"
+
+#define MENU_TITLE1	"*************************************"
+#define MENU_TITLE2	"*     Asterisk Module Selection     *"
+#define MENU_TITLE3	"*************************************"
+
+#define TITLE_HEIGHT	5
+
+#define MIN_X		80
+#define MIN_Y		20
+
+#define PAGE_OFFSET	10
+
+
+/*! Maximum number of characters horizontally */
+int max_x = 0;
+/*! Maximum number of characters vertically */
+int max_y = 0;
+
+const char * const help_info[] = {
+	"scroll        => up/down arrows",
+	"(de)select    => Enter",
+	"select all    => F8",
+	"deselect all  => F7",
+	"back          => left arrow",
+	"quit          => q",
+	"save and quit => x",
+	"",
+	"XXX means dependencies have not been met"
+};
+
+/*! \brief Handle a window resize in xterm */
+void winch_handler(int sig)
+{
+	getmaxyx(stdscr, max_y, max_x);
+
+	if (max_x < MIN_X - 1 || max_y < MIN_Y - 1) {
+		fprintf(stderr, "Terminal must be at least 80 x 25.\n");
+		max_x = MIN_X - 1;
+		max_y = MIN_Y - 1;
+	}
+}
+
+/*! \brief Display help information */
+void show_help(WINDOW *win)
+{
+	int i;
+
+	wclear(win);
+	for (i = 0; i < (sizeof(help_info) / sizeof(help_info[0])); i++) {
+		wmove(win, i, max_x / 2 - 15);
+		waddstr(win, help_info[i]);
+	}
+	wrefresh(win);
+	getch(); /* display the help until the user hits a key */
+}
+
+void draw_main_menu(WINDOW *menu, int curopt)
+{
+	struct category *cat;
+	char buf[64];
+	int i = 0;
+
+	wclear(menu);
+
+	AST_LIST_TRAVERSE(&categories, cat, list) {
+		wmove(menu, i++, max_x / 2 - 10);
+		if (!strlen_zero(cat->displayname))
+			snprintf(buf, sizeof(buf), "%d.%s %s", i, i < 10 ? " " : "", cat->displayname);
+		else
+			snprintf(buf, sizeof(buf), "%d.%s %s", i, i < 10 ? " " : "", cat->name);
+		waddstr(menu, buf);
+	}
+
+	wmove(menu, curopt, (max_x / 2) - 15);
+	waddstr(menu, "--->");
+	wmove(menu, 0, 0);
+
+	wrefresh(menu);
+}
+
+void draw_category_menu(WINDOW *menu, struct category *cat, int start, int end, int curopt)
+{
+	int i = 0;
+	int j = 0;
+	struct member *mem;
+	char buf[64];
+
+	wclear(menu);
+
+	AST_LIST_TRAVERSE(&cat->members, mem, list) {
+		if (i < start) {
+			i++;
+			continue;
+		}
+		wmove(menu, j++, max_x / 2 - 10);
+		i++;
+		if (mem->depsfailed)
+			snprintf(buf, sizeof(buf), "XXX %d.%s %s", i, i < 10 ? " " : "", mem->name);
+		else
+			snprintf(buf, sizeof(buf), "[%s] %d.%s %s", mem->enabled ? "*" : " ", i, i < 10 ? " " : "", mem->name);
+		waddstr(menu, buf);
+		if (i == end)
+			break;
+	}
+
+	wmove(menu, curopt - start, max_x / 2 - 9);
+
+	wrefresh(menu);
+}
+
+int run_category_menu(WINDOW *menu, int cat_num)
+{
+	struct category *cat;
+	int i = 0;
+	int start = 0;
+	int end = max_y - TITLE_HEIGHT - 2;
+	int c;
+	int curopt = 0;
+	int maxopt;
+
+	AST_LIST_TRAVERSE(&categories, cat, list) {
+		if (i++ == cat_num)
+			break;
+	}
+	if (!cat)
+		return -1;
+
+	maxopt = count_members(cat) - 1;
+
+	draw_category_menu(menu, cat, start, end, curopt);
+
+	while ((c = getch())) {
+		switch (c) {
+		case KEY_UP:
+			if (curopt > 0) {
+				curopt--;
+				if (curopt < start) {
+					start--;
+					end--;
+				}
+			}
+			break;
+		case KEY_DOWN:
+			if (curopt < maxopt) {
+				curopt++;
+				if (curopt > end - 1) {
+					start++;
+					end++;
+				}
+			}
+			break;
+		case KEY_NPAGE:
+			/* XXX Move down the list by PAGE_OFFSET */
+			break;
+		case KEY_PPAGE:
+			/* XXX Move up the list by PAGE_OFFSET */
+			break;
+		case KEY_LEFT:
+			return 0;
+		case KEY_RIGHT:
+		case KEY_ENTER:
+		case '\n':
+		case ' ':
+			toggle_enabled(cat, curopt);
+			break;
+		case 'h':
+		case 'H':
+			show_help(menu);
+			break;
+		case KEY_F(7):
+			set_all(cat, 0);
+			break;
+		case KEY_F(8):
+			set_all(cat, 1);
+		default:
+			break;	
+		}
+		if (c == 'x' || c == 'q')
+			break;	
+		draw_category_menu(menu, cat, start, end, curopt);
+	}
+
+	wrefresh(menu);
+
+	return c;
+}
+
+void draw_title_window(WINDOW *title)
+{
+	wmove(title, 1, (max_x / 2) - (strlen(MENU_TITLE1) / 2));
+	waddstr(title, MENU_TITLE1);
+	wmove(title, 2, (max_x / 2) - (strlen(MENU_TITLE2) / 2));
+	waddstr(title, MENU_TITLE2);
+	wmove(title, 3, (max_x / 2) - (strlen(MENU_TITLE3) / 2));
+	waddstr(title, MENU_TITLE3);
+	wmove(title, 0, 0);
+	wrefresh(title);
+}
+
+
+
+int run_menu(void)
+{
+	WINDOW *title;
+	WINDOW *menu;
+	int maxopt;
+	int curopt = 0;
+	int c;
+	int res = 0;
+
+	initscr();
+	getmaxyx(stdscr, max_y, max_x);
+	signal(SIGWINCH, winch_handler); /* handle window resizing in xterm */
+
+	if (max_x < MIN_X - 1 || max_y < MIN_Y - 1) {
+		fprintf(stderr, "Terminal must be at least %d x %d.\n", MIN_X, MIN_Y);
+		endwin();
+		return -1;
+	}
+
+	cbreak(); /* don't buffer input until the enter key is pressed */
+	noecho(); /* don't echo user input to the screen */
+	keypad(stdscr, TRUE); /* allow the use of arrow keys */
+	clear();
+	refresh();
+
+	maxopt = count_categories() - 1;
+	
+	/* We have two windows - the title window at the top, and the menu window gets the rest */
+	title = newwin(TITLE_HEIGHT, max_x, 0, 0);
+	menu = newwin(max_y - TITLE_HEIGHT, max_x, TITLE_HEIGHT, 0);
+	draw_title_window(title);	
+	draw_main_menu(menu, curopt);
+	
+	while ((c = getch())) {
+		switch (c) {
+		case KEY_UP:
+			if (curopt > 0)
+				curopt--;
+			break;
+		case KEY_DOWN:
+			if (curopt < maxopt)
+				curopt++;
+			break;
+		case KEY_RIGHT:
+		case KEY_ENTER:
+		case '\n':
+		case ' ':
+			c = run_category_menu(menu, curopt);
+			break;
+		case 'h':
+		case 'H':
+			show_help(menu);
+		default:
+			break;	
+		}
+		if (c == 'q') {
+			res = -1;
+			break;
+		}
+		if (c == 'x')
+			break;	
+		draw_main_menu(menu, curopt);
+	}
+
+	endwin();
+
+	return res;
+}

Propchange: team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: team/group/autoconf_and_menuselect/build_tools/menuselect_curses.c
------------------------------------------------------------------------------
    svn:mime-type = text/plain



More information about the svn-commits mailing list