File indexing completed on 2024-09-07 04:36:29
0001 #ifndef GEOMETRY_ECALTBHODOSCOPEGEOMETRYLOADERFROMDDD_H
0002 #define GEOMETRY_ECALTBHODOSCOPEGEOMETRYLOADERFROMDDD_H 1
0003
0004 #include "Geometry/EcalTestBeam/interface/EcalHodoscopeNumberingScheme.h"
0005
0006
0007
0008
0009
0010
0011
0012
0013 class DDCompactView;
0014 class DDFilteredView;
0015 class DDFilter;
0016 class CaloSubdetectorGeometry;
0017 class EcalTBHodoscopeGeometry;
0018
0019 #include <memory>
0020 #include <string>
0021
0022 class EcalTBHodoscopeGeometryLoaderFromDDD {
0023 public:
0024 EcalTBHodoscopeGeometryLoaderFromDDD() {}
0025
0026 virtual ~EcalTBHodoscopeGeometryLoaderFromDDD() {}
0027
0028 std::unique_ptr<CaloSubdetectorGeometry> load(const DDCompactView* cpv);
0029
0030 private:
0031 void makeGeometry(const DDCompactView* cpv, CaloSubdetectorGeometry* ebg);
0032
0033 unsigned int getDetIdForDDDNode(const DDFilteredView& fv);
0034
0035 std::string getDDDString(std::string s, DDFilteredView* fv);
0036
0037 DDFilter* getDDFilter();
0038
0039 EcalHodoscopeNumberingScheme _scheme;
0040 };
0041
0042 #endif