Commit e4acf5a6 authored by berak's avatar berak

datasets: make or_pascal fail gracefully on absent tags

parent 56eea817
...@@ -61,8 +61,8 @@ public: ...@@ -61,8 +61,8 @@ public:
private: private:
void loadDataset(const string &path, const string &nameImageSet, vector< Ptr<Object> > &imageSet); void loadDataset(const string &path, const string &nameImageSet, vector< Ptr<Object> > &imageSet);
Ptr<Object> parseAnnotation(const string path, const string id); Ptr<Object> parseAnnotation(const string &path, const string &id);
const char* parseNodeText(XMLElement* node, const string nodeName, const string defaultValue); const char* parseNodeText(XMLElement* node, const string &nodeName, const string &defaultValue);
}; };
...@@ -105,17 +105,20 @@ void OR_pascalImp::loadDataset(const string &path, const string &nameImageSet, v ...@@ -105,17 +105,20 @@ void OR_pascalImp::loadDataset(const string &path, const string &nameImageSet, v
} }
} }
const char* OR_pascalImp::parseNodeText(XMLElement* node, const string nodeName, const string defaultValue) const char* OR_pascalImp::parseNodeText(XMLElement* node, const string &nodeName, const string &defaultValue)
{ {
const char* e = node->FirstChildElement(nodeName.c_str())->GetText(); XMLElement* child = node->FirstChildElement(nodeName.c_str());
if ( child == 0 )
return defaultValue.c_str();
if( e != 0 ) const char* e = child->GetText();
return e ; if( e == 0 )
else
return defaultValue.c_str(); return defaultValue.c_str();
return e ;
} }
Ptr<Object> OR_pascalImp::parseAnnotation(const string path, const string id) Ptr<Object> OR_pascalImp::parseAnnotation(const string &path, const string &id)
{ {
string pathAnnotations(path + "Annotations/"); string pathAnnotations(path + "Annotations/");
string pathImages(path + "JPEGImages/"); string pathImages(path + "JPEGImages/");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment