ThingAlgorithm

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

/** \class ThingAlgorithm
 *
 ************************************************************/
#include "DataFormats/TestObjects/interface/ThingCollectionfwd.h"
#include <atomic>

namespace edmtest {
  class ThingAlgorithm {
  public:
    ThingAlgorithm(long iOffsetDelta = 0, int nThings = 20, bool grow = false)
        : offset_(0), offsetDelta_(iOffsetDelta), nThings_(nThings), grow_(grow) {}

    /// Runs the algorithm and returns a list of Things
    /// The user declares the vector and calls this method.
    void run(ThingCollection& thingCollection) const;

  private:
    mutable std::atomic<long> offset_;
    const long offsetDelta_;
    const int nThings_;
    const bool grow_;
  };

}  // namespace edmtest

#endif