source: src/Actions/MakroAction.hpp@ 216840

AutomationFragmentation_failures Candidate_v1.6.1 ChemicalSpaceEvaluator Enhanced_StructuralOptimization_continued Exclude_Hydrogens_annealWithBondGraph ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_contraction-expansion Gui_displays_atomic_force_velocity PythonUI_with_named_parameters StoppableMakroAction TremoloParser_IncreasedPrecision
Last change on this file since 216840 was 10aee4, checked in by Frederik Heber <heber@…>, 9 years ago

Cleaned up ActionQueue's interface: Actions are always cloned.

  • Action's dstor needs to be public as we have a clone() function.
  • ActionRegistrys' (and AQ's) getActionByName now returns const ref. We must not return a ptr as it may not get deleted elsewhere. We are handing out prototypes.
  • queueAction(action*,...) is private to prevent leakage, queueAction(string, ...) is the public interface.
  • some other small functions are now private, too.
  • MakroActions now need to clone() the prototype on prepare() and delete them on unprepare().
  • ActionSequence deletes contained actions.
  • FIX: ActionSequenceUnitTest cannot check on not-called property of removed actions anymore as these are gone now (they are deleted on removal and they are cloned on insertion).
  • DOCU: Updated documentation on Actions.
  • Property mode set to 100644
File size: 2.5 KB
RevLine 
[1fa107]1/*
2 * MakroAction.hpp
3 *
4 * Created on: Dec 17, 2009
5 * Author: crueger
6 */
7
8#ifndef MAKROACTION_HPP_
9#define MAKROACTION_HPP_
10
[56f73b]11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16
[cc04b7]17#include <string>
18
[1fa107]19#include "Actions/Action.hpp"
[329cf3]20#include "Actions/ActionSequence.hpp"
[1fa107]21
[c1d837]22class ActionSequenceTest;
23
[ce7fdc]24namespace MoleCuilder {
[22b786]25 class ActionRegistry;
[1fa107]26
27/**
28 * Action to allow producing bigger Actions from sequences of small actions.
29 *
30 * Destruction of the Actions and the sequence is handled by this class.
31 */
32class MakroAction : public Action
33{
[c1d837]34 //!> grant unit test access to sequence
35 friend class ::ActionSequenceTest;
[1fa107]36public:
[329cf3]37 MakroAction(const MakroAction &_instance);
[126867]38 MakroAction(const ActionTrait &_trait,ActionSequence& _actions);
[1fa107]39
[67e2b3]40 bool canUndo();
41 bool shouldUndo();
[1fa107]42
[af5384]43 virtual Action* clone(enum QueryOptions flag = Interactive) const;
44 void prepare(enum QueryOptions flag = Interactive);
45
[46b181]46 virtual void outputAsCLI(std::ostream &ost) const;
[477012]47 virtual void outputAsPython(std::ostream &ost, const std::string &prefix) const;
[46b181]48
[a82f61]49 virtual void setOptionValue(const std::string &_token, const std::string &_value);
50
[22b786]51 // must be called after all primitive actions are present
52 virtual void prepare(ActionRegistry &AR);
53 // must be called before alle primitive actions are removed
54 virtual void unprepare(ActionRegistry &AR);
55
[047878]56protected:
[10aee4]57 virtual ~MakroAction();
58
[237f93]59 /**
60 * MakroAction requires an own dialog for global options such as number of loop
61 * iterations, ... besides the dialog from each action in the sequence.
62 *
63 * However, fillDialog() calls ActionSequence::fillAllDialog(). Hence, the dialog
64 * for specific global options must be requested in an distinct function.
65 */
66 virtual Dialog * fillOwnDialog(Dialog*);
67
68 /** Pass-thru for removeAction to allow all derived MakroActions to manipulate action sequence.
69 *
70 * \param name name of action to remove
71 * \return true - action removed, false - action not found
72 * \sa ActionSequence::removeAction()
73 */
74 bool removeAction(const std::string &name);
[22b786]75
[b5b01e]76 virtual ActionState::ptr performCall();
77 virtual ActionState::ptr performUndo(ActionState::ptr);
78 virtual ActionState::ptr performRedo(ActionState::ptr);
[67e2b3]79
[9c1324]80 void setLoop(unsigned int _loop);
81
[22b786]82private:
[237f93]83 /** fillDialog is used to spawn sequence queries, hence must not be modified by
84 * derived MakroActions.
85 */
86 Dialog *fillDialog(Dialog *dialog);
87
[329cf3]88 //!> this points to the instance of a specific MakroAction, we need to ref for callAll()
[22b786]89 ActionSequence &actions;
[1fa107]90};
91
[ce7fdc]92}
93
[1fa107]94#endif /* MAKROACTION_HPP_ */
Note: See TracBrowser for help on using the repository browser.