Skip to content

Commit

Permalink
Replace cryptic assert with informative exceptions
Browse files Browse the repository at this point in the history
  • Loading branch information
wmtan committed Oct 8, 2015
1 parent 5792d32 commit e008ef8
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion FWCore/Utilities/src/TypeWithDict.cc
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,24 @@ namespace edm {
TypeWithDict::typeInfo() const {
if(*ti_ == typeid(dummyType) || isPointer() || isArray()) {
// No accurate type_info
assert(qualifiedName().c_str() == nullptr);
if(qualifiedName().c_str() != nullptr) {
std::string category("unknown");
if(isPointer()) {
category = "a pointer";
} else if(isArray()) {
category = "an array";
} else if(isEnum()) {
category = "an enum";
} else if(isClass()) {
throw Exception(errors::DictionaryNotFound)
<< "No Dictionary for class: '" << name() << "'" << std::endl;
}
throw Exception(errors::LogicError)
<< "Function TypeWithDict::typeInfo: Type\n"
<< qualifiedName()
<< "\ndoes not have valid type_info information in ROOT\n"
<< "because it is " << category << ".\n";
}
}
return *ti_;
}
Expand Down Expand Up @@ -490,6 +507,8 @@ namespace edm {
out << "::";
}
out << enum_->GetName();
} else if (*ti_ == typeid(dummyType) && isClass()) {
out << class_->GetName();
} else {
out << TypeID(*ti_).className();
}
Expand Down

0 comments on commit e008ef8

Please sign in to comment.