ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/UserCode/MitAna/DataTree/interface/Pair.h
Revision: 1.2
Committed: Tue Jun 16 17:08:21 2009 UTC (15 years, 10 months ago) by loizides
Content type: text/plain
Branch: MAIN
CVS Tags: Mit_032, Mit_031, Mit_025c_branch2, Mit_025c_branch1, Mit_030, Mit_029c, Mit_029b, Mit_030_pre1, Mit_029a, Mit_029, Mit_029_pre1, Mit_028a, Mit_025c_branch0, Mit_028, Mit_027a, Mit_027, Mit_026, Mit_025e, Mit_025d, Mit_025c, Mit_025b, Mit_025a, Mit_025, Mit_025pre2, Mit_024b, Mit_025pre1, Mit_024a, Mit_024, Mit_023, Mit_022a, Mit_022, Mit_020d, TMit_020d, Mit_020c, Mit_021, Mit_021pre2, Mit_021pre1, Mit_020b, Mit_020a, Mit_020, Mit_020pre1, Mit_018, Mit_017, Mit_017pre3, Mit_017pre2, Mit_017pre1, Mit_016, Mit_015b, Mit_015a, Mit_015, Mit_014e, Mit_014d, Mit_014c, Mit_014b, Mit_014a, Mit_014, Mit_014pre3, Mit_014pre2, Mit_014pre1, Mit_013d, Mit_013c, Mit_013b, Mit_013a, Mit_013, Mit_013pre1, Mit_012i, Mit_012h, Mit_012g, Mit_012f, Mit_012e, Mit_012d, Mit_012c, Mit_012b, Mit_012a, Mit_012, Mit_011a, Mit_011, Mit_010a, Mit_010, Mit_009c, Mit_009b, HEAD
Branch point for: Mit_025c_branch
Changes since 1.1: +15 -8 lines
Log Message:
Added a few instantiations of Pair objects

File Contents

# Content
1 //--------------------------------------------------------------------------------------------------
2 // $Id: Pair.h,v 1.1 2009/06/16 15:56:21 loizides Exp $
3 //
4 // Pair
5 //
6 // Pair class to allow matching of particles to each other.
7 //
8 // Authors: C.Loizides
9 //--------------------------------------------------------------------------------------------------
10
11 #ifndef MITANA_DATATREE_PAIR_H
12 #define MITANA_DATATREE_PAIR_H
13
14 #include "MitAna/DataTree/interface/DataBase.h"
15 #include "MitAna/DataTree/interface/Particle.h"
16
17 namespace mithep
18 {
19 template<class A, class B=A>
20 class Pair : public DataBase
21 {
22 public:
23 Pair() : fP1(0), fP2(0), fOwn1(0), fOwn2(0) {}
24 Pair(const A *p1, const B *p2) : fP1(const_cast<A*>(p1)), fP2(const_cast<B*>(p2)),
25 fOwn1(0), fOwn2(0) {}
26 Pair(A *p1, Bool_t o, const B *p2) : fP1(p1), fP2(const_cast<B*>(p2)),
27 fOwn1(o), fOwn2(0) {}
28 Pair(const A *p1, B *p2, Bool_t o) : fP1(const_cast<A*>(p1)), fP2(p2),
29 fOwn1(0), fOwn2(o) {}
30 Pair(A *p1, B *p2, Bool_t o1, Bool_t o2) : fP1(p1), fP2(p2),
31 fOwn1(o1), fOwn2(o2) {}
32 ~Pair() { if (fOwn1) delete fP1; if (fOwn2) delete fP2; }
33
34 const A *First() const { return fP1; }
35 const B *Second() const { return fP2; }
36 EObjType ObjType() const { return kPair; }
37 const A *P1() const { return fP1; }
38 const B *P2() const { return fP2; }
39
40 protected:
41 A *fP1; //first object
42 B *fP2; //second object
43 Bool_t fOwn1; //=true then first object is owned
44 Bool_t fOwn2; //=true then second object is owned
45
46 ClassDef(Pair, 1) // Pair class
47 };
48 }
49 #endif