MpdFemtoBaseTrackCut.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /**
  2. * \class MpdFemtoBaseTrackCut
  3. * \brief Base class for track cuts
  4. *
  5. * The pure virtual base class for track cuts. All track cuts must
  6. * inherit from this one.
  7. *
  8. * \author Grigory Nigmatkulov (NRNU MEPhI)
  9. * \date May 18, 2019
  10. * \email nigmatkulov@gmail.com
  11. */
  12. #ifndef MpdFemtoBaseTrackCut_h
  13. #define MpdFemtoBaseTrackCut_h
  14. // MpdFemtoMaker headers
  15. // Base
  16. #include "MpdFemtoBaseParticleCut.h"
  17. // Infrastructure
  18. #include "MpdFemtoTypes.h"
  19. #include "MpdFemtoTrack.h"
  20. //_________________
  21. class MpdFemtoBaseTrackCut : public MpdFemtoBaseParticleCut {
  22. public:
  23. /// Default constructor
  24. MpdFemtoBaseTrackCut();
  25. /// Copy constructor
  26. MpdFemtoBaseTrackCut(const MpdFemtoBaseTrackCut& copy);
  27. /// Assignment operator
  28. MpdFemtoBaseTrackCut& operator=(const MpdFemtoBaseTrackCut& copy);
  29. /// Default destructor
  30. virtual ~MpdFemtoBaseTrackCut() {
  31. /* no-op */
  32. }
  33. /// Returns true if passed the track cut and false if not
  34. virtual bool pass(const MpdFemtoTrack* track) = 0;
  35. /// Return track type
  36. virtual MpdFemtoParticleType type() {
  37. return hbtTrack;
  38. }
  39. /// Clone track cut
  40. virtual MpdFemtoBaseTrackCut* clone() {
  41. return nullptr;
  42. }
  43. ClassDef(MpdFemtoBaseTrackCut, 0)
  44. };
  45. //_________________
  46. inline MpdFemtoBaseTrackCut::MpdFemtoBaseTrackCut() : MpdFemtoBaseParticleCut() {
  47. /* empty */
  48. }
  49. //_________________
  50. inline MpdFemtoBaseTrackCut::MpdFemtoBaseTrackCut(const MpdFemtoBaseTrackCut& c) : MpdFemtoBaseParticleCut(c) {
  51. /* empty */
  52. }
  53. //_________________
  54. inline MpdFemtoBaseTrackCut& MpdFemtoBaseTrackCut::operator=(const MpdFemtoBaseTrackCut& c) {
  55. if (this != &c) {
  56. MpdFemtoBaseParticleCut::operator=(c);
  57. }
  58. return *this;
  59. }
  60. #endif // #define MpdFemtoTrackCut_h