#if !defined(TRACING_RMEDIATRACER_H) #define TRACING_RMEDIATRACER_H // -*- C++ -*- // // Package: // Module: RMediaTracer // // Description: // // Usage: // // // Author: Martin Lohner // Created: Tue Oct 21 12:13:23 EDT 1997 // $Id$ // // Revision history // // $Log$ // Revision 1.1 2000/06/19 19:59:33 eugenio // Initial revision // // Revision 1.5 1998/11/20 23:47:57 mkl // switch Boolean to MCFBool to avoid clashes with other typedef-ed bool types // // Revision 1.4 1998/11/20 05:32:15 mkl // more verbose findFirstMedium with nicer return type; update index after volume exit // // Revision 1.3 1998/11/03 17:43:34 mkl // changes to compile under egcs // // Revision 1.2 1997/11/12 07:49:10 mkl // major bug fixes (mostly reverse_iterator specific) -- now good agreement with fortran tracing found number of tracks // // Revision 1.1 1997/11/11 01:17:38 mkl // Major rewrite: simplify tracing loops; add x-, y-tracing loops // // system include files // user include files #include "MediaTracer.hh" // forward declarations class RMediaTracer : public MediaTracer { // friend classes and functions public: // constants, enums and typedefs // Constructors and destructor RMediaTracer( _mediatracer_medialist_& iMediaList ); virtual ~RMediaTracer(); // member functions virtual void sortMedia(); // const member functions // Printable interface virtual const char* nameOf() const { return "RMediaTracer"; } virtual void printOn( ostream& out=cout ) const; // static member functions protected: // protected member functions virtual _mediatracer_medialist_::const_iterator findFirstMedium( const MCParticle& iParticle ); // protected const member functions private: // Constructors and destructor RMediaTracer(); // stop default RMediaTracer( const RMediaTracer& ); // stop default // assignment operator(s) const RMediaTracer& operator=( const RMediaTracer& );// stop default // private member functions // private const member functions virtual MCFBool equidistantMedium( const vector::const_iterator& ) const; virtual MCFBool particleSurpassedPlus( const vector::const_iterator&, const MCParticle& ) const; virtual MCFBool particleSurpassedMinus( const vector::const_iterator&, const MCParticle& ) const; // data members // static data members }; // inline function definitions inline ostream& operator<<( ostream& os, const RMediaTracer& m ) { m.printOn(os); return os; } inline ostream& operator<<( ostream& os, const RMediaTracer* m ) { m->printOn(os); return os; } //#if defined(INCLUDE_TEMPLATE_DEFINITIONS) // templated member function definitions //# include "Tracing/Template/RMediaTracer.cc" //#endif #endif /* TRACING_RMEDIATRACER_H */