Geant4 Cross Reference

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

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 /externals/g4tools/include/tools/vdata (Version 11.3.0) and /externals/g4tools/include/tools/vdata (Version 11.0.p2)


  1 // Copyright (C) 2010, Guy Barrand. All rights      1 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.            2 // See the file tools.license for terms.
  3                                                     3 
  4 #ifndef tools_vdata                                 4 #ifndef tools_vdata
  5 #define tools_vdata                                 5 #define tools_vdata
  6                                                     6 
  7 #include <vector>                                   7 #include <vector>
  8                                                     8 
  9 #if defined(__APPLE__)                              9 #if defined(__APPLE__)
 10 #include <TargetConditionals.h>                    10 #include <TargetConditionals.h>
 11 #endif                                             11 #endif
 12                                                    12 
 13 namespace tools {                                  13 namespace tools {
 14                                                    14 
 15 // || !__GXX_EXPERIMENTAL_CXX0X__                  15 // || !__GXX_EXPERIMENTAL_CXX0X__
 16                                                    16 
 17 template <class T>                                 17 template <class T>
 18 inline const T* vec_data(const std::vector<T>&     18 inline const T* vec_data(const std::vector<T>& a_vec) {
 19 #if TARGET_OS_IPHONE || __INTEL_COMPILER || _M     19 #if TARGET_OS_IPHONE || __INTEL_COMPILER || _MSC_VER || (__GNUC__ == 4 && __GNUC_MINOR__ <= 0)
 20   if(a_vec.empty()) return 0;                      20   if(a_vec.empty()) return 0;
 21   const T& vf = a_vec.front();                     21   const T& vf = a_vec.front();
 22   return &vf;                                      22   return &vf;
 23 #else                                              23 #else
 24   return a_vec.data();                             24   return a_vec.data();
 25 #endif                                             25 #endif
 26 }                                                  26 }
 27                                                    27 
 28 template <class T>                                 28 template <class T>
 29 inline T* vec_data(std::vector<T>& a_vec) {        29 inline T* vec_data(std::vector<T>& a_vec) {
 30 #if TARGET_OS_IPHONE || __INTEL_COMPILER || _M     30 #if TARGET_OS_IPHONE || __INTEL_COMPILER || _MSC_VER || (__GNUC__ == 4 && __GNUC_MINOR__ <= 0)
 31   if(a_vec.empty()) return 0;                      31   if(a_vec.empty()) return 0;
 32   T& vf = a_vec.front();                           32   T& vf = a_vec.front();
 33   return &vf;                                      33   return &vf;
 34 #else                                              34 #else
 35   return a_vec.data();                             35   return a_vec.data();
 36 #endif                                             36 #endif
 37 }                                                  37 }
 38                                                    38 
 39 /*                                                 39 /*
 40 #include "forit"                                   40 #include "forit"
 41 //std::vector<bool>::data() does not compile.      41 //std::vector<bool>::data() does not compile. The below may do the job :
 42 inline bool* _vec_data(std::vector<bool>& a_v,     42 inline bool* _vec_data(std::vector<bool>& a_v,bool& a_to_delete) {
 43   a_to_delete = true;                              43   a_to_delete = true;
 44   bool* _data = new bool[a_v.size()+1];            44   bool* _data = new bool[a_v.size()+1];
 45   size_t count = 0;                                45   size_t count = 0;
 46   tools_vforcit(bool,a_v,it) {_data[count] = *     46   tools_vforcit(bool,a_v,it) {_data[count] = *it;count++;}
 47   return _data;                                    47   return _data;
 48 }                                                  48 }
 49                                                    49 
 50 template <class TYPE>                              50 template <class TYPE>
 51 inline TYPE* _vec_data(std::vector<TYPE>& a_v,     51 inline TYPE* _vec_data(std::vector<TYPE>& a_v,bool& a_to_delete) {
 52   a_to_delete = false;                             52   a_to_delete = false;
 53   return vec_data(a_v);                            53   return vec_data(a_v);
 54 }                                                  54 }
 55 */                                                 55 */
 56                                                    56 
 57 inline void tools_vdata_check_compile() {std::     57 inline void tools_vdata_check_compile() {std::vector<double> v;vec_data(v);}
 58                                                    58 
 59 }                                                  59 }
 60                                                    60 
 61 #endif                                             61 #endif