Changeset 690741 for src/UIElements


Ignore:
Timestamp:
Sep 19, 2013, 8:23:52 PM (12 years ago)
Author:
Frederik Heber <heber@…>
Branches:
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
Children:
a6ceab
Parents:
1d3563
git-author:
Frederik Heber <heber@…> (08/16/13 11:47:48)
git-committer:
Frederik Heber <heber@…> (09/19/13 20:23:52)
Message:

Added getListOfActions() and getActionsTrait() to completely wrap ActionRegistry.

Location:
src/UIElements
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • src/UIElements/CommandLineUI/CommandLineParser.cpp

    r1d3563 r690741  
    112112  std::set<std::string> AlreadyAddedOptionNames;
    113113
    114   ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry();
    115114  bool ActionAlreadyAdded_flag = false;
    116   for (ActionRegistry::const_iterator actioniter = AR.getBeginIter(); actioniter != AR.getEndIter(); ++actioniter) {
     115  ActionQueue &AQ = ActionQueue::getInstance();
     116  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     117  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     118      iter != tokens.end(); ++iter) {
     119    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
    117120    ActionAlreadyAdded_flag = false;
    118     Action* const currentAction = actioniter->second;
    119121    //std::cout << "Current Action to initialize is: " << actioniter->first << std::endl;
    120122
    121     for (ActionTrait::options_const_iterator optioniter = currentAction->Traits.getBeginIter();
    122         optioniter != currentAction->Traits.getEndIter();
     123    for (ActionTrait::options_const_iterator optioniter = CurrentTrait.getBeginIter();
     124        optioniter != CurrentTrait.getEndIter();
    123125        ++optioniter) {
    124       if (optioniter->first == actioniter->first)
     126      if (optioniter->first == *iter)
    125127        ActionAlreadyAdded_flag = true;
    126128      ASSERT( OptionRegistry::getInstance().isOptionPresentByName(optioniter->first),
     
    169171//      std::cout  << std::endl;
    170172
    171       ASSERT(CmdParserLookup.find(currentAction->Traits.getMenuName()) != CmdParserLookup.end(),
     173      ASSERT(CmdParserLookup.find(CurrentTrait.getMenuName()) != CmdParserLookup.end(),
    172174          "CommandLineParser: boost::program_options::options_description for this Action not present.");
    173       AddOptionToParser(dynamic_cast<const OptionTrait * const>(&(currentAction->Traits)),(CmdParserLookup[currentAction->Traits.getMenuName()]));
     175      AddOptionToParser(dynamic_cast<const OptionTrait * const>(&CurrentTrait),(CmdParserLookup[CurrentTrait.getMenuName()]));
    174176    }
    175177  }
     
    482484  std::map <std::string, std::string> result;
    483485
    484   ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry();
    485   for (ActionRegistry::const_iterator iter = AR.getBeginIter(); iter != AR.getEndIter(); ++iter)
    486     if ((iter->second)->Traits.hasShortForm()) {
    487       ASSERT(result.find((iter->second)->Traits.getShortForm()) == result.end(),
    488           "Short form "+toString((iter->second)->Traits.getShortForm())+
    489           " for action "+toString(iter->first)+" already present from "+
    490           std::string(result[(iter->second)->Traits.getShortForm()])+"!");
    491       result[(iter->second)->Traits.getShortForm()] = (iter->second)->getName();
     486  ActionQueue &AQ = ActionQueue::getInstance();
     487  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     488  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     489      iter != tokens.end(); ++iter) {
     490    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     491    if (CurrentTrait.hasShortForm()) {
     492      ASSERT(result.find(CurrentTrait.getShortForm()) == result.end(),
     493          "Short form "+toString(CurrentTrait.getShortForm())+
     494          " for action "+toString(*iter)+" already present from "+
     495          std::string(result[CurrentTrait.getShortForm()])+"!");
     496      result[CurrentTrait.getShortForm()] = *iter;
    492497    }
     498  }
    493499
    494500  return result;
  • src/UIElements/CommandLineUI/unittests/CommandLineParser_ActionRegistry_ConsistencyUnitTest.cpp

    r1d3563 r690741  
    6262void CommandLineParser_ActionRegistry_ConsistencyTest::setUp()
    6363{
    64   AR = &ActionQueue::getInstance().getActionRegistry();
    6564  CLP = CommandLineParser::getPointer();
    6665};
     
    9089
    9190  // go through all Actions and gather menu names
    92   for (ActionRegistry::const_iterator iter = AR->getBeginIter();
    93       iter != AR->getEndIter();
    94       ++iter) {
    95     const std::string &MenuName = (iter->second)->Traits.getMenuName();
     91  ActionQueue &AQ = ActionQueue::getInstance();
     92  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     93  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     94      iter != tokens.end(); ++iter) {
     95    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     96    const std::string &MenuName = CurrentTrait.getMenuName();
    9697    MenuNames_from_ActionRegistry.insert(MenuName);
    9798  }
     
    105106  }
    106107
    107 
    108108  for (std::set <std::string>::const_iterator ARiter = MenuNames_from_ActionRegistry.begin();
    109109      ARiter != MenuNames_from_ActionRegistry.end();
  • src/UIElements/CommandLineUI/unittests/CommandLineParser_ActionRegistry_ConsistencyUnitTest.hpp

    r1d3563 r690741  
    1919class CommandLineParser;
    2020
    21 namespace MoleCuilder {
    22   class ActionRegistry;
    23 }
    24 
    2521/********************************************** Test classes **************************************/
    2622
     
    3733
    3834private:
    39       MoleCuilder::ActionRegistry *AR;
    4035      CommandLineParser *CLP;
    4136};
  • src/UIElements/Menu/Menu.cpp

    r1d3563 r690741  
    122122{
    123123  // go through all actions and add those belonging to this menu
    124   ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry();
    125   for (ActionRegistry::const_iterator iter = AR.getBeginIter();
    126       iter != AR.getEndIter();
    127       ++iter) {
    128     const std::string &MenuName = iter->second->Traits.getMenuName();
     124  ActionQueue &AQ = ActionQueue::getInstance();
     125  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     126  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     127      iter != tokens.end(); ++iter) {
     128    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     129    const std::string &MenuName = CurrentTrait.getMenuName();
    129130    if (MenuName == name) {
    130       const std::string &ActionName = iter->first;
     131      const std::string &ActionName = *iter;
    131132      Menu::addAction(ActionName);
    132133    }
  • src/UIElements/Menu/MenuDescription.cpp

    r1d3563 r690741  
    158158//  std::multimap <std::string, std::string> result;
    159159//
    160 //  ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry()();
    161 //  for (ActionRegistry::const_iterator iter = AR.getBeginIter();iter != AR.getEndIter();++iter) {
    162 //    std::cout << "Inserting " << (iter->second)->getName() << " into menu " << (iter->second)->Traits.getMenuName() << std::endl;
    163 //    result.insert( std::pair<std::string, std::string> ((iter->second)->Traits.getMenuName(), (iter->second)->getName()));
     160//  ActionQueue &AQ = ActionQueue::getInstance();
     161//  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     162//  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     163//      iter != tokens.end(); ++iter) {
     164//    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     165//    std::cout << "Inserting " << *iter << " into menu " << CurrentTrait.getMenuName() << std::endl;
     166//    result.insert( std::pair<std::string, std::string> (CurrentTrait.getMenuName(), *iter));
    164167//  }
    165168//  // TODO: MenuPosition is not yet realized.
  • src/UIElements/Menu/unittests/MenuDescription_ActionRegistry_ConsistencyUnitTest.cpp

    r1d3563 r690741  
    6060void MenuDescription_ActionRegistry_ConsistencyTest::setUp()
    6161{
    62   AR = &ActionQueue::getInstance().getActionRegistry();
    63 };
     62}
    6463
    6564
     
    7271  World::purgeInstance();
    7372  WorldTime::purgeInstance();
    74 };
     73}
    7574
    7675/** UnitTest for consistency.
     
    8281
    8382  // go through all Actions and gather menu names
    84   for (ActionRegistry::const_iterator iter = AR->getBeginIter();
    85       iter != AR->getEndIter();
    86       ++iter) {
    87     const std::string &MenuName = (iter->second)->Traits.getMenuName();
     83  ActionQueue &AQ = ActionQueue::getInstance();
     84  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     85  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     86      iter != tokens.end(); ++iter) {
     87    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     88    const std::string &MenuName = CurrentTrait.getMenuName();
    8889    MenuNames_from_ActionRegistry.insert(MenuName);
    8990  }
  • src/UIElements/Menu/unittests/MenuDescription_ActionRegistry_ConsistencyUnitTest.hpp

    r1d3563 r690741  
    1919#include "UIElements/Menu/MenuDescription.hpp"
    2020
    21 namespace MoleCuilder {
    22   class ActionRegistry;
    23 }
    24 
    2521/********************************************** Test classes **************************************/
    2622
     
    3834private:
    3935      MenuDescription md;
    40       MoleCuilder::ActionRegistry *AR;
    4136};
    4237
Note: See TracChangeset for help on using the changeset viewer.