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

Last change on this file since 13179 was 13179, checked in by tbretz, 13 years ago
Updated help text for '.s'
File size: 6.8 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 return true;
127 }
128
129 if (str[0]=='#')
130 {
131 T::GetStreamOut() << "# " << Time().GetAsStr("%H:%M:%S.%f") << " - " << Tools::Trim(str.substr(1)) << endl;
132 return true;
133 }
134
135 if (T::Process(str))
136 return true;
137
138 return !fStateMachine->PostEvent(lout, str);
139 }
140
141public:
142
143 void SetReceiver(StateMachineImp &imp) { fStateMachine = &imp; }
144};
145
146// **************************************************************************
147/** @class LocalStream
148
149@brief Derives the LocalControl from ConsoleStream
150
151This is basically a LocalControl, which derives through the template
152argument from the ConsoleStream class.
153
154 */
155// **************************************************************************
156#include "Console.h"
157
158class LocalStream : public LocalControl<ConsoleStream>
159{
160public:
161 LocalStream(const char *name, bool null = false)
162 : LocalControl<ConsoleStream>(name) { SetNullOutput(null); }
163};
164
165// **************************************************************************
166/** @class LocalConsole
167
168@brief Derives the LocalControl from Control and adds prompt
169
170This is basically a LocalControl, which derives through the template
171argument from the Console class. It enhances the functionality of
172the local control with a proper updated prompt.
173
174 */
175// **************************************************************************
176#include "tools.h"
177
178class LocalConsole : public LocalControl<Console>
179{
180public:
181 LocalConsole(const char *name, bool continous=false)
182 : LocalControl<Console>(name)
183 {
184 SetContinous(continous);
185 }
186
187 string GetUpdatePrompt() const
188 {
189 return GetLinePrompt()+" "
190 "\033[34m\033[1m"+fName+"\033[0m:"
191 "\033[32m\033[1m"+fStateMachine->GetStateName()+"\033[0m> ";
192 }
193};
194
195// **************************************************************************
196/** @class LocalShell
197
198@brief Derives the LocalControl from Shell and adds a colored prompt
199
200This is basically a LocalControl, which derives through the template
201argument from the Shell class. It enhances the functionality of
202the local control with a proper updated prompt.
203
204 */
205// **************************************************************************
206#include "Shell.h"
207
208class LocalShell : public LocalControl<Shell>
209{
210public:
211 LocalShell(const char *name, bool = false)
212 : LocalControl<Shell>(name) { }
213
214 string GetUpdatePrompt() const
215 {
216 return GetLinePrompt()+' '+fName+':'+fStateMachine->GetStateName()+"> ";
217 }
218};
219
220#endif
Note: See TracBrowser for help on using the repository browser.