Changeset 6367dd for src/Actions


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, Candidate_v1.7.0, 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)
Message:

ActionHistory now is part of ActionQueue.

Location:
src/Actions
Files:
10 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/Action.cpp

    rb5b01e r6367dd  
    4141#include "Actions/Action.hpp"
    4242#include "Actions/ActionExceptions.hpp"
    43 #include "Actions/ActionHistory.hpp"
     43#include "Actions/ActionQueue.hpp"
    4444#include "Actions/ActionRegistry.hpp"
    4545#include "Actions/OptionRegistry.hpp"
     
    205205  if(shouldUndo() && state != failure){
    206206    if(canUndo()){
    207       ActionHistory::getInstance().addElement(this,state);
     207      ActionQueue::getInstance().addElement(this,state);
    208208    }
    209209    else{
    210       ActionHistory::getInstance().clear();
     210      ActionQueue::getInstance().clear();
    211211    }
    212212  }
  • src/Actions/ActionHistory.cpp

    rb5b01e r6367dd  
    4141#include <iostream>
    4242
    43 #include "CodePatterns/Singleton_impl.hpp"
    4443#include "CodePatterns/Assert.hpp"
    4544
     
    102101}
    103102
    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//}
    110107
    111108/****************** Contained actions *******************/
  • src/Actions/ActionHistory.hpp

    rb5b01e r6367dd  
    1414#endif
    1515
    16 
    17 #include "CodePatterns/Singleton.hpp"
    18 
    1916#include <deque>
    2017
     
    2522namespace MoleCuilder {
    2623
    27 class ActionHistory : public Singleton<ActionHistory,false>
     24class ActionHistory
    2825{
    29   friend class Singleton<ActionHistory,false>;
    30 
    3126  struct HistoryElement {
    3227    HistoryElement(Action *_action, ActionState::ptr _state) :
     
    3934
    4035public:
     36  ActionHistory();
     37  ~ActionHistory();
    4138
    4239  void undoLast();
     
    4845  void addElement(Action*,ActionState::ptr);
    4946  void clear();
    50 protected:
    51   ActionHistory();
    52   virtual ~ActionHistory();
     47
    5348private:
    5449  std::deque<HistoryElement> history;
     
    6055  // inside a static initialization, so we have this init function that
    6156  // needs to be called at a non-static point at the start of the program
    62   static void init();
     57//  static void init();
    6358};
    6459
  • src/Actions/ActionQueue.cpp

    rb5b01e r6367dd  
    4343#include <vector>
    4444
     45#include "Actions/ActionHistory.hpp"
    4546#include "Actions/ActionRegistry.hpp"
    4647
     
    4849
    4950ActionQueue::ActionQueue() :
    50     AR(new ActionRegistry())
     51    AR(new ActionRegistry()),
     52    history(new ActionHistory)
    5153{}
    5254
    5355ActionQueue::~ActionQueue()
    5456{
     57  delete history;
    5558  delete AR;
    5659}
     
    7881}
    7982
     83void ActionQueue::addElement(Action* _Action,ActionState::ptr _state)
     84{
     85  history->addElement(_Action, _state);
     86}
     87
     88void ActionQueue::clear()
     89{
     90  history->clear();
     91}
     92
     93
    8094const ActionQueue::ActionTokens_t ActionQueue::getListOfActions() const
    8195{
     
    90104}
    91105
     106void ActionQueue::undoLast()
     107{
     108        history->undoLast();
     109}
     110
     111void ActionQueue::redoLast()
     112{
     113        history->redoLast();
     114}
     115
     116
    92117CONSTRUCT_SINGLETON(ActionQueue)
  • src/Actions/ActionQueue.hpp

    rb5b01e r6367dd  
    2424
    2525class Action;
     26class ActionHistory;
    2627class ActionRegistry;
    2728class ActionTrait;
     
    8283  }
    8384
     85  /** Undoes last called Action.
     86   *
     87   */
     88  void undoLast();
     89
     90  /** Redoes last undone Action.
     91   *
     92   */
     93  void redoLast();
     94
     95private:
     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
    84111private:
    85112  /** Private cstor for ActionQueue.
     
    98125  ActionRegistry *AR;
    99126
     127  //!> ActionHistory is for undoing and redoing actions, requires ActionRegistry fully initialized
     128  ActionHistory *history;
     129
    100130  //!> internal queue of actions
    101131  ActionQueue_t queue;
  • src/Actions/RedoAction.cpp

    rb5b01e r6367dd  
    3636#include "CodePatterns/MemDebug.hpp"
    3737
    38 #include "ActionHistory.hpp"
     38#include "ActionQueue.hpp"
    3939
    4040#include <iostream>
     
    5353ActionState::ptr RedoAction::performCall(){
    5454  std::cout << "Redo" << std::endl;
    55   ActionHistory::getInstance().redoLast();
     55  ActionQueue::getInstance().redoLast();
    5656  return Action::success;
    5757}
  • src/Actions/UndoAction.cpp

    rb5b01e r6367dd  
    3535#include "CodePatterns/MemDebug.hpp"
    3636
    37 #include "ActionHistory.hpp"
     37#include "ActionQueue.hpp"
    3838
    3939#include <iostream>
     
    5252ActionState::ptr UndoAction::performCall(){
    5353  std::cout << "Undo" << std::endl;
    54   ActionHistory::getInstance().undoLast();
     54  ActionQueue::getInstance().undoLast();
    5555  return Action::success;
    5656}
  • src/Actions/pyMoleCuilder.cpp

    rb5b01e r6367dd  
    4747
    4848#include "cleanUp.hpp"
    49 #include "Actions/ActionHistory.hpp"
    50 #include "cleanUp.hpp"
    5149
    5250namespace MoleCuilder {
     
    7472  // need to init the history before any action is created
    7573  std::cout << "Reinitializing." << std::endl;
    76   MoleCuilder::ActionHistory::init();
    7774}
    7875
     
    117114BOOST_PYTHON_MODULE(pyMoleCuilder)
    118115{
    119   // need to init the history before any action is created
    120   MoleCuilder::ActionHistory::init();
    121 
    122116  // from this moment on, we need to be sure to deeinitialize in the correct order
    123117  // this is handled by the cleanup function
  • src/Actions/unittests/ActionSequenceUnitTest.cpp

    rb5b01e r6367dd  
    4040#include "ActionSequenceUnitTest.hpp"
    4141#include "Actions/Action.hpp"
    42 #include "Actions/ActionHistory.hpp"
    4342#include "Actions/ActionQueue.hpp"
    4443#include "Actions/ActionSequence.hpp"
     
    156155void ActionSequenceTest::setUp(){
    157156  hasDescriptor = false;
    158   ActionHistory::init();
     157  // setup ActionHistory
     158  ActionQueue::getInstance();
    159159  // TODO: find a way to really reset the factory to a clean state in tear-down
    160160  if(!hasDescriptor){
     
    190190  delete shouldNotCall2;
    191191
    192   ActionHistory::purgeInstance();
    193192  ActionQueue::purgeInstance();
    194193  {
     
    285284  CPPUNIT_ASSERT_EQUAL(true,wasCalled2->wasCalled());
    286285
    287   ActionHistory::getInstance().undoLast();
     286  ActionQueue::getInstance().undoLast();
    288287
    289288  CPPUNIT_ASSERT_EQUAL(false,wasCalled1->wasCalled());
  • src/Actions/unittests/ManipulateAtomsUnitTest.cpp

    rb5b01e r6367dd  
    4444#include "Actions/ManipulateAtomsProcess.hpp"
    4545#include "Actions/ActionQueue.hpp"
    46 #include "Actions/ActionHistory.hpp"
    4746
    4847#include "World.hpp"
     
    105104void manipulateAtomsTest::setUp(){
    106105  hasDescriptor = false;
    107   ActionHistory::init();
    108106  World::getInstance();
     107
     108  // setup ActionHistory
     109  ActionQueue::getInstance();
     110
    109111  // TODO: find a way to really reset the factory to a clean state in tear-down
    110112  if(!hasDescriptor){
     
    121123  World::purgeInstance();
    122124  ActionQueue::purgeInstance();
    123   ActionHistory::purgeInstance();
    124125  {
    125126    UIFactory::purgeInstance();
Note: See TracChangeset for help on using the changeset viewer.