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.

File:
1 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;
Note: See TracChangeset for help on using the changeset viewer.