Geant4  10.03.p01
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4ITType.hh
Go to the documentation of this file.
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 // $Id: G4ITType.hh 100802 2016-11-02 14:55:27Z gcosmo $
27 //
28 // Author: Mathieu Karamitros
29 
30 // The code is developed in the framework of the ESA AO7146
31 //
32 // We would be very happy hearing from you, send us your feedback! :)
33 //
34 // In order for Geant4-DNA to be maintained and still open-source,
35 // article citations are crucial.
36 // If you use Geant4-DNA chemistry and you publish papers about your software,
37 // in addition to the general paper on Geant4-DNA:
38 //
39 // Int. J. Model. Simul. Sci. Comput. 1 (2010) 157–178
40 //
41 // we would be very happy if you could please also cite the following
42 // reference papers on chemistry:
43 //
44 // J. Comput. Phys. 274 (2014) 841-882
45 // Prog. Nucl. Sci. Tec. 2 (2011) 503-508
46 
47 
48 #ifndef G4ITTYPE_HH
49 #define G4ITTYPE_HH 1
50 
51 #include <cstddef>
52 #include "G4Types.hh"
53 
60 struct G4ITType
61 {
62 private :
63  friend G4ITType operator +(const G4ITType& left,const int& right);
64  friend G4ITType operator -(const G4ITType& left,const int& right);
65  int fValue;
66 
67 public :
68 
69  static size_t size();
70 
71  G4ITType(const int d_ = 0) : fValue(d_) {;}
72  G4ITType(const G4ITType & d_) : fValue(d_.fValue){;}
73  G4ITType & operator=(const G4ITType & rhs);
74  inline G4ITType & operator=(const int & rhs) { fValue = rhs; return *this;}
75  inline operator int & () { return fValue; }
76  inline operator const int & () const { return fValue; }
77  inline bool operator==(const G4ITType & rhs) const { return fValue == rhs.fValue; }
78  inline bool operator==(const int & rhs) const { return fValue == rhs; }
79  inline bool operator<(const G4ITType & rhs) const { return fValue < rhs.fValue; }
80  inline void operator++() { fValue++; }
81 };
82 
83 inline G4ITType operator +(const G4ITType& left,const int& right) {
84  G4ITType output( left.fValue + right );
85  return output;
86 }
87 
88 inline G4ITType operator -(const G4ITType& left,const int& right) {
89  G4ITType output( left.fValue - right );
90  return output;
91 }
92 
94 {
95 private:
96  static /*G4ThreadLocal*/ G4ITTypeManager* fgInstance ;
97  static G4ThreadLocal G4ITTypeManager* fgInstance_local ;
98  G4ITType fLastType;
100  virtual ~G4ITTypeManager();
101 
102  size_t fRessource;
103 
104 public :
105  G4ITType NewType() ;
106  size_t size() const;
107  static G4ITTypeManager* Instance();
108  static void DeleteInstance();
109 
110  void ReserveRessource();
111  void ReleaseRessource();
112 };
113 
114 #define ITDef(T)\
115 public:\
116 static G4ITType fType;\
117 static const G4ITType ITType()\
118 {\
119  return fType;\
120 }\
121 const G4ITType GetITType() const\
122 {\
123  return fType;\
124 }\
125 virtual G4bool equal(const G4IT &right) const \
126 {\
127  const T& right_mol = (const T&)right ;\
128  return (this->operator==(right_mol));\
129 }\
130 virtual G4bool diff(const G4IT &right) const\
131 {\
132  const T& right_mol = (const T&)right ;\
133  return (this->operator<(right_mol));\
134 }
135 
136 #define ITImp(T) \
137 G4ITType T::fType = G4ITTypeManager::Instance()->NewType();
138 
139 #endif // G4ITTYPE_HH
G4ITType(const int d_=0)
Definition: G4ITType.hh:71
BasicVector3D< float > operator-(const BasicVector3D< float > &v)
BasicVector3D< float > operator+(const BasicVector3D< float > &v)
G4ITType NewType()
Definition: G4ITType.cc:105
static void DeleteInstance()
Definition: G4ITType.cc:67
#define G4ThreadLocal
Definition: tls.hh:89
friend G4ITType operator-(const G4ITType &left, const int &right)
Definition: G4ITType.hh:88
G4ITType(const G4ITType &d_)
Definition: G4ITType.hh:72
G4ITType & operator=(const G4ITType &rhs)
Definition: G4ITType.cc:51
static G4ITTypeManager * Instance()
Definition: G4ITType.cc:58
G4ITType & operator=(const int &rhs)
Definition: G4ITType.hh:74
static size_t size()
Definition: G4ITType.cc:46
bool operator==(const int &rhs) const
Definition: G4ITType.hh:78
size_t size() const
Definition: G4ITType.cc:100
void ReserveRessource()
Definition: G4ITType.cc:77
void ReleaseRessource()
Definition: G4ITType.cc:83
friend G4ITType operator+(const G4ITType &left, const int &right)
Definition: G4ITType.hh:83
bool operator==(const G4ITType &rhs) const
Definition: G4ITType.hh:77
void operator++()
Definition: G4ITType.hh:80
bool operator<(const G4ITType &rhs) const
Definition: G4ITType.hh:79