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

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

Added detailed documentation for the Action class

  • Property mode set to 100644
File size: 2.2 KB
Line 
1/*
2 * Process.hpp
3 *
4 * Created on: Feb 17, 2010
5 * Author: crueger
6 */
7
8
9/**
10 * A Process is an action that might take some time and therfore contains methods
11 * that allows showing how much is done.
12 */
13#ifndef PROCESS_HPP_
14#define PROCESS_HPP_
15
16#include <set>
17
18#include "Patterns/Observer.hpp"
19#include "Actions/Action.hpp"
20
21/**
22 * A Process is an Action that might take some time and therefore has special
23 * methods to allow communication with progress indicators. Indicators
24 * can sign on at a global place and will be notified when any process is doing
25 * a calculation.
26 *
27 * A Process has four states:
28 * - starting: It is in the process of setting itself up, and wants everybody to know that it will start
29 * the calculation soon. Indicators should set up anything they need for displaying the progress
30 * when they are notified by a process in this state.
31 * - active: The process is currently doing it's thing and wants any indicator to know it's status, i.e.
32 * the percentage done.
33 * - stopping: The process has fullfilled it's purpose and is shutting down. Indicators recieving this status
34 * should also use it to shut down their indication mechanism and delete any objects allocated for
35 * this Process
36 * - inactive: This Process is currently sleeping. If a Process is sending out any signals in this state, there
37 * is something seriously wrong.
38 */
39class Process : public Action, public Observable
40{
41public:
42 Process(int _maxSteps, std::string _name, bool _doRegister=true);
43 virtual ~Process();
44
45 bool isRunning();
46 bool doesStart();
47 bool doesStop();
48 int getCurrStep();
49 void setCurrStep(int _currStep);
50 float getDoneRatio();
51 int getMaxSteps();
52 void setMaxSteps(int _maxSteps);
53
54protected:
55 void start();
56 void step();
57 void stop();
58
59private:
60 int currStep;
61 int maxSteps;
62 bool active;
63 bool starts;
64 bool stops;
65
66 // some global static stuff to allow general Observers that can show progresses
67public:
68 static void AddObserver(Observer *);
69 static void RemoveObserver(Observer *);
70private:
71 static std::set<Observer*> processObservers;
72};
73
74#endif /* PROCESS_HPP_ */
Note: See TracBrowser for help on using the repository browser.