source: src/UIElements/Menu/Menu.hpp@ 311da7b

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 311da7b was 56f73b, checked in by Frederik Heber <heber@…>, 14 years ago

Added config.h also to all header files, code check test ascertain this in the future.

  • as we want to use config.h to pass stuff such as MEMDEBUG, NDEBUG, LOG_OBSERVER, we have to make sure that it is present in each and every file.
  • split up CodeChecks/testsuite.at: each test has its own .at file.
  • Property mode set to 100644
File size: 2.7 KB
RevLine 
[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]54class Menu : virtual public MenuInterface
[65b6e0]55{
56public:
[b59da6]57 explicit Menu(const std::string &name);
[65b6e0]58 virtual ~Menu();
59
[b59da6]60 void init();
[ef81b0]61
[b59da6]62protected:
63 // Unique name of the menu for identification.
64 const std::string name;
65
66 // populater function that adds all menu items
67 void populate();
68 void populateActions();
[65b6e0]69
70private:
[b59da6]71 void addAction(const std::string &ActionName);
72 void addSeparator();
73 void addSubmenu(const std::string &MenuName, const int MenuPosition);
74 bool isPresent(const std::string &token);
75
76 enum ItemType {ActionItem, MenuItem, SeparatorItem, NoItem};
77
78 int TopPosition; // current position to add
79 enum ItemType LastItem; // check whether separator followed separator
80 std::set <std::string> DuplicatesList; // is used to check for duplicates
[65b6e0]81};
82
[56f73b]83#endif /* MENU_HPP_ */
Note: See TracBrowser for help on using the repository browser.