1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#include "DataFormats/Candidate/interface/CompositeRefCandidate.h"
#include "FWCore/Utilities/interface/Exception.h"
using namespace reco;
CompositeRefCandidate::~CompositeRefCandidate() {}
CompositeRefCandidate* CompositeRefCandidate::clone() const { return new CompositeRefCandidate(*this); }
const Candidate* CompositeRefCandidate::daughter(size_type i) const {
return (i < numberOfDaughters()) ? &*dau[i] : nullptr; // i >= 0, since i is unsigned
}
const Candidate* CompositeRefCandidate::mother(size_type i) const {
return (i < numberOfMothers()) ? &*mom[i] : nullptr; // i >= 0, since i is unsigned
}
Candidate* CompositeRefCandidate::daughter(size_type i) { return nullptr; }
size_t CompositeRefCandidate::numberOfDaughters() const { return dau.size(); }
size_t CompositeRefCandidate::numberOfMothers() const { return mom.size(); }
bool CompositeRefCandidate::overlap(const Candidate& c2) const {
throw cms::Exception("Error") << "can't check overlap internally for CompositeRefCanddate";
}
|