source: Sophya/trunk/SophyaPI/PIext/piacmd.cc@ 332

Last change on this file since 332 was 330, checked in by ercodmgr, 26 years ago

Amelioration du Help pour piapp (Groupe de Help) Reza 24/6/99

File size: 12.3 KB
Line 
1#include "piacmd.h"
2#include <stdio.h>
3#include <stdlib.h>
4#include <math.h>
5
6#include "basexecut.h"
7
8#include "pdlmgr.h"
9#include "ctimer.h"
10// #include "dlftypes.h"
11
12#include "pistdimgapp.h"
13#include "nobjmgr.h"
14
15#include PISTDWDG_H
16#include PILIST_H
17
18// ------------------------------------------------------------
19// Gestion d'une fenetre d'aide interactive
20// ------------------------------------------------------------
21
22class PIAHelpWind : public PIWindow {
23public :
24 PIAHelpWind(PIStdImgApp* par, PIACmd* piacmd);
25 virtual ~PIAHelpWind();
26 virtual void Show();
27 virtual void Process(PIMessage msg, PIMsgHandler* sender, void* data=NULL);
28 inline void AddHelpGroup(const char * hgrp, int gid)
29 { hgrpom->AppendItem(hgrp, 20000+gid); }
30 inline void ClearHelpList()
31 { mNitem=0; hitemlist->DeleteAllItems(); }
32 inline void AddHelpItem(const char * hitem)
33 { mNitem++; hitemlist->AppendItem(hitem, 100+mNitem); }
34protected :
35 PIStdImgApp* dap;
36 PIACmd* piac;
37 int mNitem;
38 PIList* hitemlist;
39 PIOptMenu* hgrpom;
40 PIButton * mBut;
41 PILabel * mLab;
42 PIText* mTxt;
43};
44
45/* --Methode-- */
46PIAHelpWind::PIAHelpWind(PIStdImgApp *par, PIACmd* piacmd)
47 : PIWindow((PIMsgHandler *)par, "Help-PIApp", PIWK_normal, 400, 300, 100, 350)
48{
49dap = par;
50piac = piacmd;
51mNitem = 0;
52SetMsg(77);
53
54int bsx, bsy;
55int tsx, tsy;
56int spx, spy;
57PIApplicationPrefCompSize(bsx, bsy);
58spx = bsx/6; spy = bsy/6;
59tsx = 10*bsx+2*spx; tsy = 7*bsy+3*spy;
60SetSize(tsx,tsy);
61hgrpom = new PIOptMenu(this, "hgrpoptmen", bsx*2.0, bsy, spx/2, spy);
62hgrpom->SetBinding(PIBK_elastic,PIBK_elastic, PIBK_elastic,PIBK_elastic);
63hitemlist = new PIList(this, "hitemlist", bsx*2.0, tsy-3*spy-bsy, spx/2, 2*spy+bsy);
64hitemlist->SetBinding(PIBK_elastic,PIBK_elastic, PIBK_elastic,PIBK_elastic);
65// hitemlist->SetBorderWidth(2);
66mTxt = new PIText(this, "helptext", true, true, bsx*8.0, 6*bsy, bsx*2.0+1.5*spx, spy);
67// mTxt->SetMutiLineMode(true);
68mTxt->SetTextEditable(false);
69mTxt->SetText("");
70mTxt->SetBinding(PIBK_elastic,PIBK_elastic, PIBK_elastic,PIBK_elastic);
71mLab = new PILabel(this, "helpitem", bsx*4, bsy, bsx*2.5+2*spx, tsy-spy-bsy);
72mLab->SetBorderWidth(1);
73mLab->SetBinding(PIBK_elastic,PIBK_elastic, PIBK_elastic,PIBK_elastic);
74mLab->SetLabel("");
75mBut = new PIButton(this, "Close", 70, bsx, bsy, tsx-bsx*1.5-spx, tsy-spy-bsy);
76mBut->SetBinding(PIBK_elastic,PIBK_elastic, PIBK_elastic,PIBK_elastic);
77}
78
79/* --Methode-- */
80PIAHelpWind::~PIAHelpWind()
81{
82delete hgrpom;
83delete hitemlist;
84delete mTxt;
85delete mLab;
86delete mBut;
87}
88
89/* --Methode-- */
90void PIAHelpWind::Process(PIMessage msg, PIMsgHandler* sender, void* /*data*/)
91{
92PIMessage um = UserMsg(msg);
93if (((um == 77) && (ModMsg(msg) == PIMsg_Close)) || (um == 70) ) {
94 Hide();
95 return;
96 }
97else if ( (um >= 20000) && (sender == hgrpom)) { // Selection de groupe de Help
98 mTxt->SetText("");
99 mLab->SetLabel("");
100 piac->UpdateHelpList(this, um-20000);
101}
102else if ( (um > 100) && (sender == hitemlist) && (ModMsg(msg) == PIMsg_Select) ) {
103 string s = hitemlist->GetSelectionStr();
104 mTxt->SetText(piac->GetUsage(s));
105 mLab->SetLabel(s);
106 }
107}
108
109/* --Methode-- */
110void PIAHelpWind::Show()
111{
112hgrpom->SetValue(20000); // Groupe All
113mTxt->SetText("");
114mLab->SetLabel("");
115piac->UpdateHelpList(this, 0);
116PIWindow::Show();
117}
118
119static PIACmd* curpiacmd = NULL;
120/* --Methode-- */
121PIACmd::PIACmd(NamedObjMgr* omg, PIStdImgApp* app)
122{
123mObjMgr = omg;
124mImgApp = app;
125system("cp history.pic hisold.pic");
126hist.open("history.pic");
127trace = false; timing = false;
128gltimer = NULL;
129
130cmdhgrp["All"] = 0;
131cmdgrpid = 1;
132cmdhgrp["Commands"] = 1;
133helpwin = new PIAHelpWind(app, this);
134helpwin->AddHelpGroup("All", 0);
135helpwin->AddHelpGroup("Commands", 1);
136
137string kw = "piacmd";
138string usage;
139usage = ">>> (piacmd) Interpreter's keywords : \n";
140usage += " timingon timingoff traceon traceoff \n";
141usage += " set unset listvar listcommands exec shell \n";
142usage += " > set varname 'string' # To set a variable, $varname \n";
143usage += " > unset varname # clear variable definition \n";
144usage += " > listvars # List of variable names and values \n";
145usage += " > listcommands # List of all known commands \n";
146usage += " > exec filename # Execute commands from file \n";
147usage += " > shell comand_string # Execute shell command \n";
148usage += " > help <command_name> # <command_name> usage info \n";
149usage += " > helpwindow # Displays help window \n";
150string grp = "Commands";
151RegisterHelp(kw, usage, grp);
152
153basexec = new PIABaseExecutor(this, omg, app);
154AddInterpreter(this);
155curcmdi = this;
156}
157
158/* --Methode-- */
159PIACmd::~PIACmd()
160{
161hist.close();
162if (gltimer) { delete gltimer; gltimer = NULL; }
163Modmap::iterator it;
164for(it = modmap.begin(); it != modmap.end(); it++) {
165 string name = (*it).first + "_end";
166 DlModuleInitEndFunction fend = (*it).second->GetFunction(name);
167 if (fend) fend();
168 delete (*it).second;
169 }
170delete helpwin;
171if (curpiacmd == this) curpiacmd = NULL;
172}
173
174/* --Methode-- */
175PIACmd* PIACmd::GetInterpreter()
176{
177return(curpiacmd);
178}
179
180/* --Methode-- */
181string PIACmd::Name()
182{
183return("piacmd");
184}
185
186/* --Methode-- */
187void PIACmd::RegisterCommand(string& keyw, string& usage, CmdExecutor * ce, string grp)
188{
189if (!ce) {
190 RegisterHelp(keyw, usage, grp);
191 return;
192 }
193int gid = CheckHelpGrp(grp);
194cmdex cme;
195cme.group = gid;
196cme.us = usage;
197cme.cex = ce;
198cmdexmap[keyw] = cme;
199}
200
201/* --Methode-- */
202void PIACmd::RegisterHelp(string& keyw, string& usage, string& grp)
203{
204int gid = CheckHelpGrp(grp);
205cmdex cme;
206cme.group = gid;
207cme.us = usage;
208cme.cex = NULL;
209helpexmap[keyw] = cme;
210}
211
212/* --Methode-- */
213int PIACmd::CheckHelpGrp(string& grp)
214{
215int gid=0;
216CmdHGroup::iterator it = cmdhgrp.find(grp);
217if (it == cmdhgrp.end()) {
218 cmdgrpid++; gid = cmdgrpid;
219 cmdhgrp[grp] = gid;
220 helpwin->AddHelpGroup(grp.c_str(), gid);
221 }
222else gid = (*it).second;
223return(gid);
224}
225
226/* --Methode-- */
227void PIACmd::UpdateHelpList(PIAHelpWind* hw, int gid)
228{
229helpwin->ClearHelpList();
230CmdExmap::iterator it;
231for(it = helpexmap.begin(); it != helpexmap.end(); it++) {
232 if ( (gid != 0) && ((*it).second.group != gid) ) continue;
233 helpwin->AddHelpItem((*it).first.c_str());
234 }
235for(it = cmdexmap.begin(); it != cmdexmap.end(); it++) {
236 if ( (gid != 0) && ((*it).second.group != gid) ) continue;
237 helpwin->AddHelpItem((*it).first.c_str());
238 }
239}
240
241/* --Methode-- */
242void PIACmd::LoadModule(string& fnameso, string& name)
243{
244PDynLinkMgr * dynlink = new PDynLinkMgr(fnameso, false);
245if (dynlink == NULL) {
246 cerr << "PIACmd/LoadModule_Error: Pb opening SO " << fnameso << endl;
247 return;
248 }
249string fname = name + "_init";
250DlModuleInitEndFunction finit = dynlink->GetFunction(fname);
251if (!finit) {
252 cerr << "PIACmd/LoadModule_Error: Pb linking " << fname << endl;
253 return;
254 }
255cout << "PIACmd/LoadModule_Info: Initialisation module" << name
256 << " " << fname << "() ..." << endl;
257finit();
258modmap[name] = dynlink;
259return;
260}
261
262/* --Methode-- */
263void PIACmd::AddInterpreter(CmdInterpreter * cl)
264{
265if (!cl) return;
266interpmap[cl->Name()] = cl;
267}
268
269/* --Methode-- */
270void PIACmd::SelInterpreter(string& name)
271{
272InterpMap::iterator it = interpmap.find(name);
273if (it == interpmap.end()) return;
274curcmdi = (*it).second;
275}
276
277
278// Pour le decoupage des commandes en lignes
279typedef vector<string> cmdtok;
280
281/* --Methode-- */
282int PIACmd::Interpret(string& s)
283{
284
285cmdtok tokens;
286if (s.length() < 1) return(0);
287
288hist << s << endl; // On enregistre les commandes
289
290if (s[0] == '#') {
291 cout << "PIACmd::Interpret() Comment-Line:" << s << endl;
292 return(0);
293 }
294string toks,kw;
295size_t p = s.find_first_not_of(" ");
296s = s.substr(p);
297p = 0;
298size_t q = s.find_first_of(" ");
299size_t l = s.length();
300
301if (q < l)
302 { kw = s.substr(p,q-p); toks = s.substr(q, l-q); }
303else { kw = s.substr(p,l-p); toks = ""; }
304
305q = 0;
306while (q < l) {
307 p = toks.find_first_not_of(" ",q+1); // au debut d'un token
308 if (p>=l) break;
309 q = toks.find_first_of(" ",p); // la fin du token;
310 string token = toks.substr(p,q-p);
311 tokens.push_back(token);
312 }
313
314for(int k=0; k<tokens.size(); k++) { // On remplace les $varname par la valeur de la variable
315 if ((tokens[k])[0] != '$') continue;
316 CmdVarList::iterator it = mVars.find(tokens[k].substr(1));
317 if (it != mVars.end()) tokens[k] = (*it).second;
318 }
319
320// cout << "PIACmd::Do() DBG KeyW= " << kw << " NbArgs= " << tokens.size() << endl;
321// for(int ii=0; ii<tokens.size(); ii++)
322// cout << "arg[ " << ii << " ] : " << tokens[ii] << endl;
323
324// >>>>>>>>>>> Commande d'interpreteur
325if (kw == "helpwindow") ShowHelpWindow();
326else if (kw == "help") {
327 if (tokens.size() > 0) cout << GetUsage(tokens[0]) << endl;
328 else {
329 string kwh = "piacmd";
330 cout << GetUsage(kwh) << endl;
331 }
332 }
333
334else if (kw == "set") {
335 if (tokens.size() < 2) { cout << "PIACmd::Interpret() Usage: set varname string" << endl; return(0); }
336 mVars[tokens[0]] = tokens[1];
337 }
338else if (kw == "unset") {
339 if (tokens.size() < 1) { cout << "PIACmd::Interpret() Usage: unset varname" << endl; return(0); }
340 CmdVarList::iterator it = mVars.find(tokens[0]);
341 if (it != mVars.end()) mVars.erase(it);
342 else cerr << "PIACmd::Interpret() No variable with name " << tokens[0] << endl;
343 }
344else if (kw == "listvars") {
345 cout << "PIACmd::Interpret() Variable List , VarName = Value \n";
346 CmdVarList::iterator it;
347 for(it = mVars.begin(); it != mVars.end(); it++)
348 cout << (*it).first << " = " << (*it).second << "\n";
349 cout << endl;
350 }
351else if (kw == "listvars") {
352 cout << "---- PIACmd::Interpret() Command Variable List ----- \n";
353 CmdExmap::iterator it;
354 int kc = 0;
355 for(it = cmdexmap.begin(); it != cmdexmap.end(); it++) {
356 cout << (*it).first << " ";
357 kc++;
358 if (kc >= 5) { cout << "\n"; kc = 0; }
359 }
360 cout << endl;
361 }
362else if (kw == "traceon") { cout << "PIACmd::Interpret() -> Trace ON mode " << endl; trace = true; }
363else if (kw == "traceoff") { cout << "PIACmd::Interpret() -> Trace OFF mode " << endl; trace = false; }
364else if (kw == "timingon") {
365 cout << "PIACmd::Interpret() -> Timing ON mode " << endl;
366 if (gltimer) delete gltimer; gltimer = new Timer("PIA-CmdInterpreter "); timing = true;
367 }
368else if (kw == "timingoff") {
369 cout << "PIACmd::Interpret() -> Timing OFF mode " << endl;
370 if (gltimer) delete gltimer; gltimer = NULL; timing = false;
371 }
372else if (kw == "exec") {
373 if (tokens.size() < 1) { cout << "PIACmd::Interpret() Usage: exec filename" << endl; return(0); }
374 ExecFile(tokens[0]);
375 }
376else if (kw == "shell") {
377 if (tokens.size() < 1) { cout << "PIACmd::Interpret() Usage: shell cmdline" << endl; return(0); }
378 system(toks.c_str());
379 }
380// Execution d'une commande enregistree
381else {
382 CmdExmap::iterator it = cmdexmap.find(kw);
383 if (it == cmdexmap.end()) cout << "No such command : " << kw << " ! " << endl;
384 else {
385 if ((*it).second.cex) (*it).second.cex->Execute(kw, tokens);
386 else cout << "Dont know how to execute " << kw << " ? " << endl;
387 }
388 }
389
390if (timing) gltimer->Split();
391return(0);
392}
393
394
395/* --Methode-- */
396int PIACmd::ExecFile(string& file)
397{
398char line_buff[512];
399FILE *fip;
400
401if ( (fip = fopen(file.c_str(),"r")) == NULL ) {
402 cerr << "PIACmd::Exec() Error opening file " << file << endl;
403 hist << "##! PIACmd::Exec() Error opening file " << file << endl;
404 return(0);
405 }
406
407hist << "### Executing commands from " << file << endl;
408if (trace) {
409 mImgApp->GetConsole()->AddStr("### Executing commands from ", PIVA_Magenta);
410 mImgApp->GetConsole()->AddStr(file.c_str(), PIVA_Magenta);
411 mImgApp->GetConsole()->AddStr("\n", PIVA_Magenta);
412 }
413
414while (fgets(line_buff,511,fip) != NULL)
415 {
416 if (trace) mImgApp->GetConsole()->AddStr(line_buff, PIVA_Magenta);
417 line_buff[strlen(line_buff)-1] = '\0'; /* LF/CR de la fin */
418 string line(line_buff);
419 Interpret(line);
420 }
421hist << "### End of Exec( " << file << " ) " << endl;
422if (trace) {
423 mImgApp->GetConsole()->AddStr("### End of Exec( ", PIVA_Magenta);
424 mImgApp->GetConsole()->AddStr(file.c_str(), PIVA_Magenta);
425 mImgApp->GetConsole()->AddStr(" ) \n", PIVA_Magenta);
426 }
427
428return(0);
429}
430
431
432static string* videstr = NULL;
433/* --Methode-- */
434string& PIACmd::GetUsage(const string& kw)
435{
436bool fndok = false;
437CmdExmap::iterator it = cmdexmap.find(kw);
438if (it == cmdexmap.end()) {
439 it = helpexmap.find(kw);
440 if (it != helpexmap.end()) fndok = true;
441 }
442 else fndok = true;
443if (fndok) return( (*it).second.us );
444// Keyword pas trouve
445if (videstr == NULL) videstr = new string("");
446*videstr = "Nothing known about " + kw + " ?? ";
447return(*videstr);
448
449}
450
451/* --Methode-- */
452void PIACmd::ShowHelpWindow()
453{
454helpwin->Show();
455}
Note: See TracBrowser for help on using the repository browser.