G4ITBox.hh

Go to the documentation of this file.
00001 //
00002 // ********************************************************************
00003 // * License and Disclaimer                                           *
00004 // *                                                                  *
00005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
00006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
00007 // * conditions of the Geant4 Software License,  included in the file *
00008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
00009 // * include a list of copyright holders.                             *
00010 // *                                                                  *
00011 // * Neither the authors of this software system, nor their employing *
00012 // * institutes,nor the agencies providing financial support for this *
00013 // * work  make  any representation or  warranty, express or implied, *
00014 // * regarding  this  software system or assume any liability for its *
00015 // * use.  Please see the license in the file  LICENSE  and URL above *
00016 // * for the full disclaimer and the limitation of liability.         *
00017 // *                                                                  *
00018 // * This  code  implementation is the result of  the  scientific and *
00019 // * technical work of the GEANT4 collaboration.                      *
00020 // * By using,  copying,  modifying or  distributing the software (or *
00021 // * any work based  on the software)  you  agree  to acknowledge its *
00022 // * use  in  resulting  scientific  publications,  and indicate your *
00023 // * acceptance of all terms of the Geant4 Software license.          *
00024 // ********************************************************************
00025 //
00026 // $Id: G4ITBox.hh 64057 2012-10-30 15:04:49Z gcosmo $
00027 //
00028 // Author: Mathieu Karamitros (kara (AT) cenbg . in2p3 . fr) 
00029 //
00030 // WARNING : This class is released as a prototype.
00031 // It might strongly evolve or even disapear in the next releases.
00032 //
00033 // History:
00034 // -----------
00035 // 10 Oct 2011 M.Karamitros created
00036 //
00037 // -------------------------------------------------------------------
00038 
00039 #ifndef G4ITBox_h
00040 #define G4ITBox_h
00041 
00042 #include "G4IT.hh"
00043 
00050 class G4ITBox
00051 {
00052 
00053 public :
00054     G4ITBox();
00055     ~G4ITBox();
00056 
00057     void ResetStack();
00058     void Push(G4IT*);
00059     void Extract(G4IT*);
00060 
00067     G4IT* FindIT(const G4Track&) ;
00068     const G4IT* FindIT(const G4Track&) const;
00069     void TransferTo(G4ITBox*);
00070 
00071     inline G4bool Empty() const;
00072     inline G4int GetNTrack() const;
00073 
00074     inline G4IT* GetFirstIT();
00075     inline G4IT* GetLastIT();
00076     inline const G4IT* GetFirstIT() const;
00077     inline const G4IT* GetLastIT() const;
00078 
00079     inline void SetNextBox(G4ITBox* box);
00080     inline G4ITBox* GetNextBox();
00081     inline void SetPreviousBox(G4ITBox* box);
00082     inline G4ITBox* GetPreviousBox();
00083 
00084 private :
00085     const G4ITBox & operator=
00086     (const G4ITBox &right);
00087     G4int  fNbIT;
00088     G4IT * fpFirstIT;
00089     G4IT * fpLastIT;
00090 
00091     G4ITBox* fpPreviousBox;
00092     G4ITBox* fpNextBox;
00093 };
00094 
00095 inline G4bool G4ITBox::Empty() const
00096 {
00097     return (fNbIT==0);
00098 }
00099 
00100 inline G4int G4ITBox::GetNTrack() const
00101 {
00102     return fNbIT ;
00103 }
00104 inline G4IT* G4ITBox::GetFirstIT()
00105 {
00106     return fpFirstIT ;
00107 }
00108 inline G4IT* G4ITBox::GetLastIT()
00109 {
00110     return fpLastIT ;
00111 }
00112 
00113 inline const G4IT* G4ITBox::GetFirstIT() const
00114 {
00115     return fpFirstIT ;
00116 }
00117 inline const G4IT* G4ITBox::GetLastIT() const
00118 {
00119     return fpLastIT ;
00120 }
00121 
00122 inline void G4ITBox::SetNextBox(G4ITBox* box)
00123 {
00124     fpNextBox = box;
00125 }
00126 
00127 inline G4ITBox* G4ITBox::GetNextBox()
00128 {
00129     return fpNextBox ;
00130 }
00131 
00132 inline void G4ITBox::SetPreviousBox(G4ITBox* box)
00133 {
00134     fpPreviousBox = box;
00135 }
00136 
00137 inline G4ITBox* G4ITBox::GetPreviousBox()
00138 {
00139     return fpPreviousBox ;
00140 }
00141 
00142 #endif

Generated on Mon May 27 17:48:41 2013 for Geant4 by  doxygen 1.4.7