19 std::vector<std::string>::const_iterator it = selections.begin();
20 for(; it != selections.end(); ++it) {
27 : specifics_(specs), partSelections_(selections),
valid_(
false), doRegex_(
false)
33 std::vector<DDPartSelRegExpLevel> regv;
34 std::vector<DDPartSelection>
temp;
37 if (!regv.size())
throw cms::Exception(
"DDException") <<
"Could not evaluate the selection-std::string ->" << selString <<
"<-";
38 std::vector<DDPartSelRegExpLevel>::const_iterator it = regv.begin();
39 std::pair<bool,std::string> res;
40 for (; it != regv.end(); ++it) {
41 std::vector<DDLogicalPart> lpv;
44 std::string msg(
"Could not process q-name of a DDLogicalPart, reason:\n"+res.second);
45 msg+=
"\nSpecPar selection is:\n" + selString +
"\n";
54 std::vector<DDPartSelection>::const_iterator iit = temp.begin();
56 for (; iit != temp.end(); ++iit) {
66 std::vector<DDPartSelection> & selv)
73 ps_sizetype ps_sz = selv.size();
74 lpv_sizetype lpv_sz = lpv.size();
76 lpv_sizetype lpv_i = 0;
77 std::vector<DDPartSelection>
result;
78 for (; lpv_i < lpv_sz; ++lpv_i) {
79 std::vector<DDPartSelection>::const_iterator ps_it = selv.begin();
80 for (; ps_it != selv.end(); ++ps_it) {
81 result.push_back(*ps_it);
87 for(lpv_i=0; lpv_i < lpv_sz; ++lpv_i) {
88 for(ps_i = ps_sz*lpv_i; ps_i < ps_sz*(lpv_i+1); ++ps_i) {
104 os <<
" Size: " <<
specifics_.size() << std::endl;
105 os <<
"\tSelections:" << std::endl;
107 for (;pit!=pend;++pit) {
108 os << *pit << std::endl;
112 for (;vit!=ved;++vit) {
114 os <<
"\tParameter name= \"" << v.
name() <<
"\" " << std::endl;
115 os <<
"\t\t Value pairs: " << std::endl;
120 os <<
"\t\t\t\"" << v[
i].first <<
"\"" <<
", " << v[
i].second << std::endl;
123 const std::vector<std::string>& vs = v.
strings();
125 os <<
"\t\t\t\"" << vs[
i] <<
"\"" <<
", not evaluated" << std::endl;
144 std::pair<DDPartSelection*,DDsvalues_type*> pssv(ps,sv);
145 result.push_back(std::make_pair(logp,pssv));
164 edm::LogError(
"Specific") <<
" >> more or less than one part-selector, currently NOT SUPPORTED! <<" << std::endl;
165 return std::make_pair(
false,e);
169 DDPartSelection::const_iterator it = ps.begin();
170 DDPartSelection::const_iterator ed = ps.end();
171 if ( (it != ed) && ( it->selectionType_ !=
ddanyposp) ) {
172 edm::LogError(
"Specific") <<
" >> part-selector must start with //Name[no] ! << " << std::endl;
173 return std::make_pair(
false,e);
176 for (; it != ps.end(); ++it) {
178 edm::LogError(
"Specific") <<
" >> part-selector must be a concatenation of direct children\n"
179 <<
" including their copy-number only, CURRENT LIMITATION! <<" << std::endl;
180 return std::make_pair(
false,e);
186 for (; it != ed; ++it) {
199 return std::make_pair(result,e);
const std::string & name(void) const
the name of the DDValue
void addSelectionLevel(std::vector< DDLogicalPart > &lpv, int copyno, ddselection_type st, std::vector< DDPartSelection > &selv)
const std::vector< DDPartSelection > & selection() const
static const uint16_t valid_
type of data representation of DDCompactView
bool isEvaluated(void) const
true, if values are numerical evaluated; else false.
DDsvalues_type specifics_
std::vector< std::pair< unsigned int, DDValue > > DDsvalues_type
std::maps an index to a DDValue. The index corresponds to the index assigned to the name of the std::...
Specific(const std::vector< std::string > &selections, const DDsvalues_type &specs, bool doRegex=true)
void createPartSelections(const std::string &selString)
A DDLogicalPart aggregates information concerning material, solid and sensitveness ...
std::pair< bool, DDExpandedView > node() const
gives the geometrical history of a fully specified PartSelector
void updateLogicalPart(std::vector< std::pair< DDLogicalPart, std::pair< DDPartSelection *, DDsvalues_type * > > > &) const
const std::vector< std::string > & strings() const
a reference to the std::string-valued values stored in the given instance of DDValue ...
partsel_type partSelections_
std::pair< bool, std::string > DDIsValid(const std::string &ns, const std::string &name, std::vector< DDLogicalPart > &result, bool doRegex=true)
int copyno() const
Copy number associated with the current node.
bool firstChild()
set the current node to the first child ...
void DDTokenize2(const std::string &selectionString, std::vector< DDPartSelRegExpLevel > &result)
bool nextSibling()
set the current node to the next sibling ...
unsigned int size() const
the size of the stored value-pairs (std::string,double)
const DDLogicalPart & logicalPart() const
The logical-part of the current node in the expanded-view.
volatile std::atomic< bool > shutdown_flag false
Provides an exploded view of the detector (tree-view)
void stream(std::ostream &) const