source: molecuilder/src/Actions/Calculation.hpp@ 2e06c4

Last change on this file since 2e06c4 was 521e29, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Switched type of pointer used for ActionStates

  • Property mode set to 100644
File size: 1.7 KB
Line 
1/*
2 * Calculation.hpp
3 *
4 * Created on: Feb 19, 2010
5 * Author: crueger
6 */
7
8#ifndef CALCULATION_HPP_
9#define CALCULATION_HPP_
10
11#include "Actions/Process.hpp"
12
13/**
14 * A calculation is a Process that has some kind of result.
15 *
16 * This class can be used in the same way as any other Action or Process, but has some special methods
17 * for inspecting the result of the calculation.
18 */
19template<typename T>
20class Calculation : public Process
21{
22public:
23 Calculation(int _maxSteps, std::string _name, bool _doRegister=true);
24 virtual ~Calculation();
25
26 /**
27 * Reimplemented call method for Action Base class.
28 * Resets the result and then redoes the calculation. Can be used to retrigger calculations
29 * from menu Items or other places.
30 */
31 virtual bool canUndo();
32
33 virtual bool shouldUndo();
34
35 /**
36 * Does the actual calculation and returns the result.
37 * When the calculation has been done before it is not redone, but the previous cached result is returned.
38 * Call reset to delete the cached value.
39 */
40 virtual T operator()();
41
42 /**
43 * Check if a cached result is available.
44 */
45 virtual bool hasResult();
46
47 /**
48 * Get the cached result.
49 * Fails if there is no cached result.
50 */
51 virtual T getResult();
52
53 /**
54 * Delete a previously calculated result from the cache.
55 */
56 virtual void reset();
57
58protected:
59 T* result;
60
61 /**
62 * Pure virtual method for implementation of the actual calculation procedure.
63 */
64 virtual T* doCalc()=0;
65private:
66 virtual Action::state_ptr performCall();
67 virtual Action::state_ptr performUndo(Action::state_ptr);
68 virtual Action::state_ptr performRedo(Action::state_ptr);
69
70 bool done;
71};
72
73#endif /* CALCULATION_HPP_ */
Note: See TracBrowser for help on using the repository browser.