From e9eae568ff86faeab35a19861426331d8128003e Mon Sep 17 00:00:00 2001 From: Monty Montgomery Date: Sat, 14 May 2022 23:37:22 -0400 Subject: [PATCH] Don't fail silently in VersionInfo(), print useful message Having version.hpp throw an exception when built against a malformed version number (due to, eg, not having the git tag available in an automated package build from source bundle) results in _init_ failing during an otherwise apparently successful dlopen(), as well as the netgen-mesher executable crashing before hitting main(). This patch both forces an abort and prints a helpful message alerting the builder/user that something went wrong instead of handing over either a coredump or a weirdly malfunctioning library with no apparent cause. Hopefully this will avoid a repeat of automated Fedora builds shipping nonfunctional Netgen RPMs for several years! --- libsrc/core/version.hpp | 72 +++++++++++++++++++++++------------------ 1 file changed, 40 insertions(+), 32 deletions(-) diff --git a/libsrc/core/version.hpp b/libsrc/core/version.hpp index 3048ce5b..9e3973d9 100644 --- a/libsrc/core/version.hpp +++ b/libsrc/core/version.hpp @@ -1,9 +1,10 @@ #ifndef NETGEN_CORE_VERSION_HPP #define NETGEN_CORE_VERSION_HPP -#include +#include #include #include +#include "exception.hpp" #include "ngcore_api.hpp" @@ -18,37 +19,44 @@ namespace ngcore VersionInfo() = default; VersionInfo(std::string vstring) { - minor_ = release = patch = 0; - git_hash = ""; - if(vstring.substr(0,1) == "v") - vstring = vstring.substr(1,vstring.size()-1); - auto dot = vstring.find('.'); - mayor_ = std::stoi(vstring.substr(0,dot)); - if(dot == size_t(-1)) vstring = ""; - else vstring = vstring.substr(dot+1, vstring.size()-dot-1); - if(!vstring.empty()) - { - dot = vstring.find('.'); - minor_ = std::stoi(vstring.substr(0,dot)); - if (dot == size_t(-1)) vstring = ""; - else vstring = vstring.substr(dot+1, vstring.size()-dot-1); - if(!vstring.empty()) - { - dot = vstring.find('-'); - release = std::stoi(vstring.substr(0,dot)); - if(dot == size_t(-1)) vstring = ""; - else vstring = vstring.substr(dot+1,vstring.size()-dot-1); - if(!vstring.empty()) - { - dot = vstring.find('-'); - patch = std::stoi(vstring.substr(0,dot)); - if(dot == size_t(-1)) vstring = ""; - else vstring = vstring.substr(dot+1, vstring.size()-dot-1); - if(!vstring.empty()) - git_hash = vstring; - } - } - } + std::string save = vstring; + try { + minor_ = release = patch = 0; + git_hash = ""; + if(vstring.substr(0,1) == "v") + vstring = vstring.substr(1,vstring.size()-1); + auto dot = vstring.find('.'); + mayor_ = std::stoi(vstring.substr(0,dot)); + if(dot == size_t(-1)) vstring = ""; + else vstring = vstring.substr(dot+1, vstring.size()-dot-1); + if(!vstring.empty()) + { + dot = vstring.find('.'); + minor_ = std::stoi(vstring.substr(0,dot)); + if (dot == size_t(-1)) vstring = ""; + else vstring = vstring.substr(dot+1, vstring.size()-dot-1); + if(!vstring.empty()) + { + dot = vstring.find('-'); + release = std::stoi(vstring.substr(0,dot)); + if(dot == size_t(-1)) vstring = ""; + else vstring = vstring.substr(dot+1,vstring.size()-dot-1); + if(!vstring.empty()) + { + dot = vstring.find('-'); + patch = std::stoi(vstring.substr(0,dot)); + if(dot == size_t(-1)) vstring = ""; + else vstring = vstring.substr(dot+1, vstring.size()-dot-1); + if(!vstring.empty()) + git_hash = vstring; + } + } + } + } catch(...) { + std::cerr << "Malformed NETGEN_VERSION (" << save <<"\n"; + std::cerr << "Micompiled/mispackaged Netgen library\n"; + abort(); + } } VersionInfo(const char* cstr) : VersionInfo(std::string(cstr)) { }