Changeset 690741 for src/Actions


Ignore:
Timestamp:
Sep 19, 2013, 8:23:52 PM (11 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/Actions
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/ActionQueue.cpp

    r1d3563 r690741  
    3737#include "Actions/ActionQueue.hpp"
    3838
     39#include "CodePatterns/Assert.hpp"
     40#include "CodePatterns/IteratorAdaptors.hpp"
    3941#include "CodePatterns/Singleton_impl.hpp"
     42
     43#include <vector>
    4044
    4145using namespace MoleCuilder;
     
    6266}
    6367
     68const ActionTrait& ActionQueue::getActionsTrait(const std::string name) const
     69{
     70  // this const_cast is just required as long as we have a non-const getActionByName
     71  const Action * const action = const_cast<ActionQueue *>(this)->getActionByName(name);
     72  return action->Traits;
     73}
     74
     75const ActionQueue::ActionTokens_t ActionQueue::getListOfActions() const
     76{
     77  ActionTokens_t returnlist;
     78
     79  returnlist.insert(
     80      returnlist.end(),
     81      MapKeyConstIterator<ActionRegistry::const_iterator>(AR.getBeginIter()),
     82      MapKeyConstIterator<ActionRegistry::const_iterator>(AR.getEndIter()));
     83
     84  return returnlist;
     85}
     86
    6487CONSTRUCT_SINGLETON(ActionQueue)
  • src/Actions/ActionQueue.hpp

    r1d3563 r690741  
    1717
    1818#include <list>
     19#include <vector>
    1920
    2021#include "Actions/ActionRegistry.hpp"
     
    3334  friend class Singleton<ActionQueue>;
    3435public:
     36  typedef std::vector<std::string> ActionTokens_t;
    3537  typedef std::list<Action *> ActionQueue_t;
    3638
     
    5759  int getLastPosition(const std::string &MenuName) const;
    5860
     61  /** Returns the vector with the tokens of all currently known Actions.
     62   *
     63   * \return list of all tokens
     64   */
     65  const ActionTokens_t getListOfActions() const;
     66
     67  /** Returns the trait to an Action.
     68   *
     69   * \param name name of Action
     70   * \return const ref to its default Trait.
     71   */
     72  const ActionTrait& getActionsTrait(const std::string name) const;
     73
    5974  /** Getter function for the ActionRegistry for transitional purpose.
    6075   *
     
    6479    return AR;
    6580  }
    66 
    6781
    6882private:
  • src/Actions/CommandAction/HelpAction.cpp

    r1d3563 r690741  
    7979  // print list of actions or its options
    8080  ActionQueue &AQ = ActionQueue::getInstance();
    81   ActionRegistry &AR = AQ.getActionRegistry();
     81  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
    8282  if (params.actionname.get() == std::string("none")) {
    8383    // print list of all Actions
    8484    std::cout << "Here is a list of all available Actions:" << std::endl;
    85     for(ActionRegistry::const_iterator iter = AR.getBeginIter();
    86         iter != AR.getEndIter();
     85    for(ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     86        iter != tokens.end();
    8787        ++iter) {
    88       const Action *instance = iter->second;
    89       std::cout << "'" << iter->first << "': \t "
    90           << instance->Traits.getDescription() << std::endl;
     88      std::cout << "'" << *iter << "': \t "
     89          << AQ.getActionsTrait(*iter).getDescription() << std::endl;
    9190    }
    9291  } else {
  • src/Actions/OptionRegistry.cpp

    r1d3563 r690741  
    7171//void OptionRegistry::Init()
    7272//{
    73 //  ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry();
    74 //  for (ActionRegistry::const_iterator actioniter = AR.getBeginIter();
    75 //      actioniter != AR.getEndIter();
     73//  ActionQueue &AQ = ActionQueue::getInstance();
     74//  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     75//  for (ActionQueue::ActionTokens_t::const_iterator actioniter = tokens.begin();
     76//      actioniter != tokens.end();
    7677//      ++actioniter) {
    77 //    Action* const currentAction = actioniter->second;
    78 //    for (ActionTrait::options_const_iterator optioniter = currentAction->Traits.getBeginIter();
    79 //        optioniter != currentAction->Traits.getEndIter();
     78//    const ActionTrait& currentTrait = AQ.getActionsTrait(*actioniter);
     79//    for (ActionTrait::options_const_iterator optioniter = currentTrait.getBeginIter();
     80//        optioniter != currentTrait.getEndIter();
    8081//        ++optioniter) {
    8182//      // wrap option in a shared_ptr to have it exist till and automatically removed at end of code
    8283//      std::string const &OptionName = optioniter->first;
    83 //      std::type_info const &typeDesired = *((actioniter->second)->Traits.getOptionType(OptionName));
     84//      std::type_info const &typeDesired = *(currentTrait.getOptionType(OptionName));
    8485//      if (isOptionPresentByName(OptionName)) {
    8586//        std::type_info const &typePresent = *(getOptionByName(OptionName)->getType());
     
    9899void OptionRegistry::ConsistencyCheck()
    99100{
    100   ActionRegistry &AR = ActionQueue::getInstance().getActionRegistry();
    101   for (ActionRegistry::const_iterator actioniter = AR.getBeginIter();
    102       actioniter != AR.getEndIter();
     101  ActionQueue &AQ = ActionQueue::getInstance();
     102  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     103  for (ActionQueue::ActionTokens_t::const_iterator actioniter = tokens.begin();
     104      actioniter != tokens.end();
    103105      ++actioniter) {
    104     for (ActionTrait::options_const_iterator optioniter = (actioniter->second)->Traits.getBeginIter();
    105         optioniter != (actioniter->second)->Traits.getEndIter();
     106    const ActionTrait& currentTrait = AQ.getActionsTrait(*actioniter);
     107    for (ActionTrait::options_const_iterator optioniter = currentTrait.getBeginIter();
     108        optioniter != currentTrait.getEndIter();
    106109        ++optioniter) {
    107110#ifndef NDEBUG
    108111      std::string const &OptionName = optioniter->first;
    109       std::type_info const &typeDesired = *((actioniter->second)->Traits.getOption(OptionName).getType());
     112      std::type_info const &typeDesired = *(currentTrait.getOption(OptionName).getType());
    110113      std::type_info const &typePresent = *(getOptionByName(OptionName)->getType());
    111114#endif
  • src/Actions/unittests/ActionRegistryUnitTest.cpp

    r1d3563 r690741  
    6161void ActionRegistryTest::setUp()
    6262{
    63   AR = &ActionQueue::getInstance().getActionRegistry();
    6463};
    6564
     
    7473  std::map <std::string, std::string> result;
    7574
    76   for (ActionRegistry::const_iterator iter = AR->getBeginIter(); iter != AR->getEndIter(); ++iter) {
    77     if ((iter->second)->Traits.hasShortForm()) {
    78       ASSERT(result.find((iter->second)->Traits.getShortForm()) == result.end(),
    79           "Short form "+toString((iter->second)->Traits.getShortForm())+
    80           " for action "+toString(iter->first)+" already present from "+
    81           std::string(result[(iter->second)->Traits.getShortForm()])+"!");
    82       result[(iter->second)->Traits.getShortForm()] = (iter->second)->getName();
     75  ActionQueue &AQ = ActionQueue::getInstance();
     76  ActionQueue::ActionTokens_t tokens = AQ.getListOfActions();
     77  for (ActionQueue::ActionTokens_t::const_iterator iter = tokens.begin();
     78      iter != tokens.end(); ++iter) {
     79    const ActionTrait &CurrentTrait = AQ.getActionsTrait(*iter);
     80    if (CurrentTrait.hasShortForm()) {
     81      ASSERT(result.find(CurrentTrait.getShortForm()) == result.end(),
     82          "Short form "+toString(CurrentTrait.getShortForm())+
     83          " for action "+toString(*iter)+" already present from "+
     84          std::string(result[CurrentTrait.getShortForm()])+"!");
     85      result[CurrentTrait.getShortForm()] = *iter;
    8386    }
    8487  }
  • src/Actions/unittests/ActionRegistryUnitTest.hpp

    r1d3563 r690741  
    1717#include <cppunit/extensions/HelperMacros.h>
    1818
    19 namespace MoleCuilder {
    20 class ActionRegistry;
    21 };
    22 
    2319/********************************************** Test classes **************************************/
    2420
     
    3329      void tearDown();
    3430      void CheckDoublyUsedShortforms();
    35 
    36 private:
    37       MoleCuilder::ActionRegistry *AR;
    3831};
    3932
Note: See TracChangeset for help on using the changeset viewer.