CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions
CmsTrackerBuilder Class Reference

#include <CmsTrackerBuilder.h>

Inheritance diagram for CmsTrackerBuilder:
CmsTrackerLevelBuilder CmsTrackerAbstractConstruction

Public Member Functions

 CmsTrackerBuilder ()
 
- Public Member Functions inherited from CmsTrackerLevelBuilder
virtual void build (DDFilteredView &, GeometricDet *, std::string)
 
virtual ~CmsTrackerLevelBuilder ()
 

Private Member Functions

virtual void buildComponent (DDFilteredView &, GeometricDet *, std::string)
 
virtual void sortNS (DDFilteredView &, GeometricDet *)
 

Additional Inherited Members

- Protected Attributes inherited from CmsTrackerLevelBuilder
CmsTrackerStringToEnum theCmsTrackerStringToEnum
 

Detailed Description

Abstract Class to construct a Level in the hierarchy

Definition at line 11 of file CmsTrackerBuilder.h.

Constructor & Destructor Documentation

CmsTrackerBuilder::CmsTrackerBuilder ( )

Definition at line 14 of file CmsTrackerBuilder.cc.

15 {}

Member Function Documentation

void CmsTrackerBuilder::buildComponent ( DDFilteredView fv,
GeometricDet g,
std::string  s 
)
privatevirtual

Implements CmsTrackerLevelBuilder.

Definition at line 18 of file CmsTrackerBuilder.cc.

References GeometricDet::addComponent(), CmsTrackerLevelBuilder::build(), ExtractStringFromDDD::getString(), GeometricDet::OTPhase2Barrel, GeometricDet::OTPhase2EndCap, GeometricDet::PixelBarrel, GeometricDet::PixelEndCap, GeometricDet::PixelPhase1Barrel, GeometricDet::PixelPhase1EndCap, GeometricDet::PixelPhase2EndCap, GeometricDet::TEC, CmsTrackerLevelBuilder::theCmsTrackerStringToEnum, GeometricDet::TIB, GeometricDet::TID, GeometricDet::TOB, and CmsTrackerStringToEnum::type().

19 {
20  CmsTrackerSubStrctBuilder theCmsTrackerSubStrctBuilder;
21  CmsTrackerPixelPhase1EndcapBuilder theCmsTrackerPixelPhase1EndcapBuilder;
22  CmsTrackerPixelPhase2EndcapBuilder theCmsTrackerPixelPhase2EndcapBuilder;
23 
26  {
28  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
29  break;
31  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
32  break;
34  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
35  break;
37  theCmsTrackerPixelPhase1EndcapBuilder.build( fv, subdet, s );
38  break;
40  theCmsTrackerPixelPhase2EndcapBuilder.build( fv, subdet, s );
41  break;
43  theCmsTrackerPixelPhase2EndcapBuilder.build( fv, subdet, s );
44  break;
45  case GeometricDet::TIB:
46  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
47  break;
48  case GeometricDet::TOB:
49  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
50  break;
52  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
53  break;
54  case GeometricDet::TEC:
55  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
56  break;
57  case GeometricDet::TID:
58  theCmsTrackerSubStrctBuilder.build( fv, subdet, s );
59  break;
60  default:
61  edm::LogError( "CmsTrackerBuilder" ) << " ERROR - I was expecting a SubDet, I got a " << ExtractStringFromDDD::getString( s, &fv );
62  }
63 
64  g->addComponent( subdet );
65 }
static std::string getString(std::string const &, DDFilteredView *)
void addComponent(GeometricDet *)
virtual void build(DDFilteredView &, GeometricDet *, std::string)
GeometricDet::GeometricEnumType type(std::string const &) const
CmsTrackerStringToEnum theCmsTrackerStringToEnum
void CmsTrackerBuilder::sortNS ( DDFilteredView fv,
GeometricDet det 
)
privatevirtual

Reimplemented from CmsTrackerLevelBuilder.

Definition at line 68 of file CmsTrackerBuilder.cc.

References AlCaHLTBitMon_QueryRunRegistry::comp, GeometricDet::component(), GeometricDet::components(), i, GeometricDet::setGeographicalID(), and groupFilesInBlocks::temp.

69 {
71  std::stable_sort( comp.begin(), comp.end(), subDetByType());
72 
73  for( uint32_t i = 0; i < comp.size(); i++ )
74  {
75  uint32_t temp= comp[i]->type();
76  det->component(i)->setGeographicalID(temp%100); // it relies on the fact that the GeometricDet::GDEnumType enumerators used to identify the subdetectors in the upgrade geometries are equal to the ones of the present detector + n*100
77  }
78 }
int i
Definition: DBlmapReader.cc:9
void setGeographicalID(DetId id)
Definition: GeometricDet.h:80
ConstGeometricDetContainer & components()
Definition: GeometricDet.h:174
GeometricDet * component(size_t index)
Definition: GeometricDet.h:112
std::vector< GeometricDet const * > ConstGeometricDetContainer
Definition: GeometricDet.h:36