Geant4 Cross Reference

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

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/curve (Version 11.3.0) and /externals/g4tools/include/tools/curve (Version 10.0)


  1 // Copyright (C) 2010, Guy Barrand. All rights    
  2 // See the file tools.license for terms.          
  3                                                   
  4 #ifndef tools_curve                               
  5 #define tools_curve                               
  6                                                   
  7 #include "scast"                                  
  8 #include "S_STRING"                               
  9                                                   
 10 #ifdef TOOLS_MEM                                  
 11 #include "mem"                                    
 12 #endif                                            
 13                                                   
 14 #include "lina/vec3f"                             
 15 #include "lina/mat4f"                             
 16                                                   
 17 namespace tools {                                 
 18                                                   
 19 class curve {                                     
 20 public:                                           
 21   TOOLS_SCLASS(tools::curve)                      
 22   virtual void* cast(const std::string& a_clas    
 23     if(void* p = cmp_cast<curve>(this,a_class)    
 24     return 0;                                     
 25   }                                               
 26 public:                                           
 27   virtual void copy(curve*&) const = 0;           
 28 public:                                           
 29   virtual bool pos_tan_nor(float a_s,             
 30                            vec3f& a_pos,          
 31                            vec3f& a_tan,          
 32                            vec3f& a_nor) const    
 33 public:                                           
 34   curve(){                                        
 35 #ifdef TOOLS_MEM                                  
 36     mem::increment(s_class().c_str());            
 37 #endif                                            
 38     m_model.set_identity();                       
 39   }                                               
 40   virtual ~curve(){                               
 41 #ifdef TOOLS_MEM                                  
 42     mem::decrement(s_class().c_str());            
 43 #endif                                            
 44   }                                               
 45 public:                                           
 46   curve(const curve& a_from):m_model(a_from.m_    
 47 #ifdef TOOLS_MEM                                  
 48     mem::increment(s_class().c_str());            
 49 #endif                                            
 50   }                                               
 51   curve& operator=(const curve& a_from){          
 52     m_model = a_from.m_model;                     
 53     return *this;                                 
 54   }                                               
 55 public:                                           
 56   void set_model_matrix(const mat4f& a_m) {m_m    
 57 protected:                                        
 58   mat4f m_model;                                  
 59 };                                                
 60                                                   
 61 }                                                 
 62                                                   
 63 #endif