source: trunk/FACT++/src/LocalControl.h@ 13686

Last change on this file since 13686 was 13286, checked in by tbretz, 13 years ago
Changed # to be a real comment and > to be a comment writting to the log-files.
File size: 6.9 KB
Line 
1#ifndef FACT_LocalControl
2#define FACT_LocalControl
3
4#include <ostream>
5
6// **************************************************************************
7/** @class LocalControl
8
9@brief Implements a local control for a StateMachine based on a Readline class
10
11This template implements all functions which overwrite any function from the
12Readline class needed for a local control of a state machien. Since
13several derivatives of the Readline class implement different kind of
14Readline access, this class can be derived by any of them due to its
15template argument. However, the normal case will be deriving it from
16either Console or Shell.
17
18@tparam T
19 The base class for RemoteControl. Either Readlien or a class
20 deriving from it. This is usually either Console or Shell.
21
22**/
23// **************************************************************************
24#include <boost/version.hpp>
25#include <boost/filesystem.hpp>
26
27#include "tools.h"
28
29#include "WindowLog.h"
30#include "StateMachineImp.h"
31
32using namespace std;
33
34template <class T>
35class LocalControl : public T
36{
37private:
38 char **Completion(const char *text, int pos, int)
39 {
40 return pos>0 ? 0 : T::Complete(fStateMachine->GetEventNames(), text);
41 }
42
43protected:
44 StateMachineImp *fStateMachine;
45
46 std::ostream &lout;
47
48 std::string fName;
49
50 LocalControl(const char *name) : T(name),
51 fStateMachine(0), lout(T::GetStreamIn()),
52#if BOOST_VERSION < 104600
53 fName(boost::filesystem::path(name).filename())
54#else
55 fName(boost::filesystem::path(name).filename().string())
56#endif
57 { }
58
59 bool PrintGeneralHelp()
60 {
61 T::PrintGeneralHelp();
62 lout << " " << kUnderline << "Specific commands:" << endl;
63 lout << kBold << " ac,allowed " << kReset << "Display a list of all currently allowed commands." << endl;
64 lout << kBold << " st,states " << kReset << "Display a list of the available states with description." << endl;
65 lout << kBold << " > <text> " << kReset << "Echo <text> to the output stream" << endl;
66 lout << kBold << " .s " << kReset << "Wait for the state-machine to change to the given state.\n";
67 lout << " " " .s <server> [<state> [<timeout> [<label>]]]\n";
68 lout << " " "<server> The server for which state to wait (e.g. FTM_CONTROL)\n";
69 lout << " " "<state> The state id (see 'states') for which to wait (e.g. 3)\n";
70 lout << " " "<imeout> A timeout in millisenconds how long to wait (e.g. 500)\n";
71 lout << " " "<label> A label until which everything is skipped in case of timeout\n";
72 lout << endl;
73 return true;
74 }
75 bool PrintCommands()
76 {
77 lout << endl << kBold << "List of commands:" << endl;
78 fStateMachine->PrintListOfEvents(lout);
79 lout << endl;
80
81 return true;
82 }
83
84 bool Process(const std::string &str)
85 {
86 if (str.substr(0, 2)=="h " || str.substr(0, 5)=="help ")
87 {
88 lout << endl;
89 fStateMachine->PrintListOfEvents(lout, str.substr(str.find_first_of(' ')+1));
90 lout << endl;
91
92 return true;
93 }
94 if (str=="states" || str=="st")
95 {
96 fStateMachine->PrintListOfStates(lout);
97 return true;
98 }
99 if (str=="allowed" || str=="ac")
100 {
101 lout << endl << kBold << "List of commands allowed in current state:" << endl;
102 fStateMachine->PrintListOfAllowedEvents(lout);
103 lout << endl;
104 return true;
105 }
106
107 if (str.substr(0, 3)==".s ")
108 {
109 istringstream in(str.substr(3));
110
111 int state=-100, ms=0;
112 in >> state >> ms;
113
114 if (state==-100)
115 {
116 lout << kRed << "Couldn't parse state id in '" << str.substr(3) << "'" << endl;
117 return true;
118 }
119
120 const Time timeout = ms<=0 ? Time(Time::none) : Time()+boost::posix_time::millisec(ms);
121
122 const int target = stoi(str.substr(3));
123 while (fStateMachine->GetCurrentState()!=target && timeout>Time())
124 usleep(1);
125
126 if (fStateMachine->GetCurrentState()!=target)
127 {
128 int label = -1;
129 in >> label;
130 T::SetLabel(label);
131 }
132 return true;
133 }
134
135 if (str[0]=='#')
136 return true;
137
138 if (str[0]=='>')
139 {
140 fStateMachine->Comment(Tools::Trim(str.substr(1)));
141 return true;
142 }
143
144 if (T::Process(str))
145 return true;
146
147 return !fStateMachine->PostEvent(lout, str);
148 }
149
150public:
151
152 void SetReceiver(StateMachineImp &imp) { fStateMachine = &imp; }
153};
154
155// **************************************************************************
156/** @class LocalStream
157
158@brief Derives the LocalControl from ConsoleStream
159
160This is basically a LocalControl, which derives through the template
161argument from the ConsoleStream class.
162
163 */
164// **************************************************************************
165#include "Console.h"
166
167class LocalStream : public LocalControl<ConsoleStream>
168{
169public:
170 LocalStream(const char *name, bool null = false)
171 : LocalControl<ConsoleStream>(name) { SetNullOutput(null); }
172};
173
174// **************************************************************************
175/** @class LocalConsole
176
177@brief Derives the LocalControl from Control and adds prompt
178
179This is basically a LocalControl, which derives through the template
180argument from the Console class. It enhances the functionality of
181the local control with a proper updated prompt.
182
183 */
184// **************************************************************************
185#include "tools.h"
186
187class LocalConsole : public LocalControl<Console>
188{
189public:
190 LocalConsole(const char *name, bool continous=false)
191 : LocalControl<Console>(name)
192 {
193 SetContinous(continous);
194 }
195
196 string GetUpdatePrompt() const
197 {
198 return GetLinePrompt()+" "
199 "\033[34m\033[1m"+fName+"\033[0m:"
200 "\033[32m\033[1m"+fStateMachine->GetStateName()+"\033[0m> ";
201 }
202};
203
204// **************************************************************************
205/** @class LocalShell
206
207@brief Derives the LocalControl from Shell and adds a colored prompt
208
209This is basically a LocalControl, which derives through the template
210argument from the Shell class. It enhances the functionality of
211the local control with a proper updated prompt.
212
213 */
214// **************************************************************************
215#include "Shell.h"
216
217class LocalShell : public LocalControl<Shell>
218{
219public:
220 LocalShell(const char *name, bool = false)
221 : LocalControl<Shell>(name) { }
222
223 string GetUpdatePrompt() const
224 {
225 return GetLinePrompt()+' '+fName+':'+fStateMachine->GetStateName()+"> ";
226 }
227};
228
229#endif
Note: See TracBrowser for help on using the repository browser.