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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
// -*- C++ -*-
//
// Package:    __subsys__/__pkgname__
// Class:      __class__
//
/**\class __class__ __class__.cc __subsys__/__pkgname__/plugins/__class__.cc

 Description: [one line class summary]

 Implementation:
     [Notes on implementation]
*/
//
// Original Author:  __author__
//         Created:  __date__
//
//

// system include files
#include <memory>

// user include files
#include "FWCore/Framework/interface/LooperFactory.h"
#include "FWCore/Framework/interface/ESProducerLooper.h"

#include "FWCore/Framework/interface/ESHandle.h"

#include "FWCore/Framework/interface/ESProducts.h"

//
// class declaration
//

class __class__ : public edm::ESProducerLooper {
public:
  __class__(const edm::ParameterSet&);
  ~__class__() override;

#python_begin
    if  len(__datatypes__) > 1:
        datatypes = []
        for dtype in __datatypes__:
            datatypes.append("std::unique_ptr<%s>" % dtype)
        print("  using ReturnType = edm::ESProducts<%s>;" % ','.join(datatypes))
    elif len(__datatypes__) == 1:
        print("  using ReturnType = std::shared_ptr<%s>;" % __datatypes__[0])
#python_end

  ReturnType produce(const __record__&);

  void beginOfJob() override;
  void startingNewLoop(unsigned int) override;
  Status duringLoop(const edm::Event&, const edm::EventSetup&) override;
  Status endOfLoop(const edm::EventSetup&) override;
  void endOfJob() override;

private:
  // ----------member data ---------------------------
};

//
// constants, enums and typedefs
//

//
// static data member definitions
//

//
// constructors and destructor
//
__class__::__class__(const edm::ParameterSet& iConfig) {
  //the following line is needed to tell the framework what
  // data is being produced
  setWhatProduced(this);

  //now do what ever other initialization is needed
}

__class__::~__class__() {
  // do anything here that needs to be done at desctruction time
  // (e.g. close files, deallocate resources etc.)
}

//
// member functions
//

// ------------ method called to produce the data  ------------
__class__::ReturnType __class__::produce(const __record__& iRecord) {
  using namespace edm::es;
#python_begin
    out1 = []
    out2 = []
    for dtype in __datatypes__:
        out1.append("  std::unique_ptr<%s> p%s;" % (dtype, dtype))
        out2.append("p%s" % dtype)
    output  = '\n'.join(out1)
    output += "\n  return products(%s);" % ','.join(out2)
    print(output)
#python_end
}

// ------------ method called once per job just before starting to loop over events  ------------
void __class__::beginOfJob(const edm::EventSetup&) {
}

// ------------ method called at the beginning of a new loop over the event  ------------
// ------------ the argument starts at 0 and increments for each loop        ------------
void __class__::startingNewLoop(unsigned int iIteration) {
}

// ------------ called for each event in the loop.  The present event loop can be stopped by return kStop ------------
__class__::Status __class__::duringLoop(const edm::Event&, const edm::EventSetup&) {
  return kContinue;
}


// ------------ called at the end of each event loop. A new loop will occur if you return kContinue ------------
__class__::Status __class__::endOfLoop(const edm::EventSetup&, unsigned int) {
  return kStop;
}

// ------------ called once each job just before the job ends ------------
void __class__::endOfJob() {
}

//define this as a plug-in
DEFINE_FWK_LOOPER(__class__);