2 // ********************************************************************
 
    3 // * License and Disclaimer                                           *
 
    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.                             *
 
   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.         *
 
   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 // ********************************************************************
 
   27 // $Id: G4ProcTblElement.icc 71231 2013-06-12 13:06:28Z gcosmo $
 
   30 // ------------------------------------------------------------
 
   31 // GEANT 4 class header file 
 
   33 // History: first implementation, based on object model of
 
   34 // 4th Aug 1998, H.Kurashige
 
   35 // ------------------------------------------------------------
 
   36 //   Use STL vector instead of RW vector    1. Mar 00 H.Kurashige
 
   40  G4bool G4ProcTblElement::Contains(const G4ProcessManager* pManager) const
 
   42   G4ProcMgrVector::iterator i;
 
   43   for (i = pProcMgrVector->begin(); i!= pProcMgrVector->end(); ++i) {
 
   44     if (*i==pManager) return true;
 
   49 //////////////////////////
 
   51  G4int  G4ProcTblElement::GetIndex(const G4ProcessManager* pManager) const
 
   54   G4ProcMgrVector::iterator i;
 
   55   for (i = pProcMgrVector->begin(); i!= pProcMgrVector->end(); ++i) {
 
   56     if (*i==pManager) return index;
 
   63 //////////////////////////
 
   65  G4int  G4ProcTblElement::Length() const
 
   67   return pProcMgrVector->size();
 
   70 //////////////////////////
 
   72  G4ProcessManager* G4ProcTblElement::GetProcessManager(G4int index) const
 
   74   if ((index < G4int(pProcMgrVector->size())) && (index>=0)){
 
   75     return (*pProcMgrVector)[index];
 
   82 //////////////////////////
 
   84  G4VProcess* G4ProcTblElement::GetProcess() const
 
   90 //////////////////////////
 
   92  void  G4ProcTblElement::Insert(G4ProcessManager* aProcMgr)
 
   94   pProcMgrVector->push_back(aProcMgr);
 
   97 //////////////////////////
 
   99  void  G4ProcTblElement::Remove(G4ProcessManager* aProcMgr)
 
  101   G4ProcMgrVector::iterator i;
 
  102   for (i = pProcMgrVector->begin(); i!= pProcMgrVector->end(); ++i) {
 
  104       pProcMgrVector->erase(i); 
 
  110 //////////////////////////
 
  112  const G4String& G4ProcTblElement::GetProcessName() const
 
  114   return  pProcess->GetProcessName();