| 1 | // This may look like C code, but it is really -*- C++ -*- | 
|---|
| 2 | // Classe interpreteur de commande pour piapp | 
|---|
| 3 | // Reza      Aout 97 , Juillet,Aout 98 | 
|---|
| 4 | //           Octobre 2003: de PIext -> SysTools | 
|---|
| 5 | // LAL-IN2P3/CNRS  DAPNIA/CEA | 
|---|
| 6 |  | 
|---|
| 7 | #ifndef COMMANDER_H_SEEN | 
|---|
| 8 | #define COMMANDER_H_SEEN | 
|---|
| 9 |  | 
|---|
| 10 | #include "machdefs.h" | 
|---|
| 11 | #include <iostream> | 
|---|
| 12 | #include <fstream> | 
|---|
| 13 | #include <string> | 
|---|
| 14 | #include <vector> | 
|---|
| 15 | #include <list> | 
|---|
| 16 | #include <stack> | 
|---|
| 17 | #include <map> | 
|---|
| 18 | #include <functional> | 
|---|
| 19 |  | 
|---|
| 20 | #include "pdlmgr.h" | 
|---|
| 21 | #include "dvlist.h" | 
|---|
| 22 | #include "ctimer.h" | 
|---|
| 23 |  | 
|---|
| 24 | namespace SOPHYA { | 
|---|
| 25 |  | 
|---|
| 26 | ////// Classe definissant l'interface pour un interpreteur de commande | 
|---|
| 27 |  | 
|---|
| 28 | /*! | 
|---|
| 29 | \ingroup SysTools | 
|---|
| 30 | \brief  Interface definition for a generic command interpreter. | 
|---|
| 31 | */ | 
|---|
| 32 | class CmdInterpreter { | 
|---|
| 33 | public: | 
|---|
| 34 | virtual               ~CmdInterpreter() {} ; | 
|---|
| 35 | //! Returns the interpreter's name | 
|---|
| 36 | virtual string        Name()=0; | 
|---|
| 37 | //! Method to be called in order to interpret a line or string. | 
|---|
| 38 | virtual int           Interpret(string& line)=0; | 
|---|
| 39 | }; | 
|---|
| 40 |  | 
|---|
| 41 |  | 
|---|
| 42 | /////// Classe definissant l'interface pour un executeur de commande | 
|---|
| 43 |  | 
|---|
| 44 | /*! | 
|---|
| 45 | \ingroup SysTools | 
|---|
| 46 | \brief Interface definition for command executor, to be used with Commander | 
|---|
| 47 |  | 
|---|
| 48 | A command is defined by a keyword and a number of argument | 
|---|
| 49 | */ | 
|---|
| 50 |  | 
|---|
| 51 | class CmdExecutor { | 
|---|
| 52 | public: | 
|---|
| 53 | virtual       ~CmdExecutor() {} ; | 
|---|
| 54 | // keyw : Le mot cle associe , args: Arguments de la commande | 
|---|
| 55 | //! command execution method for a command defined by keyword and its arguments. | 
|---|
| 56 | virtual int   Execute(string& keyw, vector<string>& args, string& toks)=0; | 
|---|
| 57 | //! Return true if the command \b keyw is thread compatible (can be executed in a separate thread) | 
|---|
| 58 | virtual bool  IsThreadable(string const & keyw) { return false; } | 
|---|
| 59 | }; | 
|---|
| 60 |  | 
|---|
| 61 |  | 
|---|
| 62 |  | 
|---|
| 63 | class CommanderBloc;    // Bloc de type foreach / for de l'interpreteur Commander | 
|---|
| 64 | class CommanderScript;  // Script de commandes defini ds l'interpreteur Commander | 
|---|
| 65 | class CommandExeThr;    // Thread d'execution de commande | 
|---|
| 66 |  | 
|---|
| 67 | //! A simple command interpreter with c-shell like syntax and  dynamic load capability. | 
|---|
| 68 |  | 
|---|
| 69 | class Commander : public CmdInterpreter  { | 
|---|
| 70 | public: | 
|---|
| 71 | static Commander*     GetInterpreter(); | 
|---|
| 72 |  | 
|---|
| 73 | Commander(bool fgsigzt=true); | 
|---|
| 74 | virtual               ~Commander(); | 
|---|
| 75 | virtual string        Name(); | 
|---|
| 76 |  | 
|---|
| 77 | virtual void          AddHelpGroup(string& grp, string& desc); | 
|---|
| 78 | virtual void          RegisterCommand(string& keyw, string& usage, CmdExecutor * ce, | 
|---|
| 79 | string& grp); | 
|---|
| 80 | inline  void          RegisterCommand(string& keyw, string& usage, CmdExecutor * ce, | 
|---|
| 81 | const char* grp) | 
|---|
| 82 | { string sgrp = grp; RegisterCommand(keyw, usage, ce, sgrp); } | 
|---|
| 83 |  | 
|---|
| 84 | virtual void          RegisterHelp(string& keyw, string& usage, string& grp); | 
|---|
| 85 |  | 
|---|
| 86 | virtual void          LoadModule(string& fnameso, string& name); | 
|---|
| 87 |  | 
|---|
| 88 | virtual void          AddInterpreter(CmdInterpreter * cl); | 
|---|
| 89 | virtual void          SelInterpreter(string& name); | 
|---|
| 90 |  | 
|---|
| 91 | virtual int           Interpret(string& line); | 
|---|
| 92 | virtual void          StopExecution(); | 
|---|
| 93 |  | 
|---|
| 94 | virtual int           ExecuteCommand(string& keyw, vector<string>& args, string& toks); | 
|---|
| 95 | virtual int           ExecFile(string& file, vector<string>& args); | 
|---|
| 96 | virtual int           CShellExecute(string cmd); | 
|---|
| 97 | virtual string&       GetUsage(const string& kw); | 
|---|
| 98 |  | 
|---|
| 99 | inline  void          SetMaxLoopLimit(int_8 lim=0) { maxlooplimit = lim; } | 
|---|
| 100 | inline  int_8         GetMaxLoopLimit() { return maxlooplimit; } | 
|---|
| 101 |  | 
|---|
| 102 | string                GetCurrentPrompt() { return curprompt; } | 
|---|
| 103 |  | 
|---|
| 104 |  | 
|---|
| 105 | virtual void          HelptoLaTeX(string const & flnm); | 
|---|
| 106 |  | 
|---|
| 107 | //! return the current selected interpreter (default : this) | 
|---|
| 108 | inline  CmdInterpreter* CurrentInterpreter() { return(curcmdi); } | 
|---|
| 109 |  | 
|---|
| 110 | // ----- Action / gestion des variables propres de l'interpreteur | 
|---|
| 111 | // Verifie l'existence de la variable nomme vn et retourne sa valeur ds vv | 
|---|
| 112 | // Retourne false si la variable n'existe pas | 
|---|
| 113 | virtual bool    GetVar(string const & vn, string & vv); | 
|---|
| 114 | virtual bool    GetVar(string const & vn, int idx, string & vv); | 
|---|
| 115 | virtual bool    GetVar(string const & vn, vector<string> & vv); | 
|---|
| 116 | virtual bool    SetVar(string const & vn, string const & vv); | 
|---|
| 117 | virtual bool    SetVar(string const & vn, int idx, string const & vv); | 
|---|
| 118 | virtual bool    SetVar(string const & vn, vector<string> const & vv); | 
|---|
| 119 | virtual bool    CheckVarName(string const & vn); | 
|---|
| 120 | virtual bool    DeleteVar(string const & vn); | 
|---|
| 121 | virtual void    ListVar(); | 
|---|
| 122 | // Variables de l'environnement application | 
|---|
| 123 | virtual bool    GetVarApp(string const & vn, string & vv); | 
|---|
| 124 | virtual bool    SetVarApp(string const & vn, string const & vv); | 
|---|
| 125 | virtual bool    DeleteVarApp(string const & vn); | 
|---|
| 126 | virtual void    ListVarApp(); | 
|---|
| 127 | // Variables d'environnement globales | 
|---|
| 128 | virtual bool    GetVarEnv(string const & vn, string & vv); | 
|---|
| 129 | virtual bool    SetVarEnv(string const & vn, string const & vv); | 
|---|
| 130 | virtual bool    DeleteVarEnv(string const & vn); | 
|---|
| 131 | virtual void    ListVarEnv(); | 
|---|
| 132 |  | 
|---|
| 133 | //   Utilitaire pour decoupage en mot | 
|---|
| 134 | static  int   LineToWords(string& line, string& kw, vector<string>& tokens, | 
|---|
| 135 | vector<bool>& qottoks, string& toks, bool uq=true); | 
|---|
| 136 | protected: | 
|---|
| 137 | virtual int   ParseLineExecute(string& line, bool qw=true); | 
|---|
| 138 |  | 
|---|
| 139 | virtual int   ExecuteCommandLine(string & keyw, vector<string> & args, | 
|---|
| 140 | string & toks); | 
|---|
| 141 |  | 
|---|
| 142 | virtual bool  CheckHelpGrp(string& grp, int& gid, string& desc); | 
|---|
| 143 | inline  bool  CheckHelpGrp(string& grp, int& gid) | 
|---|
| 144 | { string desc=""; return CheckHelpGrp(grp, gid, desc); } | 
|---|
| 145 |  | 
|---|
| 146 | virtual int   SubstituteVars(string & s, string & s2); | 
|---|
| 147 | int           EvaluateTest(vector<string> & args, | 
|---|
| 148 | string & line, bool & res); | 
|---|
| 149 | int           EvalRPNExpr(vector<string> & args, string & line); | 
|---|
| 150 |  | 
|---|
| 151 | // variable de l'interpreteur = valeur - accepte la syntaxe de type varname[index] | 
|---|
| 152 | virtual bool    SetVariable(string const & vn, string const & vv); | 
|---|
| 153 | // Acces aux variables | 
|---|
| 154 | virtual bool    Var2Str(string const & vn, string & vv); | 
|---|
| 155 | inline  bool    Var2Str(string const & vn, int idx, string & vv) | 
|---|
| 156 | { return GetVar(vn, idx, vv); } | 
|---|
| 157 | inline  bool    Var2Str(string const & vn, vector<string> & vv) | 
|---|
| 158 | { return GetVar(vn, vv); } | 
|---|
| 159 |  | 
|---|
| 160 | virtual string  GetTmpDir(); | 
|---|
| 161 |  | 
|---|
| 162 | virtual void  SetCurrentPrompt(const char* pr); | 
|---|
| 163 | inline void   SetCurrentPrompt(string const & pr) { SetCurrentPrompt(pr.c_str()); } | 
|---|
| 164 | inline void   SetDefaultPrompt(string const & pr) { defprompt = pr; } | 
|---|
| 165 |  | 
|---|
| 166 | virtual void  ShowMessage(const char * msg, int att); | 
|---|
| 167 |  | 
|---|
| 168 | void          PushStack(vector<string> & args); | 
|---|
| 169 | void          PopStack(bool psta=true); | 
|---|
| 170 |  | 
|---|
| 171 | //   Gestion des threads d'execution de commandes | 
|---|
| 172 | void          ListThreads(); | 
|---|
| 173 | void          StopThr(uint_8 thrid, bool fgkill=true); | 
|---|
| 174 | void          CleanThrList(); | 
|---|
| 175 | void          WaitThreads(); | 
|---|
| 176 |  | 
|---|
| 177 | // ------ Attributs et variables ------ | 
|---|
| 178 | CmdInterpreter* curcmdi; | 
|---|
| 179 |  | 
|---|
| 180 | // Gestion des variables | 
|---|
| 181 | typedef map< string,  vector<string>, less<string> > CmdVarList; | 
|---|
| 182 | CmdVarList variables; | 
|---|
| 183 |  | 
|---|
| 184 | // Pour enregistrer la liste de commandes et leurs executeurs et le help | 
|---|
| 185 | /*! \cond   Pour supprimer la documentation par doxygen */ | 
|---|
| 186 | //  Command executor registration - For Commander internal use | 
|---|
| 187 | struct cmdex {int group; string us; CmdExecutor * cex; } ; | 
|---|
| 188 | //  Help text registration - For Commander internal use | 
|---|
| 189 | struct hgrpst {int gid; string desc; } ;               // Identification+description d'un groupe de help | 
|---|
| 190 | /*! \endcond */ | 
|---|
| 191 |  | 
|---|
| 192 | typedef map<string, hgrpst, less<string> > CmdHGroup;   // Liste des groupes de commandes | 
|---|
| 193 | CmdHGroup cmdhgrp; | 
|---|
| 194 | int cmdgrpid;                                        // Numero de groupe courant | 
|---|
| 195 | typedef map<string, cmdex, less<string> > CmdExmap; | 
|---|
| 196 | CmdExmap cmdexmap;                                   // Liste des commandes et leurs executeurs | 
|---|
| 197 | CmdExmap helpexmap;                                  // Pour les helps sans commande | 
|---|
| 198 | // Pour garder la liste des threads d'execution de commande | 
|---|
| 199 | list<CommandExeThr *> CmdThrExeList; | 
|---|
| 200 | uint_8 ThrId; | 
|---|
| 201 |  | 
|---|
| 202 | // Pour garder la liste des modules | 
|---|
| 203 | typedef map<string, PDynLinkMgr* , less<string> > Modmap; | 
|---|
| 204 | Modmap modmap; | 
|---|
| 205 |  | 
|---|
| 206 | // Pour garder la liste des interpreteur | 
|---|
| 207 | typedef map<string, CmdInterpreter*, less<string> > InterpMap; | 
|---|
| 208 | InterpMap interpmap; | 
|---|
| 209 |  | 
|---|
| 210 | //  Pour stocker les scripts definis ds l'interpreteur | 
|---|
| 211 | typedef map<string, CommanderScript*, less<string> > ScriptList; | 
|---|
| 212 | ScriptList mScripts;  // Liste des scripts | 
|---|
| 213 | CommanderScript* curscript; // Script en cours de definition | 
|---|
| 214 |  | 
|---|
| 215 | // Code de retour execution commande | 
|---|
| 216 | int _xstatus; | 
|---|
| 217 | // Valeur de retour (par l'instruction return) - | 
|---|
| 218 | string _retstr; | 
|---|
| 219 |  | 
|---|
| 220 | //  Pour stocker les alias definies par l'interpreteur | 
|---|
| 221 | typedef map<string, string, less<string> > CmdStrList; | 
|---|
| 222 | CmdStrList mAliases;  // Liste des alias | 
|---|
| 223 |  | 
|---|
| 224 | // Le stack pour les arguments des .pic et des scripts | 
|---|
| 225 | stack< vector<string> > ArgsStack; | 
|---|
| 226 | // Stack pour les Prompts | 
|---|
| 227 | stack<string> PromptStack; | 
|---|
| 228 |  | 
|---|
| 229 | // Gestion des blocs de commandes et tests (if) | 
|---|
| 230 | stack< CommanderBloc * > CmdBlks;  // Bloc de commande courant (foreach, ...) | 
|---|
| 231 | int felevel;                    // foreach-for level | 
|---|
| 232 | int_8 maxlooplimit;            // Limite maximum des boucles | 
|---|
| 233 | stack< list<char> > TestsStack; // Stack des resultats de test | 
|---|
| 234 | list<char>::iterator tresit;       // Test courant | 
|---|
| 235 | bool curtestresult;             // Resultat courant des tests | 
|---|
| 236 |  | 
|---|
| 237 | // Controle du flot d'execution | 
|---|
| 238 | bool fgexebrk; | 
|---|
| 239 |  | 
|---|
| 240 | // Commande splitees sur plusieurs lignes | 
|---|
| 241 | bool mulinefg;            // Bloc multi-lignes (ligne suite) | 
|---|
| 242 | string mulinecmd;         // Commande multi-lignes | 
|---|
| 243 |  | 
|---|
| 244 | // Texte de prompt (attente de commande) | 
|---|
| 245 | string spromptmul;        // Prompt console avant multi-ligne | 
|---|
| 246 | string curprompt;         // Prompt courant | 
|---|
| 247 | string defprompt;         // Prompt par defaut | 
|---|
| 248 |  | 
|---|
| 249 | // Gestion d'historique, trace, timing des commandes | 
|---|
| 250 | ofstream hist;       //  History file | 
|---|
| 251 | bool histon;        //  True ->  history file | 
|---|
| 252 | bool trace;          // Trace flag | 
|---|
| 253 | bool timing;         // Display CPU Time | 
|---|
| 254 | Timer* gltimer;      // pour Display CPU Time | 
|---|
| 255 |  | 
|---|
| 256 | friend class CommanderBloc; | 
|---|
| 257 | friend class CommanderScript; | 
|---|
| 258 |  | 
|---|
| 259 | }; | 
|---|
| 260 |  | 
|---|
| 261 | } // namespace SOPHYA | 
|---|
| 262 |  | 
|---|
| 263 | /* end of ifdef COMMANDER_H_SEEN */ | 
|---|
| 264 | #endif | 
|---|
| 265 |  | 
|---|