TrackingRecHitPipe

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
#ifndef FastSimulation_TrackingRecHitProducer_TrackingRecHitPipe_H
#define FastSimulation_TrackingRecHitProducer_TrackingRecHitPipe_H

#include "FastSimulation/TrackingRecHitProducer/interface/TrackingRecHitAlgorithm.h"
#include "FastSimulation/TrackingRecHitProducer/interface/TrackingRecHitProduct.h"

#include <vector>

class TrackingRecHitPipe {
protected:
  std::vector<TrackingRecHitAlgorithm*> _algorithms;

public:
  TrackingRecHitPipe() {}

  TrackingRecHitProductPtr produce(TrackingRecHitProductPtr product) const {
    for (unsigned int ialgo = 0; product && (ialgo < _algorithms.size()); ++ialgo) {
      product = _algorithms[ialgo]->process(product);
    }
    return product;
  }

  inline unsigned int size() const { return _algorithms.size(); }

  inline void addAlgorithm(TrackingRecHitAlgorithm* algorithm) { _algorithms.push_back(algorithm); }
};

#endif