CMS 3D CMS Logo

List of all members | Public Member Functions
DDLTrapezoid Class Referencefinal

#include <DDLTrapezoid.h>

Inheritance diagram for DDLTrapezoid:
DDLSolid DDXMLElement

Public Member Functions

 DDLTrapezoid (DDLElementRegistry *myreg)
 
void processElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv) override
 Processing the element. More...
 
- Public Member Functions inherited from DDLSolid
 DDLSolid (DDLElementRegistry *myreg)
 Constructor. More...
 
void setReference (const std::string &nmspace, DDCompactView &cpv)
 
- Public Member Functions inherited from DDXMLElement
void appendText (const std::string &inText)
 append to the current (i.e. most recently added) More...
 
virtual std::vector< DDXMLAttribute >::const_iterator begin (void)
 
virtual void clear (void)
 clear this element's contents. More...
 
 DDXMLElement (DDLElementRegistry *myreg)
 Constructor. More...
 
 DDXMLElement (DDLElementRegistry *myreg, const bool &clearme)
 Constructor for autoClear element. More...
 
virtual std::vector< DDXMLAttribute >::const_iterator end (void)
 
virtual const std::string & get (const std::string &name, size_t aIndex=0) const
 Returns a specific value from the aIndex set of attributes. More...
 
virtual const std::string & getAttribute (const std::string &name) const
 Access to attributes by name. More...
 
virtual const DDXMLAttributegetAttributeSet (size_t aIndex=0) const
 Get a "row" of attributes, i.e. one attribute set. More...
 
virtual const DDName getDDName (const std::string &defaultNS, const std::string &attname=std::string("name"), size_t aIndex=0)
 
const std::string getText (size_t tindex=0) const
 retrieve the text blob. More...
 
virtual std::vector< std::string > getVectorAttribute (const std::string &name)
 Returns a set of values as a std::vector of strings, given the attribute name. More...
 
virtual bool gotText (void) const
 gotText()? kind of like gotMilk? Yes = text has already been encountered. More...
 
virtual bool isEmpty (void) const
 Have any elements of this type been encountered but not processed? More...
 
void loadAttributes (const std::string &elemName, const std::vector< std::string > &names, const std::vector< std::string > &values, const std::string &nmspace, DDCompactView &cpv)
 Load the element attributes. More...
 
void loadText (const std::string &inText)
 Used to load both text and XML comments into this object. More...
 
std::vector< DDXMLAttribute >::const_iterator & operator++ (int inc)
 Allow the elements of this type to be iterated over using ++ operator. More...
 
const std::string & parent (void) const
 access to parent element name More...
 
virtual void preProcessElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv)
 Called by loadAttributes AFTER attributes are loaded. More...
 
void setParent (const std::string &pename)
 Set parent element name to central list of names. More...
 
void setSelf (const std::string &sename)
 Set self element name to central list of names. More...
 
virtual size_t size (void) const
 Number of elements accumulated. More...
 
virtual void stream (std::ostream &os) const
 Allow for the elements to have their own streaming method, but also provide a default. More...
 
void throwError (const std::string &keyMessage) const
 format std::string for throw an error. More...
 
virtual ~DDXMLElement (void)=default
 Destructor. More...
 

Additional Inherited Members

- Protected Attributes inherited from DDXMLElement
DDLElementRegistrymyRegistry_
 

Detailed Description

Author
Michael Case

DDLTrapezoid.h - description

begin: Mon Oct 29 2001 email: case@.nosp@m.ucdh.nosp@m.ep.uc.nosp@m.davi.nosp@m.s.edu

Trapezoid processor processes Trapezoid and Trd1 DDL elements.

Definition at line 23 of file DDLTrapezoid.h.

Constructor & Destructor Documentation

DDLTrapezoid::DDLTrapezoid ( DDLElementRegistry myreg)

Definition at line 13 of file DDLTrapezoid.cc.

14  : DDLSolid( myreg )
15 {}
DDLSolid(DDLElementRegistry *myreg)
Constructor.
Definition: DDLSolid.cc:11

Member Function Documentation

