source: trunk/source/event/include/G4HEPEvtParticle.hh@ 1246

Last change on this file since 1246 was 1228, checked in by garnier, 16 years ago

update geant4.9.3 tag

File size: 3.6 KB
RevLine 
[816]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//
27// $Id: G4HEPEvtParticle.hh,v 1.9 2006/06/29 18:08:39 gunter Exp $
[1228]28// GEANT4 tag $Name: geant4-09-03 $
[816]29//
30//
31
32
33#ifndef G4HEPEvtParticle_h
34#define G4HEPEvtParticle_h 1
35
36#include "globals.hh"
37#include "G4Allocator.hh"
38#include "G4PrimaryParticle.hh"
39
40// class desccription:
41//
42// This class is exclusively used by G4HEPEvtInterface. This class represents
43// one particle in /HEPEVT/ list.
44
45class G4HEPEvtParticle
46{
47 public:
48 inline void *operator new(size_t);
49 inline void operator delete(void *aStackedTrack);
50
51 G4HEPEvtParticle();
52 G4HEPEvtParticle(G4PrimaryParticle* pp,
53 G4int isthep, G4int jdahep1, G4int jdahep2);
54 ~G4HEPEvtParticle();
55
56 const G4HEPEvtParticle & operator=(const G4HEPEvtParticle &right);
57 G4int operator==(const G4HEPEvtParticle &right) const;
58 G4int operator!=(const G4HEPEvtParticle &right) const;
59
60 private:
61 G4PrimaryParticle * theParticle;
62 G4int ISTHEP; // Status code of the entry
63 // Set to be 0 after generating links of
64 // G4PrimaryParticle object
65 G4int JDAHEP1;
66 G4int JDAHEP2;
67
68 public:
69 inline G4PrimaryParticle * GetTheParticle()
70 { return theParticle; }
71 inline void Done()
72 { ISTHEP *= -1; }
73 inline G4int GetISTHEP()
74 { return ISTHEP; }
75 inline G4int GetJDAHEP1()
76 { return JDAHEP1; }
77 inline G4int GetJDAHEP2()
78 { return JDAHEP2; }
79};
80
81#if defined G4EVENT_ALLOC_EXPORT
82 extern G4DLLEXPORT G4Allocator<G4HEPEvtParticle> aHEPEvtParticleAllocator;
83#else
84 extern G4DLLIMPORT G4Allocator<G4HEPEvtParticle> aHEPEvtParticleAllocator;
85#endif
86
87inline void * G4HEPEvtParticle::operator new(size_t)
88{
89 void * aHEPEvtParticle;
90 aHEPEvtParticle = (void *) aHEPEvtParticleAllocator.MallocSingle();
91 return aHEPEvtParticle;
92}
93
94inline void G4HEPEvtParticle::operator delete(void * aHEPEvtParticle)
95{
96 aHEPEvtParticleAllocator.FreeSingle((G4HEPEvtParticle *) aHEPEvtParticle);
97}
98
99
100#endif
101
Note: See TracBrowser for help on using the repository browser.