Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/interfaces/core/include/G4VUIshell.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  1 //
  2 // ********************************************************************
  3 // * License and Disclaimer                                           *
  4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.                             *
 10 // *                                                                  *
 11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                                                  *
 18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // ********************************************************************
 25 //
 26 //
 27 //
 28 
 29 #ifndef G4VUIshell_h
 30 #define G4VUIshell_h 1
 31 
 32 #include "globals.hh"
 33 
 34 // ====================================================================
 35 //   Description:
 36 //   This class is the abstract base class for various UI shells.
 37 //
 38 //   GetCommadLineString() (virtual) returns a command string input from
 39 //    a commad line.
 40 //
 41 //   Two pre-inplemented shell commands(still virtual) are also included,
 42 //   (somewhat differnt flavor from ones provided by G4VBasicShell)
 43 //     ShowCurrentDirectory()   ... show current directory
 44 //     ListCommand()            ... list commands
 45 //
 46 //   [prompt string substitution] (default)
 47 //   %s ... current application status
 48 //   %/ ... current working directory
 49 //
 50 // ====================================================================
 51 
 52 // terminal color index
 53 enum TermColorIndex
 54 {
 55   BLACK = 0,
 56   RED,
 57   GREEN,
 58   YELLOW,
 59   BLUE,
 60   PURPLE,
 61   CYAN,
 62   WHITE
 63 };
 64 
 65 class G4UIcommandTree;
 66 
 67 class G4VUIshell
 68 {
 69  public:
 70   G4VUIshell(const G4String& prompt = "> ");
 71   virtual ~G4VUIshell();
 72 
 73   void SetNColumn(G4int ncol);
 74   void SetPrompt(const G4String& prompt);
 75   void SetCurrentDirectory(const G4String& ccd);
 76   virtual void SetLsColor(TermColorIndex, TermColorIndex);
 77 
 78   // shell commands
 79   virtual void ShowCurrentDirectory() const;
 80 
 81   //  "candidate" is specified with full path.
 82   virtual void ListCommand(const G4String& input, const G4String& candidate = "") const;
 83 
 84   // get command string from a command line
 85   virtual G4String GetCommandLineString(const char* msg = nullptr) = 0;
 86 
 87   virtual void ResetTerminal();
 88 
 89  protected:
 90   // make prompt string
 91   virtual void MakePrompt(const char* msg = nullptr); 
 92 
 93   // get tree node
 94   G4UIcommandTree* GetCommandTree(const G4String& dir) const;
 95 
 96   // absolute path name (ignore command)
 97   G4String GetAbsCommandDirPath(const G4String& apath) const;
 98   
 99   // tail of path ( xxx/xxx/zzz -> zzz, trancated //// -> /)
100   G4String GetCommandPathTail(const G4String& apath) const;
101 
102   G4String promptSetting;  // including %-directive
103   G4String promptString;
104   G4int nColumn;  // column size of terminal (default=80)
105 
106   // color code support (effective if your terminal supports color code.)
107   // default setting is off.
108   G4bool lsColorFlag;  // color flag for list command
109   TermColorIndex directoryColor;
110   TermColorIndex commandColor;
111 
112   // for treating G4 command tree...
113   G4String currentCommandDir;  // current command directory (absolute path)
114 };
115 
116 // ====================================================================
117 //   inline functions
118 // ====================================================================
119 inline void G4VUIshell::SetNColumn(G4int ncol) { nColumn = ncol; }
120 
121 inline void G4VUIshell::SetPrompt(const G4String& prompt) { promptSetting = prompt; }
122 
123 inline void G4VUIshell::SetCurrentDirectory(const G4String& dir) { currentCommandDir = dir; }
124 
125 inline void G4VUIshell::SetLsColor(TermColorIndex, TermColorIndex) {}
126 
127 inline void G4VUIshell::ShowCurrentDirectory() const { G4cout << currentCommandDir << G4endl; }
128 
129 #endif
130