19 curr_err +=
"material not declared; unknown material!";
21 result.first = curr_err;
27 curr_err +=
"material name=" + mip.
name().
ns() +
":" + mip.
name().
name()
28 +
" is declared but not defined";
29 result.first = curr_err;
38 curr_err += no_density;
50 curr_err += no_composites;
55 curr_err =
" NOT-DEFINED ";
59 result.first=curr_err;
66 for (; loop>=0; --
loop) {
67 std::pair<std::string,DDName> res(
"",
"");
76 result.first=curr_err;
86 bool DDCheckMaterials(std::ostream & os, std::vector<std::pair<std::string,DDName> > * res)
89 std::vector<std::pair<std::string,DDName> >
errors;
93 for(
const auto&
i : mr ) {
94 std::pair<std::string,DDName>
error(
"",
"");
98 errors.push_back(error);
103 os <<
"[DDCore:Report] Materials " << std::endl;
104 os << s << mr.size() <<
" Materials declared" << std::endl;
105 os << s <<
"detected errors:" << errors.size() << std::endl;
106 for(
auto j : errors ) {
107 os << std::endl << s <<
j.second <<
" " <<
j.first << std::endl;
double a() const
returns the atomic mass
def_type isDefined() const
DDMaterial is used to define and access material information.
const std::string & ns() const
Returns the namespace.
static value_type & instance()
double z() const
retruns the atomic number
FractionV::value_type constituent(int i) const
returns the i-th compound material and its fraction-mass
double density() const
returns the density
int noOfConstituents() const
returns the number of compound materials or 0 for elementary materials
bool DDCheckMaterials(std::ostream &, std::vector< std::pair< std::string, DDName > > *=0)
Checks all registered materials and sends a report /p os.
const std::string & name() const
Returns the name.
bool DDCheckMaterial(DDMaterial &mip, std::pair< std::string, DDName > &result, int rlevel=0)