Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/tools/vfind

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 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.
  3 
  4 #ifndef tools_vfind
  5 #define tools_vfind
  6 
  7 #include <vector>
  8 #include <string>
  9 
 10 namespace tools {
 11 
 12 template <class T>
 13 inline T* find_named(const std::vector<T*>& a_vec,const std::string& a_name) {
 14   typedef typename std::vector<T*>::const_iterator it_t;
 15   it_t it;
 16   for(it=a_vec.begin();it!=a_vec.end();++it) {
 17     if((*it)->name()==a_name) return *it;
 18   }
 19   return 0;
 20 }
 21 
 22 template <class T>
 23 inline const T* find_obj_named(const std::vector<T>& a_vec,const std::string& a_name) {  //used in hep/pdgs.
 24   typedef typename std::vector<T>::const_iterator it_t;
 25   it_t it;
 26   for(it=a_vec.begin();it!=a_vec.end();++it) {
 27     if((*it).name()==a_name) return &(*it);
 28   }
 29   return 0;
 30 }
 31 template <class T>
 32 inline T* find_obj_named(std::vector<T>& a_vec,const std::string& a_name) {  //used in hep/pdgs.
 33   typedef typename std::vector<T>::iterator it_t;
 34   it_t it;
 35   for(it=a_vec.begin();it!=a_vec.end();++it) {
 36     if((*it).name()==a_name) return &(*it);
 37   }
 38   return 0;
 39 }
 40 
 41 }
 42 
 43 #include "touplow"
 44 
 45 namespace tools {
 46 
 47 template <class T>
 48 inline T* find_named_case_insensitive(const std::vector<T*>& a_vec,const std::string& a_name) {
 49   std::string low_a_name = a_name;
 50   tolowercase(low_a_name);
 51   std::string low_name;
 52   typedef typename std::vector<T*>::const_iterator it_t;
 53   it_t it;
 54   for(it=a_vec.begin();it!=a_vec.end();++it) {
 55     low_name = (*it)->name();
 56     tolowercase(low_name);
 57     if(low_name==low_a_name) return *it;
 58   }
 59   return 0;
 60 }
 61 
 62 }
 63 
 64 #endif