diff --git a/cmake/Dependencies.cmake b/cmake/Dependencies.cmake index 71e7929a6..fd402eba9 100644 --- a/cmake/Dependencies.cmake +++ b/cmake/Dependencies.cmake @@ -214,6 +214,24 @@ add_definitions( -DGIT_VERSION="${GIT_VERSION}" ) +if (NOT GIT_DESCRIBE_EXACT) + execute_process( + COMMAND git describe --exact-match --tags HEAD + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + OUTPUT_VARIABLE GIT_DESCRIBE_EXACT + ERROR_QUIET + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + + if(NOT GIT_DESCRIBE_EXACT) + set(GIT_DESCRIBE_EXACT "Nightly") + endif() +endif() + +add_definitions( + -DGIT_DESCRIBE_EXACT="${GIT_DESCRIBE_EXACT}" +) + set(APPLE_EXT False) if (FOUNDATION_FOUND AND IOKIT_FOUND) set(APPLE_EXT True) diff --git a/src/net/updatecheck.cpp b/src/net/updatecheck.cpp index e95182d86..16e6dd816 100644 --- a/src/net/updatecheck.cpp +++ b/src/net/updatecheck.cpp @@ -29,6 +29,8 @@ #include #include +#define VERSION_REGEX_STRING "v([0-9]+)\\.([0-9]+)\\.([0-9]+)" + namespace { const QString versionUrl{QStringLiteral("https://api.github.com/repos/qTox/qTox/releases/latest")}; @@ -41,7 +43,7 @@ struct Version { Version tagToVersion(QString tagName) { // capture tag name to avoid showing update available on dev builds which include hash as part of describe - QRegularExpression versionFormat{QStringLiteral("v([0-9]+)\\.([0-9]+)\\.([0-9]+)")}; + QRegularExpression versionFormat{QStringLiteral(VERSION_REGEX_STRING)}; auto matches = versionFormat.match(tagName); assert(matches.lastCapturedIndex() == 3); @@ -85,6 +87,17 @@ bool isUpdateAvailable(Version current, Version available) return false; } +bool isCurrentVersionStable() +{ + QRegularExpression versionRegex{QStringLiteral(VERSION_REGEX_STRING)}; + auto currentVer = versionRegex.match(GIT_DESCRIBE_EXACT); + if (currentVer.hasMatch()){ + return true; + } else { + return false; + } +} + } // namespace UpdateCheck::UpdateCheck(const Settings& settings) @@ -143,5 +156,10 @@ void UpdateCheck::handleResponse(QNetworkReply* reply) qInfo() << "qTox is up to date"; emit upToDate(); } + + if (isCurrentVersionStable() == false) { + qWarning() << "qTox is running an unstable version"; + } + reply->deleteLater(); }