mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 22:18:07 +00:00 
			
		
		
		
	The "deprecated_in" and "removed_in" information can now be set in MODULEINFO for a module and is then displayed in menuselect so users can be aware of when a module is slated to be deprecated and then removed. ASTERISK-29337 Change-Id: I6952889cf08e0e9e99cf8b43f99b3cef4688087a
		
			
				
	
	
		
			185 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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;
 | |
| 	/*! if this package should be autoselected */
 | |
| 	unsigned char autoselect:1;
 | |
| 	/*! for linking */
 | |
| 	AST_LIST_ENTRY(reference) list;
 | |
| };
 | |
| 
 | |
| enum failure_types {
 | |
| 	NO_FAILURE = 0,
 | |
| 	SOFT_FAILURE = 1,
 | |
| 	HARD_FAILURE = 2,
 | |
| };
 | |
| 
 | |
| AST_LIST_HEAD_NOLOCK(reference_list, reference);
 | |
| 
 | |
| 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;
 | |
| 	const char *deprecated_in;
 | |
| 	const char *removed_in;
 | |
| 	/*! member_data is just an opaque, member-specific string */
 | |
| 	const char *member_data;
 | |
| 	/*! 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;
 | |
| 	/*! Previous failed dependencies when calculating */
 | |
| 	unsigned int depsfailedold: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 */
 | |
| 	struct reference_list deps;
 | |
| 	/*! conflicts of this module */
 | |
| 	struct reference_list conflicts;
 | |
| 	/*! optional packages used by this module */
 | |
| 	struct reference_list 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_EXTERNAL = 4,
 | |
| 	SUPPORT_OPTION = 5,
 | |
| 	SUPPORT_COUNT = 6, /* Keep this item at the end of the list. Tracks total number of support levels. */
 | |
| };
 | |
| 
 | |
| AST_LIST_HEAD_NOLOCK(support_level_bucket, member);
 | |
| 
 | |
| struct category {
 | |
| 	/*! Workspace for building support levels */
 | |
| 	struct support_level_bucket buckets[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'));
 | |
| }
 | |
| 
 | |
| #if !defined(ast_strdupa) && defined(__GNUC__)
 | |
| #define ast_strdupa(s)                                                    \
 | |
| 	(__extension__                                                    \
 | |
| 	({                                                                \
 | |
| 		const char *__old = (s);                                  \
 | |
| 		size_t __len = strlen(__old) + 1;                         \
 | |
| 		char *__new = __builtin_alloca(__len);                    \
 | |
| 		memcpy (__new, __old, __len);                             \
 | |
| 		__new;                                                    \
 | |
| 	}))
 | |
| #endif
 | |
| 
 | |
| #endif /* MENUSELECT_H */
 |