Geant4 Cross Reference

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

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/realloc (Version 11.3.0) and /externals/g4tools/include/tools/realloc (Version 10.6.p1)


  1 #ifndef tools_realloc                             
  2 #define tools_realloc                             
  3                                                   
  4 #include <cstring> //memcpy                       
  5                                                   
  6 namespace tools {                                 
  7                                                   
  8 template <class T>                                
  9 inline bool realloc(T*& a_pointer,size_t a_new    
 10   if(!a_new_size) {                               
 11     delete [] a_pointer;                          
 12     a_pointer = 0;                                
 13     return true;                                  
 14   }                                               
 15   if(!a_pointer) {                                
 16     a_pointer = new T[a_new_size];                
 17     if(!a_pointer) return false;                  
 18     return true;                                  
 19   }                                               
 20   if(a_old_size==a_new_size) return true;         
 21   T* pointer = new T[a_new_size];                 
 22   if(!pointer) {                                  
 23     delete [] a_pointer;                          
 24     a_pointer = 0;                                
 25     return false;                                 
 26   }                                               
 27   if(a_new_size>a_old_size) {                     
 28     ::memcpy(pointer,a_pointer,a_old_size*size    
 29     if(a_init){                                   
 30       size_t num = a_new_size-a_old_size;         
 31       T* pos = pointer+a_old_size;                
 32       for(size_t i=0;i<num;i++,pos++) *pos = T    
 33     }                                             
 34   } else {                                        
 35     ::memcpy(pointer,a_pointer,a_new_size*size    
 36   }                                               
 37   delete [] a_pointer;                            
 38   a_pointer = pointer;                            
 39   return true;                                    
 40 }                                                 
 41                                                   
 42 }                                                 
 43                                                   
 44 #endif