PFCandidateFwdPtrFactory

Macros

Line Code
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 27 28 29 30 31
#ifndef CommonTools_ParticleFlow_PFCandidateFwdPtrFactory_h
#define CommonTools_ParticleFlow_PFCandidateFwdPtrFactory_h

/**
  \class    reco::PFCandidateFwdPtrFactory PFCandidateFwdPtrFactory.h  "CommonTools/ParticleFlow/interface/PFCandidateFwdPtrFactory.h"
  \brief    Creates a FwdPtr<PFCandidate> from an input PFCandidate. If the PFCandidate has a valid sourceCandidatePtr, that is
            used for the FwdPtr's "backPtr". 


  \author   Salvatore Rappoccio
*/

#include "DataFormats/ParticleFlowCandidate/interface/PFCandidate.h"
#include "DataFormats/ParticleFlowCandidate/interface/PFCandidateFwd.h"

namespace reco {
  struct PFCandidateFwdPtrFactory {
    edm::FwdPtr<reco::PFCandidate> operator()(edm::View<reco::PFCandidate> const& view, unsigned int i) const {
      edm::Ptr<reco::PFCandidate> ptr = view.ptrAt(i);
      edm::Ptr<reco::PFCandidate> backPtr = ptr;
      if (ptr.isNonnull() && ptr.isAvailable() && ptr->numberOfSourceCandidatePtrs() > 0) {
        edm::Ptr<reco::Candidate> basePtr = ptr->sourceCandidatePtr(0);
        if (basePtr.isNonnull() && basePtr.isAvailable())
          backPtr = edm::Ptr<reco::PFCandidate>(basePtr);  //this cast works only for available stuff
      }
      return edm::FwdPtr<reco::PFCandidate>(ptr, backPtr);
    }
  };
}  // namespace reco

#endif