StripGeomDetType

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 32 33 34
#ifndef Geometry_TrackerGeometryBuilder_StripGeomDetType_H
#define Geometry_TrackerGeometryBuilder_StripGeomDetType_H

#include "Geometry/CommonDetUnit/interface/GeomDetType.h"
#include "Geometry/CommonTopologies/interface/StripTopology.h"
#include <vector>

/**
 * StripGeomDetType is the abstract class for SiStripGeomDetType.
 */
class StripGeomDetType final : public GeomDetType {
public:
  typedef StripTopology TopologyType;

  StripGeomDetType(TopologyType* t, std::string const& name, SubDetector& det, bool stereo)
      : GeomDetType(name, det), theTopology(t), theStereoFlag(stereo) {}

  ~StripGeomDetType() override { delete theTopology; }

  // Access to topologies
  const Topology& topology() const override { return *theTopology; }

  virtual const TopologyType& specificTopology() const { return *theTopology; }

  void setTopology(TopologyType* topol);

  bool isStereo() const { return theStereoFlag; }

private:
  TopologyType* theTopology;
  bool theStereoFlag;
};

#endif  // StripGeomDetType_H