Changeset 975b83 for src/Actions


Ignore:
Timestamp:
May 20, 2014, 9:11:52 AM (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:
415ddd
Parents:
cc6e5c
git-author:
Frederik Heber <heber@…> (02/20/14 20:23:42)
git-committer:
Frederik Heber <heber@…> (05/20/14 09:11:52)
Message:

Added ActionQueue::insertAction().

  • this is preparatory for allowing Actions to be executed inside an Action's performCall() body. Once ActionQueue::run() is executed in its own thread these command calls would just append an Action to the queue and not run the command.
Location:
src/Actions
Files:
10 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/Action.cpp

    rcc6e5c r975b83  
    168168}
    169169
     170void Action::insertAction(Action *_action, enum Action::QueryOptions state)
     171{
     172  ActionQueue::getInstance().insertAction(_action, state);
     173}
    170174
    171175bool Action::isActive(){
  • src/Actions/Action.hpp

    rcc6e5c r975b83  
    261261  virtual void endTimer() const {};
    262262
     263  /** Function pass-through for ActionQueue::insertAction().
     264   *
     265   * This pass-through is present to allow each derived Action access to private
     266   * ActionQueue::insertAction() which is not possible otherwise as friendship
     267   * is not inherited.
     268   *
     269   */
     270  static void insertAction(Action *_action, enum Action::QueryOptions state);
     271
    263272private:
    264273
  • src/Actions/ActionQueue.cpp

    rcc6e5c r975b83  
    8787    World::getInstance().setExitFlag(5);
    8888  }
     89}
     90
     91void ActionQueue::insertAction(Action *_action, enum Action::QueryOptions state)
     92{
     93  queueAction(_action, state);
    8994}
    9095
  • src/Actions/ActionQueue.hpp

    rcc6e5c r975b83  
    140140  void clear();
    141141
     142  /** Insert an action after CurrentAction.
     143   *
     144   * This is implemented only to allow action's COMMAND to work. If we
     145   * were to use queueAction, actions would come after all other already
     146   * present actions.
     147   */
     148  void insertAction(Action *_action, enum Action::QueryOptions state);
     149
    142150private:
    143151  /** Private cstor for ActionQueue.
  • src/Actions/Action_impl_header.hpp

    rcc6e5c r975b83  
    144144  ASSERT(tester.second, "ActionTrait<ACTION>::ActionTrait<ACTION>() option token present twice!");
    145145
     146#define stringtype std::string
     147
     148#define type2string(s, data, elem) \
     149  stringtype
     150
    146151namespace MoleCuilder {
    147152
     
    149154#if defined paramtypes && defined paramreferences
    150155#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
     156#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     157#include BOOST_PP_LOCAL_ITERATE()
     158#endif
     159    );
     160
     161void BOOST_PP_CAT( COMMAND, _stringargs)(
     162#if defined paramtypes && defined paramreferences && BOOST_PP_NOT_EQUAL(MAXPARAMTYPES,0)
     163#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, BOOST_PP_SEQ_TRANSFORM( type2string, , paramtypes), paramreferences)
    151164#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
    152165#include BOOST_PP_LOCAL_ITERATE()
     
    199212class ACTION : public Action {
    200213#endif
    201   #if defined paramtypes && defined paramreferences
    202214  friend void COMMAND(
    203   #define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
    204   #define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
    205   #include BOOST_PP_LOCAL_ITERATE()
     215#if defined paramtypes && defined paramreferences
     216#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
     217#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     218#include BOOST_PP_LOCAL_ITERATE()
     219#endif
    206220      );
    207   # else
    208   void COMMAND();
    209   #endif
     221
     222  friend void BOOST_PP_CAT( COMMAND, _stringargs)(
     223#if defined paramtypes && defined paramreferences && BOOST_PP_NOT_EQUAL(MAXPARAMTYPES,0)
     224#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, BOOST_PP_SEQ_TRANSFORM( type2string, , paramtypes), paramreferences)
     225#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     226#include BOOST_PP_LOCAL_ITERATE()
     227#endif
     228      );
    210229
    211230public:
  • src/Actions/Action_impl_pre.hpp

    rcc6e5c r975b83  
    376376#include BOOST_PP_LOCAL_ITERATE()
    377377#endif
    378   ActionQueue::getInstance().queueAction( ToCall, Action::NonInteractive);
     378  Action::insertAction( ToCall, Action::NonInteractive);
    379379};
    380380
     
    393393#include BOOST_PP_LOCAL_ITERATE()
    394394#endif
    395   ActionQueue::getInstance().queueAction( ToCall, Action::NonInteractive);
     395  Action::insertAction( ToCall, Action::NonInteractive);
    396396};
    397397
  • src/Actions/GlobalListOfActions.hpp

    rcc6e5c r975b83  
    1515
    1616#include <boost/preprocessor/seq/push_back.hpp>
     17#include <boost/preprocessor/seq/remove.hpp>
    1718
    1819// this is global list of actions valid for all cases
     
    166167
    167168// define final list
    168 
    169169#ifdef HAVE_PYTHON
    170170#define GLOBALLISTOFACTIONS_PYTHON \
  • src/Actions/Makefile.am

    rcc6e5c r975b83  
    663663        echo "#define ALLACTIONPYTHON_HPP_" >>$@; \
    664664        for file in $(ACTIONPROTOTYPESHEADER); do \
    665                 echo "#include \"`echo $$file | sed -e 's/hpp/def/'`\"" >>$@; \
    666                 echo "#include \"Actions/Action_impl_python.hpp\"" >>$@; \
    667                 echo "#include \"Actions/Action_impl_undef.hpp\"" >>$@; \
     665                if test "$$file" != "Actions/CommandAction/LoadSessionAction.hpp"; then \
     666                        echo "#include \"`echo $$file | sed -e 's/hpp/def/'`\"" >>$@; \
     667                        echo "#include \"Actions/Action_impl_python.hpp\"" >>$@; \
     668                        echo "#include \"Actions/Action_impl_undef.hpp\"" >>$@; \
     669                fi; \
    668670        done; \
    669671        echo "#endif /* ALLACTIONPYTHON_HPP_ */" >>$@;
  • src/Actions/MakroAction_impl_header.hpp

    rcc6e5c r975b83  
    145145  ASSERT(tester.second, "ActionTrait<ACTION>::ActionTrait<ACTION>() option token present twice!");
    146146
     147#define stringtype std::string
     148
     149#define type2string(s, data, elem) \
     150  stringtype
     151
    147152namespace MoleCuilder {
    148153
     
    150155#if defined paramtypes && defined paramreferences
    151156#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
     157#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     158#include BOOST_PP_LOCAL_ITERATE()
     159#endif
     160    );
     161
     162void BOOST_PP_CAT( COMMAND, _stringargs)(
     163#if defined paramtypes && defined paramreferences && BOOST_PP_NOT_EQUAL(MAXPARAMTYPES,0)
     164#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, BOOST_PP_SEQ_TRANSFORM( type2string, , paramtypes), paramreferences)
    152165#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
    153166#include BOOST_PP_LOCAL_ITERATE()
     
    196209
    197210class ACTION : public MakroAction {
    198   #if defined paramtypes && defined paramreferences
    199211  friend void COMMAND(
    200   #define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
    201   #define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
    202   #include BOOST_PP_LOCAL_ITERATE()
     212#if defined paramtypes && defined paramreferences
     213#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, paramtypes, paramreferences)
     214#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     215#include BOOST_PP_LOCAL_ITERATE()
     216#endif
    203217      );
    204   # else
    205   void COMMAND();
    206   #endif
     218
     219  friend void BOOST_PP_CAT( COMMAND, _stringargs)(
     220#if defined paramtypes && defined paramreferences && BOOST_PP_NOT_EQUAL(MAXPARAMTYPES,0)
     221#define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, BOOST_PP_SEQ_TRANSFORM( type2string, , paramtypes), paramreferences)
     222#define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1)
     223#include BOOST_PP_LOCAL_ITERATE()
     224#endif
     225      );
    207226
    208227public:
  • src/Actions/MakroAction_impl_pre.hpp

    rcc6e5c r975b83  
    371371#include BOOST_PP_LOCAL_ITERATE()
    372372#endif
    373   ActionQueue::getInstance().queueAction( ToCall, Action::NonInteractive);
     373  Action::insertAction( ToCall, Action::NonInteractive);
    374374};
    375375
     
    388388#include BOOST_PP_LOCAL_ITERATE()
    389389#endif
    390   ActionQueue::getInstance().queueAction( ToCall, Action::NonInteractive);
     390  Action::insertAction( ToCall, Action::NonInteractive);
    391391};
    392392
Note: See TracChangeset for help on using the changeset viewer.