void DDLTrapezoid::processElement ( const std::string &  name,
const std::string &  nmspace,
DDCompactView cpv 
)
overridevirtual

Processing the element.

The processElement method completes any necessary work to process the XML element.

For example, this can be used to call the DDCore to make the geometry in memory. There is a default for this so that if not declared in the inheriting class, no processing is done.

Reimplemented from DDXMLElement.

Definition at line 19 of file DDLTrapezoid.cc.

References ev, ClhepEvaluator::eval(), DDLElementRegistry::evaluator(), DDXMLElement::getAttributeSet(), DDXMLElement::getDDName(), mps_check::msg, DDXMLElement::myRegistry_, phi, DDLSolid::setReference(), AlCaHLTBitMon_QueryRunRegistry::string, theta(), DDXMLElement::throwError(), and DDSolidFactory::trap().

20 {
22 
24 
25  double phi = 0.0;
26  double theta = 0.0;
27  double dy2 = 0.0;
28 
29  if (atts.find("phi") != atts.end())
30  phi = ev.eval(nmspace, atts.find("phi")->second);
31 
32  if (atts.find("theta") != atts.end())
33  theta = ev.eval(nmspace, atts.find("theta")->second);
34 
35  if (atts.find("dy2") != atts.end())
36  dy2 = ev.eval(nmspace, atts.find("dy2")->second);
37  else if (atts.find("dy1") != atts.end())
38  dy2 = ev.eval(nmspace, atts.find("dy1")->second);
39 
40  if (name == "Trapezoid")
41  {
42  DDSolid myTrap =
44  ev.eval(nmspace, atts.find("dz")->second),
45  theta,
46  phi,
47  ev.eval(nmspace, atts.find("h1")->second),
48  ev.eval(nmspace, atts.find("bl1")->second),
49  ev.eval(nmspace, atts.find("tl1")->second),
50  ev.eval(nmspace, atts.find("alp1")->second),
51  ev.eval(nmspace, atts.find("h2")->second),
52  ev.eval(nmspace, atts.find("bl2")->second),
53  ev.eval(nmspace, atts.find("tl2")->second),
54  ev.eval(nmspace, atts.find("alp2")->second));
55  }
56  else if (name == "Trd1")
57  {
58  DDSolid myTrd1 =
60  ev.eval(nmspace, atts.find("dz")->second),
61  0,
62  0,
63  ev.eval(nmspace, atts.find("dy1")->second),
64  ev.eval(nmspace, atts.find("dx1")->second),
65  ev.eval(nmspace, atts.find("dx1")->second),
66  0,
67  dy2,
68  ev.eval(nmspace, atts.find("dx2")->second),
69  ev.eval(nmspace, atts.find("dx2")->second),
70  0 );
71  }
72  else
73  {
74  std::string msg = "\nDDLTrapezoid::processElement failed to process element of name: "
75  + name
76  + ". It can only process Trapezoid and Trd1.";
77  throwError(msg);
78  }
79 
80  DDLSolid::setReference( nmspace, cpv );
81 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:172
virtual const DDXMLAttribute & getAttributeSet(size_t aIndex=0) const
Get a "row" of attributes, i.e. one attribute set.
Definition: DDXMLElement.cc:72
Geom::Theta< T > theta() const
void throwError(const std::string &keyMessage) const
format std::string for throw an error.
bool ev
std::map< std::string, std::string > DDXMLAttribute
Definition: DDXMLElement.h:45
A DDSolid represents the shape of a part.
Definition: DDSolid.h:39
ClhepEvaluator & evaluator()
static DDSolid trap(const DDName &name, double pDz, double pTheta, double pPhi, double pDy1, double pDx1, double pDx2, double pAlp1, double pDy2, double pDx3, double pDx4, double pAlp2)
Definition: DDSolid.cc:792
tuple msg
Definition: mps_check.py:285
double eval(const std::string &ns, const std::string &expr)
virtual const DDName getDDName(const std::string &defaultNS, const std::string &attname=std::string("name"), size_t aIndex=0)
Definition: DDXMLElement.cc:79
void setReference(const std::string &nmspace, DDCompactView &cpv)
Definition: DDLSolid.cc:16