EcalTBHodoscopeGeometryLoaderFromDDD

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 35 36 37 38 39 40 41 42
#ifndef GEOMETRY_ECALTBHODOSCOPEGEOMETRYLOADERFROMDDD_H
#define GEOMETRY_ECALTBHODOSCOPEGEOMETRYLOADERFROMDDD_H 1

#include "Geometry/EcalTestBeam/interface/EcalHodoscopeNumberingScheme.h"

/** \class EcalTBHodoscopeGeometryLoaderFromDDD
 *
 *
 *   
 * \author P. Meridiani - INFN Roma 1
*/

class DDCompactView;
class DDFilteredView;
class DDFilter;
class CaloSubdetectorGeometry;
class EcalTBHodoscopeGeometry;

#include <memory>
#include <string>

class EcalTBHodoscopeGeometryLoaderFromDDD {
public:
  EcalTBHodoscopeGeometryLoaderFromDDD() {}

  virtual ~EcalTBHodoscopeGeometryLoaderFromDDD() {}

  std::unique_ptr<CaloSubdetectorGeometry> load(const DDCompactView* cpv);

private:
  void makeGeometry(const DDCompactView* cpv, CaloSubdetectorGeometry* ebg);

  unsigned int getDetIdForDDDNode(const DDFilteredView& fv);

  std::string getDDDString(std::string s, DDFilteredView* fv);

  DDFilter* getDDFilter();

  EcalHodoscopeNumberingScheme _scheme;
};

#endif