Skip to content

Commit

Permalink
Merge pull request #5320 from NREL/5319_gbxmlRT_Validation
Browse files Browse the repository at this point in the history
#5319 - gbXML Reverse Translator - Scan for the gbxml Schema version: skip schema validation with a warning when not 7.03
  • Loading branch information
jmarrec authored Dec 19, 2024
2 parents f3ca5f7 + ecb6a53 commit 2d4cbea
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 9 deletions.
35 changes: 30 additions & 5 deletions src/gbxml/ReverseTranslator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
#include "../model/AdditionalProperties.hpp"

#include "../utilities/core/Assert.hpp"
#include "../utilities/core/Compare.hpp"
#include "../utilities/core/FilesystemHelpers.hpp"
#include "../utilities/units/Quantity.hpp"
#include "../utilities/units/UnitFactory.hpp"
Expand Down Expand Up @@ -85,16 +86,40 @@ namespace gbxml {

if (openstudio::filesystem::exists(path)) {

// validate the gbxml prior to reverse translation
auto gbxmlValidator = XMLValidator::gbxmlValidator();
gbxmlValidator.validate(path);

openstudio::filesystem::ifstream file(path, std::ios_base::binary);
if (file.is_open()) {
pugi::xml_document doc;
auto load_result = doc.load(file);
if (load_result) {
result = this->convert(doc.document_element());
auto root = doc.document_element();
if (std::string_view{root.name()} != "gbXML") {
LOG(Error, "Expected the root element to be <gbXML>");
return boost::none;
}
// Scan version of gbxml schema
std::string version = root.attribute("version").value();
VersionString schemaVersion(7, 3);
if (version.empty()) {
LOG(Warn, "gbXML has no `version` attribute for the schema version, assuming 7.03.");
} else {
try {
schemaVersion = VersionString(version);
} catch (...) {
LOG(Warn, "gbXML has `version` '" << version << "' which was not understood, assuming 7.03.");
}
}
if (schemaVersion == VersionString(7, 3)) {
// validate the gbxml prior to reverse translation
auto gbxmlValidator = XMLValidator::gbxmlValidator(schemaVersion);
gbxmlValidator.validate(path);
} else {
LOG(Error,
"Version of schema specified: " << version
<< ", expected 7.03. gbXML Schema Validation skipped. Note that ReverseTranslator rules are built "
"for 7.03 and older versions are not officially supported, check resulting model with care.");
};

result = this->convert(root);
}
file.close();
}
Expand Down
10 changes: 7 additions & 3 deletions src/utilities/xml/XMLValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -472,14 +472,18 @@ std::vector<LogMessage> XMLValidator::logMessages() const {
return m_logMessages;
}

XMLValidator XMLValidator::gbxmlValidator() {
XMLValidator XMLValidator::gbxmlValidator(const VersionString& schemaVersion) {
const auto tmpDir = openstudio::filesystem::create_temporary_directory("xmlvalidation");
if (tmpDir.empty()) {
LOG_AND_THROW("Failed to create a temporary directory for extracting the embedded path");
}
if (schemaVersion != VersionString(7, 3)) {
LOG_AND_THROW("Unexpected gbXML Schema Version: accepted = [7.03]");
}
const bool quiet = true;
::openstudio::embedded_files::extractFile(":/xml/resources/GreenBuildingXML_Ver7.03.xsd", openstudio::toString(tmpDir), quiet);
auto validator = XMLValidator(tmpDir / "GreenBuildingXML_Ver7.03.xsd");
std::string schemaName = fmt::format("GreenBuildingXML_Ver{}.{:02}.xsd", schemaVersion.major(), schemaVersion.minor());
::openstudio::embedded_files::extractFile(fmt::format(":/xml/resources/{}", schemaName), openstudio::toString(tmpDir), quiet);
auto validator = XMLValidator(tmpDir / schemaName);
validator.m_tempDir = tmpDir;
return validator;
}
Expand Down
2 changes: 1 addition & 1 deletion src/utilities/xml/XMLValidator.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ class UTILITIES_API XMLValidator
XMLValidator& operator=(const XMLValidator& other) = default;
XMLValidator& operator=(XMLValidator&& other) noexcept = default;

static XMLValidator gbxmlValidator();
static XMLValidator gbxmlValidator(const VersionString& schemaVersion = VersionString(7, 3));

static XMLValidator bclXMLValidator(openstudio::BCLXMLType bclXMLType = openstudio::BCLXMLType::MeasureXML,
const VersionString& schemaVersion = VersionString(3, 1));
Expand Down

0 comments on commit 2d4cbea

Please sign in to comment.