[65b6e0] | 1 | /*
|
---|
[56f73b] | 2 | * Menu.hpp
|
---|
[65b6e0] | 3 | *
|
---|
| 4 | * Created on: Dec 10, 2009
|
---|
| 5 | * Author: crueger
|
---|
| 6 | */
|
---|
| 7 |
|
---|
[56f73b] | 8 | #ifndef MENU_MENU_HPP_
|
---|
| 9 | #define MENU_MENU_HPP_
|
---|
| 10 |
|
---|
| 11 | // include config.h
|
---|
| 12 | #ifdef HAVE_CONFIG_H
|
---|
| 13 | #include <config.h>
|
---|
| 14 | #endif
|
---|
[65b6e0] | 15 |
|
---|
[b59da6] | 16 | #include <set>
|
---|
| 17 | #include <string>
|
---|
[65b6e0] | 18 |
|
---|
[b59da6] | 19 | #include "Menu/MenuInterface.hpp"
|
---|
| 20 | #include "Menu/MenuDescription.hpp"
|
---|
[65b6e0] | 21 |
|
---|
[b59da6] | 22 | /** Base class for all Types of menus.
|
---|
| 23 | * Here, we simply initialize the menus. Via the MenuInterface wrapper we may
|
---|
| 24 | * access the adding of items for each specific menu in a uniform manner.
|
---|
[ef81b0] | 25 | *
|
---|
[b59da6] | 26 | * Note that this Class is never to be used directly but only via derived
|
---|
| 27 | * specializations.
|
---|
[8f3f40] | 28 | *
|
---|
| 29 | * Note that we do not call member function init() directly in the constructor
|
---|
| 30 | * to allow for something to be add to the menu beforehand which is necessary
|
---|
| 31 | * for the TextMenu for example.
|
---|
| 32 | *
|
---|
| 33 | * <h1>Howto</h1>
|
---|
| 34 | *
|
---|
| 35 | * First, derive your own menu class, see QtMenu or TextMenu for example. These
|
---|
| 36 | * have been templated because of the two Qt classes QMenu and QMenuBar to be
|
---|
| 37 | * addressable in a unified manner. TextMenu does not actually need to be a
|
---|
| 38 | * template but it does not hurt either.
|
---|
| 39 | *
|
---|
| 40 | * Basically, the structure is as follows:
|
---|
| 41 | * -# Menu implements the initialization: it goes through MenuDescription's and
|
---|
| 42 | * ActionRegistry's contents and adds MenuItem's and Action's as requested.
|
---|
| 43 | * -# It does so by calling virtual functions defined in MenuInterface. These
|
---|
| 44 | * allow for adding of specific type of items: separators, Actions, menus
|
---|
| 45 | * -# Your derived Menu implements add these specific adders, basically just as
|
---|
| 46 | * wrappers. If you really have another UI type, implement its Menu
|
---|
| 47 | * functionality separately, such as TxMenu does.
|
---|
| 48 | * -# It also inherits both Menu and virtually MenuInterface such that it
|
---|
| 49 | * contains initializing and adding functionality
|
---|
| 50 | *
|
---|
| 51 | * Note that MenuInterface is inherited by both Menu and your class and hence has
|
---|
| 52 | * to be declared as a "virtual" base class for both.
|
---|
[ef81b0] | 53 | */
|
---|
[b59da6] | 54 | class Menu : virtual public MenuInterface
|
---|
[65b6e0] | 55 | {
|
---|
| 56 | public:
|
---|
[b59da6] | 57 | explicit Menu(const std::string &name);
|
---|
[65b6e0] | 58 | virtual ~Menu();
|
---|
| 59 |
|
---|
[b59da6] | 60 | void init();
|
---|
[ef81b0] | 61 |
|
---|
[b59da6] | 62 | protected:
|
---|
[163110] | 63 | //!> Unique name of the menu for identification.
|
---|
[b59da6] | 64 | const std::string name;
|
---|
| 65 |
|
---|
[163110] | 66 | /** populater function that adds all menu items.
|
---|
| 67 | *
|
---|
| 68 | */
|
---|
[b59da6] | 69 | void populate();
|
---|
[163110] | 70 |
|
---|
| 71 | /** Populater function for all Actions in this menu.
|
---|
| 72 | *
|
---|
| 73 | */
|
---|
[b59da6] | 74 | void populateActions();
|
---|
[65b6e0] | 75 |
|
---|
| 76 | private:
|
---|
[163110] | 77 | /** Adds an action to this menu.
|
---|
| 78 | *
|
---|
| 79 | * @param ActionName name of action
|
---|
| 80 | * @param ActionDescription of the action (e.g. for tooltips)
|
---|
| 81 | */
|
---|
| 82 | void addAction(const std::string &ActionName, const std::string &ActionDescription);
|
---|
| 83 |
|
---|
| 84 | /** Adds a separator (e.g. horizontal line) to menu.
|
---|
| 85 | *
|
---|
| 86 | */
|
---|
[b59da6] | 87 | void addSeparator();
|
---|
[163110] | 88 |
|
---|
| 89 | /** Adds a submenu to this menu.
|
---|
| 90 | *
|
---|
| 91 | * @param MenuName name of submenu
|
---|
| 92 | * @param MenuPosition position in sequence of items of submenu
|
---|
| 93 | */
|
---|
[b59da6] | 94 | void addSubmenu(const std::string &MenuName, const int MenuPosition);
|
---|
[163110] | 95 |
|
---|
| 96 | /** Checks whether an item named \a token exists in this menu.
|
---|
| 97 | *
|
---|
| 98 | * @param token name of action of submenu
|
---|
| 99 | * @return true - item exists, false - item does not exist in this menu
|
---|
| 100 | */
|
---|
[b59da6] | 101 | bool isPresent(const std::string &token);
|
---|
| 102 |
|
---|
[163110] | 103 | //!> enumeration of all valid item types
|
---|
[b59da6] | 104 | enum ItemType {ActionItem, MenuItem, SeparatorItem, NoItem};
|
---|
| 105 |
|
---|
[163110] | 106 | //!> current position to add
|
---|
| 107 | int TopPosition;
|
---|
| 108 | //!> check whether separator followed separator
|
---|
| 109 | enum ItemType LastItem;
|
---|
| 110 | //!> is used to check for duplicates
|
---|
| 111 | std::set <std::string> DuplicatesList;
|
---|
[65b6e0] | 112 | };
|
---|
| 113 |
|
---|
[56f73b] | 114 | #endif /* MENU_HPP_ */
|
---|