source: src/Actions/MakroAction.hpp@ 97dff0

Last change on this file since 97dff0 was af5384, checked in by Frederik Heber <heber@…>, 11 years ago

Actions can now clone() and split off prepare() from call().

  • ActionQueue now separates call phase into clone(), prepare(), and call().
  • ActionQueue's dstor releases Actions in deque.
  • CurrentAction is an index as push_back always invalidates iterator.
  • ActionQueue_t is now a simple vector of ptrs.
  • call() is now non-interactive, (maybe) interactive part is placed in prepare() where dialogs are used to fill parameters.
  • only fully prepared Actions are placed in ActionQueue.
  • ActionQueue obtains action instances from Registry, copies, prepares them, and places them in the queue.
  • Action::clone() gets QueryOptions as param. This lets us either clone without params or really copy the instance.
  • If action is called as COMMAND, params have been filled already.
  • Reactions require a ActionQueue::getLastAction() to actually obtain result of (cloned) Action.
  • FIX: Calculation now has const has...() and getResult().
  • Property mode set to 100644
File size: 2.2 KB
Line 
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
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16
17#include <string>
18
19#include "Actions/Action.hpp"
20
21namespace MoleCuilder {
22 class ActionRegistry;
23 class ActionSequence;
24
25/**
26 * Action to allow producing bigger Actions from sequences of small actions.
27 *
28 * Destruction of the Actions and the sequence is handled by this class.
29 */
30class MakroAction : public Action
31{
32public:
33 MakroAction(const ActionTrait &_trait,ActionSequence& _actions);
34 virtual ~MakroAction();
35
36 bool canUndo();
37 bool shouldUndo();
38
39 virtual Action* clone(enum QueryOptions flag = Interactive) const;
40 void prepare(enum QueryOptions flag = Interactive);
41
42 virtual void outputAsCLI(std::ostream &ost) const;
43 virtual void outputAsPython(std::ostream &ost, const std::string &prefix) const;
44
45 // must be called after all primitive actions are present
46 virtual void prepare(ActionRegistry &AR);
47 // must be called before alle primitive actions are removed
48 virtual void unprepare(ActionRegistry &AR);
49
50protected:
51 /**
52 * MakroAction requires an own dialog for global options such as number of loop
53 * iterations, ... besides the dialog from each action in the sequence.
54 *
55 * However, fillDialog() calls ActionSequence::fillAllDialog(). Hence, the dialog
56 * for specific global options must be requested in an distinct function.
57 */
58 virtual Dialog * fillOwnDialog(Dialog*);
59
60 /** Pass-thru for removeAction to allow all derived MakroActions to manipulate action sequence.
61 *
62 * \param name name of action to remove
63 * \return true - action removed, false - action not found
64 * \sa ActionSequence::removeAction()
65 */
66 bool removeAction(const std::string &name);
67
68 virtual ActionState::ptr performCall();
69 virtual ActionState::ptr performUndo(ActionState::ptr);
70 virtual ActionState::ptr performRedo(ActionState::ptr);
71
72 void setLoop(unsigned int _loop);
73
74private:
75 /** fillDialog is used to spawn sequence queries, hence must not be modified by
76 * derived MakroActions.
77 */
78 Dialog *fillDialog(Dialog *dialog);
79
80 ActionSequence &actions;
81};
82
83}
84
85#endif /* MAKROACTION_HPP_ */
Note: See TracBrowser for help on using the repository browser.