Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/intercoms/src/G4UIcommandTree.cc

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 ]

Diff markup

Differences between /intercoms/src/G4UIcommandTree.cc (Version 11.3.0) and /intercoms/src/G4UIcommandTree.cc (Version 9.6.p2)


                                                   >>   1 //
  1 // *******************************************      2 // ********************************************************************
  2 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  3 // *                                                4 // *                                                                  *
  4 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  5 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  6 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  7 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  8 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
  9 // *                                               10 // *                                                                  *
 10 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 11 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 12 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 13 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 14 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 15 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 16 // *                                               17 // *                                                                  *
 17 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 18 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 19 // * By using,  copying,  modifying or  distri     20 // * By using,  copying,  modifying or  distributing the software (or *
 20 // * any work based  on the software)  you  ag     21 // * any work based  on the software)  you  agree  to acknowledge its *
 21 // * use  in  resulting  scientific  publicati     22 // * use  in  resulting  scientific  publications,  and indicate your *
 22 // * acceptance of all terms of the Geant4 Sof     23 // * acceptance of all terms of the Geant4 Software license.          *
 23 // *******************************************     24 // ********************************************************************
 24 //                                                 25 //
 25 // G4UIcommandTree                             << 
 26 //                                                 26 //
 27 // Author: Makoto Asai (SLAC), 1998            <<  27 // $Id$
 28 // Midified: Makoto Asai (SLAC), 2021          <<  28 //
 29 //   Improve output HTML file layout and add o << 
 30 //   command/directory names in alphabetic ord << 
 31 // ------------------------------------------- << 
 32                                                    29 
 33 #include "G4UIcommandTree.hh"                      30 #include "G4UIcommandTree.hh"
 34                                                << 
 35 #include "G4StateManager.hh"                       31 #include "G4StateManager.hh"
 36 #include "G4UIdirectory.hh"                    <<  32 #include <fstream>
 37 #include "G4UImanager.hh"                      << 
 38 #include "G4ios.hh"                                33 #include "G4ios.hh"
 39                                                    34 
 40 #include <fstream>                             <<  35 G4UIcommandTree::G4UIcommandTree()
                                                   >>  36 :guidance(NULL)
                                                   >>  37 { }
 41                                                    38 
 42 // ------------------------------------------- <<  39 G4UIcommandTree::G4UIcommandTree(const char * thePathName)
 43 G4UIcommandTree::G4UIcommandTree(const char* t <<  40 :guidance(NULL)
 44 {                                                  41 {
 45   pathName = thePathName;                          42   pathName = thePathName;
 46 }                                                  43 }
 47                                                    44 
 48 // ------------------------------------------- << 
 49 G4UIcommandTree::~G4UIcommandTree()                45 G4UIcommandTree::~G4UIcommandTree()
 50 {                                                  46 {
 51   for (auto& i : tree) {                       <<  47   G4int i;
 52     delete i;                                  <<  48   G4int n_treeEntry = tree.size();
 53   }                                            <<  49   for( i=0; i < n_treeEntry; i++ )
                                                   >>  50   { delete tree[i]; }
 54 }                                                  51 }
 55                                                    52 
 56 // ------------------------------------------- <<  53 G4int G4UIcommandTree::operator==(const G4UIcommandTree &right) const
 57 G4bool G4UIcommandTree::operator==(const G4UIc << 
 58 {                                                  54 {
 59   return (pathName == right.GetPathName());    <<  55   return ( pathName == right.GetPathName() );
 60 }                                                  56 }
 61                                                    57 
 62 // ------------------------------------------- <<  58 G4int G4UIcommandTree::operator!=(const G4UIcommandTree &right) const
 63 G4bool G4UIcommandTree::operator!=(const G4UIc << 
 64 {                                                  59 {
 65   return (pathName != right.GetPathName());    <<  60   return ( pathName != right.GetPathName() );
 66 }                                                  61 }
 67                                                    62 
 68 // ------------------------------------------- <<  63 void G4UIcommandTree::AddNewCommand(G4UIcommand *newCommand)
 69 void G4UIcommandTree::AddNewCommand(G4UIcomman << 
 70 {                                                  64 {
 71   G4String commandPath = newCommand->GetComman     65   G4String commandPath = newCommand->GetCommandPath();
 72   G4String remainingPath = commandPath;            66   G4String remainingPath = commandPath;
 73   remainingPath.erase(0, pathName.length());   <<  67   remainingPath.remove(0,pathName.length());
 74   if (remainingPath.empty()) {                 <<  68   if( remainingPath.isNull() )
 75     if (guidance == nullptr) {                 <<  69   {
 76       guidance = newCommand;                   <<  70     guidance = newCommand;
 77       if (!(newCommand->ToBeBroadcasted())) {  << 
 78         broadcastCommands = false;             << 
 79       }                                        << 
 80       if (workerThreadOnly) {                  << 
 81         newCommand->SetWorkerThreadOnly();     << 
 82       }                                        << 
 83     }                                          << 
 84     return;                                        71     return;
 85   }                                                72   }
 86                                                <<  73   G4int i = remainingPath.first('/');
 87   if (guidance != nullptr) {                   <<  74   if( i == G4int(std::string::npos) )
 88     auto* dir = static_cast<G4UIdirectory*>(gu <<  75   {
 89     ifSort = dir->IfSort();                    <<  76     // Find command
 90   }                                            <<  77     G4int n_commandEntry = command.size();
 91   std::size_t i = remainingPath.find('/');     <<  78     for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
 92   if (i == std::string::npos) {                <<  79     {
 93     // Adding a new command to this directory  <<  80       if( remainingPath == command[i_thCommand]->GetCommandName() )
 94     std::size_t n_commandEntry = command.size( <<  81       { return; }
 95     for (std::size_t i_thCommand = 0; i_thComm << 
 96       if (remainingPath == command[i_thCommand << 
 97         // a command of same name has already  << 
 98         if (G4UImanager::GetUIpointer()->GetVe << 
 99           G4ExceptionDescription ed;           << 
100           ed << "Command <" << commandPath <<  << 
101           G4Exception("G4UIcommandTree::AddNew << 
102                       // FatalException,       << 
103                       JustWarning, ed);        << 
104         }                                      << 
105         return;                                << 
106       }                                        << 
107     }                                          << 
108     if (!broadcastCommands) {                  << 
109       newCommand->SetToBeBroadcasted(false);   << 
110     }                                          << 
111     if (workerThreadOnly) {                    << 
112       newCommand->SetWorkerThreadOnly();       << 
113     }                                          << 
114     if (ifSort) {                              << 
115       auto j = command.cbegin();               << 
116       for (; j != command.cend(); ++j) {       << 
117         if (newCommand->GetCommandPath() < (*j << 
118           break;                               << 
119         }                                      << 
120       }                                        << 
121       command.insert(j, newCommand);           << 
122     }                                          << 
123     else {                                     << 
124       command.push_back(newCommand);           << 
125     }                                              82     }
                                                   >>  83     command.push_back( newCommand );
126     return;                                        84     return;
127   }                                                85   }
128                                                <<  86   else
129   // Adding a new command to a sub-directory   <<  87   {
130   G4String nextPath = pathName;                <<  88     // Find path
131   nextPath.append(remainingPath.substr(0, i +  <<  89     G4String nextPath = pathName;
132   std::size_t n_treeEntry = tree.size();       <<  90     nextPath.append(remainingPath(0,i+1));
133   for (std::size_t i_thTree = 0; i_thTree < n_ <<  91     G4int n_treeEntry = tree.size();
134     if (nextPath == tree[i_thTree]->GetPathNam <<  92     for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
135       if (!broadcastCommands) {                <<  93     {
136         newCommand->SetToBeBroadcasted(false); <<  94       if( nextPath == tree[i_thTree]->GetPathName() )
137       }                                        <<  95       { 
138       tree[i_thTree]->AddNewCommand(newCommand <<  96   tree[i_thTree]->AddNewCommand( newCommand );
139       return;                                  <<  97   return; 
140     }                                          << 
141   }                                            << 
142   // Creating a new sub-directory              << 
143   auto* newTree = new G4UIcommandTree(nextPath << 
144   if (ifSort) {                                << 
145     auto j = tree.cbegin();                    << 
146     for (; j != tree.cend(); ++j) {            << 
147       if (newTree->GetPathName() < (*j)->GetPa << 
148         break;                                 << 
149       }                                            98       }
150     }                                              99     }
151     tree.insert(j, newTree);                   << 100     G4UIcommandTree * newTree = new G4UIcommandTree( nextPath );
152   }                                            << 101     tree.push_back( newTree );
153   else {                                       << 102     newTree->AddNewCommand( newCommand );
154     tree.push_back(newTree);                   << 103     return;
155   }                                            << 
156   if (!broadcastCommands) {                    << 
157     newCommand->SetToBeBroadcasted(false);     << 
158   }                                               104   }
159   // In case a new sub-directry is created wit << 
160   // (most-likely this is the case), inherit t << 
161   newCommand->SetDefaultSortFlag(ifSort);      << 
162   newTree->AddNewCommand(newCommand, workerThr << 
163   return;                                      << 
164 }                                                 105 }
165                                                   106 
166 // ------------------------------------------- << 107 void G4UIcommandTree::RemoveCommand(G4UIcommand *aCommand)
167 void G4UIcommandTree::RemoveCommand(G4UIcomman << 
168 {                                                 108 {
169   if (workerThreadOnly && !(aCommand->IsWorker << 
170     return;                                    << 
171   }                                            << 
172   G4String commandPath = aCommand->GetCommandP    109   G4String commandPath = aCommand->GetCommandPath();
173   commandPath.erase(0, pathName.length());     << 110   G4String remainingPath = commandPath;
174   if (commandPath.empty()) {                   << 111   remainingPath.remove(0,pathName.length());
175     guidance = nullptr;                        << 112   if( remainingPath.isNull() )
176   }                                            << 113   {
177   else {                                       << 114     guidance = NULL;
178     std::size_t i = commandPath.find('/');     << 115   }
179     if (i == std::string::npos) {              << 116   else
                                                   >> 117   {
                                                   >> 118     G4int i = remainingPath.first('/');
                                                   >> 119     if( i == G4int(std::string::npos) )
                                                   >> 120     {
180       // Find command                             121       // Find command
181       std::size_t n_commandEntry = command.siz << 122       G4int n_commandEntry = command.size();
182       for (std::size_t i_thCommand = 0; i_thCo << 123       for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
183         if (commandPath == command[i_thCommand << 124       {
184           command.erase(command.begin() + i_th << 125         if( remainingPath == command[i_thCommand]->GetCommandName() )
                                                   >> 126         { 
                                                   >> 127           command.erase(command.begin()+i_thCommand);
185           break;                                  128           break;
186         }                                         129         }
187       }                                           130       }
188     }                                             131     }
189     else {                                     << 132     else
                                                   >> 133     {
190       // Find path                                134       // Find path
191       G4String nextPath = pathName;               135       G4String nextPath = pathName;
192       nextPath.append(commandPath.substr(0, i  << 136       nextPath.append(remainingPath(0,i+1));
193       std::size_t n_treeEntry = tree.size();   << 137       G4int n_treeEntry = tree.size();
194       for (std::size_t i_thTree = 0; i_thTree  << 138       for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
195         if (nextPath == tree[i_thTree]->GetPat << 139       {
196           tree[i_thTree]->RemoveCommand(aComma << 140         if( nextPath == tree[i_thTree]->GetPathName() )
197           G4int n_commandRemain = tree[i_thTre << 141         { 
198           G4int n_treeRemain = tree[i_thTree]- << 142         tree[i_thTree]->RemoveCommand( aCommand );
199           if (n_commandRemain == 0 && n_treeRe << 143         G4int n_commandRemain = tree[i_thTree]->GetCommandEntry();
200             G4UIcommandTree* emptyTree = tree[ << 144         G4int n_treeRemain = tree[i_thTree]-> GetTreeEntry();
201             tree.erase(tree.begin() + i_thTree << 145         if(n_commandRemain == 0 && n_treeRemain == 0)
202             delete emptyTree;                  << 146         {
203           }                                    << 147           G4UIcommandTree * emptyTree = tree[i_thTree];
204           break;                               << 148           tree.erase(tree.begin()+i_thTree);
                                                   >> 149           delete emptyTree;
                                                   >> 150         }
                                                   >> 151         break;
205         }                                         152         }
206       }                                           153       }
207     }                                             154     }
208   }                                               155   }
209 }                                                 156 }
210                                                   157 
211 // ------------------------------------------- << 158 // L. Garnier 01.28.08 This function has not a good name. In fact, it try
212 G4UIcommand* G4UIcommandTree::FindPath(const c << 159 // to match a command name, not a path. It should be rename as FindCommandName
213 {                                              << 
214   // This function tries to match a command na << 
215                                                   160 
                                                   >> 161 G4UIcommand * G4UIcommandTree::FindPath(const char* commandPath) const
                                                   >> 162 {
216   G4String remainingPath = commandPath;           163   G4String remainingPath = commandPath;
217   if (remainingPath.find(pathName) == std::str << 164   if( remainingPath.index( pathName ) == std::string::npos )
218     return nullptr;                            << 165   { return NULL; }
219   }                                            << 166   remainingPath.remove(0,pathName.length());
220   remainingPath.erase(0, pathName.length());   << 167   G4int i = remainingPath.first('/');
221   std::size_t i = remainingPath.find('/');     << 168   if( i == G4int(std::string::npos) )
222   if (i == std::string::npos) {                << 169   {
223     // Find command                               170     // Find command
224     std::size_t n_commandEntry = command.size( << 171     G4int n_commandEntry = command.size();
225     for (std::size_t i_thCommand = 0; i_thComm << 172     for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
226       if (remainingPath == command[i_thCommand << 173     {
227         return command[i_thCommand];           << 174       if( remainingPath == command[i_thCommand]->GetCommandName() )
228       }                                        << 175       { return command[i_thCommand]; }
229     }                                             176     }
230   }                                               177   }
231   else {                                       << 178   else
                                                   >> 179   {
232     // Find path                                  180     // Find path
233     G4String nextPath = pathName;                 181     G4String nextPath = pathName;
234     nextPath.append(remainingPath.substr(0, i  << 182     nextPath.append(remainingPath(0,i+1));
235     std::size_t n_treeEntry = tree.size();     << 183     G4int n_treeEntry = tree.size();
236     for (std::size_t i_thTree = 0; i_thTree <  << 184     for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
237       if (nextPath == tree[i_thTree]->GetPathN << 185     {
238         return tree[i_thTree]->FindPath(comman << 186       if( nextPath == tree[i_thTree]->GetPathName() )
239       }                                        << 187       { return tree[i_thTree]->FindPath( commandPath ); }
240     }                                             188     }
241   }                                               189   }
242   return nullptr;                              << 190   return NULL;
243 }                                                 191 }
244                                                   192 
245 // ------------------------------------------- << 193 
                                                   >> 194 /**
                                                   >> 195  * Try to match a command or a path with the one given.
                                                   >> 196  * @commandPath : command or path to match
                                                   >> 197  * @return the commandTree found or NULL if not
                                                   >> 198  */
246 G4UIcommandTree* G4UIcommandTree::FindCommandT    199 G4UIcommandTree* G4UIcommandTree::FindCommandTree(const char* commandPath)
247 {                                                 200 {
248   // Try to match a command or a path with the << 
249   // @commandPath : command or path to match   << 
250   // @return the commandTree found or nullptr  << 
251                                                << 
252   G4String remainingPath = commandPath;           201   G4String remainingPath = commandPath;
253   if (remainingPath.find(pathName) == std::str << 202   if( remainingPath.index( pathName ) == std::string::npos )
254     return nullptr;                            << 203   { return NULL; }
255   }                                            << 204   remainingPath.remove(0,pathName.length());
256   remainingPath.erase(0, pathName.length());   << 205   G4int i = remainingPath.first('/');
257   std::size_t i = remainingPath.find('/');     << 206   if( i != G4int(std::string::npos) )
258   if (i != std::string::npos) {                << 207   {
259     // Find path                                  208     // Find path
260     G4String nextPath = pathName;                 209     G4String nextPath = pathName;
261     nextPath.append(remainingPath.substr(0, i  << 210     nextPath.append(remainingPath(0,i+1));
262     std::size_t n_treeEntry = tree.size();     << 211     G4int n_treeEntry = tree.size();
263     for (std::size_t i_thTree = 0; i_thTree <  << 212     for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
                                                   >> 213     {
264       if (tree[i_thTree]->GetPathName() == com    214       if (tree[i_thTree]->GetPathName() == commandPath) {
265         return tree[i_thTree];                    215         return tree[i_thTree];
266       }                                           216       }
267       if (nextPath == tree[i_thTree]->GetPathN << 217       else if( nextPath == tree[i_thTree]->GetPathName() ) {
268         return tree[i_thTree]->FindCommandTree << 218         return tree[i_thTree]->FindCommandTree( commandPath );
269       }                                           219       }
270     }                                             220     }
271   }                                            << 221   } else {
272   else {                                       << 
273     return this;                                  222     return this;
274   }                                               223   }
275   return nullptr;                              << 224   return NULL;
276 }                                                 225 }
277                                                   226 
278 // ------------------------------------------- << 
279 G4String G4UIcommandTree::CompleteCommandPath(    227 G4String G4UIcommandTree::CompleteCommandPath(const G4String& aCommandPath)
280 {                                                 228 {
281   G4String pName = aCommandPath;                  229   G4String pName = aCommandPath;
282   G4String remainingPath = aCommandPath;          230   G4String remainingPath = aCommandPath;
283   G4String empty = "";                            231   G4String empty = "";
284   G4String matchingPath = empty;                  232   G4String matchingPath = empty;
285                                                   233 
286   // find the tree                                234   // find the tree
287   auto jpre = pName.rfind('/');                << 235   G4int jpre= pName.last('/');
288   if (jpre != G4String::npos) {                << 236   if(jpre != G4int(G4String::npos)) pName.remove(jpre+1);
289     pName.erase(jpre + 1);                     << 
290   }                                            << 
291   G4UIcommandTree* aTree = FindCommandTree(pNa    237   G4UIcommandTree* aTree = FindCommandTree(pName);
292                                                   238 
293   if (aTree == nullptr) {                      << 239   if (!aTree) {
294     return empty;                              << 
295   }                                            << 
296                                                << 
297   if (pName.find(pName) == std::string::npos)  << 
298     return empty;                                 240     return empty;
299   }                                               241   }
                                                   >> 242   
                                                   >> 243   if( pName.index( pName ) == std::string::npos ) return empty;
300                                                   244 
301   std::vector<G4String> paths;                    245   std::vector<G4String> paths;
302                                                   246 
303   // list matched directories/commands            247   // list matched directories/commands
304   G4String strtmp;                                248   G4String strtmp;
305   G4int nMatch = 0;                            << 249   G4int nMatch= 0;
306                                                << 
307   G4int Ndir = aTree->GetTreeEntry();          << 
308   G4int Ncmd = aTree->GetCommandEntry();       << 
309                                                   250 
                                                   >> 251   int Ndir= aTree-> GetTreeEntry();
                                                   >> 252   int Ncmd= aTree-> GetCommandEntry();
                                                   >> 253   
310   // directory ...                                254   // directory ...
311   for (G4int idir = 1; idir <= Ndir; ++idir) { << 255   for(G4int idir=1; idir<=Ndir; idir++) {
312     const G4String& fpdir = aTree->GetTree(idi << 256     G4String fpdir= aTree-> GetTree(idir)-> GetPathName();
313     // matching test                              257     // matching test
314     if (fpdir.find(remainingPath, 0) == 0) {   << 258     if( fpdir.index(remainingPath, 0) == 0) {
315       if (nMatch == 0) {                       << 259       if(nMatch==0) {
316         matchingPath = fpdir;                     260         matchingPath = fpdir;
                                                   >> 261       } else {
                                                   >> 262         matchingPath = GetFirstMatchedString(fpdir,matchingPath);
317       }                                           263       }
318       else {                                   << 264       nMatch++;
319         matchingPath = GetFirstMatchedString(f << 
320       }                                        << 
321       ++nMatch;                                << 
322       paths.push_back(fpdir);                     265       paths.push_back(fpdir);
323     }                                             266     }
324   }                                               267   }
325                                                << 268   
326   if (paths.size() >= 2) {                     << 269   if (paths.size()>=2) {
327     G4cout << "Matching directories :" << G4en << 270     G4cout << "Matching directories :" << G4endl; 
328     for (const auto& path : paths) {           << 271     for( unsigned int i_thCommand = 0; i_thCommand < paths.size(); i_thCommand++ ) {
329       G4cout << path << G4endl;                << 272       G4cout << paths[i_thCommand] << G4endl; 
330     }                                             273     }
331   }                                               274   }
332                                                << 275   
333   // command ...                                  276   // command ...
334   std::vector<G4String> commands;                 277   std::vector<G4String> commands;
335                                                   278 
336   for (G4int icmd = 1; icmd <= Ncmd; ++icmd) { << 279   for(G4int icmd=1; icmd<=Ncmd; icmd++){
337     G4String fpcmd = aTree->GetPathName() + aT << 280     G4String fpcmd= aTree-> GetPathName() +
                                                   >> 281                     aTree-> GetCommand(icmd) -> GetCommandName();
338     // matching test                              282     // matching test
339     if (fpcmd.find(remainingPath, 0) == 0) {   << 283     if( fpcmd.index(remainingPath, 0) ==0) {
340       if (nMatch == 0) {                       << 284       if(nMatch==0) {
341         matchingPath = fpcmd + " ";            << 285         matchingPath= fpcmd + " ";
342       }                                        << 286       } else {
343       else {                                   << 287         strtmp= fpcmd + " ";
344         strtmp = fpcmd + " ";                  << 288         matchingPath= GetFirstMatchedString(matchingPath, strtmp);
345         matchingPath = GetFirstMatchedString(m << 
346       }                                           289       }
347       nMatch++;                                   290       nMatch++;
348       commands.emplace_back(fpcmd + " ");      << 291       commands.push_back(fpcmd+" ");
349     }                                             292     }
350   }                                               293   }
351                                                   294 
352   if (commands.size() >= 2) {                  << 295   if (commands.size()>=2) {
353     G4cout << "Matching commands :" << G4endl; << 296     G4cout << "Matching commands :" << G4endl; 
354     for (const auto& matched : commands) {     << 297     for( unsigned int i_thCommand = 0; i_thCommand < commands.size(); i_thCommand++ ) {
355       G4cout << matched << G4endl;             << 298       G4cout << commands[i_thCommand] << G4endl; 
356     }                                             299     }
357   }                                               300   }
358                                                   301 
359   return matchingPath;                            302   return matchingPath;
360 }                                                 303 }
361                                                   304 
362 // ------------------------------------------- << 305 
363 G4String G4UIcommandTree::GetFirstMatchedStrin << 306 ////////////////////////////////////////////////////////////////////
                                                   >> 307 G4String G4UIcommandTree::GetFirstMatchedString(const G4String& str1, 
                                                   >> 308            const G4String& str2) const
                                                   >> 309 ////////////////////////////////////////////////////////////////////
364 {                                                 310 {
365   std::size_t nlen1 = str1.length();           << 311   int nlen1= str1.length();
366   std::size_t nlen2 = str2.length();           << 312   int nlen2= str2.length();
367                                                   313 
368   std::size_t nmin = nlen1 < nlen2 ? nlen1 : n << 314   int nmin = nlen1<nlen2 ? nlen1 : nlen2;
369                                                   315 
370   G4String strMatched;                            316   G4String strMatched;
371   for (G4int i = 0; i < (G4int)nmin; ++i) {    << 317   for(size_t i=0; G4int(i)<nmin; i++){
372     if (str1[i] == str2[i]) {                  << 318     if(str1[i]==str2[i]) {
373       strMatched += str1[i];                   << 319       strMatched+= str1[i];
374     }                                          << 320     } else {
375     else {                                     << 
376       break;                                      321       break;
377     }                                             322     }
378   }                                               323   }
379                                                   324 
380   return strMatched;                              325   return strMatched;
381 }                                                 326 }
382                                                   327 
383 // ------------------------------------------- << 
384 void G4UIcommandTree::ListCurrent() const         328 void G4UIcommandTree::ListCurrent() const
385 {                                                 329 {
386   G4cout << "Command directory path : " << pat    330   G4cout << "Command directory path : " << pathName << G4endl;
387   if (guidance != nullptr) {                   << 331   if( guidance != NULL ) guidance->List();
388     guidance->List();                          << 
389   }                                            << 
390   G4cout << " Sub-directories : " << G4endl;      332   G4cout << " Sub-directories : " << G4endl;
391   std::size_t n_treeEntry = tree.size();       << 333   G4int n_treeEntry = tree.size();
392   for (std::size_t i_thTree = 0; i_thTree < n_ << 334   for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
393     G4cout << "   " << tree[i_thTree]->GetPath << 335   {
394     if ((tree[i_thTree]->GetGuidance() != null << 336     G4cout << "   " << tree[i_thTree]->GetPathName() 
395         && tree[i_thTree]->GetGuidance()->IsWo << 337    << "   " << tree[i_thTree]->GetTitle() << G4endl;
396     {                                          << 
397       G4cout << " @ ";                         << 
398     }                                          << 
399     else {                                     << 
400       G4cout << "   ";                         << 
401     }                                          << 
402     G4cout << tree[i_thTree]->GetTitle() << G4 << 
403   }                                               338   }
404   G4cout << " Commands : " << G4endl;             339   G4cout << " Commands : " << G4endl;
405   std::size_t n_commandEntry = command.size(); << 340   G4int n_commandEntry = command.size();
406   for (std::size_t i_thCommand = 0; i_thComman << 341   for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
407     G4cout << "   " << command[i_thCommand]->G << 342   {
408     if (command[i_thCommand]->IsWorkerThreadOn << 343     G4cout << "   " << command[i_thCommand]->GetCommandName() 
409       G4cout << " @ ";                         << 344    << " * " << command[i_thCommand]->GetTitle() << G4endl;
410     }                                          << 
411     else {                                     << 
412       G4cout << " * ";                         << 
413     }                                          << 
414     G4cout << command[i_thCommand]->GetTitle() << 
415   }                                               345   }
416 }                                                 346 }
417                                                   347 
418 // ------------------------------------------- << 
419 void G4UIcommandTree::ListCurrentWithNum() con    348 void G4UIcommandTree::ListCurrentWithNum() const
420 {                                                 349 {
421   G4cout << "Command directory path : " << pat    350   G4cout << "Command directory path : " << pathName << G4endl;
422   if (guidance != nullptr) {                   << 351   if( guidance != NULL ) guidance->List();
423     guidance->List();                          << 
424   }                                            << 
425   G4int i = 0;                                    352   G4int i = 0;
426   G4cout << " Sub-directories : " << G4endl;      353   G4cout << " Sub-directories : " << G4endl;
427   std::size_t n_treeEntry = tree.size();       << 354   G4int n_treeEntry = tree.size();
428   for (std::size_t i_thTree = 0; i_thTree < n_ << 355   for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
429     ++i;                                       << 356   {
430     G4cout << " " << i << ") " << tree[i_thTre << 357     i++;
431            << tree[i_thTree]->GetTitle() << G4 << 358     G4cout << " " << i << ") " << tree[i_thTree]->GetPathName() 
                                                   >> 359    << "   " << tree[i_thTree]->GetTitle() << G4endl;
432   }                                               360   }
433   G4cout << " Commands : " << G4endl;             361   G4cout << " Commands : " << G4endl;
434   std::size_t n_commandEntry = command.size(); << 362   G4int n_commandEntry = command.size();
435   for (std::size_t i_thCommand = 0; i_thComman << 363   for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
436     ++i;                                       << 364   {
437     G4cout << " " << i << ") " << command[i_th << 365     i++;
438            << command[i_thCommand]->GetTitle() << 366     G4cout << " " << i << ") " << command[i_thCommand]->GetCommandName() 
                                                   >> 367    << " * " << command[i_thCommand]->GetTitle() << G4endl;
439   }                                               368   }
440 }                                                 369 }
441                                                   370 
442 // ------------------------------------------- << 
443 void G4UIcommandTree::List() const                371 void G4UIcommandTree::List() const
444 {                                                 372 {
445   ListCurrent();                                  373   ListCurrent();
446   std::size_t n_commandEntry = command.size(); << 374   G4int n_commandEntry = command.size();
447   for (std::size_t i_thCommand = 0; i_thComman << 375   for( G4int i_thCommand = 0; i_thCommand < n_commandEntry; i_thCommand++ )
                                                   >> 376   {
448     command[i_thCommand]->List();                 377     command[i_thCommand]->List();
449   }                                               378   }
450   std::size_t n_treeEntry = tree.size();       << 379   G4int n_treeEntry = tree.size();
451   for (std::size_t i_thTree = 0; i_thTree < n_ << 380   for( G4int i_thTree = 0; i_thTree < n_treeEntry; i_thTree++ )
                                                   >> 381   {
452     tree[i_thTree]->List();                       382     tree[i_thTree]->List();
453   }                                               383   }
454 }                                                 384 }
455                                                   385 
456 // ------------------------------------------- << 
457 G4String G4UIcommandTree::CreateFileName(const    386 G4String G4UIcommandTree::CreateFileName(const char* pName)
458 {                                                 387 {
459   G4String fn = pName;                            388   G4String fn = pName;
460   std::size_t idxs;                            << 389   G4int idxs;
461   while ((idxs = fn.find('/')) != std::string: << 390   while((idxs=fn.index("/"))!=G4int(std::string::npos))
462     fn[(G4int)idxs] = '_';                     << 391   { fn(idxs) = '_'; }
463   }                                            << 
464   fn += ".html";                                  392   fn += ".html";
465   return fn;                                      393   return fn;
466 }                                                 394 }
467                                                   395 
468 // ------------------------------------------- << 
469 G4String G4UIcommandTree::ModStr(const char* s    396 G4String G4UIcommandTree::ModStr(const char* strS)
470 {                                                 397 {
471   G4String sx;                                    398   G4String sx;
472   G4String str = strS;                            399   G4String str = strS;
473   for (G4int i = 0; i < G4int(str.length()); + << 400   for(G4int i=0;i<G4int(str.length());i++)
474     char c = str[i];                           << 401   {
475     switch (c) {                               << 402     char c = str(i);
476       case '<':                                << 403     switch(c)
477         sx += "&lt;";                          << 404     {
478         break;                                 << 405     case '<':
479       case '>':                                << 406       sx += "&lt;"; break;
480         sx += "&gt;";                          << 407     case '>':
481         break;                                 << 408       sx += "&gt;"; break;
482       case '&':                                << 409     case '&':
483         sx += "&amp;";                         << 410       sx += "&amp;"; break;
484         break;                                 << 411     default:
485       default:                                 << 412       sx += c;
486         sx += c;                               << 
487     }                                             413     }
488   }                                               414   }
489   return sx;                                      415   return sx;
490 }                                                 416 }
491                                                   417 
492 // ------------------------------------------- << 418 void G4UIcommandTree::CreateHTML()
493 void G4UIcommandTree::CreateHTML(const G4Strin << 
494 {                                                 419 {
495   G4String ofileName = CreateFileName(pathName    420   G4String ofileName = CreateFileName(pathName);
496   std::ofstream oF(ofileName, std::ios::out);     421   std::ofstream oF(ofileName, std::ios::out);
497                                                   422 
498   oF << "<html><head><title>Commands in " << M    423   oF << "<html><head><title>Commands in " << ModStr(pathName) << "</title></head>" << G4endl;
499   oF << "<style> \                             << 424   oF << "<body bgcolor=\"#ffffff\"><h2>" << ModStr(pathName) << "</h2><p>" << G4endl;
500     table,table td,table th { \                << 425 
501        border:1px solid #eee \                 << 426   if( guidance != NULL ) 
502     } \                                        << 427   {
503     table td,table th { \                      << 428     for(G4int i=0;i<guidance->GetGuidanceEntries();i++)
504       padding:5px 20px; \                      << 429     { oF << ModStr(guidance->GetGuidanceLine(i)) << "<br>" << G4endl; }
505       line-height:1.3; \                       << 430   }
506       text-align:inherit \                     << 431 
507     } \                                        << 432   oF << "<p><hr><p>" << G4endl;
508     a { \                                      << 433   
509       color:#17a81a; \                         << 434   oF << "<h2>Sub-directories : </h2><dl>" << G4endl;
510       text-decoration:none; \                  << 435   for( G4int i_thTree = 0; i_thTree < G4int(tree.size()); i_thTree++ )
511       transition-duration:0.3s \               << 436   {
512     } \                                        << 437     oF << "<p><br><p><dt><a href=\"" << CreateFileName(tree[i_thTree]->GetPathName())
513       a:hover { \                              << 438        << "\">" << ModStr(tree[i_thTree]->GetPathName()) << "</a>" << G4endl;
514       color:#17a81a \                          << 439     oF << "<p><dd>" << ModStr(tree[i_thTree]->GetTitle()) << G4endl;
515     } \                                        << 440     tree[i_thTree]->CreateHTML();
516     table { \                                  << 441   }
517       border-collapse:collapse; \              << 442 
518       border-spacing:0; \                      << 443   oF << "</dl><p><hr><p>" << G4endl;
519       margin-bottom:5px; \                     << 444   
520     } \                                        << 445   oF << "<h2>Commands : </h2><dl>" << G4endl;
521     h1 { \                                     << 446   for( G4int i_thCommand = 0; i_thCommand < G4int(command.size()); i_thCommand++ )
522       font-size:2.25em; \                      << 447   {
523       font-weight:300; \                       << 448     G4UIcommand* cmd = command[i_thCommand];
524       letter-spacing:-1px; \                   << 449     oF << "<p><br><p><dt><b>" << ModStr(cmd->GetCommandName());
525       line-height:1.15em; \                    << 450     if(cmd->GetParameterEntries()>0)
526       margin-bottom:0.5em; \                   << 451     {
527       word-wrap:break-word \                   << 452       for(G4int i_thParam=0;i_thParam<cmd->GetParameterEntries();i_thParam++)
528     } \                                        << 453       { oF << " [<i>" << ModStr(cmd->GetParameter(i_thParam)->GetParameterName()) << "</i>]"; }
529     h2 { \                                     << 454     }
530       font-size:1.5em; \                       << 455     oF << "</b>" << G4endl;
531       font-weight:300; \                       << 456     oF << "<p><dd>" << G4endl;
532       letter-spacing:-1px; \                   << 457     for(G4int i=0;i<cmd->GetGuidanceEntries();i++)
533       line-height:1.15em; \                    << 458     { oF << ModStr(cmd->GetGuidanceLine(i)) << "<br>" << G4endl; }
534       margin-bottom:0.5em; \                   << 459     if(!(cmd->GetRange()).isNull())
535       word-wrap:break-word \                   << 460     { oF << "<p><dd>Range : " << ModStr(cmd->GetRange()) << G4endl; }
536     } \                                        << 461     std::vector<G4ApplicationState>* availabelStateList = cmd->GetStateList();
537     h3 { \                                     << 462     if(availabelStateList->size()==6)
538       color:#26282a; \                         << 463     { oF << "<p><dd>Available at all Geant4 states." << G4endl; }
539       font-weight:300; \                       << 464     else
540       font-size:1.3em; \                       << 465     {
541       padding:15px 0 15px 0; \                 << 466       oF << "<p><dd>Available Geant4 state(s) : ";
542       border-bottom:2px #eee solid; \          << 467       for(G4int ias=0;ias<G4int(availabelStateList->size());ias++)
543       word-wrap:break-word \                   << 468       { oF << G4StateManager::GetStateManager()->GetStateString((*availabelStateList)[ias]) << " " << G4endl; }
544     } \                                        << 469     }
545     .sidebar { \                               << 470     if(cmd->GetParameterEntries()>0)
546       display:block; \                         << 471     {
547       position:relative; \                     << 472       oF << "<p><dd>Parameters<table border=1>" << G4endl;
548       position:sticky; \                       << 473       for(G4int i_thParam=0;i_thParam<cmd->GetParameterEntries();i_thParam++)
549       float:left; \                            << 474       {
550       -webkit-box-sizing:border-box; \         << 475         G4UIparameter* prm = cmd->GetParameter(i_thParam);
551       -moz-box-sizing:border-box; \            << 476         oF << "<tr><td>" << ModStr(prm->GetParameterName()) << G4endl;
552       -ms-box-sizing:border-box; \             << 477         oF << "<td>type " << prm->GetParameterType() << G4endl;
553       box-sizing:border-box; \                 << 478         oF << "<td>";
554       width:20%; \                             << 479         if(prm->IsOmittable())
555       padding-right:20px \                     << 480         { 
556     } \                                        << 481           oF << "Omittable : ";
557     .context { \                               << 482           if(prm->GetCurrentAsDefault())
558     width:80%; \                               << 483           { oF << "current value is used as the default value." << G4endl; }
559     display:inline-block; \                    << 484           else
560     background-color:#fff; \                   << 485           { oF << "default value = " << prm->GetDefaultValue() << G4endl; }
561     padding: 25px 35px 20px 30px; \            << 
562     -webkit-box-sizing:border-box; \           << 
563     -moz-box-sizing:border-box; \              << 
564     -ms-box-sizing:border-box; \               << 
565     box-sizing:border-box \                    << 
566   } \                                          << 
567     </style>"                                  << 
568      << G4endl;                                << 
569   oF << "<body bgcolor=\"#ffffff\">" << G4endl << 
570                                                << 
571   // Left Panel                                << 
572   if (createHTMLTreeLevel == 0) {              << 
573     oF << "<div class=\"sidebar\">" << sideBar << 
574   }                                            << 
575   // Right Panel                               << 
576   oF << "<div class=\"context\">";             << 
577   oF << "<h1>" << ModStr(pathName) << "</h1>"  << 
578                                                << 
579   if (guidance != nullptr) {                   << 
580     for (G4int i = 0; i < (G4int)guidance->Get << 
581       oF << ModStr(guidance->GetGuidanceLine(i << 
582     }                                          << 
583   }                                            << 
584   if (!tree.empty()) {                         << 
585     G4String menu = "";                        << 
586     G4String newSideBar = "";                  << 
587     menu += "<h2>Sub-directories </h2><table>" << 
588     newSideBar += "<h2><a href=\"" + ofileName << 
589     // Build menu short version                << 
590     for (auto& i_thTree : tree) {              << 
591       newSideBar += "<tr><td><a href=\"" + Cre << 
592                     + ModStr(i_thTree->GetPath << 
593     }                                          << 
594     // Build menu                              << 
595     for (auto& i_thTree : tree) {              << 
596       menu += "<tr><td><a href=\"" + CreateFil << 
597               + ModStr(i_thTree->GetPathName() << 
598       menu += "</td><td>" + ModStr(i_thTree->G << 
599     }                                          << 
600     menu += "</table>";                        << 
601     newSideBar += "</table>";                  << 
602     for (auto& i_thTree : tree) {              << 
603       createHTMLTreeLevel++;                   << 
604       i_thTree->CreateHTML(newSideBar);        << 
605       createHTMLTreeLevel--;                   << 
606     }                                          << 
607     oF << menu << G4endl;                      << 
608   }                                            << 
609                                                << 
610   if (!command.empty()) {                      << 
611     oF << "<h2>Commands </h2>" << G4endl;      << 
612                                                << 
613     // resume                                  << 
614     oF << "<table>" << G4endl;                 << 
615     for (std::size_t i_thCommand = 0; i_thComm << 
616       G4UIcommand* cmd = command[i_thCommand]; << 
617       oF << "<tr><td><a href=\"#c" << i_thComm << 
618       oF << "</a></td></tr>" << G4endl;        << 
619     }                                          << 
620     oF << "</table>" << G4endl;                << 
621     for (std::size_t i_thCommand = 0; i_thComm << 
622       G4UIcommand* cmd = command[i_thCommand]; << 
623       oF << "<h3 id=\"c" << i_thCommand << "\" << 
624       if (cmd->GetParameterEntries() > 0) {    << 
625         for (G4int i_thParam = 0; i_thParam <  << 
626           oF << " [<i>" << ModStr(cmd->GetPara << 
627         }                                      << 
628       }                                        << 
629       oF << "</h3>" << G4endl;                 << 
630       oF << "<p>" << G4endl;                   << 
631       for (G4int i = 0; i < (G4int)cmd->GetGui << 
632         oF << ModStr(cmd->GetGuidanceLine(i))  << 
633       }                                        << 
634       if (!(cmd->GetRange()).empty()) {        << 
635         oF << "<p>Range : " << ModStr(cmd->Get << 
636       }                                        << 
637       std::vector<G4ApplicationState>* availab << 
638       if (availabelStateList->size() == 6) {   << 
639         oF << "<p>Available at all Geant4 stat << 
640       }                                        << 
641       else {                                   << 
642         oF << "<p>Available Geant4 state(s) :  << 
643         for (auto& ias : *availabelStateList)  << 
644           oF << G4StateManager::GetStateManage << 
645         }                                      << 
646       }                                        << 
647       if (cmd->GetParameterEntries() > 0) {    << 
648         oF << "<p>Parameters<table border=1>"  << 
649         for (G4int i_thParam = 0; i_thParam <  << 
650           G4UIparameter* prm = cmd->GetParamet << 
651           oF << "<tr><td>" << ModStr(prm->GetP << 
652           oF << "<td>type " << prm->GetParamet << 
653           oF << "<td>";                        << 
654           if (prm->IsOmittable()) {            << 
655             oF << "Omittable : ";              << 
656             if (prm->GetCurrentAsDefault()) {  << 
657               oF << "current value is used as  << 
658             }                                  << 
659             else {                             << 
660               oF << "default value = " << prm- << 
661             }                                  << 
662           }                                    << 
663           oF << "<td>";                        << 
664           if (!(prm->GetParameterRange()).empt << 
665             oF << "Parameter range : " << ModS << 
666           }                                    << 
667           else if (!(prm->GetParameterCandidat << 
668             oF << "Parameter candidates : " << << 
669           }                                    << 
670         }                                         486         }
671         oF << "</table>" << G4endl;            << 487         oF << "<td>";
                                                   >> 488         if(!(prm->GetParameterRange()).isNull())
                                                   >> 489         { oF << "Parameter range : " << ModStr(prm->GetParameterRange()) << G4endl; }
                                                   >> 490         else if(!(prm->GetParameterCandidates()).isNull())
                                                   >> 491         { oF << "Parameter candidates : " << ModStr(prm->GetParameterCandidates()) << G4endl; }
672       }                                           492       }
                                                   >> 493       oF << "</table>" << G4endl;
673     }                                             494     }
                                                   >> 495 
674   }                                               496   }
675   oF << "</div></body></html>" << G4endl;      << 497   
                                                   >> 498   oF << "</dl></body></html>" << G4endl;
676   oF.close();                                     499   oF.close();
677 }                                                 500 }
678                                                   501 
679 // ------------------------------------------- << 
680 G4UIcommandTree* G4UIcommandTree::GetTree(cons << 
681 {                                              << 
682   G4String comName = comNameC;                 << 
683   for (auto& i : tree) {                       << 
684     if (comName == i->GetPathName()) {         << 
685       return i;                                << 
686     }                                          << 
687   }                                            << 
688   return nullptr;                              << 
689 }                                              << 
690                                                   502