Changeset 6367dd for src/Actions
- Timestamp:
- Sep 19, 2013, 8:23:52 PM (12 years ago)
- 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:
- d649b7
- Parents:
- b5b01e
- git-author:
- Frederik Heber <heber@…> (08/19/13 16:17:07)
- git-committer:
- Frederik Heber <heber@…> (09/19/13 20:23:52)
- Location:
- src/Actions
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/Action.cpp
rb5b01e r6367dd 41 41 #include "Actions/Action.hpp" 42 42 #include "Actions/ActionExceptions.hpp" 43 #include "Actions/Action History.hpp"43 #include "Actions/ActionQueue.hpp" 44 44 #include "Actions/ActionRegistry.hpp" 45 45 #include "Actions/OptionRegistry.hpp" … … 205 205 if(shouldUndo() && state != failure){ 206 206 if(canUndo()){ 207 Action History::getInstance().addElement(this,state);207 ActionQueue::getInstance().addElement(this,state); 208 208 } 209 209 else{ 210 Action History::getInstance().clear();210 ActionQueue::getInstance().clear(); 211 211 } 212 212 } -
src/Actions/ActionHistory.cpp
rb5b01e r6367dd 41 41 #include <iostream> 42 42 43 #include "CodePatterns/Singleton_impl.hpp"44 43 #include "CodePatterns/Assert.hpp" 45 44 … … 102 101 } 103 102 104 void ActionHistory::init(){ 105 ActionHistory *hist = new ActionHistory(); 106 setInstance(hist); 107 } 108 109 CONSTRUCT_SINGLETON(ActionHistory) 103 //void ActionHistory::init(){ 104 // ActionHistory *hist = new ActionHistory(); 105 // setInstance(hist); 106 //} 110 107 111 108 /****************** Contained actions *******************/ -
src/Actions/ActionHistory.hpp
rb5b01e r6367dd 14 14 #endif 15 15 16 17 #include "CodePatterns/Singleton.hpp"18 19 16 #include <deque> 20 17 … … 25 22 namespace MoleCuilder { 26 23 27 class ActionHistory : public Singleton<ActionHistory,false>24 class ActionHistory 28 25 { 29 friend class Singleton<ActionHistory,false>;30 31 26 struct HistoryElement { 32 27 HistoryElement(Action *_action, ActionState::ptr _state) : … … 39 34 40 35 public: 36 ActionHistory(); 37 ~ActionHistory(); 41 38 42 39 void undoLast(); … … 48 45 void addElement(Action*,ActionState::ptr); 49 46 void clear(); 50 protected: 51 ActionHistory(); 52 virtual ~ActionHistory(); 47 53 48 private: 54 49 std::deque<HistoryElement> history; … … 60 55 // inside a static initialization, so we have this init function that 61 56 // needs to be called at a non-static point at the start of the program 62 static void init();57 // static void init(); 63 58 }; 64 59 -
src/Actions/ActionQueue.cpp
rb5b01e r6367dd 43 43 #include <vector> 44 44 45 #include "Actions/ActionHistory.hpp" 45 46 #include "Actions/ActionRegistry.hpp" 46 47 … … 48 49 49 50 ActionQueue::ActionQueue() : 50 AR(new ActionRegistry()) 51 AR(new ActionRegistry()), 52 history(new ActionHistory) 51 53 {} 52 54 53 55 ActionQueue::~ActionQueue() 54 56 { 57 delete history; 55 58 delete AR; 56 59 } … … 78 81 } 79 82 83 void ActionQueue::addElement(Action* _Action,ActionState::ptr _state) 84 { 85 history->addElement(_Action, _state); 86 } 87 88 void ActionQueue::clear() 89 { 90 history->clear(); 91 } 92 93 80 94 const ActionQueue::ActionTokens_t ActionQueue::getListOfActions() const 81 95 { … … 90 104 } 91 105 106 void ActionQueue::undoLast() 107 { 108 history->undoLast(); 109 } 110 111 void ActionQueue::redoLast() 112 { 113 history->redoLast(); 114 } 115 116 92 117 CONSTRUCT_SINGLETON(ActionQueue) -
src/Actions/ActionQueue.hpp
rb5b01e r6367dd 24 24 25 25 class Action; 26 class ActionHistory; 26 27 class ActionRegistry; 27 28 class ActionTrait; … … 82 83 } 83 84 85 /** Undoes last called Action. 86 * 87 */ 88 void undoLast(); 89 90 /** Redoes last undone Action. 91 * 92 */ 93 void redoLast(); 94 95 private: 96 //!> grant Action access to internal history functions. 97 friend class Action; 98 99 /** Wrapper function to add state to ActionHistory. 100 * 101 * \param _Action Action whose state to add 102 * \param _state state to add 103 */ 104 void addElement(Action* _Action, ActionState::ptr _state); 105 106 /** Wrapper function to clear ActionHistory. 107 * 108 */ 109 void clear(); 110 84 111 private: 85 112 /** Private cstor for ActionQueue. … … 98 125 ActionRegistry *AR; 99 126 127 //!> ActionHistory is for undoing and redoing actions, requires ActionRegistry fully initialized 128 ActionHistory *history; 129 100 130 //!> internal queue of actions 101 131 ActionQueue_t queue; -
src/Actions/RedoAction.cpp
rb5b01e r6367dd 36 36 #include "CodePatterns/MemDebug.hpp" 37 37 38 #include "Action History.hpp"38 #include "ActionQueue.hpp" 39 39 40 40 #include <iostream> … … 53 53 ActionState::ptr RedoAction::performCall(){ 54 54 std::cout << "Redo" << std::endl; 55 Action History::getInstance().redoLast();55 ActionQueue::getInstance().redoLast(); 56 56 return Action::success; 57 57 } -
src/Actions/UndoAction.cpp
rb5b01e r6367dd 35 35 #include "CodePatterns/MemDebug.hpp" 36 36 37 #include "Action History.hpp"37 #include "ActionQueue.hpp" 38 38 39 39 #include <iostream> … … 52 52 ActionState::ptr UndoAction::performCall(){ 53 53 std::cout << "Undo" << std::endl; 54 Action History::getInstance().undoLast();54 ActionQueue::getInstance().undoLast(); 55 55 return Action::success; 56 56 } -
src/Actions/pyMoleCuilder.cpp
rb5b01e r6367dd 47 47 48 48 #include "cleanUp.hpp" 49 #include "Actions/ActionHistory.hpp"50 #include "cleanUp.hpp"51 49 52 50 namespace MoleCuilder { … … 74 72 // need to init the history before any action is created 75 73 std::cout << "Reinitializing." << std::endl; 76 MoleCuilder::ActionHistory::init();77 74 } 78 75 … … 117 114 BOOST_PYTHON_MODULE(pyMoleCuilder) 118 115 { 119 // need to init the history before any action is created120 MoleCuilder::ActionHistory::init();121 122 116 // from this moment on, we need to be sure to deeinitialize in the correct order 123 117 // this is handled by the cleanup function -
src/Actions/unittests/ActionSequenceUnitTest.cpp
rb5b01e r6367dd 40 40 #include "ActionSequenceUnitTest.hpp" 41 41 #include "Actions/Action.hpp" 42 #include "Actions/ActionHistory.hpp"43 42 #include "Actions/ActionQueue.hpp" 44 43 #include "Actions/ActionSequence.hpp" … … 156 155 void ActionSequenceTest::setUp(){ 157 156 hasDescriptor = false; 158 ActionHistory::init(); 157 // setup ActionHistory 158 ActionQueue::getInstance(); 159 159 // TODO: find a way to really reset the factory to a clean state in tear-down 160 160 if(!hasDescriptor){ … … 190 190 delete shouldNotCall2; 191 191 192 ActionHistory::purgeInstance();193 192 ActionQueue::purgeInstance(); 194 193 { … … 285 284 CPPUNIT_ASSERT_EQUAL(true,wasCalled2->wasCalled()); 286 285 287 Action History::getInstance().undoLast();286 ActionQueue::getInstance().undoLast(); 288 287 289 288 CPPUNIT_ASSERT_EQUAL(false,wasCalled1->wasCalled()); -
src/Actions/unittests/ManipulateAtomsUnitTest.cpp
rb5b01e r6367dd 44 44 #include "Actions/ManipulateAtomsProcess.hpp" 45 45 #include "Actions/ActionQueue.hpp" 46 #include "Actions/ActionHistory.hpp"47 46 48 47 #include "World.hpp" … … 105 104 void manipulateAtomsTest::setUp(){ 106 105 hasDescriptor = false; 107 ActionHistory::init();108 106 World::getInstance(); 107 108 // setup ActionHistory 109 ActionQueue::getInstance(); 110 109 111 // TODO: find a way to really reset the factory to a clean state in tear-down 110 112 if(!hasDescriptor){ … … 121 123 World::purgeInstance(); 122 124 ActionQueue::purgeInstance(); 123 ActionHistory::purgeInstance();124 125 { 125 126 UIFactory::purgeInstance();
Note:
See TracChangeset
for help on using the changeset viewer.