Geant4 Cross Reference |
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 // G4PhysicsTable inline methods implementation 27 // 28 // Author: G.Cosmo, 2 December 1995 - First implementation based on object model 29 // -------------------------------------------------------------------- 30 31 inline void G4PhysicsTable::clearAndDestroy() 32 { 33 G4PhysicsVector* a = nullptr; 34 while(!empty()) 35 { 36 a = G4PhysCollection::back(); 37 G4PhysCollection::pop_back(); 38 delete a; 39 } 40 G4PhysCollection::clear(); 41 vecFlag.clear(); 42 } 43 44 inline G4PhysicsVector*& G4PhysicsTable::operator()(std::size_t i) 45 { 46 return (*this)[i]; 47 } 48 49 inline G4PhysicsVector* const& G4PhysicsTable::operator()(std::size_t i) const 50 { 51 return (*this)[i]; 52 } 53 54 inline void G4PhysicsTable::push_back(G4PhysicsVector* pvec) 55 { 56 G4PhysCollection::push_back(pvec); 57 vecFlag.push_back(true); 58 } 59 60 inline void G4PhysicsTable::insert(G4PhysicsVector* pvec) 61 { 62 G4PhysCollection::push_back(pvec); 63 vecFlag.push_back(true); 64 } 65 66 inline void G4PhysicsTable::insertAt(std::size_t idx, G4PhysicsVector* pvec) 67 { 68 if(idx > entries()) 69 { 70 G4ExceptionDescription ed; 71 ed << "Sprcified index (" << idx 72 << ") is larger than the size of the vector (" << entries() << ")."; 73 G4Exception("G4PhysicsTable::insertAt()", "Global_PhysTbl0001", 74 FatalException, ed); 75 } 76 77 auto itr = cbegin(); 78 for(std::size_t i = 0; i < idx; ++i) 79 { 80 ++itr; 81 } 82 G4PhysCollection::insert(itr, pvec); 83 84 auto itrF = vecFlag.cbegin(); 85 for(std::size_t j = 0; j < idx; ++j) 86 { 87 ++itrF; 88 } 89 vecFlag.insert(itrF, true); 90 } 91 92 inline std::size_t G4PhysicsTable::entries() const 93 { 94 return G4PhysCollection::size(); 95 } 96 97 inline std::size_t G4PhysicsTable::length() const 98 { 99 return G4PhysCollection::size(); 100 } 101 102 inline G4bool G4PhysicsTable::isEmpty() const 103 { 104 return G4PhysCollection::empty(); 105 } 106 107 inline G4bool G4PhysicsTable::GetFlag(std::size_t i) const 108 { 109 return vecFlag[i]; 110 } 111 112 inline void G4PhysicsTable::ClearFlag(std::size_t i) { vecFlag[i] = false; } 113