summaryrefslogtreecommitdiff
path: root/menuselect/menuselect.h
diff options
context:
space:
mode:
Diffstat (limited to 'menuselect/menuselect.h')
-rw-r--r--menuselect/menuselect.h157
1 files changed, 157 insertions, 0 deletions
diff --git a/menuselect/menuselect.h b/menuselect/menuselect.h
new file mode 100644
index 000000000..12a36664c
--- /dev/null
+++ b/menuselect/menuselect.h
@@ -0,0 +1,157 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2005-2006, Russell Bryant
+ *
+ * Russell Bryant <russell@digium.com>
+ *
+ * See http://www.asterisk.org for more information about
+ * the Asterisk project. Please do not directly contact
+ * any of the maintainers of this project for assistance;
+ * the project provides a web site, mailing lists and IRC
+ * channels for your use.
+ *
+ * This program is free software, distributed under the terms of
+ * the GNU General Public License Version 2. See the LICENSE file
+ * at the top of the source tree.
+ */
+
+/*!
+ * \file
+ *
+ * \brief public data structures and defaults for menuselect
+ *
+ */
+
+#ifndef MENUSELECT_H
+#define MENUSELECT_H
+
+#include "linkedlists.h"
+
+#define OUTPUT_MAKEOPTS_DEFAULT "menuselect.makeopts"
+#define OUTPUT_MAKEDEPS_DEFAULT "menuselect.makedeps"
+#define MENUSELECT_DEPS "build_tools/menuselect-deps"
+
+struct member;
+
+struct reference {
+ /*! the name of the dependency */
+ const char *name;
+ /*! the display name of the dependency */
+ const char *displayname;
+ /*! if this dependency is a member, not an external object */
+ struct member *member;
+ /*! if this package was found */
+ unsigned char met:1;
+ /*! for linking */
+ AST_LIST_ENTRY(reference) list;
+};
+
+enum failure_types {
+ NO_FAILURE = 0,
+ SOFT_FAILURE = 1,
+ HARD_FAILURE = 2,
+};
+
+struct member {
+ /*! What will be sent to the makeopts file */
+ const char *name;
+ /*! Display name if known */
+ const char *displayname;
+ /*! Default setting */
+ const char *defaultenabled;
+ /*! Delete these file(s) if this member changes */
+ const char *remove_on_change;
+ /*! Touch these file(s) if this member changes */
+ const char *touch_on_change;
+ const char *support_level;
+ const char *replacement;
+ /*! This module is currently selected */
+ unsigned int enabled:1;
+ /*! This module was enabled when the config was loaded */
+ unsigned int was_enabled:1;
+ /*! This module has failed dependencies */
+ unsigned int depsfailed:2;
+ /*! This module has failed conflicts */
+ unsigned int conflictsfailed:2;
+ /*! This module's 'enabled' flag was changed by a default only */
+ unsigned int was_defaulted:1;
+ /*! This module is a dependency, and if it is selected then
+ we have included it in the MENUSELECT_BUILD_DEPS line
+ in the output file */
+ unsigned int build_deps_output:1;
+ /*! This module should never be enabled automatically, but only
+ * when explicitly set. */
+ unsigned int explicitly_enabled_only:1;
+ /*! This isn't actually a module! It's a separator, and it should
+ * be passed over for many of the usual purposes associated with members. */
+ unsigned int is_separator:1;
+ /*! dependencies of this module */
+ AST_LIST_HEAD_NOLOCK(, reference) deps;
+ /*! conflicts of this module */
+ AST_LIST_HEAD_NOLOCK(, reference) conflicts;
+ /*! optional packages used by this module */
+ AST_LIST_HEAD_NOLOCK(, reference) uses;
+ /*! for making a list of modules */
+ AST_LIST_ENTRY(member) list;
+};
+
+enum support_level_values {
+ SUPPORT_CORE = 0,
+ SUPPORT_EXTENDED = 1,
+ SUPPORT_DEPRECATED = 2,
+ SUPPORT_UNSPECIFIED = 3,
+ SUPPORT_COUNT = 4, /* Keep this item at the end of the list. Tracks total number of support levels. */
+};
+
+struct category {
+ struct member *separators[SUPPORT_COUNT];
+ /*! the Makefile variable */
+ const char *name;
+ /*! the name displayed in the menu */
+ const char *displayname;
+ /*! Delete these file(s) if anything in this category changes */
+ const char *remove_on_change;
+ /*! Touch these file(s) if anything in this category changes */
+ const char *touch_on_change;
+ /*! Output what is selected, as opposed to not selected */
+ unsigned int positive_output:1;
+ /*! All choices in this category are mutually exclusive */
+ unsigned int exclusive:1;
+ /*! 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;
+
+extern const char *menu_name;
+
+/*! This is implemented by the frontend */
+int run_menu(void);
+
+int count_categories(void);
+
+int count_members(struct category *cat);
+
+/*! \brief Toggle a member of a category at the specified index to enabled/disabled */
+void toggle_enabled_index(struct category *cat, int index);
+
+void toggle_enabled(struct member *mem);
+
+/*! \brief Set a member of a category at the specified index to enabled */
+void set_enabled(struct category *cat, int index);
+/*! \brief Set a member of a category at the specified index to not enabled */
+void clear_enabled(struct category *cat, int index);
+
+/*! \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);
+
+/*! \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 */